-
Notifications
You must be signed in to change notification settings - Fork 244
/
Copy pathhive.openshift.io_selectorsyncsets.yaml
233 lines (233 loc) · 11.4 KB
/
hive.openshift.io_selectorsyncsets.yaml
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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.16.1
name: selectorsyncsets.hive.openshift.io
spec:
group: hive.openshift.io
names:
kind: SelectorSyncSet
listKind: SelectorSyncSetList
plural: selectorsyncsets
shortNames:
- sss
singular: selectorsyncset
scope: Cluster
versions:
- name: v1
schema:
openAPIV3Schema:
description: SelectorSyncSet is the Schema for the SelectorSyncSet API
properties:
apiVersion:
description: |-
APIVersion defines the versioned schema of this representation of an object.
Servers should convert recognized schemas to the latest internal value, and
may reject unrecognized values.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
type: string
kind:
description: |-
Kind is a string value representing the REST resource this object represents.
Servers may infer this from the endpoint the client submits requests to.
Cannot be updated.
In CamelCase.
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
type: string
metadata:
type: object
spec:
description: |-
SelectorSyncSetSpec defines the SyncSetCommonSpec resources and patches to sync along
with a ClusterDeploymentSelector indicating which clusters the SelectorSyncSet applies
to in any namespace.
properties:
applyBehavior:
description: |-
ApplyBehavior indicates how resources in this syncset will be applied to the target
cluster. The default value of "Apply" indicates that resources should be applied
using the 'oc apply' command. If no value is set, "Apply" is assumed.
A value of "CreateOnly" indicates that the resource will only be created if it does
not already exist in the target cluster. Otherwise, it will be left alone.
A value of "CreateOrUpdate" indicates that the resource will be created/updated without
the use of the 'oc apply' command, allowing larger resources to be synced, but losing
some functionality of the 'oc apply' command such as the ability to remove annotations,
labels, and other map entries in general.
enum:
- ""
- Apply
- CreateOnly
- CreateOrUpdate
type: string
clusterDeploymentSelector:
description: |-
ClusterDeploymentSelector is a LabelSelector indicating which clusters the SelectorSyncSet
applies to in any namespace.
properties:
matchExpressions:
description: matchExpressions is a list of label selector requirements.
The requirements are ANDed.
items:
description: |-
A label selector requirement is a selector that contains values, a key, and an operator that
relates the key and values.
properties:
key:
description: key is the label key that the selector applies
to.
type: string
operator:
description: |-
operator represents a key's relationship to a set of values.
Valid operators are In, NotIn, Exists and DoesNotExist.
type: string
values:
description: |-
values is an array of string values. If the operator is In or NotIn,
the values array must be non-empty. If the operator is Exists or DoesNotExist,
the values array must be empty. This array is replaced during a strategic
merge patch.
items:
type: string
type: array
x-kubernetes-list-type: atomic
required:
- key
- operator
type: object
type: array
x-kubernetes-list-type: atomic
matchLabels:
additionalProperties:
type: string
description: |-
matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels
map is equivalent to an element of matchExpressions, whose key field is "key", the
operator is "In", and the values array contains only "value". The requirements are ANDed.
type: object
type: object
x-kubernetes-map-type: atomic
enablePatchTemplates:
description: |-
EnablePatchTemplates, if True, causes hive to honor golang text/templates in Patches[].Patch
strings. While the standard syntax is supported, it won't do you a whole lot of good as the
parser does not pass a data object (i.e. there is no "dot" for you to use). This currently
exists to expose a single function: {{ fromCDLabel "some.label/key" }} will be substituted
with the string value of ClusterDeployment.Labels["some.label/key"]. The empty string is
interpolated if there are no labels, or if the indicated key does not exist. Note that the
patch string must be valid JSON after interpolation. This may make for odd-looking quoting
in the uninterpolated string.
type: boolean
enableResourceTemplates:
description: |-
EnableResourceTemplates, if True, causes hive to honor golang text/templates in Resources.
While the standard syntax is supported, it won't do you a whole lot of good as the parser
does not pass a data object (i.e. there is no "dot" for you to use). This currently exists
to expose a single function: {{ fromCDLabel "some.label/key" }} will
be substituted with the string value of ClusterDeployment.Labels["some.label/key"]. The
empty string is interpolated if there are no labels, or if the indicated key does not exist.
Note that this only works in values (not e.g. map keys) that are of type string.
type: boolean
patches:
description: Patches is the list of patches to apply.
items:
description: SyncObjectPatch represents a patch to be applied to
a specific object
properties:
apiVersion:
description: APIVersion is the Group and Version of the object
to be patched.
type: string
kind:
description: Kind is the Kind of the object to be patched.
type: string
name:
description: Name is the name of the object to be patched.
type: string
namespace:
description: |-
Namespace is the Namespace in which the object to patch exists.
Defaults to the SyncSet's Namespace.
type: string
patch:
description: Patch is the patch to apply.
type: string
patchType:
description: PatchType indicates the PatchType as "strategic"
(default), "json", or "merge".
type: string
required:
- apiVersion
- kind
- name
- patch
type: object
type: array
resourceApplyMode:
description: |-
ResourceApplyMode indicates if the Resource apply mode is "Upsert" (default) or "Sync".
ApplyMode "Upsert" indicates create and update.
ApplyMode "Sync" indicates create, update and delete.
type: string
resources:
description: Resources is the list of objects to sync from RawExtension
definitions.
items:
type: object
x-kubernetes-preserve-unknown-fields: true
x-kubernetes-embedded-resource: true
type: array
secretMappings:
description: Secrets is the list of secrets to sync along with their
respective destinations.
items:
description: SecretMapping defines a source and destination for
a secret to be synced by a SyncSet
properties:
sourceRef:
description: SourceRef specifies the name and namespace of a
secret on the management cluster
properties:
name:
description: Name is the name of the secret
type: string
namespace:
description: |-
Namespace is the namespace where the secret lives. If not present for the source
secret reference, it is assumed to be the same namespace as the syncset with the
reference.
type: string
required:
- name
type: object
targetRef:
description: TargetRef specifies the target name and namespace
of the secret on the target cluster
properties:
name:
description: Name is the name of the secret
type: string
namespace:
description: |-
Namespace is the namespace where the secret lives. If not present for the source
secret reference, it is assumed to be the same namespace as the syncset with the
reference.
type: string
required:
- name
type: object
required:
- sourceRef
- targetRef
type: object
type: array
type: object
status:
description: SelectorSyncSetStatus defines the observed state of a SelectorSyncSet
type: object
type: object
served: true
storage: true
subresources:
status: {}