func ValidateProjectConfig(config api.ProjectConfig) ValidationResults { validationResults := ValidationResults{} if _, _, err := api.ParseNamespaceAndName(config.ProjectRequestTemplate); err != nil { validationResults.AddErrors(fielderrors.NewFieldInvalid("projectRequestTemplate", config.ProjectRequestTemplate, "must be in the form: namespace/templateName")) } if len(config.DefaultNodeSelector) > 0 { _, err := labelselector.Parse(config.DefaultNodeSelector) if err != nil { validationResults.AddErrors(fielderrors.NewFieldInvalid("defaultNodeSelector", config.DefaultNodeSelector, "must be a valid label selector")) } } if alloc := config.SecurityAllocator; alloc != nil { if _, err := uid.ParseRange(alloc.UIDAllocatorRange); err != nil { validationResults.AddErrors(fielderrors.NewFieldInvalid("securityAllocator.uidAllocatorRange", alloc.UIDAllocatorRange, err.Error())) } if _, err := mcs.ParseRange(alloc.MCSAllocatorRange); err != nil { validationResults.AddErrors(fielderrors.NewFieldInvalid("securityAllocator.mcsAllocatorRange", alloc.MCSAllocatorRange, err.Error())) } if alloc.MCSLabelsPerProject <= 0 { validationResults.AddErrors(fielderrors.NewFieldInvalid("securityAllocator.mcsLabelsPerProject", alloc.MCSLabelsPerProject, "must be a positive integer")) } } else { validationResults.AddWarnings(fielderrors.NewFieldInvalid("securityAllocator", "null", "allocation of UIDs and MCS labels to a project must be done manually")) } return validationResults }
func ValidateProjectConfig(config api.ProjectConfig) fielderrors.ValidationErrorList { allErrs := fielderrors.ValidationErrorList{} if _, _, err := api.ParseNamespaceAndName(config.ProjectRequestTemplate); err != nil { allErrs = append(allErrs, fielderrors.NewFieldInvalid("projectRequestTemplate", config.ProjectRequestTemplate, "must be in the form: namespace/templateName")) } if len(config.DefaultNodeSelector) > 0 { _, err := labelselector.Parse(config.DefaultNodeSelector) if err != nil { allErrs = append(allErrs, fielderrors.NewFieldInvalid("defaultNodeSelector", config.DefaultNodeSelector, "must be a valid label selector")) } } if alloc := config.SecurityAllocator; alloc != nil { if _, err := uid.ParseRange(alloc.UIDAllocatorRange); err != nil { allErrs = append(allErrs, fielderrors.NewFieldInvalid("uidAllocatorRange", alloc.UIDAllocatorRange, err.Error())) } if _, err := mcs.ParseRange(alloc.MCSAllocatorRange); err != nil { allErrs = append(allErrs, fielderrors.NewFieldInvalid("mcsAllocatorRange", alloc.MCSAllocatorRange, err.Error())) } if alloc.MCSLabelsPerProject <= 0 { allErrs = append(allErrs, fielderrors.NewFieldInvalid("mcsLabelsPerProject", alloc.MCSLabelsPerProject, "must be a positive integer")) } } return allErrs }
func (p *ProjectCache) GetNodeSelectorMap(namespace *kapi.Namespace) (map[string]string, error) { selector := p.GetNodeSelector(namespace) labelsMap, err := labelselector.Parse(selector) if err != nil { return map[string]string{}, err } return labelsMap, nil }
func ValidateNodeSelector(nodeSelector map[string]string, fldPath *field.Path) field.ErrorList { allErrs := field.ErrorList{} for k, v := range nodeSelector { _, err := labelselector.Parse(fmt.Sprintf("%s=%s", k, v)) if err != nil { allErrs = append(allErrs, field.Invalid(fldPath.Key(k), nodeSelector[k], "must be a valid node selector")) } } return allErrs }
func validateNodeSelector(p *api.Project) fielderrors.ValidationErrorList { allErrs := fielderrors.ValidationErrorList{} if len(p.Annotations) > 0 { if selector, ok := p.Annotations[projectapi.ProjectNodeSelector]; ok { if _, err := labelselector.Parse(selector); err != nil { allErrs = append(allErrs, fielderrors.NewFieldInvalid("nodeSelector", p.Annotations[projectapi.ProjectNodeSelector], "must be a valid label selector")) } } } return allErrs }