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:
committed by
Darren Shepherd
parent
a33c987eac
commit
e77815f156
40
apis/extensions/v1beta1/zz_generated_deepcopy.go
Normal file
40
apis/extensions/v1beta1/zz_generated_deepcopy.go
Normal 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
|
||||
}
|
||||
}
|
69
apis/extensions/v1beta1/zz_generated_k8s_client.go
Normal file
69
apis/extensions/v1beta1/zz_generated_k8s_client.go
Normal 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,
|
||||
}
|
||||
}
|
@@ -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)
|
||||
}
|
@@ -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)
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user