// Copyright 2019 FairwindsOps Inc // // 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 validator import ( "strings" "github.com/sirupsen/logrus" conf "github.com/fairwindsops/polaris/pkg/config" "github.com/fairwindsops/polaris/pkg/kube" ) const exemptionAnnotationKey = "polaris.fairwinds.com/exempt" // ValidateController validates a single controller, returns a Result. func ValidateController(conf *conf.Configuration, controller kube.GenericWorkload) (Result, error) { podResult, err := ValidatePod(conf, controller) if err != nil { return Result{}, err } var controllerResult ResultSet controllerResult, err = applyControllerSchemaChecks(conf, controller) if err != nil { return Result{}, err } result := Result{ Kind: controller.Kind, Name: controller.ObjectMeta.GetName(), Namespace: controller.ObjectMeta.GetNamespace(), Results: controllerResult, PodResult: &podResult, } return result, nil } // ValidateControllers validates that each deployment conforms to the Polaris config, // builds a list of ResourceResults organized by namespace. func ValidateControllers(config *conf.Configuration, kubeResources *kube.ResourceProvider) ([]Result, error) { controllersToAudit := kubeResources.Controllers results := []Result{} for _, controller := range controllersToAudit { if !config.DisallowExemptions && hasExemptionAnnotation(controller) { continue } result, err := ValidateController(config, controller) if err != nil { logrus.Warn("An error occurred validating controller:", err) return nil, err } results = append(results, result) } return results, nil } func hasExemptionAnnotation(ctrl kube.GenericWorkload) bool { annot := ctrl.ObjectMeta.GetAnnotations() val := annot[exemptionAnnotationKey] return strings.ToLower(val) == "true" }