| /* |
| Copyright 2023 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 app |
| |
| import ( |
| "context" |
| |
| apiextensionsscheme "k8s.io/apiextensions-apiserver/pkg/client/clientset/clientset/scheme" |
| pluginvalidatingadmissionpolicy "k8s.io/apiserver/pkg/admission/plugin/policy/validating" |
| "k8s.io/apiserver/pkg/cel/openapi/resolver" |
| genericfeatures "k8s.io/apiserver/pkg/features" |
| k8sscheme "k8s.io/client-go/kubernetes/scheme" |
| "k8s.io/component-base/featuregate" |
| "k8s.io/controller-manager/controller" |
| "k8s.io/kubernetes/cmd/kube-controller-manager/names" |
| "k8s.io/kubernetes/pkg/controller/validatingadmissionpolicystatus" |
| "k8s.io/kubernetes/pkg/generated/openapi" |
| ) |
| |
| func newValidatingAdmissionPolicyStatusControllerDescriptor() *ControllerDescriptor { |
| return &ControllerDescriptor{ |
| name: names.ValidatingAdmissionPolicyStatusController, |
| initFunc: startValidatingAdmissionPolicyStatusController, |
| requiredFeatureGates: []featuregate.Feature{ |
| genericfeatures.ValidatingAdmissionPolicy, |
| }, |
| } |
| } |
| |
| func startValidatingAdmissionPolicyStatusController(ctx context.Context, controllerContext ControllerContext, controllerName string) (controller.Interface, bool, error) { |
| // KCM won't start the controller without the feature gate set. |
| |
| schemaResolver := resolver.NewDefinitionsSchemaResolver(openapi.GetOpenAPIDefinitions, k8sscheme.Scheme, apiextensionsscheme.Scheme). |
| Combine(&resolver.ClientDiscoveryResolver{Discovery: controllerContext.ClientBuilder.DiscoveryClientOrDie(names.ValidatingAdmissionPolicyStatusController)}) |
| |
| typeChecker := &pluginvalidatingadmissionpolicy.TypeChecker{ |
| SchemaResolver: schemaResolver, |
| RestMapper: controllerContext.RESTMapper, |
| } |
| c, err := validatingadmissionpolicystatus.NewController( |
| controllerContext.InformerFactory.Admissionregistration().V1().ValidatingAdmissionPolicies(), |
| controllerContext.ClientBuilder.ClientOrDie(names.ValidatingAdmissionPolicyStatusController).AdmissionregistrationV1().ValidatingAdmissionPolicies(), |
| typeChecker, |
| ) |
| |
| go c.Run(ctx, int(controllerContext.ComponentConfig.ValidatingAdmissionPolicyStatusController.ConcurrentPolicySyncs)) |
| return nil, true, err |
| } |