(feat) Add auto-discovery in k8s | Adarsh
This commit is contained in:
		
							
								
								
									
										23
									
								
								vendor/k8s.io/api/rbac/v1alpha1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								vendor/k8s.io/api/rbac/v1alpha1/doc.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | ||||
| /* | ||||
| Copyright 2016 The Kubernetes 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. | ||||
| */ | ||||
|  | ||||
| // +k8s:deepcopy-gen=package | ||||
| // +k8s:protobuf-gen=package | ||||
| // +k8s:openapi-gen=true | ||||
|  | ||||
| // +groupName=rbac.authorization.k8s.io | ||||
|  | ||||
| package v1alpha1 // import "k8s.io/api/rbac/v1alpha1" | ||||
							
								
								
									
										2735
									
								
								vendor/k8s.io/api/rbac/v1alpha1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2735
									
								
								vendor/k8s.io/api/rbac/v1alpha1/generated.pb.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										201
									
								
								vendor/k8s.io/api/rbac/v1alpha1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										201
									
								
								vendor/k8s.io/api/rbac/v1alpha1/generated.proto
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,201 @@ | ||||
| /* | ||||
| Copyright The Kubernetes 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. | ||||
| */ | ||||
|  | ||||
|  | ||||
| // This file was autogenerated by go-to-protobuf. Do not edit it manually! | ||||
|  | ||||
| syntax = 'proto2'; | ||||
|  | ||||
| package k8s.io.api.rbac.v1alpha1; | ||||
|  | ||||
| import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/generated.proto"; | ||||
| import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto"; | ||||
|  | ||||
| // Package-wide variables from generator "generated". | ||||
| option go_package = "v1alpha1"; | ||||
|  | ||||
| // AggregationRule describes how to locate ClusterRoles to aggregate into the ClusterRole | ||||
| message AggregationRule { | ||||
|   // ClusterRoleSelectors holds a list of selectors which will be used to find ClusterRoles and create the rules. | ||||
|   // If any of the selectors match, then the ClusterRole's permissions will be added | ||||
|   // +optional | ||||
|   repeated k8s.io.apimachinery.pkg.apis.meta.v1.LabelSelector clusterRoleSelectors = 1; | ||||
| } | ||||
|  | ||||
| // ClusterRole is a cluster level, logical grouping of PolicyRules that can be referenced as a unit by a RoleBinding or ClusterRoleBinding. | ||||
| message ClusterRole { | ||||
|   // Standard object's metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Rules holds all the PolicyRules for this ClusterRole | ||||
|   // +optional | ||||
|   repeated PolicyRule rules = 2; | ||||
|  | ||||
|   // AggregationRule is an optional field that describes how to build the Rules for this ClusterRole. | ||||
|   // If AggregationRule is set, then the Rules are controller managed and direct changes to Rules will be | ||||
|   // stomped by the controller. | ||||
|   // +optional | ||||
|   optional AggregationRule aggregationRule = 3; | ||||
| } | ||||
|  | ||||
| // ClusterRoleBinding references a ClusterRole, but not contain it.  It can reference a ClusterRole in the global namespace, | ||||
| // and adds who information via Subject. | ||||
| message ClusterRoleBinding { | ||||
|   // Standard object's metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Subjects holds references to the objects the role applies to. | ||||
|   // +optional | ||||
|   repeated Subject subjects = 2; | ||||
|  | ||||
|   // RoleRef can only reference a ClusterRole in the global namespace. | ||||
|   // If the RoleRef cannot be resolved, the Authorizer must return an error. | ||||
|   optional RoleRef roleRef = 3; | ||||
| } | ||||
|  | ||||
| // ClusterRoleBindingList is a collection of ClusterRoleBindings | ||||
| message ClusterRoleBindingList { | ||||
|   // Standard object's metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // Items is a list of ClusterRoleBindings | ||||
|   repeated ClusterRoleBinding items = 2; | ||||
| } | ||||
|  | ||||
| // ClusterRoleList is a collection of ClusterRoles | ||||
| message ClusterRoleList { | ||||
|   // Standard object's metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // Items is a list of ClusterRoles | ||||
|   repeated ClusterRole items = 2; | ||||
| } | ||||
|  | ||||
| // PolicyRule holds information that describes a policy rule, but does not contain information | ||||
| // about who the rule applies to or which namespace the rule applies to. | ||||
| message PolicyRule { | ||||
|   // Verbs is a list of Verbs that apply to ALL the ResourceKinds and AttributeRestrictions contained in this rule.  VerbAll represents all kinds. | ||||
|   repeated string verbs = 1; | ||||
|  | ||||
|   // APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of | ||||
|   // the enumerated resources in any API group will be allowed. | ||||
|   // +optional | ||||
|   repeated string apiGroups = 3; | ||||
|  | ||||
|   // Resources is a list of resources this rule applies to.  ResourceAll represents all resources. | ||||
|   // +optional | ||||
|   repeated string resources = 4; | ||||
|  | ||||
|   // ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed. | ||||
|   // +optional | ||||
|   repeated string resourceNames = 5; | ||||
|  | ||||
|   // NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, final step in the path | ||||
|   // This name is intentionally different than the internal type so that the DefaultConvert works nicely and because the ordering may be different. | ||||
|   // Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. | ||||
|   // Rules can either apply to API resources (such as "pods" or "secrets") or non-resource URL paths (such as "/api"),  but not both. | ||||
|   // +optional | ||||
|   repeated string nonResourceURLs = 6; | ||||
| } | ||||
|  | ||||
| // Role is a namespaced, logical grouping of PolicyRules that can be referenced as a unit by a RoleBinding. | ||||
| message Role { | ||||
|   // Standard object's metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Rules holds all the PolicyRules for this Role | ||||
|   // +optional | ||||
|   repeated PolicyRule rules = 2; | ||||
| } | ||||
|  | ||||
| // RoleBinding references a role, but does not contain it.  It can reference a Role in the same namespace or a ClusterRole in the global namespace. | ||||
| // It adds who information via Subjects and namespace information by which namespace it exists in.  RoleBindings in a given | ||||
| // namespace only have effect in that namespace. | ||||
| message RoleBinding { | ||||
|   // Standard object's metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||
|  | ||||
|   // Subjects holds references to the objects the role applies to. | ||||
|   // +optional | ||||
|   repeated Subject subjects = 2; | ||||
|  | ||||
|   // RoleRef can reference a Role in the current namespace or a ClusterRole in the global namespace. | ||||
|   // If the RoleRef cannot be resolved, the Authorizer must return an error. | ||||
|   optional RoleRef roleRef = 3; | ||||
| } | ||||
|  | ||||
| // RoleBindingList is a collection of RoleBindings | ||||
| message RoleBindingList { | ||||
|   // Standard object's metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // Items is a list of RoleBindings | ||||
|   repeated RoleBinding items = 2; | ||||
| } | ||||
|  | ||||
| // RoleList is a collection of Roles | ||||
| message RoleList { | ||||
|   // Standard object's metadata. | ||||
|   // +optional | ||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||
|  | ||||
|   // Items is a list of Roles | ||||
|   repeated Role items = 2; | ||||
| } | ||||
|  | ||||
| // RoleRef contains information that points to the role being used | ||||
| message RoleRef { | ||||
|   // APIGroup is the group for the resource being referenced | ||||
|   optional string apiGroup = 1; | ||||
|  | ||||
|   // Kind is the type of resource being referenced | ||||
|   optional string kind = 2; | ||||
|  | ||||
|   // Name is the name of resource being referenced | ||||
|   optional string name = 3; | ||||
| } | ||||
|  | ||||
| // Subject contains a reference to the object or user identities a role binding applies to.  This can either hold a direct API object reference, | ||||
| // or a value for non-objects such as user and group names. | ||||
| message Subject { | ||||
|   // Kind of object being referenced. Values defined by this API group are "User", "Group", and "ServiceAccount". | ||||
|   // If the Authorizer does not recognized the kind value, the Authorizer should report an error. | ||||
|   optional string kind = 1; | ||||
|  | ||||
|   // APIVersion holds the API group and version of the referenced subject. | ||||
|   // Defaults to "v1" for ServiceAccount subjects. | ||||
|   // Defaults to "rbac.authorization.k8s.io/v1alpha1" for User and Group subjects. | ||||
|   // +k8s:conversion-gen=false | ||||
|   // +optional | ||||
|   optional string apiVersion = 2; | ||||
|  | ||||
|   // Name of the object being referenced. | ||||
|   optional string name = 3; | ||||
|  | ||||
|   // Namespace of the referenced object.  If the object kind is non-namespace, such as "User" or "Group", and this value is not empty | ||||
|   // the Authorizer should report an error. | ||||
|   // +optional | ||||
|   optional string namespace = 4; | ||||
| } | ||||
|  | ||||
							
								
								
									
										58
									
								
								vendor/k8s.io/api/rbac/v1alpha1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								vendor/k8s.io/api/rbac/v1alpha1/register.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,58 @@ | ||||
| /* | ||||
| Copyright 2016 The Kubernetes 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. | ||||
| */ | ||||
|  | ||||
| package v1alpha1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/apimachinery/pkg/runtime" | ||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||
| ) | ||||
|  | ||||
| const GroupName = "rbac.authorization.k8s.io" | ||||
|  | ||||
| // SchemeGroupVersion is group version used to register these objects | ||||
| var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1alpha1"} | ||||
|  | ||||
| // Resource takes an unqualified resource and returns a Group qualified GroupResource | ||||
| func Resource(resource string) schema.GroupResource { | ||||
| 	return SchemeGroupVersion.WithResource(resource).GroupResource() | ||||
| } | ||||
|  | ||||
| var ( | ||||
| 	// TODO: move SchemeBuilder with zz_generated.deepcopy.go to k8s.io/api. | ||||
| 	// localSchemeBuilder and AddToScheme will stay in k8s.io/kubernetes. | ||||
| 	SchemeBuilder      = runtime.NewSchemeBuilder(addKnownTypes) | ||||
| 	localSchemeBuilder = &SchemeBuilder | ||||
| 	AddToScheme        = localSchemeBuilder.AddToScheme | ||||
| ) | ||||
|  | ||||
| // Adds the list of known types to the given scheme. | ||||
| func addKnownTypes(scheme *runtime.Scheme) error { | ||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||
| 		&Role{}, | ||||
| 		&RoleBinding{}, | ||||
| 		&RoleBindingList{}, | ||||
| 		&RoleList{}, | ||||
|  | ||||
| 		&ClusterRole{}, | ||||
| 		&ClusterRoleBinding{}, | ||||
| 		&ClusterRoleBindingList{}, | ||||
| 		&ClusterRoleList{}, | ||||
| 	) | ||||
| 	metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||||
| 	return nil | ||||
| } | ||||
							
								
								
									
										239
									
								
								vendor/k8s.io/api/rbac/v1alpha1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										239
									
								
								vendor/k8s.io/api/rbac/v1alpha1/types.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,239 @@ | ||||
| /* | ||||
| Copyright 2016 The Kubernetes 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. | ||||
| */ | ||||
|  | ||||
| package v1alpha1 | ||||
|  | ||||
| import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| ) | ||||
|  | ||||
| // Authorization is calculated against | ||||
| // 1. evaluation of ClusterRoleBindings - short circuit on match | ||||
| // 2. evaluation of RoleBindings in the namespace requested - short circuit on match | ||||
| // 3. deny by default | ||||
|  | ||||
| const ( | ||||
| 	APIGroupAll    = "*" | ||||
| 	ResourceAll    = "*" | ||||
| 	VerbAll        = "*" | ||||
| 	NonResourceAll = "*" | ||||
|  | ||||
| 	GroupKind          = "Group" | ||||
| 	ServiceAccountKind = "ServiceAccount" | ||||
| 	UserKind           = "User" | ||||
|  | ||||
| 	// AutoUpdateAnnotationKey is the name of an annotation which prevents reconciliation if set to "false" | ||||
| 	AutoUpdateAnnotationKey = "rbac.authorization.kubernetes.io/autoupdate" | ||||
| ) | ||||
|  | ||||
| // Authorization is calculated against | ||||
| // 1. evaluation of ClusterRoleBindings - short circuit on match | ||||
| // 2. evaluation of RoleBindings in the namespace requested - short circuit on match | ||||
| // 3. deny by default | ||||
|  | ||||
| // PolicyRule holds information that describes a policy rule, but does not contain information | ||||
| // about who the rule applies to or which namespace the rule applies to. | ||||
| type PolicyRule struct { | ||||
| 	// Verbs is a list of Verbs that apply to ALL the ResourceKinds and AttributeRestrictions contained in this rule.  VerbAll represents all kinds. | ||||
| 	Verbs []string `json:"verbs" protobuf:"bytes,1,rep,name=verbs"` | ||||
|  | ||||
| 	// APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of | ||||
| 	// the enumerated resources in any API group will be allowed. | ||||
| 	// +optional | ||||
| 	APIGroups []string `json:"apiGroups,omitempty" protobuf:"bytes,3,rep,name=apiGroups"` | ||||
| 	// Resources is a list of resources this rule applies to.  ResourceAll represents all resources. | ||||
| 	// +optional | ||||
| 	Resources []string `json:"resources,omitempty" protobuf:"bytes,4,rep,name=resources"` | ||||
| 	// ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed. | ||||
| 	// +optional | ||||
| 	ResourceNames []string `json:"resourceNames,omitempty" protobuf:"bytes,5,rep,name=resourceNames"` | ||||
|  | ||||
| 	// NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, final step in the path | ||||
| 	// This name is intentionally different than the internal type so that the DefaultConvert works nicely and because the ordering may be different. | ||||
| 	// Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. | ||||
| 	// Rules can either apply to API resources (such as "pods" or "secrets") or non-resource URL paths (such as "/api"),  but not both. | ||||
| 	// +optional | ||||
| 	NonResourceURLs []string `json:"nonResourceURLs,omitempty" protobuf:"bytes,6,rep,name=nonResourceURLs"` | ||||
| } | ||||
|  | ||||
| // Subject contains a reference to the object or user identities a role binding applies to.  This can either hold a direct API object reference, | ||||
| // or a value for non-objects such as user and group names. | ||||
| type Subject struct { | ||||
| 	// Kind of object being referenced. Values defined by this API group are "User", "Group", and "ServiceAccount". | ||||
| 	// If the Authorizer does not recognized the kind value, the Authorizer should report an error. | ||||
| 	Kind string `json:"kind" protobuf:"bytes,1,opt,name=kind"` | ||||
| 	// APIVersion holds the API group and version of the referenced subject. | ||||
| 	// Defaults to "v1" for ServiceAccount subjects. | ||||
| 	// Defaults to "rbac.authorization.k8s.io/v1alpha1" for User and Group subjects. | ||||
| 	// +k8s:conversion-gen=false | ||||
| 	// +optional | ||||
| 	APIVersion string `json:"apiVersion,omitempty" protobuf:"bytes,2,opt.name=apiVersion"` | ||||
| 	// Name of the object being referenced. | ||||
| 	Name string `json:"name" protobuf:"bytes,3,opt,name=name"` | ||||
| 	// Namespace of the referenced object.  If the object kind is non-namespace, such as "User" or "Group", and this value is not empty | ||||
| 	// the Authorizer should report an error. | ||||
| 	// +optional | ||||
| 	Namespace string `json:"namespace,omitempty" protobuf:"bytes,4,opt,name=namespace"` | ||||
| } | ||||
|  | ||||
| // RoleRef contains information that points to the role being used | ||||
| type RoleRef struct { | ||||
| 	// APIGroup is the group for the resource being referenced | ||||
| 	APIGroup string `json:"apiGroup" protobuf:"bytes,1,opt,name=apiGroup"` | ||||
| 	// Kind is the type of resource being referenced | ||||
| 	Kind string `json:"kind" protobuf:"bytes,2,opt,name=kind"` | ||||
| 	// Name is the name of resource being referenced | ||||
| 	Name string `json:"name" protobuf:"bytes,3,opt,name=name"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // Role is a namespaced, logical grouping of PolicyRules that can be referenced as a unit by a RoleBinding. | ||||
| type Role struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Rules holds all the PolicyRules for this Role | ||||
| 	// +optional | ||||
| 	Rules []PolicyRule `json:"rules" protobuf:"bytes,2,rep,name=rules"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // RoleBinding references a role, but does not contain it.  It can reference a Role in the same namespace or a ClusterRole in the global namespace. | ||||
| // It adds who information via Subjects and namespace information by which namespace it exists in.  RoleBindings in a given | ||||
| // namespace only have effect in that namespace. | ||||
| type RoleBinding struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Subjects holds references to the objects the role applies to. | ||||
| 	// +optional | ||||
| 	Subjects []Subject `json:"subjects,omitempty" protobuf:"bytes,2,rep,name=subjects"` | ||||
|  | ||||
| 	// RoleRef can reference a Role in the current namespace or a ClusterRole in the global namespace. | ||||
| 	// If the RoleRef cannot be resolved, the Authorizer must return an error. | ||||
| 	RoleRef RoleRef `json:"roleRef" protobuf:"bytes,3,opt,name=roleRef"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // RoleBindingList is a collection of RoleBindings | ||||
| type RoleBindingList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Items is a list of RoleBindings | ||||
| 	Items []RoleBinding `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // RoleList is a collection of Roles | ||||
| type RoleList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Items is a list of Roles | ||||
| 	Items []Role `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ClusterRole is a cluster level, logical grouping of PolicyRules that can be referenced as a unit by a RoleBinding or ClusterRoleBinding. | ||||
| type ClusterRole struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Rules holds all the PolicyRules for this ClusterRole | ||||
| 	// +optional | ||||
| 	Rules []PolicyRule `json:"rules" protobuf:"bytes,2,rep,name=rules"` | ||||
|  | ||||
| 	// AggregationRule is an optional field that describes how to build the Rules for this ClusterRole. | ||||
| 	// If AggregationRule is set, then the Rules are controller managed and direct changes to Rules will be | ||||
| 	// stomped by the controller. | ||||
| 	// +optional | ||||
| 	AggregationRule *AggregationRule `json:"aggregationRule,omitempty" protobuf:"bytes,3,opt,name=aggregationRule"` | ||||
| } | ||||
|  | ||||
| // AggregationRule describes how to locate ClusterRoles to aggregate into the ClusterRole | ||||
| type AggregationRule struct { | ||||
| 	// ClusterRoleSelectors holds a list of selectors which will be used to find ClusterRoles and create the rules. | ||||
| 	// If any of the selectors match, then the ClusterRole's permissions will be added | ||||
| 	// +optional | ||||
| 	ClusterRoleSelectors []metav1.LabelSelector `json:"clusterRoleSelectors,omitempty" protobuf:"bytes,1,rep,name=clusterRoleSelectors"` | ||||
| } | ||||
|  | ||||
| // +genclient | ||||
| // +genclient:nonNamespaced | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ClusterRoleBinding references a ClusterRole, but not contain it.  It can reference a ClusterRole in the global namespace, | ||||
| // and adds who information via Subject. | ||||
| type ClusterRoleBinding struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// +optional | ||||
| 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Subjects holds references to the objects the role applies to. | ||||
| 	// +optional | ||||
| 	Subjects []Subject `json:"subjects,omitempty" protobuf:"bytes,2,rep,name=subjects"` | ||||
|  | ||||
| 	// RoleRef can only reference a ClusterRole in the global namespace. | ||||
| 	// If the RoleRef cannot be resolved, the Authorizer must return an error. | ||||
| 	RoleRef RoleRef `json:"roleRef" protobuf:"bytes,3,opt,name=roleRef"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ClusterRoleBindingList is a collection of ClusterRoleBindings | ||||
| type ClusterRoleBindingList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Items is a list of ClusterRoleBindings | ||||
| 	Items []ClusterRoleBinding `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
|  | ||||
| // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||
|  | ||||
| // ClusterRoleList is a collection of ClusterRoles | ||||
| type ClusterRoleList struct { | ||||
| 	metav1.TypeMeta `json:",inline"` | ||||
| 	// Standard object's metadata. | ||||
| 	// +optional | ||||
| 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||
|  | ||||
| 	// Items is a list of ClusterRoles | ||||
| 	Items []ClusterRole `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||
| } | ||||
							
								
								
									
										158
									
								
								vendor/k8s.io/api/rbac/v1alpha1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								vendor/k8s.io/api/rbac/v1alpha1/types_swagger_doc_generated.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,158 @@ | ||||
| /* | ||||
| Copyright The Kubernetes 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. | ||||
| */ | ||||
|  | ||||
| package v1alpha1 | ||||
|  | ||||
| // This file contains a collection of methods that can be used from go-restful to | ||||
| // generate Swagger API documentation for its models. Please read this PR for more | ||||
| // information on the implementation: https://github.com/emicklei/go-restful/pull/215 | ||||
| // | ||||
| // TODOs are ignored from the parser (e.g. TODO(andronat):... || TODO:...) if and only if | ||||
| // they are on one line! For multiple line or blocks that you want to ignore use ---. | ||||
| // Any context after a --- is ignored. | ||||
| // | ||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS START HERE. DO NOT EDIT. | ||||
| var map_AggregationRule = map[string]string{ | ||||
| 	"":                     "AggregationRule describes how to locate ClusterRoles to aggregate into the ClusterRole", | ||||
| 	"clusterRoleSelectors": "ClusterRoleSelectors holds a list of selectors which will be used to find ClusterRoles and create the rules. If any of the selectors match, then the ClusterRole's permissions will be added", | ||||
| } | ||||
|  | ||||
| func (AggregationRule) SwaggerDoc() map[string]string { | ||||
| 	return map_AggregationRule | ||||
| } | ||||
|  | ||||
| var map_ClusterRole = map[string]string{ | ||||
| 	"":                "ClusterRole is a cluster level, logical grouping of PolicyRules that can be referenced as a unit by a RoleBinding or ClusterRoleBinding.", | ||||
| 	"metadata":        "Standard object's metadata.", | ||||
| 	"rules":           "Rules holds all the PolicyRules for this ClusterRole", | ||||
| 	"aggregationRule": "AggregationRule is an optional field that describes how to build the Rules for this ClusterRole. If AggregationRule is set, then the Rules are controller managed and direct changes to Rules will be stomped by the controller.", | ||||
| } | ||||
|  | ||||
| func (ClusterRole) SwaggerDoc() map[string]string { | ||||
| 	return map_ClusterRole | ||||
| } | ||||
|  | ||||
| var map_ClusterRoleBinding = map[string]string{ | ||||
| 	"":         "ClusterRoleBinding references a ClusterRole, but not contain it.  It can reference a ClusterRole in the global namespace, and adds who information via Subject.", | ||||
| 	"metadata": "Standard object's metadata.", | ||||
| 	"subjects": "Subjects holds references to the objects the role applies to.", | ||||
| 	"roleRef":  "RoleRef can only reference a ClusterRole in the global namespace. If the RoleRef cannot be resolved, the Authorizer must return an error.", | ||||
| } | ||||
|  | ||||
| func (ClusterRoleBinding) SwaggerDoc() map[string]string { | ||||
| 	return map_ClusterRoleBinding | ||||
| } | ||||
|  | ||||
| var map_ClusterRoleBindingList = map[string]string{ | ||||
| 	"":         "ClusterRoleBindingList is a collection of ClusterRoleBindings", | ||||
| 	"metadata": "Standard object's metadata.", | ||||
| 	"items":    "Items is a list of ClusterRoleBindings", | ||||
| } | ||||
|  | ||||
| func (ClusterRoleBindingList) SwaggerDoc() map[string]string { | ||||
| 	return map_ClusterRoleBindingList | ||||
| } | ||||
|  | ||||
| var map_ClusterRoleList = map[string]string{ | ||||
| 	"":         "ClusterRoleList is a collection of ClusterRoles", | ||||
| 	"metadata": "Standard object's metadata.", | ||||
| 	"items":    "Items is a list of ClusterRoles", | ||||
| } | ||||
|  | ||||
| func (ClusterRoleList) SwaggerDoc() map[string]string { | ||||
| 	return map_ClusterRoleList | ||||
| } | ||||
|  | ||||
| var map_PolicyRule = map[string]string{ | ||||
| 	"":                "PolicyRule holds information that describes a policy rule, but does not contain information about who the rule applies to or which namespace the rule applies to.", | ||||
| 	"verbs":           "Verbs is a list of Verbs that apply to ALL the ResourceKinds and AttributeRestrictions contained in this rule.  VerbAll represents all kinds.", | ||||
| 	"apiGroups":       "APIGroups is the name of the APIGroup that contains the resources.  If multiple API groups are specified, any action requested against one of the enumerated resources in any API group will be allowed.", | ||||
| 	"resources":       "Resources is a list of resources this rule applies to.  ResourceAll represents all resources.", | ||||
| 	"resourceNames":   "ResourceNames is an optional white list of names that the rule applies to.  An empty set means that everything is allowed.", | ||||
| 	"nonResourceURLs": "NonResourceURLs is a set of partial urls that a user should have access to.  *s are allowed, but only as the full, final step in the path This name is intentionally different than the internal type so that the DefaultConvert works nicely and because the ordering may be different. Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. Rules can either apply to API resources (such as \"pods\" or \"secrets\") or non-resource URL paths (such as \"/api\"),  but not both.", | ||||
| } | ||||
|  | ||||
| func (PolicyRule) SwaggerDoc() map[string]string { | ||||
| 	return map_PolicyRule | ||||
| } | ||||
|  | ||||
| var map_Role = map[string]string{ | ||||
| 	"":         "Role is a namespaced, logical grouping of PolicyRules that can be referenced as a unit by a RoleBinding.", | ||||
| 	"metadata": "Standard object's metadata.", | ||||
| 	"rules":    "Rules holds all the PolicyRules for this Role", | ||||
| } | ||||
|  | ||||
| func (Role) SwaggerDoc() map[string]string { | ||||
| 	return map_Role | ||||
| } | ||||
|  | ||||
| var map_RoleBinding = map[string]string{ | ||||
| 	"":         "RoleBinding references a role, but does not contain it.  It can reference a Role in the same namespace or a ClusterRole in the global namespace. It adds who information via Subjects and namespace information by which namespace it exists in.  RoleBindings in a given namespace only have effect in that namespace.", | ||||
| 	"metadata": "Standard object's metadata.", | ||||
| 	"subjects": "Subjects holds references to the objects the role applies to.", | ||||
| 	"roleRef":  "RoleRef can reference a Role in the current namespace or a ClusterRole in the global namespace. If the RoleRef cannot be resolved, the Authorizer must return an error.", | ||||
| } | ||||
|  | ||||
| func (RoleBinding) SwaggerDoc() map[string]string { | ||||
| 	return map_RoleBinding | ||||
| } | ||||
|  | ||||
| var map_RoleBindingList = map[string]string{ | ||||
| 	"":         "RoleBindingList is a collection of RoleBindings", | ||||
| 	"metadata": "Standard object's metadata.", | ||||
| 	"items":    "Items is a list of RoleBindings", | ||||
| } | ||||
|  | ||||
| func (RoleBindingList) SwaggerDoc() map[string]string { | ||||
| 	return map_RoleBindingList | ||||
| } | ||||
|  | ||||
| var map_RoleList = map[string]string{ | ||||
| 	"":         "RoleList is a collection of Roles", | ||||
| 	"metadata": "Standard object's metadata.", | ||||
| 	"items":    "Items is a list of Roles", | ||||
| } | ||||
|  | ||||
| func (RoleList) SwaggerDoc() map[string]string { | ||||
| 	return map_RoleList | ||||
| } | ||||
|  | ||||
| var map_RoleRef = map[string]string{ | ||||
| 	"":         "RoleRef contains information that points to the role being used", | ||||
| 	"apiGroup": "APIGroup is the group for the resource being referenced", | ||||
| 	"kind":     "Kind is the type of resource being referenced", | ||||
| 	"name":     "Name is the name of resource being referenced", | ||||
| } | ||||
|  | ||||
| func (RoleRef) SwaggerDoc() map[string]string { | ||||
| 	return map_RoleRef | ||||
| } | ||||
|  | ||||
| var map_Subject = map[string]string{ | ||||
| 	"":           "Subject contains a reference to the object or user identities a role binding applies to.  This can either hold a direct API object reference, or a value for non-objects such as user and group names.", | ||||
| 	"kind":       "Kind of object being referenced. Values defined by this API group are \"User\", \"Group\", and \"ServiceAccount\". If the Authorizer does not recognized the kind value, the Authorizer should report an error.", | ||||
| 	"apiVersion": "APIVersion holds the API group and version of the referenced subject. Defaults to \"v1\" for ServiceAccount subjects. Defaults to \"rbac.authorization.k8s.io/v1alpha1\" for User and Group subjects.", | ||||
| 	"name":       "Name of the object being referenced.", | ||||
| 	"namespace":  "Namespace of the referenced object.  If the object kind is non-namespace, such as \"User\" or \"Group\", and this value is not empty the Authorizer should report an error.", | ||||
| } | ||||
|  | ||||
| func (Subject) SwaggerDoc() map[string]string { | ||||
| 	return map_Subject | ||||
| } | ||||
|  | ||||
| // AUTO-GENERATED FUNCTIONS END HERE | ||||
							
								
								
									
										389
									
								
								vendor/k8s.io/api/rbac/v1alpha1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										389
									
								
								vendor/k8s.io/api/rbac/v1alpha1/zz_generated.deepcopy.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,389 @@ | ||||
| // +build !ignore_autogenerated | ||||
|  | ||||
| /* | ||||
| Copyright The Kubernetes 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 deepcopy-gen. DO NOT EDIT. | ||||
|  | ||||
| package v1alpha1 | ||||
|  | ||||
| import ( | ||||
| 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	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 *AggregationRule) DeepCopyInto(out *AggregationRule) { | ||||
| 	*out = *in | ||||
| 	if in.ClusterRoleSelectors != nil { | ||||
| 		in, out := &in.ClusterRoleSelectors, &out.ClusterRoleSelectors | ||||
| 		*out = make([]v1.LabelSelector, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new AggregationRule. | ||||
| func (in *AggregationRule) DeepCopy() *AggregationRule { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(AggregationRule) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ClusterRole) DeepCopyInto(out *ClusterRole) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	if in.Rules != nil { | ||||
| 		in, out := &in.Rules, &out.Rules | ||||
| 		*out = make([]PolicyRule, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	if in.AggregationRule != nil { | ||||
| 		in, out := &in.AggregationRule, &out.AggregationRule | ||||
| 		*out = new(AggregationRule) | ||||
| 		(*in).DeepCopyInto(*out) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ClusterRole. | ||||
| func (in *ClusterRole) DeepCopy() *ClusterRole { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ClusterRole) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ClusterRole) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ClusterRoleBinding) DeepCopyInto(out *ClusterRoleBinding) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	if in.Subjects != nil { | ||||
| 		in, out := &in.Subjects, &out.Subjects | ||||
| 		*out = make([]Subject, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	out.RoleRef = in.RoleRef | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ClusterRoleBinding. | ||||
| func (in *ClusterRoleBinding) DeepCopy() *ClusterRoleBinding { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ClusterRoleBinding) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ClusterRoleBinding) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ClusterRoleBindingList) DeepCopyInto(out *ClusterRoleBindingList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]ClusterRoleBinding, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ClusterRoleBindingList. | ||||
| func (in *ClusterRoleBindingList) DeepCopy() *ClusterRoleBindingList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ClusterRoleBindingList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ClusterRoleBindingList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *ClusterRoleList) DeepCopyInto(out *ClusterRoleList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]ClusterRole, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new ClusterRoleList. | ||||
| func (in *ClusterRoleList) DeepCopy() *ClusterRoleList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(ClusterRoleList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *ClusterRoleList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *PolicyRule) DeepCopyInto(out *PolicyRule) { | ||||
| 	*out = *in | ||||
| 	if in.Verbs != nil { | ||||
| 		in, out := &in.Verbs, &out.Verbs | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.APIGroups != nil { | ||||
| 		in, out := &in.APIGroups, &out.APIGroups | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.Resources != nil { | ||||
| 		in, out := &in.Resources, &out.Resources | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.ResourceNames != nil { | ||||
| 		in, out := &in.ResourceNames, &out.ResourceNames | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	if in.NonResourceURLs != nil { | ||||
| 		in, out := &in.NonResourceURLs, &out.NonResourceURLs | ||||
| 		*out = make([]string, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PolicyRule. | ||||
| func (in *PolicyRule) DeepCopy() *PolicyRule { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(PolicyRule) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Role) DeepCopyInto(out *Role) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	if in.Rules != nil { | ||||
| 		in, out := &in.Rules, &out.Rules | ||||
| 		*out = make([]PolicyRule, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Role. | ||||
| func (in *Role) DeepCopy() *Role { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Role) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *Role) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RoleBinding) DeepCopyInto(out *RoleBinding) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||
| 	if in.Subjects != nil { | ||||
| 		in, out := &in.Subjects, &out.Subjects | ||||
| 		*out = make([]Subject, len(*in)) | ||||
| 		copy(*out, *in) | ||||
| 	} | ||||
| 	out.RoleRef = in.RoleRef | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RoleBinding. | ||||
| func (in *RoleBinding) DeepCopy() *RoleBinding { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RoleBinding) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *RoleBinding) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RoleBindingList) DeepCopyInto(out *RoleBindingList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]RoleBinding, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RoleBindingList. | ||||
| func (in *RoleBindingList) DeepCopy() *RoleBindingList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RoleBindingList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *RoleBindingList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RoleList) DeepCopyInto(out *RoleList) { | ||||
| 	*out = *in | ||||
| 	out.TypeMeta = in.TypeMeta | ||||
| 	out.ListMeta = in.ListMeta | ||||
| 	if in.Items != nil { | ||||
| 		in, out := &in.Items, &out.Items | ||||
| 		*out = make([]Role, len(*in)) | ||||
| 		for i := range *in { | ||||
| 			(*in)[i].DeepCopyInto(&(*out)[i]) | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RoleList. | ||||
| func (in *RoleList) DeepCopy() *RoleList { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RoleList) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||
| func (in *RoleList) DeepCopyObject() runtime.Object { | ||||
| 	if c := in.DeepCopy(); c != nil { | ||||
| 		return c | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *RoleRef) DeepCopyInto(out *RoleRef) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RoleRef. | ||||
| func (in *RoleRef) DeepCopy() *RoleRef { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(RoleRef) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
|  | ||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||
| func (in *Subject) DeepCopyInto(out *Subject) { | ||||
| 	*out = *in | ||||
| 	return | ||||
| } | ||||
|  | ||||
| // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new Subject. | ||||
| func (in *Subject) DeepCopy() *Subject { | ||||
| 	if in == nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	out := new(Subject) | ||||
| 	in.DeepCopyInto(out) | ||||
| 	return out | ||||
| } | ||||
		Reference in New Issue
	
	Block a user