forked from knative/serving
-
Notifications
You must be signed in to change notification settings - Fork 0
/
configuration_validation.go
84 lines (69 loc) · 2.9 KB
/
configuration_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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/*
Copyright 2018 The Knative 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 v1alpha1
import (
"context"
"k8s.io/apimachinery/pkg/api/equality"
"knative.dev/pkg/apis"
"knative.dev/serving/pkg/apis/serving"
)
// Validate makes sure that Configuration is properly configured.
func (c *Configuration) Validate(ctx context.Context) (errs *apis.FieldError) {
// If we are in a status sub resource update, the metadata and spec cannot change.
// So, to avoid rejecting controller status updates due to validations that may
// have changed (i.e. due to config-defaults changes), we elide the metadata and
// spec validation.
if !apis.IsInStatusUpdate(ctx) {
errs = errs.Also(serving.ValidateObjectMetadata(c.GetObjectMeta()).ViaField("metadata"))
ctx = apis.WithinParent(ctx, c.ObjectMeta)
errs = errs.Also(c.Spec.Validate(apis.WithinSpec(ctx)).ViaField("spec"))
}
if apis.IsInUpdate(ctx) {
original := apis.GetBaseline(ctx).(*Configuration)
// Don't validate annotations(creator and lastModifier) when configuration owned by service
// validate only when configuration created independently.
if c.GetOwnerReferences() == nil {
errs = errs.Also(apis.ValidateCreatorAndModifier(original.Spec, c.Spec, original.GetAnnotations(),
c.GetAnnotations(), serving.GroupName).ViaField("metadata.annotations"))
}
err := c.Spec.GetTemplate().VerifyNameChange(ctx,
original.Spec.GetTemplate())
errs = errs.Also(err.ViaField("spec.revisionTemplate"))
}
return errs
}
// Validate makes sure that ConfigurationSpec is properly configured.
func (cs *ConfigurationSpec) Validate(ctx context.Context) *apis.FieldError {
if equality.Semantic.DeepEqual(cs, &ConfigurationSpec{}) {
return apis.ErrMissingField(apis.CurrentField)
}
errs := apis.CheckDeprecated(ctx, cs)
// Build support is now disabled.
if cs.DeprecatedBuild != nil {
errs = errs.Also(apis.ErrDisallowedFields("build"))
}
var templateField string
switch {
case cs.DeprecatedRevisionTemplate != nil && cs.Template != nil:
return apis.ErrMultipleOneOf("revisionTemplate", "template")
case cs.DeprecatedRevisionTemplate != nil:
templateField = "revisionTemplate"
case cs.Template != nil:
templateField = "template"
// Disallow the use of deprecated fields under "template".
ctx = apis.DisallowDeprecated(ctx)
default:
return apis.ErrMissingOneOf("revisionTemplate", "template")
}
return errs.Also(cs.GetTemplate().Validate(ctx).ViaField(templateField))
}