diff --git a/pkg/client/clientset/versioned/clientset.go b/pkg/client/clientset/versioned/clientset.go index 1ec3f730..25f5be2e 100644 --- a/pkg/client/clientset/versioned/clientset.go +++ b/pkg/client/clientset/versioned/clientset.go @@ -17,6 +17,7 @@ package versioned import ( + kubeflowv1 "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned/typed/mxnet/v1" kubeflowv1beta1 "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned/typed/mxnet/v1beta1" discovery "k8s.io/client-go/discovery" rest "k8s.io/client-go/rest" @@ -26,8 +27,9 @@ import ( type Interface interface { Discovery() discovery.DiscoveryInterface KubeflowV1beta1() kubeflowv1beta1.KubeflowV1beta1Interface + KubeflowV1() kubeflowv1.KubeflowV1Interface // Deprecated: please explicitly pick a version if possible. - Kubeflow() kubeflowv1beta1.KubeflowV1beta1Interface + Kubeflow() kubeflowv1.KubeflowV1Interface } // Clientset contains the clients for groups. Each group has exactly one @@ -35,6 +37,7 @@ type Interface interface { type Clientset struct { *discovery.DiscoveryClient kubeflowV1beta1 *kubeflowv1beta1.KubeflowV1beta1Client + kubeflowV1 *kubeflowv1.KubeflowV1Client } // KubeflowV1beta1 retrieves the KubeflowV1beta1Client @@ -42,10 +45,15 @@ func (c *Clientset) KubeflowV1beta1() kubeflowv1beta1.KubeflowV1beta1Interface { return c.kubeflowV1beta1 } +// KubeflowV1 retrieves the KubeflowV1Client +func (c *Clientset) KubeflowV1() kubeflowv1.KubeflowV1Interface { + return c.kubeflowV1 +} + // Deprecated: Kubeflow retrieves the default version of KubeflowClient. // Please explicitly pick a version. -func (c *Clientset) Kubeflow() kubeflowv1beta1.KubeflowV1beta1Interface { - return c.kubeflowV1beta1 +func (c *Clientset) Kubeflow() kubeflowv1.KubeflowV1Interface { + return c.kubeflowV1 } // Discovery retrieves the DiscoveryClient @@ -68,6 +76,10 @@ func NewForConfig(c *rest.Config) (*Clientset, error) { if err != nil { return nil, err } + cs.kubeflowV1, err = kubeflowv1.NewForConfig(&configShallowCopy) + if err != nil { + return nil, err + } cs.DiscoveryClient, err = discovery.NewDiscoveryClientForConfig(&configShallowCopy) if err != nil { @@ -81,6 +93,7 @@ func NewForConfig(c *rest.Config) (*Clientset, error) { func NewForConfigOrDie(c *rest.Config) *Clientset { var cs Clientset cs.kubeflowV1beta1 = kubeflowv1beta1.NewForConfigOrDie(c) + cs.kubeflowV1 = kubeflowv1.NewForConfigOrDie(c) cs.DiscoveryClient = discovery.NewDiscoveryClientForConfigOrDie(c) return &cs @@ -90,6 +103,7 @@ func NewForConfigOrDie(c *rest.Config) *Clientset { func New(c rest.Interface) *Clientset { var cs Clientset cs.kubeflowV1beta1 = kubeflowv1beta1.New(c) + cs.kubeflowV1 = kubeflowv1.New(c) cs.DiscoveryClient = discovery.NewDiscoveryClient(c) return &cs diff --git a/pkg/client/clientset/versioned/fake/clientset_generated.go b/pkg/client/clientset/versioned/fake/clientset_generated.go index 202604a4..fe3450e1 100644 --- a/pkg/client/clientset/versioned/fake/clientset_generated.go +++ b/pkg/client/clientset/versioned/fake/clientset_generated.go @@ -18,6 +18,8 @@ package fake import ( clientset "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned" + kubeflowv1 "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned/typed/mxnet/v1" + fakekubeflowv1 "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned/typed/mxnet/v1/fake" kubeflowv1beta1 "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned/typed/mxnet/v1beta1" fakekubeflowv1beta1 "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned/typed/mxnet/v1beta1/fake" "k8s.io/apimachinery/pkg/runtime" @@ -74,7 +76,12 @@ func (c *Clientset) KubeflowV1beta1() kubeflowv1beta1.KubeflowV1beta1Interface { return &fakekubeflowv1beta1.FakeKubeflowV1beta1{Fake: &c.Fake} } -// Kubeflow retrieves the KubeflowV1beta1Client -func (c *Clientset) Kubeflow() kubeflowv1beta1.KubeflowV1beta1Interface { - return &fakekubeflowv1beta1.FakeKubeflowV1beta1{Fake: &c.Fake} +// KubeflowV1 retrieves the KubeflowV1Client +func (c *Clientset) KubeflowV1() kubeflowv1.KubeflowV1Interface { + return &fakekubeflowv1.FakeKubeflowV1{Fake: &c.Fake} +} + +// Kubeflow retrieves the KubeflowV1Client +func (c *Clientset) Kubeflow() kubeflowv1.KubeflowV1Interface { + return &fakekubeflowv1.FakeKubeflowV1{Fake: &c.Fake} } diff --git a/pkg/client/clientset/versioned/fake/register.go b/pkg/client/clientset/versioned/fake/register.go index 47339eb1..2938fb81 100644 --- a/pkg/client/clientset/versioned/fake/register.go +++ b/pkg/client/clientset/versioned/fake/register.go @@ -17,6 +17,7 @@ package fake import ( + kubeflowv1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1" kubeflowv1beta1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1beta1" v1 "k8s.io/apimachinery/pkg/apis/meta/v1" runtime "k8s.io/apimachinery/pkg/runtime" @@ -49,4 +50,5 @@ func init() { // correctly. func AddToScheme(scheme *runtime.Scheme) { kubeflowv1beta1.AddToScheme(scheme) + kubeflowv1.AddToScheme(scheme) } diff --git a/pkg/client/clientset/versioned/scheme/register.go b/pkg/client/clientset/versioned/scheme/register.go index 8e15377c..c08bb5d5 100644 --- a/pkg/client/clientset/versioned/scheme/register.go +++ b/pkg/client/clientset/versioned/scheme/register.go @@ -17,6 +17,7 @@ package scheme import ( + kubeflowv1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1" kubeflowv1beta1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1beta1" v1 "k8s.io/apimachinery/pkg/apis/meta/v1" runtime "k8s.io/apimachinery/pkg/runtime" @@ -49,4 +50,5 @@ func init() { // correctly. func AddToScheme(scheme *runtime.Scheme) { kubeflowv1beta1.AddToScheme(scheme) + kubeflowv1.AddToScheme(scheme) } diff --git a/pkg/client/clientset/versioned/typed/mxnet/v1/doc.go b/pkg/client/clientset/versioned/typed/mxnet/v1/doc.go new file mode 100644 index 00000000..5c8101df --- /dev/null +++ b/pkg/client/clientset/versioned/typed/mxnet/v1/doc.go @@ -0,0 +1,18 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by client-gen. DO NOT EDIT. + +// This package has the automatically generated typed clients. +package v1 diff --git a/pkg/client/clientset/versioned/typed/mxnet/v1/fake/doc.go b/pkg/client/clientset/versioned/typed/mxnet/v1/fake/doc.go new file mode 100644 index 00000000..ce2fa8a9 --- /dev/null +++ b/pkg/client/clientset/versioned/typed/mxnet/v1/fake/doc.go @@ -0,0 +1,18 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by client-gen. DO NOT EDIT. + +// Package fake has the automatically generated clients. +package fake diff --git a/pkg/client/clientset/versioned/typed/mxnet/v1/fake/fake_mxjob.go b/pkg/client/clientset/versioned/typed/mxnet/v1/fake/fake_mxjob.go new file mode 100644 index 00000000..55b76cb4 --- /dev/null +++ b/pkg/client/clientset/versioned/typed/mxnet/v1/fake/fake_mxjob.go @@ -0,0 +1,138 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by client-gen. DO NOT EDIT. + +package fake + +import ( + mxnetv1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" + labels "k8s.io/apimachinery/pkg/labels" + schema "k8s.io/apimachinery/pkg/runtime/schema" + types "k8s.io/apimachinery/pkg/types" + watch "k8s.io/apimachinery/pkg/watch" + testing "k8s.io/client-go/testing" +) + +// FakeMXJobs implements MXJobInterface +type FakeMXJobs struct { + Fake *FakeKubeflowV1 + ns string +} + +var mxjobsResource = schema.GroupVersionResource{Group: "kubeflow.org", Version: "v1", Resource: "mxjobs"} + +var mxjobsKind = schema.GroupVersionKind{Group: "kubeflow.org", Version: "v1", Kind: "MXJob"} + +// Get takes name of the mXJob, and returns the corresponding mXJob object, and an error if there is any. +func (c *FakeMXJobs) Get(name string, options v1.GetOptions) (result *mxnetv1.MXJob, err error) { + obj, err := c.Fake. + Invokes(testing.NewGetAction(mxjobsResource, c.ns, name), &mxnetv1.MXJob{}) + + if obj == nil { + return nil, err + } + return obj.(*mxnetv1.MXJob), err +} + +// List takes label and field selectors, and returns the list of MXJobs that match those selectors. +func (c *FakeMXJobs) List(opts v1.ListOptions) (result *mxnetv1.MXJobList, err error) { + obj, err := c.Fake. + Invokes(testing.NewListAction(mxjobsResource, mxjobsKind, c.ns, opts), &mxnetv1.MXJobList{}) + + if obj == nil { + return nil, err + } + + label, _, _ := testing.ExtractFromListOptions(opts) + if label == nil { + label = labels.Everything() + } + list := &mxnetv1.MXJobList{ListMeta: obj.(*mxnetv1.MXJobList).ListMeta} + for _, item := range obj.(*mxnetv1.MXJobList).Items { + if label.Matches(labels.Set(item.Labels)) { + list.Items = append(list.Items, item) + } + } + return list, err +} + +// Watch returns a watch.Interface that watches the requested mXJobs. +func (c *FakeMXJobs) Watch(opts v1.ListOptions) (watch.Interface, error) { + return c.Fake. + InvokesWatch(testing.NewWatchAction(mxjobsResource, c.ns, opts)) + +} + +// Create takes the representation of a mXJob and creates it. Returns the server's representation of the mXJob, and an error, if there is any. +func (c *FakeMXJobs) Create(mXJob *mxnetv1.MXJob) (result *mxnetv1.MXJob, err error) { + obj, err := c.Fake. + Invokes(testing.NewCreateAction(mxjobsResource, c.ns, mXJob), &mxnetv1.MXJob{}) + + if obj == nil { + return nil, err + } + return obj.(*mxnetv1.MXJob), err +} + +// Update takes the representation of a mXJob and updates it. Returns the server's representation of the mXJob, and an error, if there is any. +func (c *FakeMXJobs) Update(mXJob *mxnetv1.MXJob) (result *mxnetv1.MXJob, err error) { + obj, err := c.Fake. + Invokes(testing.NewUpdateAction(mxjobsResource, c.ns, mXJob), &mxnetv1.MXJob{}) + + if obj == nil { + return nil, err + } + return obj.(*mxnetv1.MXJob), err +} + +// UpdateStatus was generated because the type contains a Status member. +// Add a +genclient:noStatus comment above the type to avoid generating UpdateStatus(). +func (c *FakeMXJobs) UpdateStatus(mXJob *mxnetv1.MXJob) (*mxnetv1.MXJob, error) { + obj, err := c.Fake. + Invokes(testing.NewUpdateSubresourceAction(mxjobsResource, "status", c.ns, mXJob), &mxnetv1.MXJob{}) + + if obj == nil { + return nil, err + } + return obj.(*mxnetv1.MXJob), err +} + +// Delete takes name of the mXJob and deletes it. Returns an error if one occurs. +func (c *FakeMXJobs) Delete(name string, options *v1.DeleteOptions) error { + _, err := c.Fake. + Invokes(testing.NewDeleteAction(mxjobsResource, c.ns, name), &mxnetv1.MXJob{}) + + return err +} + +// DeleteCollection deletes a collection of objects. +func (c *FakeMXJobs) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { + action := testing.NewDeleteCollectionAction(mxjobsResource, c.ns, listOptions) + + _, err := c.Fake.Invokes(action, &mxnetv1.MXJobList{}) + return err +} + +// Patch applies the patch and returns the patched mXJob. +func (c *FakeMXJobs) Patch(name string, pt types.PatchType, data []byte, subresources ...string) (result *mxnetv1.MXJob, err error) { + obj, err := c.Fake. + Invokes(testing.NewPatchSubresourceAction(mxjobsResource, c.ns, name, data, subresources...), &mxnetv1.MXJob{}) + + if obj == nil { + return nil, err + } + return obj.(*mxnetv1.MXJob), err +} diff --git a/pkg/client/clientset/versioned/typed/mxnet/v1/fake/fake_mxnet_client.go b/pkg/client/clientset/versioned/typed/mxnet/v1/fake/fake_mxnet_client.go new file mode 100644 index 00000000..337ecdfa --- /dev/null +++ b/pkg/client/clientset/versioned/typed/mxnet/v1/fake/fake_mxnet_client.go @@ -0,0 +1,38 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by client-gen. DO NOT EDIT. + +package fake + +import ( + v1 "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned/typed/mxnet/v1" + rest "k8s.io/client-go/rest" + testing "k8s.io/client-go/testing" +) + +type FakeKubeflowV1 struct { + *testing.Fake +} + +func (c *FakeKubeflowV1) MXJobs(namespace string) v1.MXJobInterface { + return &FakeMXJobs{c, namespace} +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *FakeKubeflowV1) RESTClient() rest.Interface { + var ret *rest.RESTClient + return ret +} diff --git a/pkg/client/clientset/versioned/typed/mxnet/v1/generated_expansion.go b/pkg/client/clientset/versioned/typed/mxnet/v1/generated_expansion.go new file mode 100644 index 00000000..e1fc0a68 --- /dev/null +++ b/pkg/client/clientset/versioned/typed/mxnet/v1/generated_expansion.go @@ -0,0 +1,19 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by client-gen. DO NOT EDIT. + +package v1 + +type MXJobExpansion interface{} diff --git a/pkg/client/clientset/versioned/typed/mxnet/v1/mxjob.go b/pkg/client/clientset/versioned/typed/mxnet/v1/mxjob.go new file mode 100644 index 00000000..4149c61a --- /dev/null +++ b/pkg/client/clientset/versioned/typed/mxnet/v1/mxjob.go @@ -0,0 +1,172 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by client-gen. DO NOT EDIT. + +package v1 + +import ( + v1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1" + scheme "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned/scheme" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + types "k8s.io/apimachinery/pkg/types" + watch "k8s.io/apimachinery/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// MXJobsGetter has a method to return a MXJobInterface. +// A group's client should implement this interface. +type MXJobsGetter interface { + MXJobs(namespace string) MXJobInterface +} + +// MXJobInterface has methods to work with MXJob resources. +type MXJobInterface interface { + Create(*v1.MXJob) (*v1.MXJob, error) + Update(*v1.MXJob) (*v1.MXJob, error) + UpdateStatus(*v1.MXJob) (*v1.MXJob, error) + Delete(name string, options *metav1.DeleteOptions) error + DeleteCollection(options *metav1.DeleteOptions, listOptions metav1.ListOptions) error + Get(name string, options metav1.GetOptions) (*v1.MXJob, error) + List(opts metav1.ListOptions) (*v1.MXJobList, error) + Watch(opts metav1.ListOptions) (watch.Interface, error) + Patch(name string, pt types.PatchType, data []byte, subresources ...string) (result *v1.MXJob, err error) + MXJobExpansion +} + +// mXJobs implements MXJobInterface +type mXJobs struct { + client rest.Interface + ns string +} + +// newMXJobs returns a MXJobs +func newMXJobs(c *KubeflowV1Client, namespace string) *mXJobs { + return &mXJobs{ + client: c.RESTClient(), + ns: namespace, + } +} + +// Get takes name of the mXJob, and returns the corresponding mXJob object, and an error if there is any. +func (c *mXJobs) Get(name string, options metav1.GetOptions) (result *v1.MXJob, err error) { + result = &v1.MXJob{} + err = c.client.Get(). + Namespace(c.ns). + Resource("mxjobs"). + Name(name). + VersionedParams(&options, scheme.ParameterCodec). + Do(). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of MXJobs that match those selectors. +func (c *mXJobs) List(opts metav1.ListOptions) (result *v1.MXJobList, err error) { + result = &v1.MXJobList{} + err = c.client.Get(). + Namespace(c.ns). + Resource("mxjobs"). + VersionedParams(&opts, scheme.ParameterCodec). + Do(). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested mXJobs. +func (c *mXJobs) Watch(opts metav1.ListOptions) (watch.Interface, error) { + opts.Watch = true + return c.client.Get(). + Namespace(c.ns). + Resource("mxjobs"). + VersionedParams(&opts, scheme.ParameterCodec). + Watch() +} + +// Create takes the representation of a mXJob and creates it. Returns the server's representation of the mXJob, and an error, if there is any. +func (c *mXJobs) Create(mXJob *v1.MXJob) (result *v1.MXJob, err error) { + result = &v1.MXJob{} + err = c.client.Post(). + Namespace(c.ns). + Resource("mxjobs"). + Body(mXJob). + Do(). + Into(result) + return +} + +// Update takes the representation of a mXJob and updates it. Returns the server's representation of the mXJob, and an error, if there is any. +func (c *mXJobs) Update(mXJob *v1.MXJob) (result *v1.MXJob, err error) { + result = &v1.MXJob{} + err = c.client.Put(). + Namespace(c.ns). + Resource("mxjobs"). + Name(mXJob.Name). + Body(mXJob). + Do(). + Into(result) + return +} + +// UpdateStatus was generated because the type contains a Status member. +// Add a +genclient:noStatus comment above the type to avoid generating UpdateStatus(). + +func (c *mXJobs) UpdateStatus(mXJob *v1.MXJob) (result *v1.MXJob, err error) { + result = &v1.MXJob{} + err = c.client.Put(). + Namespace(c.ns). + Resource("mxjobs"). + Name(mXJob.Name). + SubResource("status"). + Body(mXJob). + Do(). + Into(result) + return +} + +// Delete takes name of the mXJob and deletes it. Returns an error if one occurs. +func (c *mXJobs) Delete(name string, options *metav1.DeleteOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("mxjobs"). + Name(name). + Body(options). + Do(). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *mXJobs) DeleteCollection(options *metav1.DeleteOptions, listOptions metav1.ListOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("mxjobs"). + VersionedParams(&listOptions, scheme.ParameterCodec). + Body(options). + Do(). + Error() +} + +// Patch applies the patch and returns the patched mXJob. +func (c *mXJobs) Patch(name string, pt types.PatchType, data []byte, subresources ...string) (result *v1.MXJob, err error) { + result = &v1.MXJob{} + err = c.client.Patch(pt). + Namespace(c.ns). + Resource("mxjobs"). + SubResource(subresources...). + Name(name). + Body(data). + Do(). + Into(result) + return +} diff --git a/pkg/client/clientset/versioned/typed/mxnet/v1/mxnet_client.go b/pkg/client/clientset/versioned/typed/mxnet/v1/mxnet_client.go new file mode 100644 index 00000000..8e47590a --- /dev/null +++ b/pkg/client/clientset/versioned/typed/mxnet/v1/mxnet_client.go @@ -0,0 +1,88 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by client-gen. DO NOT EDIT. + +package v1 + +import ( + v1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1" + "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned/scheme" + serializer "k8s.io/apimachinery/pkg/runtime/serializer" + rest "k8s.io/client-go/rest" +) + +type KubeflowV1Interface interface { + RESTClient() rest.Interface + MXJobsGetter +} + +// KubeflowV1Client is used to interact with features provided by the kubeflow.org group. +type KubeflowV1Client struct { + restClient rest.Interface +} + +func (c *KubeflowV1Client) MXJobs(namespace string) MXJobInterface { + return newMXJobs(c, namespace) +} + +// NewForConfig creates a new KubeflowV1Client for the given config. +func NewForConfig(c *rest.Config) (*KubeflowV1Client, error) { + config := *c + if err := setConfigDefaults(&config); err != nil { + return nil, err + } + client, err := rest.RESTClientFor(&config) + if err != nil { + return nil, err + } + return &KubeflowV1Client{client}, nil +} + +// NewForConfigOrDie creates a new KubeflowV1Client for the given config and +// panics if there is an error in the config. +func NewForConfigOrDie(c *rest.Config) *KubeflowV1Client { + client, err := NewForConfig(c) + if err != nil { + panic(err) + } + return client +} + +// New creates a new KubeflowV1Client for the given RESTClient. +func New(c rest.Interface) *KubeflowV1Client { + return &KubeflowV1Client{c} +} + +func setConfigDefaults(config *rest.Config) error { + gv := v1.SchemeGroupVersion + config.GroupVersion = &gv + config.APIPath = "/apis" + config.NegotiatedSerializer = serializer.DirectCodecFactory{CodecFactory: scheme.Codecs} + + if config.UserAgent == "" { + config.UserAgent = rest.DefaultKubernetesUserAgent() + } + + return nil +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *KubeflowV1Client) RESTClient() rest.Interface { + if c == nil { + return nil + } + return c.restClient +} diff --git a/pkg/client/informers/externalversions/generic.go b/pkg/client/informers/externalversions/generic.go index afb538e1..cace5438 100644 --- a/pkg/client/informers/externalversions/generic.go +++ b/pkg/client/informers/externalversions/generic.go @@ -19,6 +19,7 @@ package externalversions import ( "fmt" + v1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1" v1beta1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1beta1" schema "k8s.io/apimachinery/pkg/runtime/schema" cache "k8s.io/client-go/tools/cache" @@ -50,7 +51,11 @@ func (f *genericInformer) Lister() cache.GenericLister { // TODO extend this to unknown resources with a client pool func (f *sharedInformerFactory) ForResource(resource schema.GroupVersionResource) (GenericInformer, error) { switch resource { - // Group=kubeflow.org, Version=v1beta1 + // Group=kubeflow.org, Version=v1 + case v1.SchemeGroupVersion.WithResource("mxjobs"): + return &genericInformer{resource: resource.GroupResource(), informer: f.Kubeflow().V1().MXJobs().Informer()}, nil + + // Group=kubeflow.org, Version=v1beta1 case v1beta1.SchemeGroupVersion.WithResource("mxjobs"): return &genericInformer{resource: resource.GroupResource(), informer: f.Kubeflow().V1beta1().MXJobs().Informer()}, nil diff --git a/pkg/client/informers/externalversions/mxnet/interface.go b/pkg/client/informers/externalversions/mxnet/interface.go index 57ffc7bb..7a60fa9d 100644 --- a/pkg/client/informers/externalversions/mxnet/interface.go +++ b/pkg/client/informers/externalversions/mxnet/interface.go @@ -18,6 +18,7 @@ package kubeflow import ( internalinterfaces "github.com/kubeflow/mxnet-operator/pkg/client/informers/externalversions/internalinterfaces" + v1 "github.com/kubeflow/mxnet-operator/pkg/client/informers/externalversions/mxnet/v1" v1beta1 "github.com/kubeflow/mxnet-operator/pkg/client/informers/externalversions/mxnet/v1beta1" ) @@ -25,6 +26,8 @@ import ( type Interface interface { // V1beta1 provides access to shared informers for resources in V1beta1. V1beta1() v1beta1.Interface + // V1 provides access to shared informers for resources in V1. + V1() v1.Interface } type group struct { @@ -42,3 +45,8 @@ func New(f internalinterfaces.SharedInformerFactory, namespace string, tweakList func (g *group) V1beta1() v1beta1.Interface { return v1beta1.New(g.factory, g.namespace, g.tweakListOptions) } + +// V1 returns a new v1.Interface. +func (g *group) V1() v1.Interface { + return v1.New(g.factory, g.namespace, g.tweakListOptions) +} diff --git a/pkg/client/informers/externalversions/mxnet/v1/interface.go b/pkg/client/informers/externalversions/mxnet/v1/interface.go new file mode 100644 index 00000000..f4dd4c76 --- /dev/null +++ b/pkg/client/informers/externalversions/mxnet/v1/interface.go @@ -0,0 +1,43 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by informer-gen. DO NOT EDIT. + +package v1 + +import ( + internalinterfaces "github.com/kubeflow/mxnet-operator/pkg/client/informers/externalversions/internalinterfaces" +) + +// Interface provides access to all the informers in this group version. +type Interface interface { + // MXJobs returns a MXJobInformer. + MXJobs() MXJobInformer +} + +type version struct { + factory internalinterfaces.SharedInformerFactory + namespace string + tweakListOptions internalinterfaces.TweakListOptionsFunc +} + +// New returns a new Interface. +func New(f internalinterfaces.SharedInformerFactory, namespace string, tweakListOptions internalinterfaces.TweakListOptionsFunc) Interface { + return &version{factory: f, namespace: namespace, tweakListOptions: tweakListOptions} +} + +// MXJobs returns a MXJobInformer. +func (v *version) MXJobs() MXJobInformer { + return &mXJobInformer{factory: v.factory, namespace: v.namespace, tweakListOptions: v.tweakListOptions} +} diff --git a/pkg/client/informers/externalversions/mxnet/v1/mxjob.go b/pkg/client/informers/externalversions/mxnet/v1/mxjob.go new file mode 100644 index 00000000..c394a811 --- /dev/null +++ b/pkg/client/informers/externalversions/mxnet/v1/mxjob.go @@ -0,0 +1,87 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by informer-gen. DO NOT EDIT. + +package v1 + +import ( + time "time" + + mxnetv1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1" + versioned "github.com/kubeflow/mxnet-operator/pkg/client/clientset/versioned" + internalinterfaces "github.com/kubeflow/mxnet-operator/pkg/client/informers/externalversions/internalinterfaces" + v1 "github.com/kubeflow/mxnet-operator/pkg/client/listers/mxnet/v1" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + runtime "k8s.io/apimachinery/pkg/runtime" + watch "k8s.io/apimachinery/pkg/watch" + cache "k8s.io/client-go/tools/cache" +) + +// MXJobInformer provides access to a shared informer and lister for +// MXJobs. +type MXJobInformer interface { + Informer() cache.SharedIndexInformer + Lister() v1.MXJobLister +} + +type mXJobInformer struct { + factory internalinterfaces.SharedInformerFactory + tweakListOptions internalinterfaces.TweakListOptionsFunc + namespace string +} + +// NewMXJobInformer constructs a new informer for MXJob type. +// Always prefer using an informer factory to get a shared informer instead of getting an independent +// one. This reduces memory footprint and number of connections to the server. +func NewMXJobInformer(client versioned.Interface, namespace string, resyncPeriod time.Duration, indexers cache.Indexers) cache.SharedIndexInformer { + return NewFilteredMXJobInformer(client, namespace, resyncPeriod, indexers, nil) +} + +// NewFilteredMXJobInformer constructs a new informer for MXJob type. +// Always prefer using an informer factory to get a shared informer instead of getting an independent +// one. This reduces memory footprint and number of connections to the server. +func NewFilteredMXJobInformer(client versioned.Interface, namespace string, resyncPeriod time.Duration, indexers cache.Indexers, tweakListOptions internalinterfaces.TweakListOptionsFunc) cache.SharedIndexInformer { + return cache.NewSharedIndexInformer( + &cache.ListWatch{ + ListFunc: func(options metav1.ListOptions) (runtime.Object, error) { + if tweakListOptions != nil { + tweakListOptions(&options) + } + return client.KubeflowV1().MXJobs(namespace).List(options) + }, + WatchFunc: func(options metav1.ListOptions) (watch.Interface, error) { + if tweakListOptions != nil { + tweakListOptions(&options) + } + return client.KubeflowV1().MXJobs(namespace).Watch(options) + }, + }, + &mxnetv1.MXJob{}, + resyncPeriod, + indexers, + ) +} + +func (f *mXJobInformer) defaultInformer(client versioned.Interface, resyncPeriod time.Duration) cache.SharedIndexInformer { + return NewFilteredMXJobInformer(client, f.namespace, resyncPeriod, cache.Indexers{cache.NamespaceIndex: cache.MetaNamespaceIndexFunc}, f.tweakListOptions) +} + +func (f *mXJobInformer) Informer() cache.SharedIndexInformer { + return f.factory.InformerFor(&mxnetv1.MXJob{}, f.defaultInformer) +} + +func (f *mXJobInformer) Lister() v1.MXJobLister { + return v1.NewMXJobLister(f.Informer().GetIndexer()) +} diff --git a/pkg/client/listers/mxnet/v1/expansion_generated.go b/pkg/client/listers/mxnet/v1/expansion_generated.go new file mode 100644 index 00000000..eb7a4b9a --- /dev/null +++ b/pkg/client/listers/mxnet/v1/expansion_generated.go @@ -0,0 +1,25 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by lister-gen. DO NOT EDIT. + +package v1 + +// MXJobListerExpansion allows custom methods to be added to +// MXJobLister. +type MXJobListerExpansion interface{} + +// MXJobNamespaceListerExpansion allows custom methods to be added to +// MXJobNamespaceLister. +type MXJobNamespaceListerExpansion interface{} diff --git a/pkg/client/listers/mxnet/v1/mxjob.go b/pkg/client/listers/mxnet/v1/mxjob.go new file mode 100644 index 00000000..8397f376 --- /dev/null +++ b/pkg/client/listers/mxnet/v1/mxjob.go @@ -0,0 +1,92 @@ +// Copyright 2019 The Kubeflow Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by lister-gen. DO NOT EDIT. + +package v1 + +import ( + v1 "github.com/kubeflow/mxnet-operator/pkg/apis/mxnet/v1" + "k8s.io/apimachinery/pkg/api/errors" + "k8s.io/apimachinery/pkg/labels" + "k8s.io/client-go/tools/cache" +) + +// MXJobLister helps list MXJobs. +type MXJobLister interface { + // List lists all MXJobs in the indexer. + List(selector labels.Selector) (ret []*v1.MXJob, err error) + // MXJobs returns an object that can list and get MXJobs. + MXJobs(namespace string) MXJobNamespaceLister + MXJobListerExpansion +} + +// mXJobLister implements the MXJobLister interface. +type mXJobLister struct { + indexer cache.Indexer +} + +// NewMXJobLister returns a new MXJobLister. +func NewMXJobLister(indexer cache.Indexer) MXJobLister { + return &mXJobLister{indexer: indexer} +} + +// List lists all MXJobs in the indexer. +func (s *mXJobLister) List(selector labels.Selector) (ret []*v1.MXJob, err error) { + err = cache.ListAll(s.indexer, selector, func(m interface{}) { + ret = append(ret, m.(*v1.MXJob)) + }) + return ret, err +} + +// MXJobs returns an object that can list and get MXJobs. +func (s *mXJobLister) MXJobs(namespace string) MXJobNamespaceLister { + return mXJobNamespaceLister{indexer: s.indexer, namespace: namespace} +} + +// MXJobNamespaceLister helps list and get MXJobs. +type MXJobNamespaceLister interface { + // List lists all MXJobs in the indexer for a given namespace. + List(selector labels.Selector) (ret []*v1.MXJob, err error) + // Get retrieves the MXJob from the indexer for a given namespace and name. + Get(name string) (*v1.MXJob, error) + MXJobNamespaceListerExpansion +} + +// mXJobNamespaceLister implements the MXJobNamespaceLister +// interface. +type mXJobNamespaceLister struct { + indexer cache.Indexer + namespace string +} + +// List lists all MXJobs in the indexer for a given namespace. +func (s mXJobNamespaceLister) List(selector labels.Selector) (ret []*v1.MXJob, err error) { + err = cache.ListAllByNamespace(s.indexer, s.namespace, selector, func(m interface{}) { + ret = append(ret, m.(*v1.MXJob)) + }) + return ret, err +} + +// Get retrieves the MXJob from the indexer for a given namespace and name. +func (s mXJobNamespaceLister) Get(name string) (*v1.MXJob, error) { + obj, exists, err := s.indexer.GetByKey(s.namespace + "/" + name) + if err != nil { + return nil, err + } + if !exists { + return nil, errors.NewNotFound(v1.Resource("mxjob"), name) + } + return obj.(*v1.MXJob), nil +}