forked from openshift/origin
/
validation.go
55 lines (42 loc) · 1.98 KB
/
validation.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
package validation
import (
errs "github.com/GoogleCloudPlatform/kubernetes/pkg/api/errors"
"github.com/GoogleCloudPlatform/kubernetes/pkg/api/validation"
"github.com/GoogleCloudPlatform/kubernetes/pkg/util"
authorizationapi "github.com/openshift/origin/pkg/authorization/api"
)
// ValidatePolicyBinding tests required fields for a PolicyBinding.
func ValidatePolicyBinding(policyBinding *authorizationapi.PolicyBinding) errs.ValidationErrorList {
allErrs := errs.ValidationErrorList{}
if len(policyBinding.Name) == 0 {
allErrs = append(allErrs, errs.NewFieldRequired("name", policyBinding.Name))
}
if len(policyBinding.PolicyRef.Namespace) == 0 {
allErrs = append(allErrs, errs.NewFieldRequired("policyRef.Namespace", policyBinding.PolicyRef.Namespace))
}
allErrs = append(allErrs, validation.ValidateLabels(policyBinding.Labels, "labels")...)
return allErrs
}
// ValidateRole tests required fields for a Role.
func ValidateRole(role *authorizationapi.Role) errs.ValidationErrorList {
allErrs := errs.ValidationErrorList{}
if len(role.Name) == 0 {
allErrs = append(allErrs, errs.NewFieldRequired("name", role.Name))
}
allErrs = append(allErrs, validation.ValidateLabels(role.Labels, "labels")...)
return allErrs
}
// ValidateRoleBinding tests required fields for a RoleBinding.
func ValidateRoleBinding(roleBinding *authorizationapi.RoleBinding) errs.ValidationErrorList {
allErrs := errs.ValidationErrorList{}
if len(roleBinding.Name) == 0 {
allErrs = append(allErrs, errs.NewFieldRequired("name", roleBinding.Name))
}
if len(roleBinding.RoleRef.Namespace) == 0 {
allErrs = append(allErrs, errs.NewFieldRequired("roleRef.namespace", roleBinding.RoleRef.Namespace))
} else if !util.IsDNSSubdomain(roleBinding.RoleRef.Namespace) {
allErrs = append(allErrs, errs.NewFieldInvalid("roleRef.namespace", roleBinding.RoleRef.Namespace, "roleRef.namespace must be a valid subdomain"))
}
allErrs = append(allErrs, validation.ValidateLabels(roleBinding.Labels, "labels")...)
return allErrs
}