-
Notifications
You must be signed in to change notification settings - Fork 20
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Handled IPAM policy properly to fully support strict IPAM #619
Changes from 3 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
@@ -34,7 +34,6 @@ import ( | |||||||||||||||||||||||||||||||||||||||||||||||||
"os" | ||||||||||||||||||||||||||||||||||||||||||||||||||
"os/signal" | ||||||||||||||||||||||||||||||||||||||||||||||||||
"path/filepath" | ||||||||||||||||||||||||||||||||||||||||||||||||||
"strings" | ||||||||||||||||||||||||||||||||||||||||||||||||||
"sync/atomic" | ||||||||||||||||||||||||||||||||||||||||||||||||||
"syscall" | ||||||||||||||||||||||||||||||||||||||||||||||||||
"time" | ||||||||||||||||||||||||||||||||||||||||||||||||||
|
@@ -67,7 +66,6 @@ import ( | |||||||||||||||||||||||||||||||||||||||||||||||||
"github.com/networkservicemesh/sdk/pkg/networkservice/common/policyroute" | ||||||||||||||||||||||||||||||||||||||||||||||||||
"github.com/networkservicemesh/sdk/pkg/networkservice/connectioncontext/dnscontext" | ||||||||||||||||||||||||||||||||||||||||||||||||||
"github.com/networkservicemesh/sdk/pkg/networkservice/ipam/groupipam" | ||||||||||||||||||||||||||||||||||||||||||||||||||
"github.com/networkservicemesh/sdk/pkg/networkservice/ipam/point2pointipam" | ||||||||||||||||||||||||||||||||||||||||||||||||||
"github.com/networkservicemesh/sdk/pkg/networkservice/ipam/strictipam" | ||||||||||||||||||||||||||||||||||||||||||||||||||
registryclient "github.com/networkservicemesh/sdk/pkg/registry/chains/client" | ||||||||||||||||||||||||||||||||||||||||||||||||||
registryauthorize "github.com/networkservicemesh/sdk/pkg/registry/common/authorize" | ||||||||||||||||||||||||||||||||||||||||||||||||||
|
@@ -94,7 +92,7 @@ type Config struct { | |||||||||||||||||||||||||||||||||||||||||||||||||
ConnectTo url.URL `default:"unix:///var/lib/networkservicemesh/nsm.io.sock" desc:"url to connect to" split_words:"true"` | ||||||||||||||||||||||||||||||||||||||||||||||||||
MaxTokenLifetime time.Duration `default:"10m" desc:"maximum lifetime of tokens" split_words:"true"` | ||||||||||||||||||||||||||||||||||||||||||||||||||
RegistryClientPolicies []string `default:"etc/nsm/opa/common/.*.rego,etc/nsm/opa/registry/.*.rego,etc/nsm/opa/client/.*.rego" desc:"paths to files and directories that contain registry client policies" split_words:"true"` | ||||||||||||||||||||||||||||||||||||||||||||||||||
IPAMPolicy ipamPolicyFunc `default:"polite" desc:"defines NSE's IPAM Policy. Possible values: polite, strict. Polite policy accepts any addresses sent by client. Strict policy resets ip_context if any of the client's addresses doesn't match endpoint's CIDR." split_words:"true"` | ||||||||||||||||||||||||||||||||||||||||||||||||||
IPAMPolicy string `default:"polite" desc:"defines NSE's IPAM Policy. Possible values: polite, strict. Polite policy accepts any addresses sent by client. Strict policy resets ip_context if any of the client's addresses doesn't match endpoint's CIDR." split_words:"true"` | ||||||||||||||||||||||||||||||||||||||||||||||||||
ServiceNames []string `default:"icmp-responder" desc:"Name of provided services" split_words:"true"` | ||||||||||||||||||||||||||||||||||||||||||||||||||
Payload string `default:"ETHERNET" desc:"Name of provided service payload" split_words:"true"` | ||||||||||||||||||||||||||||||||||||||||||||||||||
Labels map[string]string `default:"" desc:"Endpoint labels"` | ||||||||||||||||||||||||||||||||||||||||||||||||||
|
@@ -111,23 +109,6 @@ type Config struct { | |||||||||||||||||||||||||||||||||||||||||||||||||
PprofListenOn string `default:"localhost:6060" desc:"pprof URL to ListenAndServe" split_words:"true"` | ||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Done |
||||||||||||||||||||||||||||||||||||||||||||||||||
type ipamPolicyFunc func(...*net.IPNet) networkservice.NetworkServiceServer | ||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||
// Decode takes a string IPAM Policy and returns the IPAM Policy func | ||||||||||||||||||||||||||||||||||||||||||||||||||
func (f *ipamPolicyFunc) Decode(policy string) error { | ||||||||||||||||||||||||||||||||||||||||||||||||||
switch strings.ToLower(policy) { | ||||||||||||||||||||||||||||||||||||||||||||||||||
case "strict": | ||||||||||||||||||||||||||||||||||||||||||||||||||
*f = func(prefixes ...*net.IPNet) networkservice.NetworkServiceServer { | ||||||||||||||||||||||||||||||||||||||||||||||||||
return strictipam.NewServer(point2pointipam.NewServer, prefixes...) | ||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||
return nil | ||||||||||||||||||||||||||||||||||||||||||||||||||
case "polite": | ||||||||||||||||||||||||||||||||||||||||||||||||||
*f = point2pointipam.NewServer | ||||||||||||||||||||||||||||||||||||||||||||||||||
return nil | ||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||
return errors.Errorf("not a valid IPAM Policy: %s", policy) | ||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||
// Process prints and processes env to config | ||||||||||||||||||||||||||||||||||||||||||||||||||
func (c *Config) Process() error { | ||||||||||||||||||||||||||||||||||||||||||||||||||
if err := envconfig.Usage("nsm", c); err != nil { | ||||||||||||||||||||||||||||||||||||||||||||||||||
|
@@ -239,13 +220,30 @@ func main() { | |||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||
tokenServer := getSriovTokenServerChainElement(ctx) | ||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||
ipnetList := []*net.IPNet{} | ||||||||||||||||||||||||||||||||||||||||||||||||||
for _, group := range config.CidrPrefix { | ||||||||||||||||||||||||||||||||||||||||||||||||||
ipnetList = append(ipnetList, group...) | ||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||
var IPAMServer networkservice.NetworkServiceServer | ||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||
switch config.IPAMPolicy { | ||||||||||||||||||||||||||||||||||||||||||||||||||
case "strict": | ||||||||||||||||||||||||||||||||||||||||||||||||||
IPAMServer = strictipam.NewServer(func(i ...*net.IPNet) networkservice.NetworkServiceServer { | ||||||||||||||||||||||||||||||||||||||||||||||||||
return groupipam.NewServer(config.CidrPrefix) | ||||||||||||||||||||||||||||||||||||||||||||||||||
}, ipnetList...) | ||||||||||||||||||||||||||||||||||||||||||||||||||
case "polite": | ||||||||||||||||||||||||||||||||||||||||||||||||||
IPAMServer = groupipam.NewServer(config.CidrPrefix) | ||||||||||||||||||||||||||||||||||||||||||||||||||
default: | ||||||||||||||||||||||||||||||||||||||||||||||||||
logrus.Fatalf("not a valid IPAM Policy: %s", config.IPAMPolicy) | ||||||||||||||||||||||||||||||||||||||||||||||||||
} | ||||||||||||||||||||||||||||||||||||||||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Done |
||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||
responderEndpoint := endpoint.NewServer(ctx, | ||||||||||||||||||||||||||||||||||||||||||||||||||
spiffejwt.TokenGeneratorFunc(source, config.MaxTokenLifetime), | ||||||||||||||||||||||||||||||||||||||||||||||||||
endpoint.WithName(config.Name), | ||||||||||||||||||||||||||||||||||||||||||||||||||
endpoint.WithAuthorizeServer(authorize.NewServer()), | ||||||||||||||||||||||||||||||||||||||||||||||||||
endpoint.WithAdditionalFunctionality( | ||||||||||||||||||||||||||||||||||||||||||||||||||
onidle.NewServer(ctx, cancel, config.IdleTimeout), | ||||||||||||||||||||||||||||||||||||||||||||||||||
groupipam.NewServer(config.CidrPrefix, groupipam.WithCustomIPAMServer(config.IPAMPolicy)), | ||||||||||||||||||||||||||||||||||||||||||||||||||
IPAMServer, | ||||||||||||||||||||||||||||||||||||||||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Done |
||||||||||||||||||||||||||||||||||||||||||||||||||
policyroute.NewServer(newPolicyRoutesGetter(ctx, config.PBRConfigPath).Get), | ||||||||||||||||||||||||||||||||||||||||||||||||||
mechanisms.NewServer(map[string]networkservice.NetworkServiceServer{ | ||||||||||||||||||||||||||||||||||||||||||||||||||
kernelmech.MECHANISM: kernel.NewServer(), | ||||||||||||||||||||||||||||||||||||||||||||||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done