/
assign_types.go
109 lines (86 loc) 路 3.83 KB
/
assign_types.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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*
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 v1
import (
"github.com/open-policy-agent/gatekeeper/v3/apis/status/v1beta1"
"github.com/open-policy-agent/gatekeeper/v3/pkg/mutation/match"
"github.com/open-policy-agent/gatekeeper/v3/pkg/mutation/path/tester"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
// EDIT THIS FILE! THIS IS SCAFFOLDING FOR YOU TO OWN!
// NOTE: json tags are required. Any new fields you add must have json tags for the fields to be serialized.
// AssignSpec defines the desired state of Assign.
type AssignSpec struct {
// INSERT ADDITIONAL SPEC FIELDS - desired state of cluster
// Important: Run "make" to regenerate code after modifying this file
// ApplyTo lists the specific groups, versions and kinds a mutation will be applied to.
// This is necessary because every mutation implies part of an object schema and object
// schemas are associated with specific GVKs.
ApplyTo []match.ApplyTo `json:"applyTo,omitempty"`
// Match allows the user to limit which resources get mutated.
// Individual match criteria are AND-ed together. An undefined
// match criteria matches everything.
Match match.Match `json:"match,omitempty"`
// Location describes the path to be mutated, for example: `spec.containers[name: main]`.
Location string `json:"location,omitempty"`
// Parameters define the behavior of the mutator.
Parameters Parameters `json:"parameters,omitempty"`
}
type Parameters struct {
PathTests []PathTest `json:"pathTests,omitempty"`
// TODO(maxsmythe): Now that https://github.com/kubernetes-sigs/controller-tools/pull/528
// is merged, we can use an actual object for `Assign`
// Assign.value holds the value to be assigned
Assign AssignField `json:"assign,omitempty"`
}
// PathTest allows the user to customize how the mutation works if parent
// paths are missing. It traverses the list in order. All sub paths are
// tested against the provided condition, if the test fails, the mutation is
// not applied. All `subPath` entries must be a prefix of `location`. Any
// glob characters will take on the same value as was used to
// expand the matching glob in `location`.
//
// Available Tests:
// * MustExist - the path must exist or do not mutate
// * MustNotExist - the path must not exist or do not mutate.
type PathTest struct {
SubPath string `json:"subPath,omitempty"`
Condition tester.Condition `json:"condition,omitempty"`
}
// AssignStatus defines the observed state of Assign.
type AssignStatus struct {
// INSERT ADDITIONAL STATUS FIELD - define observed state of cluster
// Important: Run "make" to regenerate code after modifying this file
ByPod []v1beta1.MutatorPodStatusStatus `json:"byPod,omitempty"`
}
// +kubebuilder:object:root=true
// +kubebuilder:resource:path="assign"
// +kubebuilder:resource:scope="Cluster"
// +kubebuilder:subresource:status
// +kubebuilder:storageversion
// Assign is the Schema for the assign API.
type Assign struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
Spec AssignSpec `json:"spec,omitempty"`
Status AssignStatus `json:"status,omitempty"`
}
// +kubebuilder:object:root=true
// AssignList contains a list of Assign.
type AssignList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []Assign `json:"items"`
}
func init() {
SchemeBuilder.Register(&Assign{}, &AssignList{})
}