1
0
mirror of https://github.com/rancher/types.git synced 2025-09-09 00:48:56 +00:00

Add native types for their listers

This commit is contained in:
Craig Jellick
2017-12-09 09:19:33 -07:00
committed by Darren Shepherd
parent a33c987eac
commit e77815f156
18 changed files with 1532 additions and 4 deletions

View File

@@ -0,0 +1,40 @@
package v1beta1
import (
extensions_v1beta1 "k8s.io/api/extensions/v1beta1"
runtime "k8s.io/apimachinery/pkg/runtime"
)
// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.
func (in *PodSecurityPolicyList) DeepCopyInto(out *PodSecurityPolicyList) {
*out = *in
out.TypeMeta = in.TypeMeta
out.ListMeta = in.ListMeta
if in.Items != nil {
in, out := &in.Items, &out.Items
*out = make([]extensions_v1beta1.PodSecurityPolicy, len(*in))
for i := range *in {
(*in)[i].DeepCopyInto(&(*out)[i])
}
}
return
}
// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodSecurityPolicyList.
func (in *PodSecurityPolicyList) DeepCopy() *PodSecurityPolicyList {
if in == nil {
return nil
}
out := new(PodSecurityPolicyList)
in.DeepCopyInto(out)
return out
}
// DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object.
func (in *PodSecurityPolicyList) DeepCopyObject() runtime.Object {
if c := in.DeepCopy(); c != nil {
return c
} else {
return nil
}
}

View File

@@ -0,0 +1,69 @@
package v1beta1
import (
"context"
"sync"
"github.com/rancher/norman/clientbase"
"github.com/rancher/norman/controller"
"k8s.io/client-go/dynamic"
"k8s.io/client-go/rest"
)
type Interface interface {
RESTClient() rest.Interface
controller.Starter
PodSecurityPoliciesGetter
}
type Client struct {
sync.Mutex
restClient rest.Interface
starters []controller.Starter
podSecurityPolicyControllers map[string]PodSecurityPolicyController
}
func NewForConfig(config rest.Config) (Interface, error) {
if config.NegotiatedSerializer == nil {
configConfig := dynamic.ContentConfig()
config.NegotiatedSerializer = configConfig.NegotiatedSerializer
}
restClient, err := rest.UnversionedRESTClientFor(&config)
if err != nil {
return nil, err
}
return &Client{
restClient: restClient,
podSecurityPolicyControllers: map[string]PodSecurityPolicyController{},
}, nil
}
func (c *Client) RESTClient() rest.Interface {
return c.restClient
}
func (c *Client) Sync(ctx context.Context) error {
return controller.Sync(ctx, c.starters...)
}
func (c *Client) Start(ctx context.Context, threadiness int) error {
return controller.Start(ctx, threadiness, c.starters...)
}
type PodSecurityPoliciesGetter interface {
PodSecurityPolicies(namespace string) PodSecurityPolicyInterface
}
func (c *Client) PodSecurityPolicies(namespace string) PodSecurityPolicyInterface {
objectClient := clientbase.NewObjectClient(namespace, c.restClient, &PodSecurityPolicyResource, PodSecurityPolicyGroupVersionKind, podSecurityPolicyFactory{})
return &podSecurityPolicyClient{
ns: namespace,
client: c,
objectClient: objectClient,
}
}

View File

@@ -0,0 +1,188 @@
package v1beta1
import (
"context"
"github.com/rancher/norman/clientbase"
"github.com/rancher/norman/controller"
"k8s.io/api/extensions/v1beta1"
"k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/labels"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/runtime/schema"
"k8s.io/apimachinery/pkg/watch"
"k8s.io/client-go/tools/cache"
)
var (
PodSecurityPolicyGroupVersionKind = schema.GroupVersionKind{
Version: "v1beta1",
Group: "extensions",
Kind: "PodSecurityPolicy",
}
PodSecurityPolicyResource = metav1.APIResource{
Name: "podsecuritypolicies",
SingularName: "podsecuritypolicy",
Namespaced: false,
Kind: PodSecurityPolicyGroupVersionKind.Kind,
}
)
type PodSecurityPolicyList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []v1beta1.PodSecurityPolicy
}
type PodSecurityPolicyHandlerFunc func(key string, obj *v1beta1.PodSecurityPolicy) error
type PodSecurityPolicyLister interface {
List(namespace string, selector labels.Selector) (ret []*v1beta1.PodSecurityPolicy, err error)
Get(namespace, name string) (*v1beta1.PodSecurityPolicy, error)
}
type PodSecurityPolicyController interface {
Informer() cache.SharedIndexInformer
Lister() PodSecurityPolicyLister
AddHandler(handler PodSecurityPolicyHandlerFunc)
Enqueue(namespace, name string)
Sync(ctx context.Context) error
Start(ctx context.Context, threadiness int) error
}
type PodSecurityPolicyInterface interface {
ObjectClient() *clientbase.ObjectClient
Create(*v1beta1.PodSecurityPolicy) (*v1beta1.PodSecurityPolicy, error)
Get(name string, opts metav1.GetOptions) (*v1beta1.PodSecurityPolicy, error)
Update(*v1beta1.PodSecurityPolicy) (*v1beta1.PodSecurityPolicy, error)
Delete(name string, options *metav1.DeleteOptions) error
List(opts metav1.ListOptions) (*PodSecurityPolicyList, error)
Watch(opts metav1.ListOptions) (watch.Interface, error)
DeleteCollection(deleteOpts *metav1.DeleteOptions, listOpts metav1.ListOptions) error
Controller() PodSecurityPolicyController
}
type podSecurityPolicyLister struct {
controller *podSecurityPolicyController
}
func (l *podSecurityPolicyLister) List(namespace string, selector labels.Selector) (ret []*v1beta1.PodSecurityPolicy, err error) {
err = cache.ListAllByNamespace(l.controller.Informer().GetIndexer(), namespace, selector, func(obj interface{}) {
ret = append(ret, obj.(*v1beta1.PodSecurityPolicy))
})
return
}
func (l *podSecurityPolicyLister) Get(namespace, name string) (*v1beta1.PodSecurityPolicy, error) {
obj, exists, err := l.controller.Informer().GetIndexer().GetByKey(namespace + "/" + name)
if err != nil {
return nil, err
}
if !exists {
return nil, errors.NewNotFound(schema.GroupResource{
Group: PodSecurityPolicyGroupVersionKind.Group,
Resource: "podSecurityPolicy",
}, name)
}
return obj.(*v1beta1.PodSecurityPolicy), nil
}
type podSecurityPolicyController struct {
controller.GenericController
}
func (c *podSecurityPolicyController) Lister() PodSecurityPolicyLister {
return &podSecurityPolicyLister{
controller: c,
}
}
func (c *podSecurityPolicyController) AddHandler(handler PodSecurityPolicyHandlerFunc) {
c.GenericController.AddHandler(func(key string) error {
obj, exists, err := c.Informer().GetStore().GetByKey(key)
if err != nil {
return err
}
if !exists {
return handler(key, nil)
}
return handler(key, obj.(*v1beta1.PodSecurityPolicy))
})
}
type podSecurityPolicyFactory struct {
}
func (c podSecurityPolicyFactory) Object() runtime.Object {
return &v1beta1.PodSecurityPolicy{}
}
func (c podSecurityPolicyFactory) List() runtime.Object {
return &PodSecurityPolicyList{}
}
func (s *podSecurityPolicyClient) Controller() PodSecurityPolicyController {
s.client.Lock()
defer s.client.Unlock()
c, ok := s.client.podSecurityPolicyControllers[s.ns]
if ok {
return c
}
genericController := controller.NewGenericController(PodSecurityPolicyGroupVersionKind.Kind+"Controller",
s.objectClient)
c = &podSecurityPolicyController{
GenericController: genericController,
}
s.client.podSecurityPolicyControllers[s.ns] = c
s.client.starters = append(s.client.starters, c)
return c
}
type podSecurityPolicyClient struct {
client *Client
ns string
objectClient *clientbase.ObjectClient
controller PodSecurityPolicyController
}
func (s *podSecurityPolicyClient) ObjectClient() *clientbase.ObjectClient {
return s.objectClient
}
func (s *podSecurityPolicyClient) Create(o *v1beta1.PodSecurityPolicy) (*v1beta1.PodSecurityPolicy, error) {
obj, err := s.objectClient.Create(o)
return obj.(*v1beta1.PodSecurityPolicy), err
}
func (s *podSecurityPolicyClient) Get(name string, opts metav1.GetOptions) (*v1beta1.PodSecurityPolicy, error) {
obj, err := s.objectClient.Get(name, opts)
return obj.(*v1beta1.PodSecurityPolicy), err
}
func (s *podSecurityPolicyClient) Update(o *v1beta1.PodSecurityPolicy) (*v1beta1.PodSecurityPolicy, error) {
obj, err := s.objectClient.Update(o.Name, o)
return obj.(*v1beta1.PodSecurityPolicy), err
}
func (s *podSecurityPolicyClient) Delete(name string, options *metav1.DeleteOptions) error {
return s.objectClient.Delete(name, options)
}
func (s *podSecurityPolicyClient) List(opts metav1.ListOptions) (*PodSecurityPolicyList, error) {
obj, err := s.objectClient.List(opts)
return obj.(*PodSecurityPolicyList), err
}
func (s *podSecurityPolicyClient) Watch(opts metav1.ListOptions) (watch.Interface, error) {
return s.objectClient.Watch(opts)
}
func (s *podSecurityPolicyClient) DeleteCollection(deleteOpts *metav1.DeleteOptions, listOpts metav1.ListOptions) error {
return s.objectClient.DeleteCollection(deleteOpts, listOpts)
}

View File

@@ -0,0 +1,40 @@
package v1beta1
import (
"github.com/rancher/norman/lifecycle"
"k8s.io/api/extensions/v1beta1"
"k8s.io/apimachinery/pkg/runtime"
)
type PodSecurityPolicyLifecycle interface {
Create(obj *v1beta1.PodSecurityPolicy) error
Remove(obj *v1beta1.PodSecurityPolicy) error
Updated(obj *v1beta1.PodSecurityPolicy) error
}
type podSecurityPolicyLifecycleAdapter struct {
lifecycle PodSecurityPolicyLifecycle
}
func (w *podSecurityPolicyLifecycleAdapter) Create(obj runtime.Object) error {
return w.lifecycle.Create(obj.(*v1beta1.PodSecurityPolicy))
}
func (w *podSecurityPolicyLifecycleAdapter) Finalize(obj runtime.Object) error {
return w.lifecycle.Remove(obj.(*v1beta1.PodSecurityPolicy))
}
func (w *podSecurityPolicyLifecycleAdapter) Updated(obj runtime.Object) error {
return w.lifecycle.Updated(obj.(*v1beta1.PodSecurityPolicy))
}
func NewPodSecurityPolicyLifecycleAdapter(name string, client PodSecurityPolicyInterface, l PodSecurityPolicyLifecycle) PodSecurityPolicyHandlerFunc {
adapter := &podSecurityPolicyLifecycleAdapter{lifecycle: l}
syncFn := lifecycle.NewObjectLifecycleAdapter(name, adapter, client.ObjectClient())
return func(key string, obj *v1beta1.PodSecurityPolicy) error {
if obj == nil {
return syncFn(key, nil)
}
return syncFn(key, obj)
}
}