Merge pull request #54933 from php-coder/psp_introduce_new_api_group
Automatic merge from submit-queue. If you want to cherry-pick this change to another branch, please follow the instructions <a href="https://github.com/kubernetes/community/blob/master/contributors/devel/cherry-picks.md">here</a>. Introduce PodSecurityPolicy in the policy/v1beta1 API group Types/constants are completely the same as in `extensions/v1beta1` except that they are located outside of the `extensions` API group. **What this PR does / why we need it**: This is the first step for migrating PSP-related stuff away of `extensions` group. See #43214 for more information. Also it related to https://github.com/kubernetes/features/issues/5 **Example**: ```console $ cat restricted2.yaml apiVersion: policy/v1beta1 kind: PodSecurityPolicy metadata: name: restricted2 ... $ kubectl create -f restricted.yaml podsecuritypolicy "restricted2" created $ kubectl get psp restricted2 -o yaml apiVersion: extensions/v1beta1 kind: PodSecurityPolicy ... ``` **Release note**: ```release-note The `PodSecurityPolicy` API has been moved to the `policy/v1beta1` API group. The `PodSecurityPolicy` API in the `extensions/v1beta1` API group is deprecated and will be removed in a future release. ```
This commit is contained in:
		
							
								
								
									
										998
									
								
								api/openapi-spec/swagger.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										998
									
								
								api/openapi-spec/swagger.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1013
									
								
								api/swagger-spec/policy_v1beta1.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1013
									
								
								api/swagger-spec/policy_v1beta1.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -23,6 +23,7 @@ go_library( | |||||||
|         "//pkg/apis/events:go_default_library", |         "//pkg/apis/events:go_default_library", | ||||||
|         "//pkg/apis/extensions:go_default_library", |         "//pkg/apis/extensions:go_default_library", | ||||||
|         "//pkg/apis/networking:go_default_library", |         "//pkg/apis/networking:go_default_library", | ||||||
|  |         "//pkg/apis/policy:go_default_library", | ||||||
|         "//pkg/apis/storage:go_default_library", |         "//pkg/apis/storage:go_default_library", | ||||||
|         "//pkg/capabilities:go_default_library", |         "//pkg/capabilities:go_default_library", | ||||||
|         "//pkg/client/clientset_generated/internalclientset:go_default_library", |         "//pkg/client/clientset_generated/internalclientset:go_default_library", | ||||||
|   | |||||||
| @@ -69,6 +69,7 @@ import ( | |||||||
| 	"k8s.io/kubernetes/pkg/apis/events" | 	"k8s.io/kubernetes/pkg/apis/events" | ||||||
| 	"k8s.io/kubernetes/pkg/apis/extensions" | 	"k8s.io/kubernetes/pkg/apis/extensions" | ||||||
| 	"k8s.io/kubernetes/pkg/apis/networking" | 	"k8s.io/kubernetes/pkg/apis/networking" | ||||||
|  | 	"k8s.io/kubernetes/pkg/apis/policy" | ||||||
| 	"k8s.io/kubernetes/pkg/apis/storage" | 	"k8s.io/kubernetes/pkg/apis/storage" | ||||||
| 	"k8s.io/kubernetes/pkg/capabilities" | 	"k8s.io/kubernetes/pkg/capabilities" | ||||||
| 	"k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset" | 	"k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset" | ||||||
| @@ -600,6 +601,8 @@ func BuildStorageFactory(s *options.ServerRunOptions, apiResourceConfig *servers | |||||||
| 	storageFactory.AddCohabitatingResources(apps.Resource("daemonsets"), extensions.Resource("daemonsets")) | 	storageFactory.AddCohabitatingResources(apps.Resource("daemonsets"), extensions.Resource("daemonsets")) | ||||||
| 	storageFactory.AddCohabitatingResources(apps.Resource("replicasets"), extensions.Resource("replicasets")) | 	storageFactory.AddCohabitatingResources(apps.Resource("replicasets"), extensions.Resource("replicasets")) | ||||||
| 	storageFactory.AddCohabitatingResources(api.Resource("events"), events.Resource("events")) | 	storageFactory.AddCohabitatingResources(api.Resource("events"), events.Resource("events")) | ||||||
|  | 	// TODO(#54933): 1.11: switch to using policy storage and flip the order here | ||||||
|  | 	storageFactory.AddCohabitatingResources(extensions.Resource("podsecuritypolicies"), policy.Resource("podsecuritypolicies")) | ||||||
| 	for _, override := range s.Etcd.EtcdServersOverrides { | 	for _, override := range s.Etcd.EtcdServersOverrides { | ||||||
| 		tokens := strings.Split(override, "#") | 		tokens := strings.Split(override, "#") | ||||||
| 		if len(tokens) != 2 { | 		if len(tokens) != 2 { | ||||||
|   | |||||||
							
								
								
									
										1212
									
								
								docs/api-reference/policy/v1beta1/definitions.html
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1212
									
								
								docs/api-reference/policy/v1beta1/definitions.html
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1368
									
								
								docs/api-reference/policy/v1beta1/operations.html
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1368
									
								
								docs/api-reference/policy/v1beta1/operations.html
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| apiVersion: extensions/v1beta1 | apiVersion: policy/v1beta1 | ||||||
| kind: PodSecurityPolicy | kind: PodSecurityPolicy | ||||||
| metadata: | metadata: | ||||||
|   name: privileged |   name: privileged | ||||||
| @@ -23,7 +23,7 @@ spec: | |||||||
|   - min: 1 |   - min: 1 | ||||||
|     max: 65536 |     max: 65536 | ||||||
| --- | --- | ||||||
| apiVersion: extensions/v1beta1 | apiVersion: policy/v1beta1 | ||||||
| kind: PodSecurityPolicy | kind: PodSecurityPolicy | ||||||
| metadata: | metadata: | ||||||
|   name: restricted |   name: restricted | ||||||
|   | |||||||
| @@ -119,6 +119,8 @@ func TestDefaulting(t *testing.T) { | |||||||
| 		{Group: "extensions", Version: "v1beta1", Kind: "ReplicaSetList"}:                                       {}, | 		{Group: "extensions", Version: "v1beta1", Kind: "ReplicaSetList"}:                                       {}, | ||||||
| 		{Group: "extensions", Version: "v1beta1", Kind: "NetworkPolicy"}:                                        {}, | 		{Group: "extensions", Version: "v1beta1", Kind: "NetworkPolicy"}:                                        {}, | ||||||
| 		{Group: "extensions", Version: "v1beta1", Kind: "NetworkPolicyList"}:                                    {}, | 		{Group: "extensions", Version: "v1beta1", Kind: "NetworkPolicyList"}:                                    {}, | ||||||
|  | 		{Group: "policy", Version: "v1beta1", Kind: "PodSecurityPolicy"}:                                        {}, | ||||||
|  | 		{Group: "policy", Version: "v1beta1", Kind: "PodSecurityPolicyList"}:                                    {}, | ||||||
| 		{Group: "rbac.authorization.k8s.io", Version: "v1alpha1", Kind: "ClusterRoleBinding"}:                   {}, | 		{Group: "rbac.authorization.k8s.io", Version: "v1alpha1", Kind: "ClusterRoleBinding"}:                   {}, | ||||||
| 		{Group: "rbac.authorization.k8s.io", Version: "v1alpha1", Kind: "ClusterRoleBindingList"}:               {}, | 		{Group: "rbac.authorization.k8s.io", Version: "v1alpha1", Kind: "ClusterRoleBindingList"}:               {}, | ||||||
| 		{Group: "rbac.authorization.k8s.io", Version: "v1alpha1", Kind: "RoleBinding"}:                          {}, | 		{Group: "rbac.authorization.k8s.io", Version: "v1alpha1", Kind: "RoleBinding"}:                          {}, | ||||||
|   | |||||||
| @@ -15,6 +15,7 @@ go_library( | |||||||
|     ], |     ], | ||||||
|     importpath = "k8s.io/kubernetes/pkg/apis/policy", |     importpath = "k8s.io/kubernetes/pkg/apis/policy", | ||||||
|     deps = [ |     deps = [ | ||||||
|  |         "//pkg/apis/extensions:go_default_library", | ||||||
|         "//vendor/k8s.io/apimachinery/pkg/apis/meta/v1:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/apis/meta/v1:go_default_library", | ||||||
|         "//vendor/k8s.io/apimachinery/pkg/runtime:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/runtime:go_default_library", | ||||||
|         "//vendor/k8s.io/apimachinery/pkg/runtime/schema:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/runtime/schema:go_default_library", | ||||||
|   | |||||||
| @@ -2,3 +2,7 @@ approvers: | |||||||
| - sig-apps-api-approvers | - sig-apps-api-approvers | ||||||
| reviewers: | reviewers: | ||||||
| - sig-apps-reviewers | - sig-apps-reviewers | ||||||
|  | - pweil- | ||||||
|  | - liggitt | ||||||
|  | - tallclair | ||||||
|  | - php-coder | ||||||
|   | |||||||
| @@ -16,6 +16,7 @@ go_library( | |||||||
|         "//vendor/k8s.io/apimachinery/pkg/apimachinery/announced:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/apimachinery/announced:go_default_library", | ||||||
|         "//vendor/k8s.io/apimachinery/pkg/apimachinery/registered:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/apimachinery/registered:go_default_library", | ||||||
|         "//vendor/k8s.io/apimachinery/pkg/runtime:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/runtime:go_default_library", | ||||||
|  |         "//vendor/k8s.io/apimachinery/pkg/util/sets:go_default_library", | ||||||
|     ], |     ], | ||||||
| ) | ) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -22,6 +22,7 @@ import ( | |||||||
| 	"k8s.io/apimachinery/pkg/apimachinery/announced" | 	"k8s.io/apimachinery/pkg/apimachinery/announced" | ||||||
| 	"k8s.io/apimachinery/pkg/apimachinery/registered" | 	"k8s.io/apimachinery/pkg/apimachinery/registered" | ||||||
| 	"k8s.io/apimachinery/pkg/runtime" | 	"k8s.io/apimachinery/pkg/runtime" | ||||||
|  | 	"k8s.io/apimachinery/pkg/util/sets" | ||||||
| 	"k8s.io/kubernetes/pkg/api/legacyscheme" | 	"k8s.io/kubernetes/pkg/api/legacyscheme" | ||||||
| 	"k8s.io/kubernetes/pkg/apis/policy" | 	"k8s.io/kubernetes/pkg/apis/policy" | ||||||
| 	"k8s.io/kubernetes/pkg/apis/policy/v1beta1" | 	"k8s.io/kubernetes/pkg/apis/policy/v1beta1" | ||||||
| @@ -37,6 +38,7 @@ func Install(groupFactoryRegistry announced.APIGroupFactoryRegistry, registry *r | |||||||
| 		&announced.GroupMetaFactoryArgs{ | 		&announced.GroupMetaFactoryArgs{ | ||||||
| 			GroupName:                  policy.GroupName, | 			GroupName:                  policy.GroupName, | ||||||
| 			VersionPreferenceOrder:     []string{v1beta1.SchemeGroupVersion.Version}, | 			VersionPreferenceOrder:     []string{v1beta1.SchemeGroupVersion.Version}, | ||||||
|  | 			RootScopedKinds:            sets.NewString("PodSecurityPolicy"), | ||||||
| 			AddInternalObjectsToScheme: policy.AddToScheme, | 			AddInternalObjectsToScheme: policy.AddToScheme, | ||||||
| 		}, | 		}, | ||||||
| 		announced.VersionToSchemeFunc{ | 		announced.VersionToSchemeFunc{ | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ package policy | |||||||
| import ( | import ( | ||||||
| 	"k8s.io/apimachinery/pkg/runtime" | 	"k8s.io/apimachinery/pkg/runtime" | ||||||
| 	"k8s.io/apimachinery/pkg/runtime/schema" | 	"k8s.io/apimachinery/pkg/runtime/schema" | ||||||
|  | 	"k8s.io/kubernetes/pkg/apis/extensions" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| // GroupName is the group name use in this package | // GroupName is the group name use in this package | ||||||
| @@ -48,6 +49,8 @@ func addKnownTypes(scheme *runtime.Scheme) error { | |||||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||||
| 		&PodDisruptionBudget{}, | 		&PodDisruptionBudget{}, | ||||||
| 		&PodDisruptionBudgetList{}, | 		&PodDisruptionBudgetList{}, | ||||||
|  | 		&extensions.PodSecurityPolicy{}, | ||||||
|  | 		&extensions.PodSecurityPolicyList{}, | ||||||
| 		&Eviction{}, | 		&Eviction{}, | ||||||
| 	) | 	) | ||||||
| 	return nil | 	return nil | ||||||
|   | |||||||
| @@ -8,6 +8,7 @@ load( | |||||||
| go_library( | go_library( | ||||||
|     name = "go_default_library", |     name = "go_default_library", | ||||||
|     srcs = [ |     srcs = [ | ||||||
|  |         "defaults.go", | ||||||
|         "doc.go", |         "doc.go", | ||||||
|         "register.go", |         "register.go", | ||||||
|         "zz_generated.conversion.go", |         "zz_generated.conversion.go", | ||||||
| @@ -15,7 +16,10 @@ go_library( | |||||||
|     ], |     ], | ||||||
|     importpath = "k8s.io/kubernetes/pkg/apis/policy/v1beta1", |     importpath = "k8s.io/kubernetes/pkg/apis/policy/v1beta1", | ||||||
|     deps = [ |     deps = [ | ||||||
|  |         "//pkg/apis/core:go_default_library", | ||||||
|  |         "//pkg/apis/extensions:go_default_library", | ||||||
|         "//pkg/apis/policy:go_default_library", |         "//pkg/apis/policy:go_default_library", | ||||||
|  |         "//vendor/k8s.io/api/core/v1:go_default_library", | ||||||
|         "//vendor/k8s.io/api/policy/v1beta1:go_default_library", |         "//vendor/k8s.io/api/policy/v1beta1:go_default_library", | ||||||
|         "//vendor/k8s.io/apimachinery/pkg/apis/meta/v1:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/apis/meta/v1:go_default_library", | ||||||
|         "//vendor/k8s.io/apimachinery/pkg/conversion:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/conversion:go_default_library", | ||||||
|   | |||||||
							
								
								
									
										35
									
								
								pkg/apis/policy/v1beta1/defaults.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								pkg/apis/policy/v1beta1/defaults.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | /* | ||||||
|  | Copyright 2018 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 v1beta1 | ||||||
|  |  | ||||||
|  | import ( | ||||||
|  | 	policyv1beta1 "k8s.io/api/policy/v1beta1" | ||||||
|  | 	"k8s.io/apimachinery/pkg/runtime" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | func addDefaultingFuncs(scheme *runtime.Scheme) error { | ||||||
|  | 	return RegisterDefaults(scheme) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func SetDefaults_PodSecurityPolicySpec(obj *policyv1beta1.PodSecurityPolicySpec) { | ||||||
|  | 	// This field was added after PodSecurityPolicy was released. | ||||||
|  | 	// Policies that do not include this field must remain as permissive as they were prior to the introduction of this field. | ||||||
|  | 	if obj.AllowPrivilegeEscalation == nil { | ||||||
|  | 		t := true | ||||||
|  | 		obj.AllowPrivilegeEscalation = &t | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @@ -15,6 +15,7 @@ limitations under the License. | |||||||
| */ | */ | ||||||
|  |  | ||||||
| // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/policy | // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/policy | ||||||
|  | // +k8s:conversion-gen=k8s.io/kubernetes/pkg/apis/extensions | ||||||
| // +k8s:conversion-gen-external-types=k8s.io/api/policy/v1beta1 | // +k8s:conversion-gen-external-types=k8s.io/api/policy/v1beta1 | ||||||
| // +k8s:defaulter-gen=TypeMeta | // +k8s:defaulter-gen=TypeMeta | ||||||
| // +k8s:defaulter-gen-input=../../../../vendor/k8s.io/api/policy/v1beta1 | // +k8s:defaulter-gen-input=../../../../vendor/k8s.io/api/policy/v1beta1 | ||||||
|   | |||||||
							
								
								
									
										315
									
								
								pkg/apis/policy/v1beta1/zz_generated.conversion.go
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										315
									
								
								pkg/apis/policy/v1beta1/zz_generated.conversion.go
									
									
									
										generated
									
									
									
								
							| @@ -23,11 +23,14 @@ package v1beta1 | |||||||
| import ( | import ( | ||||||
| 	unsafe "unsafe" | 	unsafe "unsafe" | ||||||
|  |  | ||||||
|  | 	core_v1 "k8s.io/api/core/v1" | ||||||
| 	v1beta1 "k8s.io/api/policy/v1beta1" | 	v1beta1 "k8s.io/api/policy/v1beta1" | ||||||
| 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||||
| 	conversion "k8s.io/apimachinery/pkg/conversion" | 	conversion "k8s.io/apimachinery/pkg/conversion" | ||||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||||
| 	intstr "k8s.io/apimachinery/pkg/util/intstr" | 	intstr "k8s.io/apimachinery/pkg/util/intstr" | ||||||
|  | 	core "k8s.io/kubernetes/pkg/apis/core" | ||||||
|  | 	extensions "k8s.io/kubernetes/pkg/apis/extensions" | ||||||
| 	policy "k8s.io/kubernetes/pkg/apis/policy" | 	policy "k8s.io/kubernetes/pkg/apis/policy" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -39,8 +42,16 @@ func init() { | |||||||
| // Public to allow building arbitrary schemes. | // Public to allow building arbitrary schemes. | ||||||
| func RegisterConversions(scheme *runtime.Scheme) error { | func RegisterConversions(scheme *runtime.Scheme) error { | ||||||
| 	return scheme.AddGeneratedConversionFuncs( | 	return scheme.AddGeneratedConversionFuncs( | ||||||
|  | 		Convert_v1beta1_AllowedFlexVolume_To_extensions_AllowedFlexVolume, | ||||||
|  | 		Convert_extensions_AllowedFlexVolume_To_v1beta1_AllowedFlexVolume, | ||||||
|  | 		Convert_v1beta1_AllowedHostPath_To_extensions_AllowedHostPath, | ||||||
|  | 		Convert_extensions_AllowedHostPath_To_v1beta1_AllowedHostPath, | ||||||
| 		Convert_v1beta1_Eviction_To_policy_Eviction, | 		Convert_v1beta1_Eviction_To_policy_Eviction, | ||||||
| 		Convert_policy_Eviction_To_v1beta1_Eviction, | 		Convert_policy_Eviction_To_v1beta1_Eviction, | ||||||
|  | 		Convert_v1beta1_FSGroupStrategyOptions_To_extensions_FSGroupStrategyOptions, | ||||||
|  | 		Convert_extensions_FSGroupStrategyOptions_To_v1beta1_FSGroupStrategyOptions, | ||||||
|  | 		Convert_v1beta1_HostPortRange_To_extensions_HostPortRange, | ||||||
|  | 		Convert_extensions_HostPortRange_To_v1beta1_HostPortRange, | ||||||
| 		Convert_v1beta1_PodDisruptionBudget_To_policy_PodDisruptionBudget, | 		Convert_v1beta1_PodDisruptionBudget_To_policy_PodDisruptionBudget, | ||||||
| 		Convert_policy_PodDisruptionBudget_To_v1beta1_PodDisruptionBudget, | 		Convert_policy_PodDisruptionBudget_To_v1beta1_PodDisruptionBudget, | ||||||
| 		Convert_v1beta1_PodDisruptionBudgetList_To_policy_PodDisruptionBudgetList, | 		Convert_v1beta1_PodDisruptionBudgetList_To_policy_PodDisruptionBudgetList, | ||||||
| @@ -49,9 +60,61 @@ func RegisterConversions(scheme *runtime.Scheme) error { | |||||||
| 		Convert_policy_PodDisruptionBudgetSpec_To_v1beta1_PodDisruptionBudgetSpec, | 		Convert_policy_PodDisruptionBudgetSpec_To_v1beta1_PodDisruptionBudgetSpec, | ||||||
| 		Convert_v1beta1_PodDisruptionBudgetStatus_To_policy_PodDisruptionBudgetStatus, | 		Convert_v1beta1_PodDisruptionBudgetStatus_To_policy_PodDisruptionBudgetStatus, | ||||||
| 		Convert_policy_PodDisruptionBudgetStatus_To_v1beta1_PodDisruptionBudgetStatus, | 		Convert_policy_PodDisruptionBudgetStatus_To_v1beta1_PodDisruptionBudgetStatus, | ||||||
|  | 		Convert_v1beta1_PodSecurityPolicy_To_extensions_PodSecurityPolicy, | ||||||
|  | 		Convert_extensions_PodSecurityPolicy_To_v1beta1_PodSecurityPolicy, | ||||||
|  | 		Convert_v1beta1_PodSecurityPolicyList_To_extensions_PodSecurityPolicyList, | ||||||
|  | 		Convert_extensions_PodSecurityPolicyList_To_v1beta1_PodSecurityPolicyList, | ||||||
|  | 		Convert_v1beta1_PodSecurityPolicySpec_To_extensions_PodSecurityPolicySpec, | ||||||
|  | 		Convert_extensions_PodSecurityPolicySpec_To_v1beta1_PodSecurityPolicySpec, | ||||||
|  | 		Convert_v1beta1_RunAsUserStrategyOptions_To_extensions_RunAsUserStrategyOptions, | ||||||
|  | 		Convert_extensions_RunAsUserStrategyOptions_To_v1beta1_RunAsUserStrategyOptions, | ||||||
|  | 		Convert_v1beta1_SELinuxStrategyOptions_To_extensions_SELinuxStrategyOptions, | ||||||
|  | 		Convert_extensions_SELinuxStrategyOptions_To_v1beta1_SELinuxStrategyOptions, | ||||||
|  | 		Convert_v1beta1_SupplementalGroupsStrategyOptions_To_extensions_SupplementalGroupsStrategyOptions, | ||||||
|  | 		Convert_extensions_SupplementalGroupsStrategyOptions_To_v1beta1_SupplementalGroupsStrategyOptions, | ||||||
| 	) | 	) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func autoConvert_v1beta1_AllowedFlexVolume_To_extensions_AllowedFlexVolume(in *v1beta1.AllowedFlexVolume, out *extensions.AllowedFlexVolume, s conversion.Scope) error { | ||||||
|  | 	out.Driver = in.Driver | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_v1beta1_AllowedFlexVolume_To_extensions_AllowedFlexVolume is an autogenerated conversion function. | ||||||
|  | func Convert_v1beta1_AllowedFlexVolume_To_extensions_AllowedFlexVolume(in *v1beta1.AllowedFlexVolume, out *extensions.AllowedFlexVolume, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_v1beta1_AllowedFlexVolume_To_extensions_AllowedFlexVolume(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_extensions_AllowedFlexVolume_To_v1beta1_AllowedFlexVolume(in *extensions.AllowedFlexVolume, out *v1beta1.AllowedFlexVolume, s conversion.Scope) error { | ||||||
|  | 	out.Driver = in.Driver | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_extensions_AllowedFlexVolume_To_v1beta1_AllowedFlexVolume is an autogenerated conversion function. | ||||||
|  | func Convert_extensions_AllowedFlexVolume_To_v1beta1_AllowedFlexVolume(in *extensions.AllowedFlexVolume, out *v1beta1.AllowedFlexVolume, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_extensions_AllowedFlexVolume_To_v1beta1_AllowedFlexVolume(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_v1beta1_AllowedHostPath_To_extensions_AllowedHostPath(in *v1beta1.AllowedHostPath, out *extensions.AllowedHostPath, s conversion.Scope) error { | ||||||
|  | 	out.PathPrefix = in.PathPrefix | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_v1beta1_AllowedHostPath_To_extensions_AllowedHostPath is an autogenerated conversion function. | ||||||
|  | func Convert_v1beta1_AllowedHostPath_To_extensions_AllowedHostPath(in *v1beta1.AllowedHostPath, out *extensions.AllowedHostPath, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_v1beta1_AllowedHostPath_To_extensions_AllowedHostPath(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_extensions_AllowedHostPath_To_v1beta1_AllowedHostPath(in *extensions.AllowedHostPath, out *v1beta1.AllowedHostPath, s conversion.Scope) error { | ||||||
|  | 	out.PathPrefix = in.PathPrefix | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_extensions_AllowedHostPath_To_v1beta1_AllowedHostPath is an autogenerated conversion function. | ||||||
|  | func Convert_extensions_AllowedHostPath_To_v1beta1_AllowedHostPath(in *extensions.AllowedHostPath, out *v1beta1.AllowedHostPath, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_extensions_AllowedHostPath_To_v1beta1_AllowedHostPath(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
| func autoConvert_v1beta1_Eviction_To_policy_Eviction(in *v1beta1.Eviction, out *policy.Eviction, s conversion.Scope) error { | func autoConvert_v1beta1_Eviction_To_policy_Eviction(in *v1beta1.Eviction, out *policy.Eviction, s conversion.Scope) error { | ||||||
| 	out.ObjectMeta = in.ObjectMeta | 	out.ObjectMeta = in.ObjectMeta | ||||||
| 	out.DeleteOptions = (*v1.DeleteOptions)(unsafe.Pointer(in.DeleteOptions)) | 	out.DeleteOptions = (*v1.DeleteOptions)(unsafe.Pointer(in.DeleteOptions)) | ||||||
| @@ -74,6 +137,50 @@ func Convert_policy_Eviction_To_v1beta1_Eviction(in *policy.Eviction, out *v1bet | |||||||
| 	return autoConvert_policy_Eviction_To_v1beta1_Eviction(in, out, s) | 	return autoConvert_policy_Eviction_To_v1beta1_Eviction(in, out, s) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func autoConvert_v1beta1_FSGroupStrategyOptions_To_extensions_FSGroupStrategyOptions(in *v1beta1.FSGroupStrategyOptions, out *extensions.FSGroupStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	out.Rule = extensions.FSGroupStrategyType(in.Rule) | ||||||
|  | 	out.Ranges = *(*[]extensions.GroupIDRange)(unsafe.Pointer(&in.Ranges)) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_v1beta1_FSGroupStrategyOptions_To_extensions_FSGroupStrategyOptions is an autogenerated conversion function. | ||||||
|  | func Convert_v1beta1_FSGroupStrategyOptions_To_extensions_FSGroupStrategyOptions(in *v1beta1.FSGroupStrategyOptions, out *extensions.FSGroupStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_v1beta1_FSGroupStrategyOptions_To_extensions_FSGroupStrategyOptions(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_extensions_FSGroupStrategyOptions_To_v1beta1_FSGroupStrategyOptions(in *extensions.FSGroupStrategyOptions, out *v1beta1.FSGroupStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	out.Rule = v1beta1.FSGroupStrategyType(in.Rule) | ||||||
|  | 	out.Ranges = *(*[]v1beta1.IDRange)(unsafe.Pointer(&in.Ranges)) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_extensions_FSGroupStrategyOptions_To_v1beta1_FSGroupStrategyOptions is an autogenerated conversion function. | ||||||
|  | func Convert_extensions_FSGroupStrategyOptions_To_v1beta1_FSGroupStrategyOptions(in *extensions.FSGroupStrategyOptions, out *v1beta1.FSGroupStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_extensions_FSGroupStrategyOptions_To_v1beta1_FSGroupStrategyOptions(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_v1beta1_HostPortRange_To_extensions_HostPortRange(in *v1beta1.HostPortRange, out *extensions.HostPortRange, s conversion.Scope) error { | ||||||
|  | 	out.Min = in.Min | ||||||
|  | 	out.Max = in.Max | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_v1beta1_HostPortRange_To_extensions_HostPortRange is an autogenerated conversion function. | ||||||
|  | func Convert_v1beta1_HostPortRange_To_extensions_HostPortRange(in *v1beta1.HostPortRange, out *extensions.HostPortRange, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_v1beta1_HostPortRange_To_extensions_HostPortRange(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_extensions_HostPortRange_To_v1beta1_HostPortRange(in *extensions.HostPortRange, out *v1beta1.HostPortRange, s conversion.Scope) error { | ||||||
|  | 	out.Min = in.Min | ||||||
|  | 	out.Max = in.Max | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_extensions_HostPortRange_To_v1beta1_HostPortRange is an autogenerated conversion function. | ||||||
|  | func Convert_extensions_HostPortRange_To_v1beta1_HostPortRange(in *extensions.HostPortRange, out *v1beta1.HostPortRange, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_extensions_HostPortRange_To_v1beta1_HostPortRange(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
| func autoConvert_v1beta1_PodDisruptionBudget_To_policy_PodDisruptionBudget(in *v1beta1.PodDisruptionBudget, out *policy.PodDisruptionBudget, s conversion.Scope) error { | func autoConvert_v1beta1_PodDisruptionBudget_To_policy_PodDisruptionBudget(in *v1beta1.PodDisruptionBudget, out *policy.PodDisruptionBudget, s conversion.Scope) error { | ||||||
| 	out.ObjectMeta = in.ObjectMeta | 	out.ObjectMeta = in.ObjectMeta | ||||||
| 	if err := Convert_v1beta1_PodDisruptionBudgetSpec_To_policy_PodDisruptionBudgetSpec(&in.Spec, &out.Spec, s); err != nil { | 	if err := Convert_v1beta1_PodDisruptionBudgetSpec_To_policy_PodDisruptionBudgetSpec(&in.Spec, &out.Spec, s); err != nil { | ||||||
| @@ -181,3 +288,211 @@ func autoConvert_policy_PodDisruptionBudgetStatus_To_v1beta1_PodDisruptionBudget | |||||||
| func Convert_policy_PodDisruptionBudgetStatus_To_v1beta1_PodDisruptionBudgetStatus(in *policy.PodDisruptionBudgetStatus, out *v1beta1.PodDisruptionBudgetStatus, s conversion.Scope) error { | func Convert_policy_PodDisruptionBudgetStatus_To_v1beta1_PodDisruptionBudgetStatus(in *policy.PodDisruptionBudgetStatus, out *v1beta1.PodDisruptionBudgetStatus, s conversion.Scope) error { | ||||||
| 	return autoConvert_policy_PodDisruptionBudgetStatus_To_v1beta1_PodDisruptionBudgetStatus(in, out, s) | 	return autoConvert_policy_PodDisruptionBudgetStatus_To_v1beta1_PodDisruptionBudgetStatus(in, out, s) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func autoConvert_v1beta1_PodSecurityPolicy_To_extensions_PodSecurityPolicy(in *v1beta1.PodSecurityPolicy, out *extensions.PodSecurityPolicy, s conversion.Scope) error { | ||||||
|  | 	out.ObjectMeta = in.ObjectMeta | ||||||
|  | 	if err := Convert_v1beta1_PodSecurityPolicySpec_To_extensions_PodSecurityPolicySpec(&in.Spec, &out.Spec, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_v1beta1_PodSecurityPolicy_To_extensions_PodSecurityPolicy is an autogenerated conversion function. | ||||||
|  | func Convert_v1beta1_PodSecurityPolicy_To_extensions_PodSecurityPolicy(in *v1beta1.PodSecurityPolicy, out *extensions.PodSecurityPolicy, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_v1beta1_PodSecurityPolicy_To_extensions_PodSecurityPolicy(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_extensions_PodSecurityPolicy_To_v1beta1_PodSecurityPolicy(in *extensions.PodSecurityPolicy, out *v1beta1.PodSecurityPolicy, s conversion.Scope) error { | ||||||
|  | 	out.ObjectMeta = in.ObjectMeta | ||||||
|  | 	if err := Convert_extensions_PodSecurityPolicySpec_To_v1beta1_PodSecurityPolicySpec(&in.Spec, &out.Spec, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_extensions_PodSecurityPolicy_To_v1beta1_PodSecurityPolicy is an autogenerated conversion function. | ||||||
|  | func Convert_extensions_PodSecurityPolicy_To_v1beta1_PodSecurityPolicy(in *extensions.PodSecurityPolicy, out *v1beta1.PodSecurityPolicy, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_extensions_PodSecurityPolicy_To_v1beta1_PodSecurityPolicy(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_v1beta1_PodSecurityPolicyList_To_extensions_PodSecurityPolicyList(in *v1beta1.PodSecurityPolicyList, out *extensions.PodSecurityPolicyList, s conversion.Scope) error { | ||||||
|  | 	out.ListMeta = in.ListMeta | ||||||
|  | 	if in.Items != nil { | ||||||
|  | 		in, out := &in.Items, &out.Items | ||||||
|  | 		*out = make([]extensions.PodSecurityPolicy, len(*in)) | ||||||
|  | 		for i := range *in { | ||||||
|  | 			if err := Convert_v1beta1_PodSecurityPolicy_To_extensions_PodSecurityPolicy(&(*in)[i], &(*out)[i], s); err != nil { | ||||||
|  | 				return err | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} else { | ||||||
|  | 		out.Items = nil | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_v1beta1_PodSecurityPolicyList_To_extensions_PodSecurityPolicyList is an autogenerated conversion function. | ||||||
|  | func Convert_v1beta1_PodSecurityPolicyList_To_extensions_PodSecurityPolicyList(in *v1beta1.PodSecurityPolicyList, out *extensions.PodSecurityPolicyList, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_v1beta1_PodSecurityPolicyList_To_extensions_PodSecurityPolicyList(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_extensions_PodSecurityPolicyList_To_v1beta1_PodSecurityPolicyList(in *extensions.PodSecurityPolicyList, out *v1beta1.PodSecurityPolicyList, s conversion.Scope) error { | ||||||
|  | 	out.ListMeta = in.ListMeta | ||||||
|  | 	if in.Items != nil { | ||||||
|  | 		in, out := &in.Items, &out.Items | ||||||
|  | 		*out = make([]v1beta1.PodSecurityPolicy, len(*in)) | ||||||
|  | 		for i := range *in { | ||||||
|  | 			if err := Convert_extensions_PodSecurityPolicy_To_v1beta1_PodSecurityPolicy(&(*in)[i], &(*out)[i], s); err != nil { | ||||||
|  | 				return err | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} else { | ||||||
|  | 		out.Items = nil | ||||||
|  | 	} | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_extensions_PodSecurityPolicyList_To_v1beta1_PodSecurityPolicyList is an autogenerated conversion function. | ||||||
|  | func Convert_extensions_PodSecurityPolicyList_To_v1beta1_PodSecurityPolicyList(in *extensions.PodSecurityPolicyList, out *v1beta1.PodSecurityPolicyList, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_extensions_PodSecurityPolicyList_To_v1beta1_PodSecurityPolicyList(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_v1beta1_PodSecurityPolicySpec_To_extensions_PodSecurityPolicySpec(in *v1beta1.PodSecurityPolicySpec, out *extensions.PodSecurityPolicySpec, s conversion.Scope) error { | ||||||
|  | 	out.Privileged = in.Privileged | ||||||
|  | 	out.DefaultAddCapabilities = *(*[]core.Capability)(unsafe.Pointer(&in.DefaultAddCapabilities)) | ||||||
|  | 	out.RequiredDropCapabilities = *(*[]core.Capability)(unsafe.Pointer(&in.RequiredDropCapabilities)) | ||||||
|  | 	out.AllowedCapabilities = *(*[]core.Capability)(unsafe.Pointer(&in.AllowedCapabilities)) | ||||||
|  | 	out.Volumes = *(*[]extensions.FSType)(unsafe.Pointer(&in.Volumes)) | ||||||
|  | 	out.HostNetwork = in.HostNetwork | ||||||
|  | 	out.HostPorts = *(*[]extensions.HostPortRange)(unsafe.Pointer(&in.HostPorts)) | ||||||
|  | 	out.HostPID = in.HostPID | ||||||
|  | 	out.HostIPC = in.HostIPC | ||||||
|  | 	if err := Convert_v1beta1_SELinuxStrategyOptions_To_extensions_SELinuxStrategyOptions(&in.SELinux, &out.SELinux, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	if err := Convert_v1beta1_RunAsUserStrategyOptions_To_extensions_RunAsUserStrategyOptions(&in.RunAsUser, &out.RunAsUser, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	if err := Convert_v1beta1_SupplementalGroupsStrategyOptions_To_extensions_SupplementalGroupsStrategyOptions(&in.SupplementalGroups, &out.SupplementalGroups, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	if err := Convert_v1beta1_FSGroupStrategyOptions_To_extensions_FSGroupStrategyOptions(&in.FSGroup, &out.FSGroup, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	out.ReadOnlyRootFilesystem = in.ReadOnlyRootFilesystem | ||||||
|  | 	out.DefaultAllowPrivilegeEscalation = (*bool)(unsafe.Pointer(in.DefaultAllowPrivilegeEscalation)) | ||||||
|  | 	if err := v1.Convert_Pointer_bool_To_bool(&in.AllowPrivilegeEscalation, &out.AllowPrivilegeEscalation, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	out.AllowedHostPaths = *(*[]extensions.AllowedHostPath)(unsafe.Pointer(&in.AllowedHostPaths)) | ||||||
|  | 	out.AllowedFlexVolumes = *(*[]extensions.AllowedFlexVolume)(unsafe.Pointer(&in.AllowedFlexVolumes)) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_v1beta1_PodSecurityPolicySpec_To_extensions_PodSecurityPolicySpec is an autogenerated conversion function. | ||||||
|  | func Convert_v1beta1_PodSecurityPolicySpec_To_extensions_PodSecurityPolicySpec(in *v1beta1.PodSecurityPolicySpec, out *extensions.PodSecurityPolicySpec, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_v1beta1_PodSecurityPolicySpec_To_extensions_PodSecurityPolicySpec(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_extensions_PodSecurityPolicySpec_To_v1beta1_PodSecurityPolicySpec(in *extensions.PodSecurityPolicySpec, out *v1beta1.PodSecurityPolicySpec, s conversion.Scope) error { | ||||||
|  | 	out.Privileged = in.Privileged | ||||||
|  | 	out.DefaultAddCapabilities = *(*[]core_v1.Capability)(unsafe.Pointer(&in.DefaultAddCapabilities)) | ||||||
|  | 	out.RequiredDropCapabilities = *(*[]core_v1.Capability)(unsafe.Pointer(&in.RequiredDropCapabilities)) | ||||||
|  | 	out.AllowedCapabilities = *(*[]core_v1.Capability)(unsafe.Pointer(&in.AllowedCapabilities)) | ||||||
|  | 	out.Volumes = *(*[]v1beta1.FSType)(unsafe.Pointer(&in.Volumes)) | ||||||
|  | 	out.HostNetwork = in.HostNetwork | ||||||
|  | 	out.HostPorts = *(*[]v1beta1.HostPortRange)(unsafe.Pointer(&in.HostPorts)) | ||||||
|  | 	out.HostPID = in.HostPID | ||||||
|  | 	out.HostIPC = in.HostIPC | ||||||
|  | 	if err := Convert_extensions_SELinuxStrategyOptions_To_v1beta1_SELinuxStrategyOptions(&in.SELinux, &out.SELinux, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	if err := Convert_extensions_RunAsUserStrategyOptions_To_v1beta1_RunAsUserStrategyOptions(&in.RunAsUser, &out.RunAsUser, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	if err := Convert_extensions_SupplementalGroupsStrategyOptions_To_v1beta1_SupplementalGroupsStrategyOptions(&in.SupplementalGroups, &out.SupplementalGroups, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	if err := Convert_extensions_FSGroupStrategyOptions_To_v1beta1_FSGroupStrategyOptions(&in.FSGroup, &out.FSGroup, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	out.ReadOnlyRootFilesystem = in.ReadOnlyRootFilesystem | ||||||
|  | 	out.DefaultAllowPrivilegeEscalation = (*bool)(unsafe.Pointer(in.DefaultAllowPrivilegeEscalation)) | ||||||
|  | 	if err := v1.Convert_bool_To_Pointer_bool(&in.AllowPrivilegeEscalation, &out.AllowPrivilegeEscalation, s); err != nil { | ||||||
|  | 		return err | ||||||
|  | 	} | ||||||
|  | 	out.AllowedHostPaths = *(*[]v1beta1.AllowedHostPath)(unsafe.Pointer(&in.AllowedHostPaths)) | ||||||
|  | 	out.AllowedFlexVolumes = *(*[]v1beta1.AllowedFlexVolume)(unsafe.Pointer(&in.AllowedFlexVolumes)) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_extensions_PodSecurityPolicySpec_To_v1beta1_PodSecurityPolicySpec is an autogenerated conversion function. | ||||||
|  | func Convert_extensions_PodSecurityPolicySpec_To_v1beta1_PodSecurityPolicySpec(in *extensions.PodSecurityPolicySpec, out *v1beta1.PodSecurityPolicySpec, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_extensions_PodSecurityPolicySpec_To_v1beta1_PodSecurityPolicySpec(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_v1beta1_RunAsUserStrategyOptions_To_extensions_RunAsUserStrategyOptions(in *v1beta1.RunAsUserStrategyOptions, out *extensions.RunAsUserStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	out.Rule = extensions.RunAsUserStrategy(in.Rule) | ||||||
|  | 	out.Ranges = *(*[]extensions.UserIDRange)(unsafe.Pointer(&in.Ranges)) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_v1beta1_RunAsUserStrategyOptions_To_extensions_RunAsUserStrategyOptions is an autogenerated conversion function. | ||||||
|  | func Convert_v1beta1_RunAsUserStrategyOptions_To_extensions_RunAsUserStrategyOptions(in *v1beta1.RunAsUserStrategyOptions, out *extensions.RunAsUserStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_v1beta1_RunAsUserStrategyOptions_To_extensions_RunAsUserStrategyOptions(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_extensions_RunAsUserStrategyOptions_To_v1beta1_RunAsUserStrategyOptions(in *extensions.RunAsUserStrategyOptions, out *v1beta1.RunAsUserStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	out.Rule = v1beta1.RunAsUserStrategy(in.Rule) | ||||||
|  | 	out.Ranges = *(*[]v1beta1.IDRange)(unsafe.Pointer(&in.Ranges)) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_extensions_RunAsUserStrategyOptions_To_v1beta1_RunAsUserStrategyOptions is an autogenerated conversion function. | ||||||
|  | func Convert_extensions_RunAsUserStrategyOptions_To_v1beta1_RunAsUserStrategyOptions(in *extensions.RunAsUserStrategyOptions, out *v1beta1.RunAsUserStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_extensions_RunAsUserStrategyOptions_To_v1beta1_RunAsUserStrategyOptions(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_v1beta1_SELinuxStrategyOptions_To_extensions_SELinuxStrategyOptions(in *v1beta1.SELinuxStrategyOptions, out *extensions.SELinuxStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	out.Rule = extensions.SELinuxStrategy(in.Rule) | ||||||
|  | 	out.SELinuxOptions = (*core.SELinuxOptions)(unsafe.Pointer(in.SELinuxOptions)) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_v1beta1_SELinuxStrategyOptions_To_extensions_SELinuxStrategyOptions is an autogenerated conversion function. | ||||||
|  | func Convert_v1beta1_SELinuxStrategyOptions_To_extensions_SELinuxStrategyOptions(in *v1beta1.SELinuxStrategyOptions, out *extensions.SELinuxStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_v1beta1_SELinuxStrategyOptions_To_extensions_SELinuxStrategyOptions(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_extensions_SELinuxStrategyOptions_To_v1beta1_SELinuxStrategyOptions(in *extensions.SELinuxStrategyOptions, out *v1beta1.SELinuxStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	out.Rule = v1beta1.SELinuxStrategy(in.Rule) | ||||||
|  | 	out.SELinuxOptions = (*core_v1.SELinuxOptions)(unsafe.Pointer(in.SELinuxOptions)) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_extensions_SELinuxStrategyOptions_To_v1beta1_SELinuxStrategyOptions is an autogenerated conversion function. | ||||||
|  | func Convert_extensions_SELinuxStrategyOptions_To_v1beta1_SELinuxStrategyOptions(in *extensions.SELinuxStrategyOptions, out *v1beta1.SELinuxStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_extensions_SELinuxStrategyOptions_To_v1beta1_SELinuxStrategyOptions(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_v1beta1_SupplementalGroupsStrategyOptions_To_extensions_SupplementalGroupsStrategyOptions(in *v1beta1.SupplementalGroupsStrategyOptions, out *extensions.SupplementalGroupsStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	out.Rule = extensions.SupplementalGroupsStrategyType(in.Rule) | ||||||
|  | 	out.Ranges = *(*[]extensions.GroupIDRange)(unsafe.Pointer(&in.Ranges)) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_v1beta1_SupplementalGroupsStrategyOptions_To_extensions_SupplementalGroupsStrategyOptions is an autogenerated conversion function. | ||||||
|  | func Convert_v1beta1_SupplementalGroupsStrategyOptions_To_extensions_SupplementalGroupsStrategyOptions(in *v1beta1.SupplementalGroupsStrategyOptions, out *extensions.SupplementalGroupsStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_v1beta1_SupplementalGroupsStrategyOptions_To_extensions_SupplementalGroupsStrategyOptions(in, out, s) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func autoConvert_extensions_SupplementalGroupsStrategyOptions_To_v1beta1_SupplementalGroupsStrategyOptions(in *extensions.SupplementalGroupsStrategyOptions, out *v1beta1.SupplementalGroupsStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	out.Rule = v1beta1.SupplementalGroupsStrategyType(in.Rule) | ||||||
|  | 	out.Ranges = *(*[]v1beta1.IDRange)(unsafe.Pointer(&in.Ranges)) | ||||||
|  | 	return nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Convert_extensions_SupplementalGroupsStrategyOptions_To_v1beta1_SupplementalGroupsStrategyOptions is an autogenerated conversion function. | ||||||
|  | func Convert_extensions_SupplementalGroupsStrategyOptions_To_v1beta1_SupplementalGroupsStrategyOptions(in *extensions.SupplementalGroupsStrategyOptions, out *v1beta1.SupplementalGroupsStrategyOptions, s conversion.Scope) error { | ||||||
|  | 	return autoConvert_extensions_SupplementalGroupsStrategyOptions_To_v1beta1_SupplementalGroupsStrategyOptions(in, out, s) | ||||||
|  | } | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								pkg/apis/policy/v1beta1/zz_generated.defaults.go
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										14
									
								
								pkg/apis/policy/v1beta1/zz_generated.defaults.go
									
									
									
										generated
									
									
									
								
							| @@ -21,6 +21,7 @@ limitations under the License. | |||||||
| package v1beta1 | package v1beta1 | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
|  | 	v1beta1 "k8s.io/api/policy/v1beta1" | ||||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -28,5 +29,18 @@ import ( | |||||||
| // Public to allow building arbitrary schemes. | // Public to allow building arbitrary schemes. | ||||||
| // All generated defaulters are covering - they call all nested defaulters. | // All generated defaulters are covering - they call all nested defaulters. | ||||||
| func RegisterDefaults(scheme *runtime.Scheme) error { | func RegisterDefaults(scheme *runtime.Scheme) error { | ||||||
|  | 	scheme.AddTypeDefaultingFunc(&v1beta1.PodSecurityPolicy{}, func(obj interface{}) { SetObjectDefaults_PodSecurityPolicy(obj.(*v1beta1.PodSecurityPolicy)) }) | ||||||
|  | 	scheme.AddTypeDefaultingFunc(&v1beta1.PodSecurityPolicyList{}, func(obj interface{}) { SetObjectDefaults_PodSecurityPolicyList(obj.(*v1beta1.PodSecurityPolicyList)) }) | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func SetObjectDefaults_PodSecurityPolicy(in *v1beta1.PodSecurityPolicy) { | ||||||
|  | 	SetDefaults_PodSecurityPolicySpec(&in.Spec) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func SetObjectDefaults_PodSecurityPolicyList(in *v1beta1.PodSecurityPolicyList) { | ||||||
|  | 	for i := range in.Items { | ||||||
|  | 		a := &in.Items[i] | ||||||
|  | 		SetObjectDefaults_PodSecurityPolicy(a) | ||||||
|  | 	} | ||||||
|  | } | ||||||
|   | |||||||
| @@ -33,6 +33,7 @@ var SpecialDefaultResourcePrefixes = map[schema.GroupResource]string{ | |||||||
| 	{Group: "", Resource: "services"}:                      "services/specs", | 	{Group: "", Resource: "services"}:                      "services/specs", | ||||||
| 	{Group: "extensions", Resource: "ingresses"}:           "ingress", | 	{Group: "extensions", Resource: "ingresses"}:           "ingress", | ||||||
| 	{Group: "extensions", Resource: "podsecuritypolicies"}: "podsecuritypolicy", | 	{Group: "extensions", Resource: "podsecuritypolicies"}: "podsecuritypolicy", | ||||||
|  | 	{Group: "policy", Resource: "podsecuritypolicies"}:     "podsecuritypolicy", | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewStorageFactory builds the DefaultStorageFactory. | // NewStorageFactory builds the DefaultStorageFactory. | ||||||
|   | |||||||
| @@ -12,6 +12,7 @@ go_library( | |||||||
|     deps = [ |     deps = [ | ||||||
|         "//pkg/api/legacyscheme:go_default_library", |         "//pkg/api/legacyscheme:go_default_library", | ||||||
|         "//pkg/apis/policy:go_default_library", |         "//pkg/apis/policy:go_default_library", | ||||||
|  |         "//pkg/registry/extensions/podsecuritypolicy/storage:go_default_library", | ||||||
|         "//pkg/registry/policy/poddisruptionbudget/storage:go_default_library", |         "//pkg/registry/policy/poddisruptionbudget/storage:go_default_library", | ||||||
|         "//vendor/k8s.io/api/policy/v1beta1:go_default_library", |         "//vendor/k8s.io/api/policy/v1beta1:go_default_library", | ||||||
|         "//vendor/k8s.io/apiserver/pkg/registry/generic:go_default_library", |         "//vendor/k8s.io/apiserver/pkg/registry/generic:go_default_library", | ||||||
|   | |||||||
| @@ -24,6 +24,7 @@ import ( | |||||||
| 	serverstorage "k8s.io/apiserver/pkg/server/storage" | 	serverstorage "k8s.io/apiserver/pkg/server/storage" | ||||||
| 	"k8s.io/kubernetes/pkg/api/legacyscheme" | 	"k8s.io/kubernetes/pkg/api/legacyscheme" | ||||||
| 	"k8s.io/kubernetes/pkg/apis/policy" | 	"k8s.io/kubernetes/pkg/apis/policy" | ||||||
|  | 	pspstore "k8s.io/kubernetes/pkg/registry/extensions/podsecuritypolicy/storage" | ||||||
| 	poddisruptionbudgetstore "k8s.io/kubernetes/pkg/registry/policy/poddisruptionbudget/storage" | 	poddisruptionbudgetstore "k8s.io/kubernetes/pkg/registry/policy/poddisruptionbudget/storage" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -48,6 +49,8 @@ func (p RESTStorageProvider) v1beta1Storage(apiResourceConfigSource serverstorag | |||||||
| 	storage["poddisruptionbudgets"] = poddisruptionbudgetStorage | 	storage["poddisruptionbudgets"] = poddisruptionbudgetStorage | ||||||
| 	storage["poddisruptionbudgets/status"] = poddisruptionbudgetStatusStorage | 	storage["poddisruptionbudgets/status"] = poddisruptionbudgetStatusStorage | ||||||
|  |  | ||||||
|  | 	storage["podsecuritypolicies"] = pspstore.NewREST(restOptionsGetter) | ||||||
|  |  | ||||||
| 	return storage | 	return storage | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,3 +2,7 @@ approvers: | |||||||
| - sig-apps-api-approvers | - sig-apps-api-approvers | ||||||
| reviewers: | reviewers: | ||||||
| - sig-apps-reviewers | - sig-apps-reviewers | ||||||
|  | - pweil- | ||||||
|  | - liggitt | ||||||
|  | - tallclair | ||||||
|  | - php-coder | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ go_library( | |||||||
|     deps = [ |     deps = [ | ||||||
|         "//vendor/github.com/gogo/protobuf/proto:go_default_library", |         "//vendor/github.com/gogo/protobuf/proto:go_default_library", | ||||||
|         "//vendor/github.com/gogo/protobuf/sortkeys:go_default_library", |         "//vendor/github.com/gogo/protobuf/sortkeys:go_default_library", | ||||||
|  |         "//vendor/k8s.io/api/core/v1:go_default_library", | ||||||
|         "//vendor/k8s.io/apimachinery/pkg/apis/meta/v1:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/apis/meta/v1:go_default_library", | ||||||
|         "//vendor/k8s.io/apimachinery/pkg/runtime:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/runtime:go_default_library", | ||||||
|         "//vendor/k8s.io/apimachinery/pkg/runtime/schema:go_default_library", |         "//vendor/k8s.io/apimachinery/pkg/runtime/schema:go_default_library", | ||||||
|   | |||||||
							
								
								
									
										2574
									
								
								staging/src/k8s.io/api/policy/v1beta1/generated.pb.go
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2574
									
								
								staging/src/k8s.io/api/policy/v1beta1/generated.pb.go
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -30,6 +30,25 @@ import "k8s.io/apimachinery/pkg/util/intstr/generated.proto"; | |||||||
| // Package-wide variables from generator "generated". | // Package-wide variables from generator "generated". | ||||||
| option go_package = "v1beta1"; | option go_package = "v1beta1"; | ||||||
|  |  | ||||||
|  | // AllowedFlexVolume represents a single Flexvolume that is allowed to be used. | ||||||
|  | message AllowedFlexVolume { | ||||||
|  |   // Driver is the name of the Flexvolume driver. | ||||||
|  |   optional string driver = 1; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // defines the host volume conditions that will be enabled by a policy | ||||||
|  | // for pods to use. It requires the path prefix to be defined. | ||||||
|  | message AllowedHostPath { | ||||||
|  |   // is the path prefix that the host volume must match. | ||||||
|  |   // It does not support `*`. | ||||||
|  |   // Trailing slashes are trimmed when validating the path prefix with a host path. | ||||||
|  |   //  | ||||||
|  |   // Examples: | ||||||
|  |   // `/foo` would allow `/foo`, `/foo/` and `/foo/bar` | ||||||
|  |   // `/foo` would not allow `/food` or `/etc/foo` | ||||||
|  |   optional string pathPrefix = 1; | ||||||
|  | } | ||||||
|  |  | ||||||
| // Eviction evicts a pod from its node subject to certain policies and safety constraints. | // Eviction evicts a pod from its node subject to certain policies and safety constraints. | ||||||
| // This is a subresource of Pod.  A request to cause such an eviction is | // This is a subresource of Pod.  A request to cause such an eviction is | ||||||
| // created by POSTing to .../pods/<pod name>/evictions. | // created by POSTing to .../pods/<pod name>/evictions. | ||||||
| @@ -41,6 +60,37 @@ message Eviction { | |||||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.DeleteOptions deleteOptions = 2; |   optional k8s.io.apimachinery.pkg.apis.meta.v1.DeleteOptions deleteOptions = 2; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // FSGroupStrategyOptions defines the strategy type and options used to create the strategy. | ||||||
|  | message FSGroupStrategyOptions { | ||||||
|  |   // Rule is the strategy that will dictate what FSGroup is used in the SecurityContext. | ||||||
|  |   // +optional | ||||||
|  |   optional string rule = 1; | ||||||
|  |  | ||||||
|  |   // Ranges are the allowed ranges of fs groups.  If you would like to force a single | ||||||
|  |   // fs group then supply a single range with the same start and end. | ||||||
|  |   // +optional | ||||||
|  |   repeated IDRange ranges = 2; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Host Port Range defines a range of host ports that will be enabled by a policy | ||||||
|  | // for pods to use.  It requires both the start and end to be defined. | ||||||
|  | message HostPortRange { | ||||||
|  |   // min is the start of the range, inclusive. | ||||||
|  |   optional int32 min = 1; | ||||||
|  |  | ||||||
|  |   // max is the end of the range, inclusive. | ||||||
|  |   optional int32 max = 2; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // ID Range provides a min/max of an allowed range of IDs. | ||||||
|  | message IDRange { | ||||||
|  |   // Min is the start of the range, inclusive. | ||||||
|  |   optional int64 min = 1; | ||||||
|  |  | ||||||
|  |   // Max is the end of the range, inclusive. | ||||||
|  |   optional int64 max = 2; | ||||||
|  | } | ||||||
|  |  | ||||||
| // PodDisruptionBudget is an object to define the max disruption that can be caused to a collection of pods | // PodDisruptionBudget is an object to define the max disruption that can be caused to a collection of pods | ||||||
| message PodDisruptionBudget { | message PodDisruptionBudget { | ||||||
|   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; |   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||||
| @@ -112,3 +162,146 @@ message PodDisruptionBudgetStatus { | |||||||
|   optional int32 expectedPods = 6; |   optional int32 expectedPods = 6; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // Pod Security Policy governs the ability to make requests that affect the Security Context | ||||||
|  | // that will be applied to a pod and container. | ||||||
|  | message PodSecurityPolicy { | ||||||
|  |   // Standard object's metadata. | ||||||
|  |   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||||
|  |   // +optional | ||||||
|  |   optional k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1; | ||||||
|  |  | ||||||
|  |   // spec defines the policy enforced. | ||||||
|  |   // +optional | ||||||
|  |   optional PodSecurityPolicySpec spec = 2; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Pod Security Policy List is a list of PodSecurityPolicy objects. | ||||||
|  | message PodSecurityPolicyList { | ||||||
|  |   // Standard list metadata. | ||||||
|  |   // More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||||
|  |   // +optional | ||||||
|  |   optional k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1; | ||||||
|  |  | ||||||
|  |   // Items is a list of schema objects. | ||||||
|  |   repeated PodSecurityPolicy items = 2; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Pod Security Policy Spec defines the policy enforced. | ||||||
|  | message PodSecurityPolicySpec { | ||||||
|  |   // privileged determines if a pod can request to be run as privileged. | ||||||
|  |   // +optional | ||||||
|  |   optional bool privileged = 1; | ||||||
|  |  | ||||||
|  |   // DefaultAddCapabilities is the default set of capabilities that will be added to the container | ||||||
|  |   // unless the pod spec specifically drops the capability.  You may not list a capability in both | ||||||
|  |   // DefaultAddCapabilities and RequiredDropCapabilities. Capabilities added here are implicitly | ||||||
|  |   // allowed, and need not be included in the AllowedCapabilities list. | ||||||
|  |   // +optional | ||||||
|  |   repeated string defaultAddCapabilities = 2; | ||||||
|  |  | ||||||
|  |   // RequiredDropCapabilities are the capabilities that will be dropped from the container.  These | ||||||
|  |   // are required to be dropped and cannot be added. | ||||||
|  |   // +optional | ||||||
|  |   repeated string requiredDropCapabilities = 3; | ||||||
|  |  | ||||||
|  |   // AllowedCapabilities is a list of capabilities that can be requested to add to the container. | ||||||
|  |   // Capabilities in this field may be added at the pod author's discretion. | ||||||
|  |   // You must not list a capability in both AllowedCapabilities and RequiredDropCapabilities. | ||||||
|  |   // +optional | ||||||
|  |   repeated string allowedCapabilities = 4; | ||||||
|  |  | ||||||
|  |   // volumes is a white list of allowed volume plugins.  Empty indicates that all plugins | ||||||
|  |   // may be used. | ||||||
|  |   // +optional | ||||||
|  |   repeated string volumes = 5; | ||||||
|  |  | ||||||
|  |   // hostNetwork determines if the policy allows the use of HostNetwork in the pod spec. | ||||||
|  |   // +optional | ||||||
|  |   optional bool hostNetwork = 6; | ||||||
|  |  | ||||||
|  |   // hostPorts determines which host port ranges are allowed to be exposed. | ||||||
|  |   // +optional | ||||||
|  |   repeated HostPortRange hostPorts = 7; | ||||||
|  |  | ||||||
|  |   // hostPID determines if the policy allows the use of HostPID in the pod spec. | ||||||
|  |   // +optional | ||||||
|  |   optional bool hostPID = 8; | ||||||
|  |  | ||||||
|  |   // hostIPC determines if the policy allows the use of HostIPC in the pod spec. | ||||||
|  |   // +optional | ||||||
|  |   optional bool hostIPC = 9; | ||||||
|  |  | ||||||
|  |   // seLinux is the strategy that will dictate the allowable labels that may be set. | ||||||
|  |   optional SELinuxStrategyOptions seLinux = 10; | ||||||
|  |  | ||||||
|  |   // runAsUser is the strategy that will dictate the allowable RunAsUser values that may be set. | ||||||
|  |   optional RunAsUserStrategyOptions runAsUser = 11; | ||||||
|  |  | ||||||
|  |   // SupplementalGroups is the strategy that will dictate what supplemental groups are used by the SecurityContext. | ||||||
|  |   optional SupplementalGroupsStrategyOptions supplementalGroups = 12; | ||||||
|  |  | ||||||
|  |   // FSGroup is the strategy that will dictate what fs group is used by the SecurityContext. | ||||||
|  |   optional FSGroupStrategyOptions fsGroup = 13; | ||||||
|  |  | ||||||
|  |   // ReadOnlyRootFilesystem when set to true will force containers to run with a read only root file | ||||||
|  |   // system.  If the container specifically requests to run with a non-read only root file system | ||||||
|  |   // the PSP should deny the pod. | ||||||
|  |   // If set to false the container may run with a read only root file system if it wishes but it | ||||||
|  |   // will not be forced to. | ||||||
|  |   // +optional | ||||||
|  |   optional bool readOnlyRootFilesystem = 14; | ||||||
|  |  | ||||||
|  |   // DefaultAllowPrivilegeEscalation controls the default setting for whether a | ||||||
|  |   // process can gain more privileges than its parent process. | ||||||
|  |   // +optional | ||||||
|  |   optional bool defaultAllowPrivilegeEscalation = 15; | ||||||
|  |  | ||||||
|  |   // AllowPrivilegeEscalation determines if a pod can request to allow | ||||||
|  |   // privilege escalation. If unspecified, defaults to true. | ||||||
|  |   // +optional | ||||||
|  |   optional bool allowPrivilegeEscalation = 16; | ||||||
|  |  | ||||||
|  |   // is a white list of allowed host paths. Empty indicates that all host paths may be used. | ||||||
|  |   // +optional | ||||||
|  |   repeated AllowedHostPath allowedHostPaths = 17; | ||||||
|  |  | ||||||
|  |   // AllowedFlexVolumes is a whitelist of allowed Flexvolumes.  Empty or nil indicates that all | ||||||
|  |   // Flexvolumes may be used.  This parameter is effective only when the usage of the Flexvolumes | ||||||
|  |   // is allowed in the "Volumes" field. | ||||||
|  |   // +optional | ||||||
|  |   repeated AllowedFlexVolume allowedFlexVolumes = 18; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Run A sUser Strategy Options defines the strategy type and any options used to create the strategy. | ||||||
|  | message RunAsUserStrategyOptions { | ||||||
|  |   // Rule is the strategy that will dictate the allowable RunAsUser values that may be set. | ||||||
|  |   optional string rule = 1; | ||||||
|  |  | ||||||
|  |   // Ranges are the allowed ranges of uids that may be used. | ||||||
|  |   // +optional | ||||||
|  |   repeated IDRange ranges = 2; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // SELinux  Strategy Options defines the strategy type and any options used to create the strategy. | ||||||
|  | message SELinuxStrategyOptions { | ||||||
|  |   // type is the strategy that will dictate the allowable labels that may be set. | ||||||
|  |   optional string rule = 1; | ||||||
|  |  | ||||||
|  |   // seLinuxOptions required to run as; required for MustRunAs | ||||||
|  |   // More info: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/ | ||||||
|  |   // +optional | ||||||
|  |   optional k8s.io.api.core.v1.SELinuxOptions seLinuxOptions = 2; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // SupplementalGroupsStrategyOptions defines the strategy type and options used to create the strategy. | ||||||
|  | message SupplementalGroupsStrategyOptions { | ||||||
|  |   // Rule is the strategy that will dictate what supplemental groups is used in the SecurityContext. | ||||||
|  |   // +optional | ||||||
|  |   optional string rule = 1; | ||||||
|  |  | ||||||
|  |   // Ranges are the allowed ranges of supplemental groups.  If you would like to force a single | ||||||
|  |   // supplemental group then supply a single range with the same start and end. | ||||||
|  |   // +optional | ||||||
|  |   repeated IDRange ranges = 2; | ||||||
|  | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -46,6 +46,8 @@ func addKnownTypes(scheme *runtime.Scheme) error { | |||||||
| 	scheme.AddKnownTypes(SchemeGroupVersion, | 	scheme.AddKnownTypes(SchemeGroupVersion, | ||||||
| 		&PodDisruptionBudget{}, | 		&PodDisruptionBudget{}, | ||||||
| 		&PodDisruptionBudgetList{}, | 		&PodDisruptionBudgetList{}, | ||||||
|  | 		&PodSecurityPolicy{}, | ||||||
|  | 		&PodSecurityPolicyList{}, | ||||||
| 		&Eviction{}, | 		&Eviction{}, | ||||||
| 	) | 	) | ||||||
| 	// Add the watch version that applies | 	// Add the watch version that applies | ||||||
|   | |||||||
| @@ -17,6 +17,7 @@ limitations under the License. | |||||||
| package v1beta1 | package v1beta1 | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
|  | 	"k8s.io/api/core/v1" | ||||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||||
| 	"k8s.io/apimachinery/pkg/util/intstr" | 	"k8s.io/apimachinery/pkg/util/intstr" | ||||||
| ) | ) | ||||||
| @@ -113,3 +114,255 @@ type Eviction struct { | |||||||
| 	// DeleteOptions may be provided | 	// DeleteOptions may be provided | ||||||
| 	DeleteOptions *metav1.DeleteOptions `json:"deleteOptions,omitempty" protobuf:"bytes,2,opt,name=deleteOptions"` | 	DeleteOptions *metav1.DeleteOptions `json:"deleteOptions,omitempty" protobuf:"bytes,2,opt,name=deleteOptions"` | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // +genclient | ||||||
|  | // +genclient:nonNamespaced | ||||||
|  | // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||||
|  |  | ||||||
|  | // Pod Security Policy governs the ability to make requests that affect the Security Context | ||||||
|  | // that will be applied to a pod and container. | ||||||
|  | type PodSecurityPolicy struct { | ||||||
|  | 	metav1.TypeMeta `json:",inline"` | ||||||
|  | 	// Standard object's metadata. | ||||||
|  | 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||||
|  | 	// +optional | ||||||
|  | 	metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||||
|  |  | ||||||
|  | 	// spec defines the policy enforced. | ||||||
|  | 	// +optional | ||||||
|  | 	Spec PodSecurityPolicySpec `json:"spec,omitempty" protobuf:"bytes,2,opt,name=spec"` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Pod Security Policy Spec defines the policy enforced. | ||||||
|  | type PodSecurityPolicySpec struct { | ||||||
|  | 	// privileged determines if a pod can request to be run as privileged. | ||||||
|  | 	// +optional | ||||||
|  | 	Privileged bool `json:"privileged,omitempty" protobuf:"varint,1,opt,name=privileged"` | ||||||
|  | 	// DefaultAddCapabilities is the default set of capabilities that will be added to the container | ||||||
|  | 	// unless the pod spec specifically drops the capability.  You may not list a capability in both | ||||||
|  | 	// DefaultAddCapabilities and RequiredDropCapabilities. Capabilities added here are implicitly | ||||||
|  | 	// allowed, and need not be included in the AllowedCapabilities list. | ||||||
|  | 	// +optional | ||||||
|  | 	DefaultAddCapabilities []v1.Capability `json:"defaultAddCapabilities,omitempty" protobuf:"bytes,2,rep,name=defaultAddCapabilities,casttype=k8s.io/api/core/v1.Capability"` | ||||||
|  | 	// RequiredDropCapabilities are the capabilities that will be dropped from the container.  These | ||||||
|  | 	// are required to be dropped and cannot be added. | ||||||
|  | 	// +optional | ||||||
|  | 	RequiredDropCapabilities []v1.Capability `json:"requiredDropCapabilities,omitempty" protobuf:"bytes,3,rep,name=requiredDropCapabilities,casttype=k8s.io/api/core/v1.Capability"` | ||||||
|  | 	// AllowedCapabilities is a list of capabilities that can be requested to add to the container. | ||||||
|  | 	// Capabilities in this field may be added at the pod author's discretion. | ||||||
|  | 	// You must not list a capability in both AllowedCapabilities and RequiredDropCapabilities. | ||||||
|  | 	// +optional | ||||||
|  | 	AllowedCapabilities []v1.Capability `json:"allowedCapabilities,omitempty" protobuf:"bytes,4,rep,name=allowedCapabilities,casttype=k8s.io/api/core/v1.Capability"` | ||||||
|  | 	// volumes is a white list of allowed volume plugins.  Empty indicates that all plugins | ||||||
|  | 	// may be used. | ||||||
|  | 	// +optional | ||||||
|  | 	Volumes []FSType `json:"volumes,omitempty" protobuf:"bytes,5,rep,name=volumes,casttype=FSType"` | ||||||
|  | 	// hostNetwork determines if the policy allows the use of HostNetwork in the pod spec. | ||||||
|  | 	// +optional | ||||||
|  | 	HostNetwork bool `json:"hostNetwork,omitempty" protobuf:"varint,6,opt,name=hostNetwork"` | ||||||
|  | 	// hostPorts determines which host port ranges are allowed to be exposed. | ||||||
|  | 	// +optional | ||||||
|  | 	HostPorts []HostPortRange `json:"hostPorts,omitempty" protobuf:"bytes,7,rep,name=hostPorts"` | ||||||
|  | 	// hostPID determines if the policy allows the use of HostPID in the pod spec. | ||||||
|  | 	// +optional | ||||||
|  | 	HostPID bool `json:"hostPID,omitempty" protobuf:"varint,8,opt,name=hostPID"` | ||||||
|  | 	// hostIPC determines if the policy allows the use of HostIPC in the pod spec. | ||||||
|  | 	// +optional | ||||||
|  | 	HostIPC bool `json:"hostIPC,omitempty" protobuf:"varint,9,opt,name=hostIPC"` | ||||||
|  | 	// seLinux is the strategy that will dictate the allowable labels that may be set. | ||||||
|  | 	SELinux SELinuxStrategyOptions `json:"seLinux" protobuf:"bytes,10,opt,name=seLinux"` | ||||||
|  | 	// runAsUser is the strategy that will dictate the allowable RunAsUser values that may be set. | ||||||
|  | 	RunAsUser RunAsUserStrategyOptions `json:"runAsUser" protobuf:"bytes,11,opt,name=runAsUser"` | ||||||
|  | 	// SupplementalGroups is the strategy that will dictate what supplemental groups are used by the SecurityContext. | ||||||
|  | 	SupplementalGroups SupplementalGroupsStrategyOptions `json:"supplementalGroups" protobuf:"bytes,12,opt,name=supplementalGroups"` | ||||||
|  | 	// FSGroup is the strategy that will dictate what fs group is used by the SecurityContext. | ||||||
|  | 	FSGroup FSGroupStrategyOptions `json:"fsGroup" protobuf:"bytes,13,opt,name=fsGroup"` | ||||||
|  | 	// ReadOnlyRootFilesystem when set to true will force containers to run with a read only root file | ||||||
|  | 	// system.  If the container specifically requests to run with a non-read only root file system | ||||||
|  | 	// the PSP should deny the pod. | ||||||
|  | 	// If set to false the container may run with a read only root file system if it wishes but it | ||||||
|  | 	// will not be forced to. | ||||||
|  | 	// +optional | ||||||
|  | 	ReadOnlyRootFilesystem bool `json:"readOnlyRootFilesystem,omitempty" protobuf:"varint,14,opt,name=readOnlyRootFilesystem"` | ||||||
|  | 	// DefaultAllowPrivilegeEscalation controls the default setting for whether a | ||||||
|  | 	// process can gain more privileges than its parent process. | ||||||
|  | 	// +optional | ||||||
|  | 	DefaultAllowPrivilegeEscalation *bool `json:"defaultAllowPrivilegeEscalation,omitempty" protobuf:"varint,15,opt,name=defaultAllowPrivilegeEscalation"` | ||||||
|  | 	// AllowPrivilegeEscalation determines if a pod can request to allow | ||||||
|  | 	// privilege escalation. If unspecified, defaults to true. | ||||||
|  | 	// +optional | ||||||
|  | 	AllowPrivilegeEscalation *bool `json:"allowPrivilegeEscalation,omitempty" protobuf:"varint,16,opt,name=allowPrivilegeEscalation"` | ||||||
|  | 	// is a white list of allowed host paths. Empty indicates that all host paths may be used. | ||||||
|  | 	// +optional | ||||||
|  | 	AllowedHostPaths []AllowedHostPath `json:"allowedHostPaths,omitempty" protobuf:"bytes,17,rep,name=allowedHostPaths"` | ||||||
|  | 	// AllowedFlexVolumes is a whitelist of allowed Flexvolumes.  Empty or nil indicates that all | ||||||
|  | 	// Flexvolumes may be used.  This parameter is effective only when the usage of the Flexvolumes | ||||||
|  | 	// is allowed in the "Volumes" field. | ||||||
|  | 	// +optional | ||||||
|  | 	AllowedFlexVolumes []AllowedFlexVolume `json:"allowedFlexVolumes,omitempty" protobuf:"bytes,18,rep,name=allowedFlexVolumes"` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // defines the host volume conditions that will be enabled by a policy | ||||||
|  | // for pods to use. It requires the path prefix to be defined. | ||||||
|  | type AllowedHostPath struct { | ||||||
|  | 	// is the path prefix that the host volume must match. | ||||||
|  | 	// It does not support `*`. | ||||||
|  | 	// Trailing slashes are trimmed when validating the path prefix with a host path. | ||||||
|  | 	// | ||||||
|  | 	// Examples: | ||||||
|  | 	// `/foo` would allow `/foo`, `/foo/` and `/foo/bar` | ||||||
|  | 	// `/foo` would not allow `/food` or `/etc/foo` | ||||||
|  | 	PathPrefix string `json:"pathPrefix,omitempty" protobuf:"bytes,1,rep,name=pathPrefix"` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // FS Type gives strong typing to different file systems that are used by volumes. | ||||||
|  | type FSType string | ||||||
|  |  | ||||||
|  | var ( | ||||||
|  | 	AzureFile             FSType = "azureFile" | ||||||
|  | 	Flocker               FSType = "flocker" | ||||||
|  | 	FlexVolume            FSType = "flexVolume" | ||||||
|  | 	HostPath              FSType = "hostPath" | ||||||
|  | 	EmptyDir              FSType = "emptyDir" | ||||||
|  | 	GCEPersistentDisk     FSType = "gcePersistentDisk" | ||||||
|  | 	AWSElasticBlockStore  FSType = "awsElasticBlockStore" | ||||||
|  | 	GitRepo               FSType = "gitRepo" | ||||||
|  | 	Secret                FSType = "secret" | ||||||
|  | 	NFS                   FSType = "nfs" | ||||||
|  | 	ISCSI                 FSType = "iscsi" | ||||||
|  | 	Glusterfs             FSType = "glusterfs" | ||||||
|  | 	PersistentVolumeClaim FSType = "persistentVolumeClaim" | ||||||
|  | 	RBD                   FSType = "rbd" | ||||||
|  | 	Cinder                FSType = "cinder" | ||||||
|  | 	CephFS                FSType = "cephFS" | ||||||
|  | 	DownwardAPI           FSType = "downwardAPI" | ||||||
|  | 	FC                    FSType = "fc" | ||||||
|  | 	ConfigMap             FSType = "configMap" | ||||||
|  | 	Quobyte               FSType = "quobyte" | ||||||
|  | 	AzureDisk             FSType = "azureDisk" | ||||||
|  | 	All                   FSType = "*" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // AllowedFlexVolume represents a single Flexvolume that is allowed to be used. | ||||||
|  | type AllowedFlexVolume struct { | ||||||
|  | 	// Driver is the name of the Flexvolume driver. | ||||||
|  | 	Driver string `json:"driver" protobuf:"bytes,1,opt,name=driver"` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Host Port Range defines a range of host ports that will be enabled by a policy | ||||||
|  | // for pods to use.  It requires both the start and end to be defined. | ||||||
|  | type HostPortRange struct { | ||||||
|  | 	// min is the start of the range, inclusive. | ||||||
|  | 	Min int32 `json:"min" protobuf:"varint,1,opt,name=min"` | ||||||
|  | 	// max is the end of the range, inclusive. | ||||||
|  | 	Max int32 `json:"max" protobuf:"varint,2,opt,name=max"` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // SELinux  Strategy Options defines the strategy type and any options used to create the strategy. | ||||||
|  | type SELinuxStrategyOptions struct { | ||||||
|  | 	// type is the strategy that will dictate the allowable labels that may be set. | ||||||
|  | 	Rule SELinuxStrategy `json:"rule" protobuf:"bytes,1,opt,name=rule,casttype=SELinuxStrategy"` | ||||||
|  | 	// seLinuxOptions required to run as; required for MustRunAs | ||||||
|  | 	// More info: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/ | ||||||
|  | 	// +optional | ||||||
|  | 	SELinuxOptions *v1.SELinuxOptions `json:"seLinuxOptions,omitempty" protobuf:"bytes,2,opt,name=seLinuxOptions"` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // SELinuxStrategy denotes strategy types for generating SELinux options for a | ||||||
|  | // Security Context. | ||||||
|  | type SELinuxStrategy string | ||||||
|  |  | ||||||
|  | const ( | ||||||
|  | 	// container must have SELinux labels of X applied. | ||||||
|  | 	SELinuxStrategyMustRunAs SELinuxStrategy = "MustRunAs" | ||||||
|  | 	// container may make requests for any SELinux context labels. | ||||||
|  | 	SELinuxStrategyRunAsAny SELinuxStrategy = "RunAsAny" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // Run A sUser Strategy Options defines the strategy type and any options used to create the strategy. | ||||||
|  | type RunAsUserStrategyOptions struct { | ||||||
|  | 	// Rule is the strategy that will dictate the allowable RunAsUser values that may be set. | ||||||
|  | 	Rule RunAsUserStrategy `json:"rule" protobuf:"bytes,1,opt,name=rule,casttype=RunAsUserStrategy"` | ||||||
|  | 	// Ranges are the allowed ranges of uids that may be used. | ||||||
|  | 	// +optional | ||||||
|  | 	Ranges []IDRange `json:"ranges,omitempty" protobuf:"bytes,2,rep,name=ranges"` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // ID Range provides a min/max of an allowed range of IDs. | ||||||
|  | type IDRange struct { | ||||||
|  | 	// Min is the start of the range, inclusive. | ||||||
|  | 	Min int64 `json:"min" protobuf:"varint,1,opt,name=min"` | ||||||
|  | 	// Max is the end of the range, inclusive. | ||||||
|  | 	Max int64 `json:"max" protobuf:"varint,2,opt,name=max"` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // RunAsUserStrategy denotes strategy types for generating RunAsUser values for a | ||||||
|  | // Security Context. | ||||||
|  | type RunAsUserStrategy string | ||||||
|  |  | ||||||
|  | const ( | ||||||
|  | 	// container must run as a particular uid. | ||||||
|  | 	RunAsUserStrategyMustRunAs RunAsUserStrategy = "MustRunAs" | ||||||
|  | 	// container must run as a non-root uid | ||||||
|  | 	RunAsUserStrategyMustRunAsNonRoot RunAsUserStrategy = "MustRunAsNonRoot" | ||||||
|  | 	// container may make requests for any uid. | ||||||
|  | 	RunAsUserStrategyRunAsAny RunAsUserStrategy = "RunAsAny" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // FSGroupStrategyOptions defines the strategy type and options used to create the strategy. | ||||||
|  | type FSGroupStrategyOptions struct { | ||||||
|  | 	// Rule is the strategy that will dictate what FSGroup is used in the SecurityContext. | ||||||
|  | 	// +optional | ||||||
|  | 	Rule FSGroupStrategyType `json:"rule,omitempty" protobuf:"bytes,1,opt,name=rule,casttype=FSGroupStrategyType"` | ||||||
|  | 	// Ranges are the allowed ranges of fs groups.  If you would like to force a single | ||||||
|  | 	// fs group then supply a single range with the same start and end. | ||||||
|  | 	// +optional | ||||||
|  | 	Ranges []IDRange `json:"ranges,omitempty" protobuf:"bytes,2,rep,name=ranges"` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // FSGroupStrategyType denotes strategy types for generating FSGroup values for a | ||||||
|  | // SecurityContext | ||||||
|  | type FSGroupStrategyType string | ||||||
|  |  | ||||||
|  | const ( | ||||||
|  | 	// container must have FSGroup of X applied. | ||||||
|  | 	FSGroupStrategyMustRunAs FSGroupStrategyType = "MustRunAs" | ||||||
|  | 	// container may make requests for any FSGroup labels. | ||||||
|  | 	FSGroupStrategyRunAsAny FSGroupStrategyType = "RunAsAny" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // SupplementalGroupsStrategyOptions defines the strategy type and options used to create the strategy. | ||||||
|  | type SupplementalGroupsStrategyOptions struct { | ||||||
|  | 	// Rule is the strategy that will dictate what supplemental groups is used in the SecurityContext. | ||||||
|  | 	// +optional | ||||||
|  | 	Rule SupplementalGroupsStrategyType `json:"rule,omitempty" protobuf:"bytes,1,opt,name=rule,casttype=SupplementalGroupsStrategyType"` | ||||||
|  | 	// Ranges are the allowed ranges of supplemental groups.  If you would like to force a single | ||||||
|  | 	// supplemental group then supply a single range with the same start and end. | ||||||
|  | 	// +optional | ||||||
|  | 	Ranges []IDRange `json:"ranges,omitempty" protobuf:"bytes,2,rep,name=ranges"` | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // SupplementalGroupsStrategyType denotes strategy types for determining valid supplemental | ||||||
|  | // groups for a SecurityContext. | ||||||
|  | type SupplementalGroupsStrategyType string | ||||||
|  |  | ||||||
|  | const ( | ||||||
|  | 	// container must run as a particular gid. | ||||||
|  | 	SupplementalGroupsStrategyMustRunAs SupplementalGroupsStrategyType = "MustRunAs" | ||||||
|  | 	// container may make requests for any gid. | ||||||
|  | 	SupplementalGroupsStrategyRunAsAny SupplementalGroupsStrategyType = "RunAsAny" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||||||
|  |  | ||||||
|  | // Pod Security Policy List is a list of PodSecurityPolicy objects. | ||||||
|  | type PodSecurityPolicyList struct { | ||||||
|  | 	metav1.TypeMeta `json:",inline"` | ||||||
|  | 	// Standard list metadata. | ||||||
|  | 	// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||||||
|  | 	// +optional | ||||||
|  | 	metav1.ListMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"` | ||||||
|  |  | ||||||
|  | 	// Items is a list of schema objects. | ||||||
|  | 	Items []PodSecurityPolicy `json:"items" protobuf:"bytes,2,rep,name=items"` | ||||||
|  | } | ||||||
|   | |||||||
| @@ -27,6 +27,24 @@ package v1beta1 | |||||||
| // Those methods can be generated by using hack/update-generated-swagger-docs.sh | // Those methods can be generated by using hack/update-generated-swagger-docs.sh | ||||||
|  |  | ||||||
| // AUTO-GENERATED FUNCTIONS START HERE | // AUTO-GENERATED FUNCTIONS START HERE | ||||||
|  | var map_AllowedFlexVolume = map[string]string{ | ||||||
|  | 	"":       "AllowedFlexVolume represents a single Flexvolume that is allowed to be used.", | ||||||
|  | 	"driver": "Driver is the name of the Flexvolume driver.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (AllowedFlexVolume) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_AllowedFlexVolume | ||||||
|  | } | ||||||
|  |  | ||||||
|  | var map_AllowedHostPath = map[string]string{ | ||||||
|  | 	"":           "defines the host volume conditions that will be enabled by a policy for pods to use. It requires the path prefix to be defined.", | ||||||
|  | 	"pathPrefix": "is the path prefix that the host volume must match. It does not support `*`. Trailing slashes are trimmed when validating the path prefix with a host path.\n\nExamples: `/foo` would allow `/foo`, `/foo/` and `/foo/bar` `/foo` would not allow `/food` or `/etc/foo`", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (AllowedHostPath) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_AllowedHostPath | ||||||
|  | } | ||||||
|  |  | ||||||
| var map_Eviction = map[string]string{ | var map_Eviction = map[string]string{ | ||||||
| 	"":              "Eviction evicts a pod from its node subject to certain policies and safety constraints. This is a subresource of Pod.  A request to cause such an eviction is created by POSTing to .../pods/<pod name>/evictions.", | 	"":              "Eviction evicts a pod from its node subject to certain policies and safety constraints. This is a subresource of Pod.  A request to cause such an eviction is created by POSTing to .../pods/<pod name>/evictions.", | ||||||
| 	"metadata":      "ObjectMeta describes the pod that is being evicted.", | 	"metadata":      "ObjectMeta describes the pod that is being evicted.", | ||||||
| @@ -37,6 +55,36 @@ func (Eviction) SwaggerDoc() map[string]string { | |||||||
| 	return map_Eviction | 	return map_Eviction | ||||||
| } | } | ||||||
|  |  | ||||||
|  | var map_FSGroupStrategyOptions = map[string]string{ | ||||||
|  | 	"":       "FSGroupStrategyOptions defines the strategy type and options used to create the strategy.", | ||||||
|  | 	"rule":   "Rule is the strategy that will dictate what FSGroup is used in the SecurityContext.", | ||||||
|  | 	"ranges": "Ranges are the allowed ranges of fs groups.  If you would like to force a single fs group then supply a single range with the same start and end.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (FSGroupStrategyOptions) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_FSGroupStrategyOptions | ||||||
|  | } | ||||||
|  |  | ||||||
|  | var map_HostPortRange = map[string]string{ | ||||||
|  | 	"":    "Host Port Range defines a range of host ports that will be enabled by a policy for pods to use.  It requires both the start and end to be defined.", | ||||||
|  | 	"min": "min is the start of the range, inclusive.", | ||||||
|  | 	"max": "max is the end of the range, inclusive.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (HostPortRange) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_HostPortRange | ||||||
|  | } | ||||||
|  |  | ||||||
|  | var map_IDRange = map[string]string{ | ||||||
|  | 	"":    "ID Range provides a min/max of an allowed range of IDs.", | ||||||
|  | 	"min": "Min is the start of the range, inclusive.", | ||||||
|  | 	"max": "Max is the end of the range, inclusive.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (IDRange) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_IDRange | ||||||
|  | } | ||||||
|  |  | ||||||
| var map_PodDisruptionBudget = map[string]string{ | var map_PodDisruptionBudget = map[string]string{ | ||||||
| 	"":       "PodDisruptionBudget is an object to define the max disruption that can be caused to a collection of pods", | 	"":       "PodDisruptionBudget is an object to define the max disruption that can be caused to a collection of pods", | ||||||
| 	"spec":   "Specification of the desired behavior of the PodDisruptionBudget.", | 	"spec":   "Specification of the desired behavior of the PodDisruptionBudget.", | ||||||
| @@ -80,4 +128,80 @@ func (PodDisruptionBudgetStatus) SwaggerDoc() map[string]string { | |||||||
| 	return map_PodDisruptionBudgetStatus | 	return map_PodDisruptionBudgetStatus | ||||||
| } | } | ||||||
|  |  | ||||||
|  | var map_PodSecurityPolicy = map[string]string{ | ||||||
|  | 	"":         "Pod Security Policy governs the ability to make requests that affect the Security Context that will be applied to a pod and container.", | ||||||
|  | 	"metadata": "Standard object's metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||||
|  | 	"spec":     "spec defines the policy enforced.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (PodSecurityPolicy) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_PodSecurityPolicy | ||||||
|  | } | ||||||
|  |  | ||||||
|  | var map_PodSecurityPolicyList = map[string]string{ | ||||||
|  | 	"":         "Pod Security Policy List is a list of PodSecurityPolicy objects.", | ||||||
|  | 	"metadata": "Standard list metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata", | ||||||
|  | 	"items":    "Items is a list of schema objects.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (PodSecurityPolicyList) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_PodSecurityPolicyList | ||||||
|  | } | ||||||
|  |  | ||||||
|  | var map_PodSecurityPolicySpec = map[string]string{ | ||||||
|  | 	"":                                "Pod Security Policy Spec defines the policy enforced.", | ||||||
|  | 	"privileged":                      "privileged determines if a pod can request to be run as privileged.", | ||||||
|  | 	"defaultAddCapabilities":          "DefaultAddCapabilities is the default set of capabilities that will be added to the container unless the pod spec specifically drops the capability.  You may not list a capability in both DefaultAddCapabilities and RequiredDropCapabilities. Capabilities added here are implicitly allowed, and need not be included in the AllowedCapabilities list.", | ||||||
|  | 	"requiredDropCapabilities":        "RequiredDropCapabilities are the capabilities that will be dropped from the container.  These are required to be dropped and cannot be added.", | ||||||
|  | 	"allowedCapabilities":             "AllowedCapabilities is a list of capabilities that can be requested to add to the container. Capabilities in this field may be added at the pod author's discretion. You must not list a capability in both AllowedCapabilities and RequiredDropCapabilities.", | ||||||
|  | 	"volumes":                         "volumes is a white list of allowed volume plugins.  Empty indicates that all plugins may be used.", | ||||||
|  | 	"hostNetwork":                     "hostNetwork determines if the policy allows the use of HostNetwork in the pod spec.", | ||||||
|  | 	"hostPorts":                       "hostPorts determines which host port ranges are allowed to be exposed.", | ||||||
|  | 	"hostPID":                         "hostPID determines if the policy allows the use of HostPID in the pod spec.", | ||||||
|  | 	"hostIPC":                         "hostIPC determines if the policy allows the use of HostIPC in the pod spec.", | ||||||
|  | 	"seLinux":                         "seLinux is the strategy that will dictate the allowable labels that may be set.", | ||||||
|  | 	"runAsUser":                       "runAsUser is the strategy that will dictate the allowable RunAsUser values that may be set.", | ||||||
|  | 	"supplementalGroups":              "SupplementalGroups is the strategy that will dictate what supplemental groups are used by the SecurityContext.", | ||||||
|  | 	"fsGroup":                         "FSGroup is the strategy that will dictate what fs group is used by the SecurityContext.", | ||||||
|  | 	"readOnlyRootFilesystem":          "ReadOnlyRootFilesystem when set to true will force containers to run with a read only root file system.  If the container specifically requests to run with a non-read only root file system the PSP should deny the pod. If set to false the container may run with a read only root file system if it wishes but it will not be forced to.", | ||||||
|  | 	"defaultAllowPrivilegeEscalation": "DefaultAllowPrivilegeEscalation controls the default setting for whether a process can gain more privileges than its parent process.", | ||||||
|  | 	"allowPrivilegeEscalation":        "AllowPrivilegeEscalation determines if a pod can request to allow privilege escalation. If unspecified, defaults to true.", | ||||||
|  | 	"allowedHostPaths":                "is a white list of allowed host paths. Empty indicates that all host paths may be used.", | ||||||
|  | 	"allowedFlexVolumes":              "AllowedFlexVolumes is a whitelist of allowed Flexvolumes.  Empty or nil indicates that all Flexvolumes may be used.  This parameter is effective only when the usage of the Flexvolumes is allowed in the \"Volumes\" field.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (PodSecurityPolicySpec) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_PodSecurityPolicySpec | ||||||
|  | } | ||||||
|  |  | ||||||
|  | var map_RunAsUserStrategyOptions = map[string]string{ | ||||||
|  | 	"":       "Run A sUser Strategy Options defines the strategy type and any options used to create the strategy.", | ||||||
|  | 	"rule":   "Rule is the strategy that will dictate the allowable RunAsUser values that may be set.", | ||||||
|  | 	"ranges": "Ranges are the allowed ranges of uids that may be used.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (RunAsUserStrategyOptions) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_RunAsUserStrategyOptions | ||||||
|  | } | ||||||
|  |  | ||||||
|  | var map_SELinuxStrategyOptions = map[string]string{ | ||||||
|  | 	"":               "SELinux  Strategy Options defines the strategy type and any options used to create the strategy.", | ||||||
|  | 	"rule":           "type is the strategy that will dictate the allowable labels that may be set.", | ||||||
|  | 	"seLinuxOptions": "seLinuxOptions required to run as; required for MustRunAs More info: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (SELinuxStrategyOptions) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_SELinuxStrategyOptions | ||||||
|  | } | ||||||
|  |  | ||||||
|  | var map_SupplementalGroupsStrategyOptions = map[string]string{ | ||||||
|  | 	"":       "SupplementalGroupsStrategyOptions defines the strategy type and options used to create the strategy.", | ||||||
|  | 	"rule":   "Rule is the strategy that will dictate what supplemental groups is used in the SecurityContext.", | ||||||
|  | 	"ranges": "Ranges are the allowed ranges of supplemental groups.  If you would like to force a single supplemental group then supply a single range with the same start and end.", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (SupplementalGroupsStrategyOptions) SwaggerDoc() map[string]string { | ||||||
|  | 	return map_SupplementalGroupsStrategyOptions | ||||||
|  | } | ||||||
|  |  | ||||||
| // AUTO-GENERATED FUNCTIONS END HERE | // AUTO-GENERATED FUNCTIONS END HERE | ||||||
|   | |||||||
| @@ -21,11 +21,44 @@ limitations under the License. | |||||||
| package v1beta1 | package v1beta1 | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
|  | 	core_v1 "k8s.io/api/core/v1" | ||||||
| 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||||
| 	runtime "k8s.io/apimachinery/pkg/runtime" | 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||||
| 	intstr "k8s.io/apimachinery/pkg/util/intstr" | 	intstr "k8s.io/apimachinery/pkg/util/intstr" | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
|  | func (in *AllowedFlexVolume) DeepCopyInto(out *AllowedFlexVolume) { | ||||||
|  | 	*out = *in | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new AllowedFlexVolume. | ||||||
|  | func (in *AllowedFlexVolume) DeepCopy() *AllowedFlexVolume { | ||||||
|  | 	if in == nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	out := new(AllowedFlexVolume) | ||||||
|  | 	in.DeepCopyInto(out) | ||||||
|  | 	return out | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
|  | func (in *AllowedHostPath) DeepCopyInto(out *AllowedHostPath) { | ||||||
|  | 	*out = *in | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new AllowedHostPath. | ||||||
|  | func (in *AllowedHostPath) DeepCopy() *AllowedHostPath { | ||||||
|  | 	if in == nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	out := new(AllowedHostPath) | ||||||
|  | 	in.DeepCopyInto(out) | ||||||
|  | 	return out | ||||||
|  | } | ||||||
|  |  | ||||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
| func (in *Eviction) DeepCopyInto(out *Eviction) { | func (in *Eviction) DeepCopyInto(out *Eviction) { | ||||||
| 	*out = *in | 	*out = *in | ||||||
| @@ -62,6 +95,59 @@ func (in *Eviction) DeepCopyObject() runtime.Object { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
|  | func (in *FSGroupStrategyOptions) DeepCopyInto(out *FSGroupStrategyOptions) { | ||||||
|  | 	*out = *in | ||||||
|  | 	if in.Ranges != nil { | ||||||
|  | 		in, out := &in.Ranges, &out.Ranges | ||||||
|  | 		*out = make([]IDRange, len(*in)) | ||||||
|  | 		copy(*out, *in) | ||||||
|  | 	} | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new FSGroupStrategyOptions. | ||||||
|  | func (in *FSGroupStrategyOptions) DeepCopy() *FSGroupStrategyOptions { | ||||||
|  | 	if in == nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	out := new(FSGroupStrategyOptions) | ||||||
|  | 	in.DeepCopyInto(out) | ||||||
|  | 	return out | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
|  | func (in *HostPortRange) DeepCopyInto(out *HostPortRange) { | ||||||
|  | 	*out = *in | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new HostPortRange. | ||||||
|  | func (in *HostPortRange) DeepCopy() *HostPortRange { | ||||||
|  | 	if in == nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	out := new(HostPortRange) | ||||||
|  | 	in.DeepCopyInto(out) | ||||||
|  | 	return out | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
|  | func (in *IDRange) DeepCopyInto(out *IDRange) { | ||||||
|  | 	*out = *in | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new IDRange. | ||||||
|  | func (in *IDRange) DeepCopy() *IDRange { | ||||||
|  | 	if in == nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	out := new(IDRange) | ||||||
|  | 	in.DeepCopyInto(out) | ||||||
|  | 	return out | ||||||
|  | } | ||||||
|  |  | ||||||
| // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
| func (in *PodDisruptionBudget) DeepCopyInto(out *PodDisruptionBudget) { | func (in *PodDisruptionBudget) DeepCopyInto(out *PodDisruptionBudget) { | ||||||
| 	*out = *in | 	*out = *in | ||||||
| @@ -190,3 +276,205 @@ func (in *PodDisruptionBudgetStatus) DeepCopy() *PodDisruptionBudgetStatus { | |||||||
| 	in.DeepCopyInto(out) | 	in.DeepCopyInto(out) | ||||||
| 	return out | 	return out | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
|  | func (in *PodSecurityPolicy) DeepCopyInto(out *PodSecurityPolicy) { | ||||||
|  | 	*out = *in | ||||||
|  | 	out.TypeMeta = in.TypeMeta | ||||||
|  | 	in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) | ||||||
|  | 	in.Spec.DeepCopyInto(&out.Spec) | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodSecurityPolicy. | ||||||
|  | func (in *PodSecurityPolicy) DeepCopy() *PodSecurityPolicy { | ||||||
|  | 	if in == nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	out := new(PodSecurityPolicy) | ||||||
|  | 	in.DeepCopyInto(out) | ||||||
|  | 	return out | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. | ||||||
|  | func (in *PodSecurityPolicy) DeepCopyObject() runtime.Object { | ||||||
|  | 	if c := in.DeepCopy(); c != nil { | ||||||
|  | 		return c | ||||||
|  | 	} else { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // 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([]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 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
|  | func (in *PodSecurityPolicySpec) DeepCopyInto(out *PodSecurityPolicySpec) { | ||||||
|  | 	*out = *in | ||||||
|  | 	if in.DefaultAddCapabilities != nil { | ||||||
|  | 		in, out := &in.DefaultAddCapabilities, &out.DefaultAddCapabilities | ||||||
|  | 		*out = make([]core_v1.Capability, len(*in)) | ||||||
|  | 		copy(*out, *in) | ||||||
|  | 	} | ||||||
|  | 	if in.RequiredDropCapabilities != nil { | ||||||
|  | 		in, out := &in.RequiredDropCapabilities, &out.RequiredDropCapabilities | ||||||
|  | 		*out = make([]core_v1.Capability, len(*in)) | ||||||
|  | 		copy(*out, *in) | ||||||
|  | 	} | ||||||
|  | 	if in.AllowedCapabilities != nil { | ||||||
|  | 		in, out := &in.AllowedCapabilities, &out.AllowedCapabilities | ||||||
|  | 		*out = make([]core_v1.Capability, len(*in)) | ||||||
|  | 		copy(*out, *in) | ||||||
|  | 	} | ||||||
|  | 	if in.Volumes != nil { | ||||||
|  | 		in, out := &in.Volumes, &out.Volumes | ||||||
|  | 		*out = make([]FSType, len(*in)) | ||||||
|  | 		copy(*out, *in) | ||||||
|  | 	} | ||||||
|  | 	if in.HostPorts != nil { | ||||||
|  | 		in, out := &in.HostPorts, &out.HostPorts | ||||||
|  | 		*out = make([]HostPortRange, len(*in)) | ||||||
|  | 		copy(*out, *in) | ||||||
|  | 	} | ||||||
|  | 	in.SELinux.DeepCopyInto(&out.SELinux) | ||||||
|  | 	in.RunAsUser.DeepCopyInto(&out.RunAsUser) | ||||||
|  | 	in.SupplementalGroups.DeepCopyInto(&out.SupplementalGroups) | ||||||
|  | 	in.FSGroup.DeepCopyInto(&out.FSGroup) | ||||||
|  | 	if in.DefaultAllowPrivilegeEscalation != nil { | ||||||
|  | 		in, out := &in.DefaultAllowPrivilegeEscalation, &out.DefaultAllowPrivilegeEscalation | ||||||
|  | 		if *in == nil { | ||||||
|  | 			*out = nil | ||||||
|  | 		} else { | ||||||
|  | 			*out = new(bool) | ||||||
|  | 			**out = **in | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if in.AllowPrivilegeEscalation != nil { | ||||||
|  | 		in, out := &in.AllowPrivilegeEscalation, &out.AllowPrivilegeEscalation | ||||||
|  | 		if *in == nil { | ||||||
|  | 			*out = nil | ||||||
|  | 		} else { | ||||||
|  | 			*out = new(bool) | ||||||
|  | 			**out = **in | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if in.AllowedHostPaths != nil { | ||||||
|  | 		in, out := &in.AllowedHostPaths, &out.AllowedHostPaths | ||||||
|  | 		*out = make([]AllowedHostPath, len(*in)) | ||||||
|  | 		copy(*out, *in) | ||||||
|  | 	} | ||||||
|  | 	if in.AllowedFlexVolumes != nil { | ||||||
|  | 		in, out := &in.AllowedFlexVolumes, &out.AllowedFlexVolumes | ||||||
|  | 		*out = make([]AllowedFlexVolume, len(*in)) | ||||||
|  | 		copy(*out, *in) | ||||||
|  | 	} | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PodSecurityPolicySpec. | ||||||
|  | func (in *PodSecurityPolicySpec) DeepCopy() *PodSecurityPolicySpec { | ||||||
|  | 	if in == nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	out := new(PodSecurityPolicySpec) | ||||||
|  | 	in.DeepCopyInto(out) | ||||||
|  | 	return out | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
|  | func (in *RunAsUserStrategyOptions) DeepCopyInto(out *RunAsUserStrategyOptions) { | ||||||
|  | 	*out = *in | ||||||
|  | 	if in.Ranges != nil { | ||||||
|  | 		in, out := &in.Ranges, &out.Ranges | ||||||
|  | 		*out = make([]IDRange, len(*in)) | ||||||
|  | 		copy(*out, *in) | ||||||
|  | 	} | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new RunAsUserStrategyOptions. | ||||||
|  | func (in *RunAsUserStrategyOptions) DeepCopy() *RunAsUserStrategyOptions { | ||||||
|  | 	if in == nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	out := new(RunAsUserStrategyOptions) | ||||||
|  | 	in.DeepCopyInto(out) | ||||||
|  | 	return out | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
|  | func (in *SELinuxStrategyOptions) DeepCopyInto(out *SELinuxStrategyOptions) { | ||||||
|  | 	*out = *in | ||||||
|  | 	if in.SELinuxOptions != nil { | ||||||
|  | 		in, out := &in.SELinuxOptions, &out.SELinuxOptions | ||||||
|  | 		if *in == nil { | ||||||
|  | 			*out = nil | ||||||
|  | 		} else { | ||||||
|  | 			*out = new(core_v1.SELinuxOptions) | ||||||
|  | 			**out = **in | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SELinuxStrategyOptions. | ||||||
|  | func (in *SELinuxStrategyOptions) DeepCopy() *SELinuxStrategyOptions { | ||||||
|  | 	if in == nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	out := new(SELinuxStrategyOptions) | ||||||
|  | 	in.DeepCopyInto(out) | ||||||
|  | 	return out | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. | ||||||
|  | func (in *SupplementalGroupsStrategyOptions) DeepCopyInto(out *SupplementalGroupsStrategyOptions) { | ||||||
|  | 	*out = *in | ||||||
|  | 	if in.Ranges != nil { | ||||||
|  | 		in, out := &in.Ranges, &out.Ranges | ||||||
|  | 		*out = make([]IDRange, len(*in)) | ||||||
|  | 		copy(*out, *in) | ||||||
|  | 	} | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new SupplementalGroupsStrategyOptions. | ||||||
|  | func (in *SupplementalGroupsStrategyOptions) DeepCopy() *SupplementalGroupsStrategyOptions { | ||||||
|  | 	if in == nil { | ||||||
|  | 		return nil | ||||||
|  | 	} | ||||||
|  | 	out := new(SupplementalGroupsStrategyOptions) | ||||||
|  | 	in.DeepCopyInto(out) | ||||||
|  | 	return out | ||||||
|  | } | ||||||
|   | |||||||
| @@ -198,6 +198,8 @@ func (f *sharedInformerFactory) ForResource(resource schema.GroupVersionResource | |||||||
| 		// Group=policy, Version=v1beta1 | 		// Group=policy, Version=v1beta1 | ||||||
| 	case policy_v1beta1.SchemeGroupVersion.WithResource("poddisruptionbudgets"): | 	case policy_v1beta1.SchemeGroupVersion.WithResource("poddisruptionbudgets"): | ||||||
| 		return &genericInformer{resource: resource.GroupResource(), informer: f.Policy().V1beta1().PodDisruptionBudgets().Informer()}, nil | 		return &genericInformer{resource: resource.GroupResource(), informer: f.Policy().V1beta1().PodDisruptionBudgets().Informer()}, nil | ||||||
|  | 	case policy_v1beta1.SchemeGroupVersion.WithResource("podsecuritypolicies"): | ||||||
|  | 		return &genericInformer{resource: resource.GroupResource(), informer: f.Policy().V1beta1().PodSecurityPolicies().Informer()}, nil | ||||||
|  |  | ||||||
| 		// Group=rbac.authorization.k8s.io, Version=v1 | 		// Group=rbac.authorization.k8s.io, Version=v1 | ||||||
| 	case rbac_v1.SchemeGroupVersion.WithResource("clusterroles"): | 	case rbac_v1.SchemeGroupVersion.WithResource("clusterroles"): | ||||||
|   | |||||||
| @@ -10,6 +10,7 @@ go_library( | |||||||
|     srcs = [ |     srcs = [ | ||||||
|         "interface.go", |         "interface.go", | ||||||
|         "poddisruptionbudget.go", |         "poddisruptionbudget.go", | ||||||
|  |         "podsecuritypolicy.go", | ||||||
|     ], |     ], | ||||||
|     importpath = "k8s.io/client-go/informers/policy/v1beta1", |     importpath = "k8s.io/client-go/informers/policy/v1beta1", | ||||||
|     deps = [ |     deps = [ | ||||||
|   | |||||||
| @@ -26,6 +26,8 @@ import ( | |||||||
| type Interface interface { | type Interface interface { | ||||||
| 	// PodDisruptionBudgets returns a PodDisruptionBudgetInformer. | 	// PodDisruptionBudgets returns a PodDisruptionBudgetInformer. | ||||||
| 	PodDisruptionBudgets() PodDisruptionBudgetInformer | 	PodDisruptionBudgets() PodDisruptionBudgetInformer | ||||||
|  | 	// PodSecurityPolicies returns a PodSecurityPolicyInformer. | ||||||
|  | 	PodSecurityPolicies() PodSecurityPolicyInformer | ||||||
| } | } | ||||||
|  |  | ||||||
| type version struct { | type version struct { | ||||||
| @@ -43,3 +45,8 @@ func New(f internalinterfaces.SharedInformerFactory, namespace string, tweakList | |||||||
| func (v *version) PodDisruptionBudgets() PodDisruptionBudgetInformer { | func (v *version) PodDisruptionBudgets() PodDisruptionBudgetInformer { | ||||||
| 	return &podDisruptionBudgetInformer{factory: v.factory, namespace: v.namespace, tweakListOptions: v.tweakListOptions} | 	return &podDisruptionBudgetInformer{factory: v.factory, namespace: v.namespace, tweakListOptions: v.tweakListOptions} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // PodSecurityPolicies returns a PodSecurityPolicyInformer. | ||||||
|  | func (v *version) PodSecurityPolicies() PodSecurityPolicyInformer { | ||||||
|  | 	return &podSecurityPolicyInformer{factory: v.factory, tweakListOptions: v.tweakListOptions} | ||||||
|  | } | ||||||
|   | |||||||
| @@ -0,0 +1,88 @@ | |||||||
|  | /* | ||||||
|  | Copyright 2018 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 automatically generated by informer-gen | ||||||
|  |  | ||||||
|  | package v1beta1 | ||||||
|  |  | ||||||
|  | import ( | ||||||
|  | 	time "time" | ||||||
|  |  | ||||||
|  | 	policy_v1beta1 "k8s.io/api/policy/v1beta1" | ||||||
|  | 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||||
|  | 	runtime "k8s.io/apimachinery/pkg/runtime" | ||||||
|  | 	watch "k8s.io/apimachinery/pkg/watch" | ||||||
|  | 	internalinterfaces "k8s.io/client-go/informers/internalinterfaces" | ||||||
|  | 	kubernetes "k8s.io/client-go/kubernetes" | ||||||
|  | 	v1beta1 "k8s.io/client-go/listers/policy/v1beta1" | ||||||
|  | 	cache "k8s.io/client-go/tools/cache" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // PodSecurityPolicyInformer provides access to a shared informer and lister for | ||||||
|  | // PodSecurityPolicies. | ||||||
|  | type PodSecurityPolicyInformer interface { | ||||||
|  | 	Informer() cache.SharedIndexInformer | ||||||
|  | 	Lister() v1beta1.PodSecurityPolicyLister | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type podSecurityPolicyInformer struct { | ||||||
|  | 	factory          internalinterfaces.SharedInformerFactory | ||||||
|  | 	tweakListOptions internalinterfaces.TweakListOptionsFunc | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // NewPodSecurityPolicyInformer constructs a new informer for PodSecurityPolicy 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 NewPodSecurityPolicyInformer(client kubernetes.Interface, resyncPeriod time.Duration, indexers cache.Indexers) cache.SharedIndexInformer { | ||||||
|  | 	return NewFilteredPodSecurityPolicyInformer(client, resyncPeriod, indexers, nil) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // NewFilteredPodSecurityPolicyInformer constructs a new informer for PodSecurityPolicy 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 NewFilteredPodSecurityPolicyInformer(client kubernetes.Interface, resyncPeriod time.Duration, indexers cache.Indexers, tweakListOptions internalinterfaces.TweakListOptionsFunc) cache.SharedIndexInformer { | ||||||
|  | 	return cache.NewSharedIndexInformer( | ||||||
|  | 		&cache.ListWatch{ | ||||||
|  | 			ListFunc: func(options v1.ListOptions) (runtime.Object, error) { | ||||||
|  | 				if tweakListOptions != nil { | ||||||
|  | 					tweakListOptions(&options) | ||||||
|  | 				} | ||||||
|  | 				return client.PolicyV1beta1().PodSecurityPolicies().List(options) | ||||||
|  | 			}, | ||||||
|  | 			WatchFunc: func(options v1.ListOptions) (watch.Interface, error) { | ||||||
|  | 				if tweakListOptions != nil { | ||||||
|  | 					tweakListOptions(&options) | ||||||
|  | 				} | ||||||
|  | 				return client.PolicyV1beta1().PodSecurityPolicies().Watch(options) | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		&policy_v1beta1.PodSecurityPolicy{}, | ||||||
|  | 		resyncPeriod, | ||||||
|  | 		indexers, | ||||||
|  | 	) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (f *podSecurityPolicyInformer) defaultInformer(client kubernetes.Interface, resyncPeriod time.Duration) cache.SharedIndexInformer { | ||||||
|  | 	return NewFilteredPodSecurityPolicyInformer(client, resyncPeriod, cache.Indexers{cache.NamespaceIndex: cache.MetaNamespaceIndexFunc}, f.tweakListOptions) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (f *podSecurityPolicyInformer) Informer() cache.SharedIndexInformer { | ||||||
|  | 	return f.factory.InformerFor(&policy_v1beta1.PodSecurityPolicy{}, f.defaultInformer) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (f *podSecurityPolicyInformer) Lister() v1beta1.PodSecurityPolicyLister { | ||||||
|  | 	return v1beta1.NewPodSecurityPolicyLister(f.Informer().GetIndexer()) | ||||||
|  | } | ||||||
| @@ -13,6 +13,7 @@ go_library( | |||||||
|         "eviction_expansion.go", |         "eviction_expansion.go", | ||||||
|         "generated_expansion.go", |         "generated_expansion.go", | ||||||
|         "poddisruptionbudget.go", |         "poddisruptionbudget.go", | ||||||
|  |         "podsecuritypolicy.go", | ||||||
|         "policy_client.go", |         "policy_client.go", | ||||||
|     ], |     ], | ||||||
|     importpath = "k8s.io/client-go/kubernetes/typed/policy/v1beta1", |     importpath = "k8s.io/client-go/kubernetes/typed/policy/v1beta1", | ||||||
|   | |||||||
| @@ -12,6 +12,7 @@ go_library( | |||||||
|         "fake_eviction.go", |         "fake_eviction.go", | ||||||
|         "fake_eviction_expansion.go", |         "fake_eviction_expansion.go", | ||||||
|         "fake_poddisruptionbudget.go", |         "fake_poddisruptionbudget.go", | ||||||
|  |         "fake_podsecuritypolicy.go", | ||||||
|         "fake_policy_client.go", |         "fake_policy_client.go", | ||||||
|     ], |     ], | ||||||
|     importpath = "k8s.io/client-go/kubernetes/typed/policy/v1beta1/fake", |     importpath = "k8s.io/client-go/kubernetes/typed/policy/v1beta1/fake", | ||||||
|   | |||||||
| @@ -0,0 +1,118 @@ | |||||||
|  | /* | ||||||
|  | Copyright 2018 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 fake | ||||||
|  |  | ||||||
|  | import ( | ||||||
|  | 	v1beta1 "k8s.io/api/policy/v1beta1" | ||||||
|  | 	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" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // FakePodSecurityPolicies implements PodSecurityPolicyInterface | ||||||
|  | type FakePodSecurityPolicies struct { | ||||||
|  | 	Fake *FakePolicyV1beta1 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | var podsecuritypoliciesResource = schema.GroupVersionResource{Group: "policy", Version: "v1beta1", Resource: "podsecuritypolicies"} | ||||||
|  |  | ||||||
|  | var podsecuritypoliciesKind = schema.GroupVersionKind{Group: "policy", Version: "v1beta1", Kind: "PodSecurityPolicy"} | ||||||
|  |  | ||||||
|  | // Get takes name of the podSecurityPolicy, and returns the corresponding podSecurityPolicy object, and an error if there is any. | ||||||
|  | func (c *FakePodSecurityPolicies) Get(name string, options v1.GetOptions) (result *v1beta1.PodSecurityPolicy, err error) { | ||||||
|  | 	obj, err := c.Fake. | ||||||
|  | 		Invokes(testing.NewRootGetAction(podsecuritypoliciesResource, name), &v1beta1.PodSecurityPolicy{}) | ||||||
|  | 	if obj == nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	return obj.(*v1beta1.PodSecurityPolicy), err | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // List takes label and field selectors, and returns the list of PodSecurityPolicies that match those selectors. | ||||||
|  | func (c *FakePodSecurityPolicies) List(opts v1.ListOptions) (result *v1beta1.PodSecurityPolicyList, err error) { | ||||||
|  | 	obj, err := c.Fake. | ||||||
|  | 		Invokes(testing.NewRootListAction(podsecuritypoliciesResource, podsecuritypoliciesKind, opts), &v1beta1.PodSecurityPolicyList{}) | ||||||
|  | 	if obj == nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	label, _, _ := testing.ExtractFromListOptions(opts) | ||||||
|  | 	if label == nil { | ||||||
|  | 		label = labels.Everything() | ||||||
|  | 	} | ||||||
|  | 	list := &v1beta1.PodSecurityPolicyList{} | ||||||
|  | 	for _, item := range obj.(*v1beta1.PodSecurityPolicyList).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 podSecurityPolicies. | ||||||
|  | func (c *FakePodSecurityPolicies) Watch(opts v1.ListOptions) (watch.Interface, error) { | ||||||
|  | 	return c.Fake. | ||||||
|  | 		InvokesWatch(testing.NewRootWatchAction(podsecuritypoliciesResource, opts)) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Create takes the representation of a podSecurityPolicy and creates it.  Returns the server's representation of the podSecurityPolicy, and an error, if there is any. | ||||||
|  | func (c *FakePodSecurityPolicies) Create(podSecurityPolicy *v1beta1.PodSecurityPolicy) (result *v1beta1.PodSecurityPolicy, err error) { | ||||||
|  | 	obj, err := c.Fake. | ||||||
|  | 		Invokes(testing.NewRootCreateAction(podsecuritypoliciesResource, podSecurityPolicy), &v1beta1.PodSecurityPolicy{}) | ||||||
|  | 	if obj == nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	return obj.(*v1beta1.PodSecurityPolicy), err | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Update takes the representation of a podSecurityPolicy and updates it. Returns the server's representation of the podSecurityPolicy, and an error, if there is any. | ||||||
|  | func (c *FakePodSecurityPolicies) Update(podSecurityPolicy *v1beta1.PodSecurityPolicy) (result *v1beta1.PodSecurityPolicy, err error) { | ||||||
|  | 	obj, err := c.Fake. | ||||||
|  | 		Invokes(testing.NewRootUpdateAction(podsecuritypoliciesResource, podSecurityPolicy), &v1beta1.PodSecurityPolicy{}) | ||||||
|  | 	if obj == nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	return obj.(*v1beta1.PodSecurityPolicy), err | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Delete takes name of the podSecurityPolicy and deletes it. Returns an error if one occurs. | ||||||
|  | func (c *FakePodSecurityPolicies) Delete(name string, options *v1.DeleteOptions) error { | ||||||
|  | 	_, err := c.Fake. | ||||||
|  | 		Invokes(testing.NewRootDeleteAction(podsecuritypoliciesResource, name), &v1beta1.PodSecurityPolicy{}) | ||||||
|  | 	return err | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeleteCollection deletes a collection of objects. | ||||||
|  | func (c *FakePodSecurityPolicies) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { | ||||||
|  | 	action := testing.NewRootDeleteCollectionAction(podsecuritypoliciesResource, listOptions) | ||||||
|  |  | ||||||
|  | 	_, err := c.Fake.Invokes(action, &v1beta1.PodSecurityPolicyList{}) | ||||||
|  | 	return err | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Patch applies the patch and returns the patched podSecurityPolicy. | ||||||
|  | func (c *FakePodSecurityPolicies) Patch(name string, pt types.PatchType, data []byte, subresources ...string) (result *v1beta1.PodSecurityPolicy, err error) { | ||||||
|  | 	obj, err := c.Fake. | ||||||
|  | 		Invokes(testing.NewRootPatchSubresourceAction(podsecuritypoliciesResource, name, data, subresources...), &v1beta1.PodSecurityPolicy{}) | ||||||
|  | 	if obj == nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	return obj.(*v1beta1.PodSecurityPolicy), err | ||||||
|  | } | ||||||
| @@ -34,6 +34,10 @@ func (c *FakePolicyV1beta1) PodDisruptionBudgets(namespace string) v1beta1.PodDi | |||||||
| 	return &FakePodDisruptionBudgets{c, namespace} | 	return &FakePodDisruptionBudgets{c, namespace} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (c *FakePolicyV1beta1) PodSecurityPolicies() v1beta1.PodSecurityPolicyInterface { | ||||||
|  | 	return &FakePodSecurityPolicies{c} | ||||||
|  | } | ||||||
|  |  | ||||||
| // RESTClient returns a RESTClient that is used to communicate | // RESTClient returns a RESTClient that is used to communicate | ||||||
| // with API server by this client implementation. | // with API server by this client implementation. | ||||||
| func (c *FakePolicyV1beta1) RESTClient() rest.Interface { | func (c *FakePolicyV1beta1) RESTClient() rest.Interface { | ||||||
|   | |||||||
| @@ -17,3 +17,5 @@ limitations under the License. | |||||||
| package v1beta1 | package v1beta1 | ||||||
|  |  | ||||||
| type PodDisruptionBudgetExpansion interface{} | type PodDisruptionBudgetExpansion interface{} | ||||||
|  |  | ||||||
|  | type PodSecurityPolicyExpansion interface{} | ||||||
|   | |||||||
| @@ -0,0 +1,145 @@ | |||||||
|  | /* | ||||||
|  | Copyright 2018 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 v1beta1 | ||||||
|  |  | ||||||
|  | import ( | ||||||
|  | 	v1beta1 "k8s.io/api/policy/v1beta1" | ||||||
|  | 	v1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||||
|  | 	types "k8s.io/apimachinery/pkg/types" | ||||||
|  | 	watch "k8s.io/apimachinery/pkg/watch" | ||||||
|  | 	scheme "k8s.io/client-go/kubernetes/scheme" | ||||||
|  | 	rest "k8s.io/client-go/rest" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // PodSecurityPoliciesGetter has a method to return a PodSecurityPolicyInterface. | ||||||
|  | // A group's client should implement this interface. | ||||||
|  | type PodSecurityPoliciesGetter interface { | ||||||
|  | 	PodSecurityPolicies() PodSecurityPolicyInterface | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // PodSecurityPolicyInterface has methods to work with PodSecurityPolicy resources. | ||||||
|  | type PodSecurityPolicyInterface interface { | ||||||
|  | 	Create(*v1beta1.PodSecurityPolicy) (*v1beta1.PodSecurityPolicy, error) | ||||||
|  | 	Update(*v1beta1.PodSecurityPolicy) (*v1beta1.PodSecurityPolicy, error) | ||||||
|  | 	Delete(name string, options *v1.DeleteOptions) error | ||||||
|  | 	DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error | ||||||
|  | 	Get(name string, options v1.GetOptions) (*v1beta1.PodSecurityPolicy, error) | ||||||
|  | 	List(opts v1.ListOptions) (*v1beta1.PodSecurityPolicyList, error) | ||||||
|  | 	Watch(opts v1.ListOptions) (watch.Interface, error) | ||||||
|  | 	Patch(name string, pt types.PatchType, data []byte, subresources ...string) (result *v1beta1.PodSecurityPolicy, err error) | ||||||
|  | 	PodSecurityPolicyExpansion | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // podSecurityPolicies implements PodSecurityPolicyInterface | ||||||
|  | type podSecurityPolicies struct { | ||||||
|  | 	client rest.Interface | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // newPodSecurityPolicies returns a PodSecurityPolicies | ||||||
|  | func newPodSecurityPolicies(c *PolicyV1beta1Client) *podSecurityPolicies { | ||||||
|  | 	return &podSecurityPolicies{ | ||||||
|  | 		client: c.RESTClient(), | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Get takes name of the podSecurityPolicy, and returns the corresponding podSecurityPolicy object, and an error if there is any. | ||||||
|  | func (c *podSecurityPolicies) Get(name string, options v1.GetOptions) (result *v1beta1.PodSecurityPolicy, err error) { | ||||||
|  | 	result = &v1beta1.PodSecurityPolicy{} | ||||||
|  | 	err = c.client.Get(). | ||||||
|  | 		Resource("podsecuritypolicies"). | ||||||
|  | 		Name(name). | ||||||
|  | 		VersionedParams(&options, scheme.ParameterCodec). | ||||||
|  | 		Do(). | ||||||
|  | 		Into(result) | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // List takes label and field selectors, and returns the list of PodSecurityPolicies that match those selectors. | ||||||
|  | func (c *podSecurityPolicies) List(opts v1.ListOptions) (result *v1beta1.PodSecurityPolicyList, err error) { | ||||||
|  | 	result = &v1beta1.PodSecurityPolicyList{} | ||||||
|  | 	err = c.client.Get(). | ||||||
|  | 		Resource("podsecuritypolicies"). | ||||||
|  | 		VersionedParams(&opts, scheme.ParameterCodec). | ||||||
|  | 		Do(). | ||||||
|  | 		Into(result) | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Watch returns a watch.Interface that watches the requested podSecurityPolicies. | ||||||
|  | func (c *podSecurityPolicies) Watch(opts v1.ListOptions) (watch.Interface, error) { | ||||||
|  | 	opts.Watch = true | ||||||
|  | 	return c.client.Get(). | ||||||
|  | 		Resource("podsecuritypolicies"). | ||||||
|  | 		VersionedParams(&opts, scheme.ParameterCodec). | ||||||
|  | 		Watch() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Create takes the representation of a podSecurityPolicy and creates it.  Returns the server's representation of the podSecurityPolicy, and an error, if there is any. | ||||||
|  | func (c *podSecurityPolicies) Create(podSecurityPolicy *v1beta1.PodSecurityPolicy) (result *v1beta1.PodSecurityPolicy, err error) { | ||||||
|  | 	result = &v1beta1.PodSecurityPolicy{} | ||||||
|  | 	err = c.client.Post(). | ||||||
|  | 		Resource("podsecuritypolicies"). | ||||||
|  | 		Body(podSecurityPolicy). | ||||||
|  | 		Do(). | ||||||
|  | 		Into(result) | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Update takes the representation of a podSecurityPolicy and updates it. Returns the server's representation of the podSecurityPolicy, and an error, if there is any. | ||||||
|  | func (c *podSecurityPolicies) Update(podSecurityPolicy *v1beta1.PodSecurityPolicy) (result *v1beta1.PodSecurityPolicy, err error) { | ||||||
|  | 	result = &v1beta1.PodSecurityPolicy{} | ||||||
|  | 	err = c.client.Put(). | ||||||
|  | 		Resource("podsecuritypolicies"). | ||||||
|  | 		Name(podSecurityPolicy.Name). | ||||||
|  | 		Body(podSecurityPolicy). | ||||||
|  | 		Do(). | ||||||
|  | 		Into(result) | ||||||
|  | 	return | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Delete takes name of the podSecurityPolicy and deletes it. Returns an error if one occurs. | ||||||
|  | func (c *podSecurityPolicies) Delete(name string, options *v1.DeleteOptions) error { | ||||||
|  | 	return c.client.Delete(). | ||||||
|  | 		Resource("podsecuritypolicies"). | ||||||
|  | 		Name(name). | ||||||
|  | 		Body(options). | ||||||
|  | 		Do(). | ||||||
|  | 		Error() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // DeleteCollection deletes a collection of objects. | ||||||
|  | func (c *podSecurityPolicies) DeleteCollection(options *v1.DeleteOptions, listOptions v1.ListOptions) error { | ||||||
|  | 	return c.client.Delete(). | ||||||
|  | 		Resource("podsecuritypolicies"). | ||||||
|  | 		VersionedParams(&listOptions, scheme.ParameterCodec). | ||||||
|  | 		Body(options). | ||||||
|  | 		Do(). | ||||||
|  | 		Error() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Patch applies the patch and returns the patched podSecurityPolicy. | ||||||
|  | func (c *podSecurityPolicies) Patch(name string, pt types.PatchType, data []byte, subresources ...string) (result *v1beta1.PodSecurityPolicy, err error) { | ||||||
|  | 	result = &v1beta1.PodSecurityPolicy{} | ||||||
|  | 	err = c.client.Patch(pt). | ||||||
|  | 		Resource("podsecuritypolicies"). | ||||||
|  | 		SubResource(subresources...). | ||||||
|  | 		Name(name). | ||||||
|  | 		Body(data). | ||||||
|  | 		Do(). | ||||||
|  | 		Into(result) | ||||||
|  | 	return | ||||||
|  | } | ||||||
| @@ -27,6 +27,7 @@ type PolicyV1beta1Interface interface { | |||||||
| 	RESTClient() rest.Interface | 	RESTClient() rest.Interface | ||||||
| 	EvictionsGetter | 	EvictionsGetter | ||||||
| 	PodDisruptionBudgetsGetter | 	PodDisruptionBudgetsGetter | ||||||
|  | 	PodSecurityPoliciesGetter | ||||||
| } | } | ||||||
|  |  | ||||||
| // PolicyV1beta1Client is used to interact with features provided by the policy group. | // PolicyV1beta1Client is used to interact with features provided by the policy group. | ||||||
| @@ -42,6 +43,10 @@ func (c *PolicyV1beta1Client) PodDisruptionBudgets(namespace string) PodDisrupti | |||||||
| 	return newPodDisruptionBudgets(c, namespace) | 	return newPodDisruptionBudgets(c, namespace) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (c *PolicyV1beta1Client) PodSecurityPolicies() PodSecurityPolicyInterface { | ||||||
|  | 	return newPodSecurityPolicies(c) | ||||||
|  | } | ||||||
|  |  | ||||||
| // NewForConfig creates a new PolicyV1beta1Client for the given config. | // NewForConfig creates a new PolicyV1beta1Client for the given config. | ||||||
| func NewForConfig(c *rest.Config) (*PolicyV1beta1Client, error) { | func NewForConfig(c *rest.Config) (*PolicyV1beta1Client, error) { | ||||||
| 	config := *c | 	config := *c | ||||||
|   | |||||||
| @@ -12,6 +12,7 @@ go_library( | |||||||
|         "expansion_generated.go", |         "expansion_generated.go", | ||||||
|         "poddisruptionbudget.go", |         "poddisruptionbudget.go", | ||||||
|         "poddisruptionbudget_expansion.go", |         "poddisruptionbudget_expansion.go", | ||||||
|  |         "podsecuritypolicy.go", | ||||||
|     ], |     ], | ||||||
|     importpath = "k8s.io/client-go/listers/policy/v1beta1", |     importpath = "k8s.io/client-go/listers/policy/v1beta1", | ||||||
|     deps = [ |     deps = [ | ||||||
|   | |||||||
| @@ -25,3 +25,7 @@ type EvictionListerExpansion interface{} | |||||||
| // EvictionNamespaceListerExpansion allows custom methods to be added to | // EvictionNamespaceListerExpansion allows custom methods to be added to | ||||||
| // EvictionNamespaceLister. | // EvictionNamespaceLister. | ||||||
| type EvictionNamespaceListerExpansion interface{} | type EvictionNamespaceListerExpansion interface{} | ||||||
|  |  | ||||||
|  | // PodSecurityPolicyListerExpansion allows custom methods to be added to | ||||||
|  | // PodSecurityPolicyLister. | ||||||
|  | type PodSecurityPolicyListerExpansion interface{} | ||||||
|   | |||||||
| @@ -0,0 +1,65 @@ | |||||||
|  | /* | ||||||
|  | Copyright 2018 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 automatically generated by lister-gen | ||||||
|  |  | ||||||
|  | package v1beta1 | ||||||
|  |  | ||||||
|  | import ( | ||||||
|  | 	v1beta1 "k8s.io/api/policy/v1beta1" | ||||||
|  | 	"k8s.io/apimachinery/pkg/api/errors" | ||||||
|  | 	"k8s.io/apimachinery/pkg/labels" | ||||||
|  | 	"k8s.io/client-go/tools/cache" | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | // PodSecurityPolicyLister helps list PodSecurityPolicies. | ||||||
|  | type PodSecurityPolicyLister interface { | ||||||
|  | 	// List lists all PodSecurityPolicies in the indexer. | ||||||
|  | 	List(selector labels.Selector) (ret []*v1beta1.PodSecurityPolicy, err error) | ||||||
|  | 	// Get retrieves the PodSecurityPolicy from the index for a given name. | ||||||
|  | 	Get(name string) (*v1beta1.PodSecurityPolicy, error) | ||||||
|  | 	PodSecurityPolicyListerExpansion | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // podSecurityPolicyLister implements the PodSecurityPolicyLister interface. | ||||||
|  | type podSecurityPolicyLister struct { | ||||||
|  | 	indexer cache.Indexer | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // NewPodSecurityPolicyLister returns a new PodSecurityPolicyLister. | ||||||
|  | func NewPodSecurityPolicyLister(indexer cache.Indexer) PodSecurityPolicyLister { | ||||||
|  | 	return &podSecurityPolicyLister{indexer: indexer} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // List lists all PodSecurityPolicies in the indexer. | ||||||
|  | func (s *podSecurityPolicyLister) List(selector labels.Selector) (ret []*v1beta1.PodSecurityPolicy, err error) { | ||||||
|  | 	err = cache.ListAll(s.indexer, selector, func(m interface{}) { | ||||||
|  | 		ret = append(ret, m.(*v1beta1.PodSecurityPolicy)) | ||||||
|  | 	}) | ||||||
|  | 	return ret, err | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Get retrieves the PodSecurityPolicy from the index for a given name. | ||||||
|  | func (s *podSecurityPolicyLister) Get(name string) (*v1beta1.PodSecurityPolicy, error) { | ||||||
|  | 	obj, exists, err := s.indexer.GetByKey(name) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	if !exists { | ||||||
|  | 		return nil, errors.NewNotFound(v1beta1.Resource("podsecuritypolicy"), name) | ||||||
|  | 	} | ||||||
|  | 	return obj.(*v1beta1.PodSecurityPolicy), nil | ||||||
|  | } | ||||||
| @@ -296,6 +296,11 @@ var etcdStorageData = map[schema.GroupVersionResource]struct { | |||||||
| 		stub:             `{"metadata": {"name": "pdb1"}, "spec": {"selector": {"matchLabels": {"anokkey": "anokvalue"}}}}`, | 		stub:             `{"metadata": {"name": "pdb1"}, "spec": {"selector": {"matchLabels": {"anokkey": "anokvalue"}}}}`, | ||||||
| 		expectedEtcdPath: "/registry/poddisruptionbudgets/etcdstoragepathtestnamespace/pdb1", | 		expectedEtcdPath: "/registry/poddisruptionbudgets/etcdstoragepathtestnamespace/pdb1", | ||||||
| 	}, | 	}, | ||||||
|  | 	gvr("policy", "v1beta1", "podsecuritypolicies"): { | ||||||
|  | 		stub:             `{"metadata": {"name": "psp2"}, "spec": {"fsGroup": {"rule": "RunAsAny"}, "privileged": true, "runAsUser": {"rule": "RunAsAny"}, "seLinux": {"rule": "MustRunAs"}, "supplementalGroups": {"rule": "RunAsAny"}}}`, | ||||||
|  | 		expectedEtcdPath: "/registry/podsecuritypolicy/psp2", | ||||||
|  | 		expectedGVK:      gvkP("extensions", "v1beta1", "PodSecurityPolicy"), | ||||||
|  | 	}, | ||||||
| 	// -- | 	// -- | ||||||
|  |  | ||||||
| 	// k8s.io/kubernetes/pkg/apis/storage/v1alpha1 | 	// k8s.io/kubernetes/pkg/apis/storage/v1alpha1 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Submit Queue
					Kubernetes Submit Queue