// NewREST returns a RESTStorage object that will work against subnets func NewREST(s storage.Interface) *REST { store := &etcdgeneric.Etcd{ NewFunc: func() runtime.Object { return &api.HostSubnet{} }, NewListFunc: func() runtime.Object { return &api.HostSubnetList{} }, KeyRootFunc: func(ctx kapi.Context) string { return etcdPrefix }, KeyFunc: func(ctx kapi.Context, name string) (string, error) { return etcdgeneric.NoNamespaceKeyFunc(ctx, etcdPrefix, name) }, ObjectNameFunc: func(obj runtime.Object) (string, error) { return obj.(*api.HostSubnet).Host, nil }, PredicateFunc: func(label labels.Selector, field fields.Selector) generic.Matcher { return hostsubnet.Matcher(label, field) }, QualifiedResource: api.Resource("hostsubnets"), Storage: s, } store.CreateStrategy = hostsubnet.Strategy store.UpdateStrategy = hostsubnet.Strategy return &REST{*store} }
// NewREST returns a RESTStorage object that will work against subnets func NewREST(optsGetter restoptions.Getter) (*REST, error) { store := ®istry.Store{ NewFunc: func() runtime.Object { return &api.ClusterNetwork{} }, NewListFunc: func() runtime.Object { return &api.ClusterNetworkList{} }, KeyRootFunc: func(ctx kapi.Context) string { return etcdPrefix }, KeyFunc: func(ctx kapi.Context, name string) (string, error) { return registry.NoNamespaceKeyFunc(ctx, etcdPrefix, name) }, ObjectNameFunc: func(obj runtime.Object) (string, error) { return obj.(*api.ClusterNetwork).Name, nil }, PredicateFunc: func(label labels.Selector, field fields.Selector) generic.Matcher { return clusternetwork.Matcher(label, field) }, QualifiedResource: api.Resource("clusternetworks"), CreateStrategy: clusternetwork.Strategy, UpdateStrategy: clusternetwork.Strategy, } if err := restoptions.ApplyOptions(optsGetter, store, etcdPrefix); err != nil { return nil, err } return &REST{*store}, nil }
// Get retrieves the ClusterNetwork from the indexer for a given namespace and name. func (s clusterNetworkNamespaceLister) Get(name string) (*v1.ClusterNetwork, error) { obj, exists, err := s.indexer.GetByKey(s.namespace + "/" + name) if err != nil { return nil, err } if !exists { return nil, errors.NewNotFound(api.Resource("clusternetwork"), name) } return obj.(*v1.ClusterNetwork), nil }
// NewREST returns a RESTStorage object that will work against subnets func NewREST(optsGetter restoptions.Getter) (*REST, error) { store := ®istry.Store{ NewFunc: func() runtime.Object { return &api.HostSubnet{} }, NewListFunc: func() runtime.Object { return &api.HostSubnetList{} }, ObjectNameFunc: func(obj runtime.Object) (string, error) { return obj.(*api.HostSubnet).Host, nil }, PredicateFunc: func(label labels.Selector, field fields.Selector) storage.SelectionPredicate { return hostsubnet.Matcher(label, field) }, QualifiedResource: api.Resource("hostsubnets"), CreateStrategy: hostsubnet.Strategy, UpdateStrategy: hostsubnet.Strategy, } if err := restoptions.ApplyOptions(optsGetter, store, false, storage.NoTriggerPublisher); err != nil { return nil, err } return &REST{*store}, nil }
// NewREST returns a RESTStorage object that will work against egress network policy func NewREST(optsGetter restoptions.Getter) (*REST, error) { store := ®istry.Store{ NewFunc: func() runtime.Object { return &api.EgressNetworkPolicy{} }, NewListFunc: func() runtime.Object { return &api.EgressNetworkPolicyList{} }, ObjectNameFunc: func(obj runtime.Object) (string, error) { return obj.(*api.EgressNetworkPolicy).Name, nil }, PredicateFunc: func(label labels.Selector, field fields.Selector) *generic.SelectionPredicate { return egressnetworkpolicy.Matcher(label, field) }, QualifiedResource: api.Resource("egressnetworkpolicies"), CreateStrategy: egressnetworkpolicy.Strategy, UpdateStrategy: egressnetworkpolicy.Strategy, } if err := restoptions.ApplyOptions(optsGetter, store, true, storage.NoTriggerPublisher); err != nil { return nil, err } return &REST{*store}, nil }