diff --git a/tests/all-config-demo-naked.expected.yaml b/tests/all-config-demo-naked.expected.yaml
deleted file mode 100644
index b67390d2..00000000
--- a/tests/all-config-demo-naked.expected.yaml
+++ /dev/null
@@ -1,236 +0,0 @@
----
-# Source: config-demo/templates/config-demo-cm.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: config-demo-configmap
- labels:
- app.kubernetes.io/instance: config-demo
-data:
- "index.html": |-
-
-
-
-
- Config Demo
-
-
-
- Hub Cluster domain is 'hub.example.com'
- Pod is running on Local Cluster Domain 'region.example.com'
-
-
- The secret is secret
-
-
-
----
-# Source: config-demo/templates/config-demo-svc.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: config-demo
- name: config-demo
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- selector:
- app: config-demo
- deploymentconfig: config-demo
- sessionAffinity: None
- type: ClusterIP
----
-# Source: config-demo/templates/config-demo-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- application: config-demo
- name: config-demo
-spec:
- replicas: 2
- revisionHistoryLimit: 3
- selector:
- matchLabels:
- deploymentconfig: config-demo
- template:
- metadata:
- creationTimestamp: null
- labels:
- app: config-demo
- deploymentconfig: config-demo
- name: config-demo
- spec:
- containers:
- - name: apache
- image: registry.access.redhat.com/ubi8/httpd-24
- #imagePullPolicy: Always
- ports:
- - containerPort: 8080
- name: http
- protocol: TCP
- volumeMounts:
- - mountPath: /var/www/html
- name: config-demo-configmap
- - mountPath: /var/www/html/secret
- readOnly: true
- name: config-demo-secret
- resources: {}
- terminationMessagePath: /dev/termination-log
- terminationMessagePolicy: File
- livenessProbe:
- httpGet:
- path: /index.html
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 5
- timeoutSeconds: 1
- periodSeconds: 10
- successThreshold: 1
- failureThreshold: 3
- readinessProbe:
- httpGet:
- path: /index.html
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 5
- timeoutSeconds: 1
- periodSeconds: 10
- successThreshold: 1
- failureThreshold: 3
- volumes:
- - name: config-demo-configmap
- configMap:
- defaultMode: 438
- name: config-demo-configmap
- - name: config-demo-secret
- secret:
- secretName: config-demo-secret
----
-# Source: config-demo/templates/config-demo-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: config-demo/templates/config-demo-external-secret.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- name: config-demo-secret
- namespace: config-demo
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: config-demo-secret
- template:
- type: Opaque
- dataFrom:
- - extract:
- key: secret/data/hub/config-demo
----
-# Source: config-demo/templates/config-demo-is.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: config-demo
-spec:
- lookupPolicy:
- local: true
- tags:
- - name: registry.access.redhat.com/ubi8/httpd-24
- importPolicy: {}
- referencePolicy:
- type: Local
----
-# Source: config-demo/templates/config-demo-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: configdemo-region-secret-placement-binding
-placementRef:
- name: configdemo-region-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: configdemo-region-secret-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: config-demo/templates/config-demo-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: configdemo-region-secret-placement
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: config-demo/templates/config-demo-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: configdemo-region-secret-policy
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: config-demo-secret
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- policy.open-cluster-management.io/trigger-update: "2"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- object-templates:
- - complianceType: musthave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: config-demo-secret
- namespace: config-demo
- apiVersion: v1
- data:
- secret: '{{hub (lookup "v1" "Secret" "config-demo" "config-demo-secret").data.secret hub}}'
----
-# Source: config-demo/templates/config-demo-route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: config-demo
- name: config-demo
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: config-demo
- weight: 100
- wildcardPolicy: None
diff --git a/tests/all-config-demo-normal.expected.yaml b/tests/all-config-demo-normal.expected.yaml
deleted file mode 100644
index b67390d2..00000000
--- a/tests/all-config-demo-normal.expected.yaml
+++ /dev/null
@@ -1,236 +0,0 @@
----
-# Source: config-demo/templates/config-demo-cm.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: config-demo-configmap
- labels:
- app.kubernetes.io/instance: config-demo
-data:
- "index.html": |-
-
-
-
-
- Config Demo
-
-
-
- Hub Cluster domain is 'hub.example.com'
- Pod is running on Local Cluster Domain 'region.example.com'
-
-
- The secret is secret
-
-
-
----
-# Source: config-demo/templates/config-demo-svc.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: config-demo
- name: config-demo
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- selector:
- app: config-demo
- deploymentconfig: config-demo
- sessionAffinity: None
- type: ClusterIP
----
-# Source: config-demo/templates/config-demo-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- application: config-demo
- name: config-demo
-spec:
- replicas: 2
- revisionHistoryLimit: 3
- selector:
- matchLabels:
- deploymentconfig: config-demo
- template:
- metadata:
- creationTimestamp: null
- labels:
- app: config-demo
- deploymentconfig: config-demo
- name: config-demo
- spec:
- containers:
- - name: apache
- image: registry.access.redhat.com/ubi8/httpd-24
- #imagePullPolicy: Always
- ports:
- - containerPort: 8080
- name: http
- protocol: TCP
- volumeMounts:
- - mountPath: /var/www/html
- name: config-demo-configmap
- - mountPath: /var/www/html/secret
- readOnly: true
- name: config-demo-secret
- resources: {}
- terminationMessagePath: /dev/termination-log
- terminationMessagePolicy: File
- livenessProbe:
- httpGet:
- path: /index.html
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 5
- timeoutSeconds: 1
- periodSeconds: 10
- successThreshold: 1
- failureThreshold: 3
- readinessProbe:
- httpGet:
- path: /index.html
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 5
- timeoutSeconds: 1
- periodSeconds: 10
- successThreshold: 1
- failureThreshold: 3
- volumes:
- - name: config-demo-configmap
- configMap:
- defaultMode: 438
- name: config-demo-configmap
- - name: config-demo-secret
- secret:
- secretName: config-demo-secret
----
-# Source: config-demo/templates/config-demo-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: config-demo/templates/config-demo-external-secret.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- name: config-demo-secret
- namespace: config-demo
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: config-demo-secret
- template:
- type: Opaque
- dataFrom:
- - extract:
- key: secret/data/hub/config-demo
----
-# Source: config-demo/templates/config-demo-is.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: config-demo
-spec:
- lookupPolicy:
- local: true
- tags:
- - name: registry.access.redhat.com/ubi8/httpd-24
- importPolicy: {}
- referencePolicy:
- type: Local
----
-# Source: config-demo/templates/config-demo-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: configdemo-region-secret-placement-binding
-placementRef:
- name: configdemo-region-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: configdemo-region-secret-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: config-demo/templates/config-demo-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: configdemo-region-secret-placement
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: config-demo/templates/config-demo-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: configdemo-region-secret-policy
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: config-demo-secret
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- policy.open-cluster-management.io/trigger-update: "2"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- object-templates:
- - complianceType: musthave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: config-demo-secret
- namespace: config-demo
- apiVersion: v1
- data:
- secret: '{{hub (lookup "v1" "Secret" "config-demo" "config-demo-secret").data.secret hub}}'
----
-# Source: config-demo/templates/config-demo-route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: config-demo
- name: config-demo
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: config-demo
- weight: 100
- wildcardPolicy: None
diff --git a/tests/all-in-one-industrial-edge-factory.expected.yaml b/tests/all-in-one-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 82f44b15..00000000
--- a/tests/all-in-one-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,229 +0,0 @@
----
-# Source: all-in-one/templates/rbac/serviceaccount-all-in-one.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: all-in-one-sa
- labels:
- helm.sh/chart: all-in-one-0.1.0
- app.kubernetes.io/name: all-in-one
- app.kubernetes.io/instance: all-in-one
- app.kubernetes.io/version: "1.16.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: all-in-one/templates/cm-configure-all-in-one.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: configure-all-in-one
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- configure-all-in-one.sh: |
- echo -n "Checking if quay-enterpise namespace exists ..."
- EXISTS=$(oc get ns quay-enterprise > /dev/null 2>&1; echo $?)
-
- while [ $EXISTS -ne 0 ]; do
- sleep 3
- echo -n "."
- EXISTS=$(oc get ns quay-enterprise > /dev/null 2>&1; echo $?)
- done
- echo "done"
-
- sleep 2
- echo -n "Checking if route for Quay application exists ..."
- EXISTS=$(oc get route quay-registry-quay -n quay-enterprise > /dev/null 2>&1; echo $?)
- ##### oc get route -n quay-enterprise quay-registry-quay -o json > /dev/null 2>&1; echo $?
- while [ $EXISTS -ne 0 ]; do
- sleep 3
- echo -n "."
- EXISTS=$(oc get route quay-registry-quay -n quay-enterprise > /dev/null 2>&1; echo $?)
- done
- echo "done"
- sleep 2
-
- echo -n "Getting route for Quay application ..."
- #REGISTRY=$(oc get route -n quay-enterprise quay-registry-quay -o json | grep quay-registry-hostname | cut -d ':' -f 2 | tr -d '"' | tr -d ' ')
- REGISTRY=quay-registry-quay-quay-enterprise.apps.region.example.com
- echo "done"
- cat < /tmp/registry.json
- spec:
- registrySources:
- insecureRegistries:
- - $REGISTRY
- EOF
- oc patch --patch-file /tmp/registry.json image.config.openshift.io/cluster --type=merge
- sleep 2
-
- echo "Verify you config is updated"
- oc get image.config.openshift.io/cluster -o yaml
-
- echo "Checking to nodes for change"
-
- NODES=$(oc get nodes | grep -v NAME | awk '{print $1}')
-
- for node in $NODES; do
- echo "Checking [$node] for updates. This could take a while."
- UPDATED=$(oc debug -q node/$node -- chroot /host cat /etc/containers/registries.conf | grep location > /dev/null 2>&1;echo $?)
- while [ $UPDATED -ne 0 ]; do
- sleep 2
- UPDATED=$(oc debug -q node/$node -- chroot /host cat /etc/containers/registries.conf | grep location > /dev/null 2>&1;echo $?)
- done
- echo "[$node] has been updated"
- done
-
- # copy quay pull secret into pipeline namespace
- echo -n "Copy quay pull secret into pipeline namespace ... "
- EXISTS=$(oc get secrets | grep quay-pull-secret > /dev/null 2>&1; echo $?)
- if [ $EXISTS -ne 0 ]; then
- oc get secret quay-pull-secret --namespace=devsecops-ci -oyaml | grep -v '\s*namespace:\s' | grep -v '\s*creationTimestamp:\s' | grep -v '\s*resourceVersion:\s' | grep -v '\s*uid:\s' | oc apply --namespace=devsecops-dev -f -
- echo "done"
- else
- echo " already exists"
- fi
-
-
- echo "Updating default service account"
- cat < /tmp/default-sa-update.json
- imagePullSecrets:
- - name: quay-pull-secret
- EOF
- oc patch --patch-file /tmp/default-sa-update.json sa/default -n devsecops-dev --type=merge
- echo "Done updating default service account"
----
-# Source: all-in-one/templates/cm-copy-acs-token.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: copy-acs-token
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- copy-acs-token.sh: |
- echo "Checking for acs-api-token existence"
- EXISTS=$(oc get secret acs-api-token -n stackrox > /dev/null 2>&1;echo $?)
- while [ $EXISTS -ne 0 ]; do
- sleep 2
- # copy acs-api-token secret into pipeline namespace
- EXISTS=$(oc get secret acs-api-token -n stackrox > /dev/null 2>&1;echo $?)
- done
- EXISTS=$(oc get secret acs-api-token -n devsecops-ci > /dev/null 2>&1;echo $?)
- if [ $EXISTS -ne 0 ]; then
- oc get secret acs-api-token --namespace=stackrox -oyaml | grep -v '\s*namespace:\s' |oc apply --namespace=devsecops-ci -f -
- else
- echo "The acs-api-token secret already exists in namespace devsecops-ci"
- fi
----
-# Source: all-in-one/templates/rbac/role-all-in-one.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: all-in-one-role
-rules:
- - apiGroups:
- - "*"
- resources:
- - "*"
- verbs:
- - "*"
----
-# Source: all-in-one/templates/rbac/rolebinding-all-in-one.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: all-in-one-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: all-in-one-role
-subjects:
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: stackrox
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: devsecops-ci
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: devsecops-dev
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: quay-enterprise
----
-# Source: all-in-one/templates/job-configure-all-in-one.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: configure-all-in-one
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/configure-all-in-one.sh'
- name: configure-all-in-one
- volumeMounts:
- - mountPath: /tmp/configure-all-in-one.sh
- name: configure-all-in-one
- subPath: configure-all-in-one.sh
- volumes:
- - name: configure-all-in-one
- configMap:
- name: configure-all-in-one
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: all-in-one-sa
- terminationGracePeriodSeconds: 60
----
-# Source: all-in-one/templates/job-copy-acs-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: hub-devel-copy-acs-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/copy-acs-token.sh'
- name: copy-acs-token
- volumeMounts:
- - mountPath: /tmp/copy-acs-token.sh
- name: copy-acs-token
- subPath: copy-acs-token.sh
- volumes:
- - name: copy-acs-token
- configMap:
- name: copy-acs-token
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: all-in-one-sa
- terminationGracePeriodSeconds: 60
diff --git a/tests/all-in-one-industrial-edge-hub.expected.yaml b/tests/all-in-one-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 82f44b15..00000000
--- a/tests/all-in-one-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,229 +0,0 @@
----
-# Source: all-in-one/templates/rbac/serviceaccount-all-in-one.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: all-in-one-sa
- labels:
- helm.sh/chart: all-in-one-0.1.0
- app.kubernetes.io/name: all-in-one
- app.kubernetes.io/instance: all-in-one
- app.kubernetes.io/version: "1.16.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: all-in-one/templates/cm-configure-all-in-one.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: configure-all-in-one
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- configure-all-in-one.sh: |
- echo -n "Checking if quay-enterpise namespace exists ..."
- EXISTS=$(oc get ns quay-enterprise > /dev/null 2>&1; echo $?)
-
- while [ $EXISTS -ne 0 ]; do
- sleep 3
- echo -n "."
- EXISTS=$(oc get ns quay-enterprise > /dev/null 2>&1; echo $?)
- done
- echo "done"
-
- sleep 2
- echo -n "Checking if route for Quay application exists ..."
- EXISTS=$(oc get route quay-registry-quay -n quay-enterprise > /dev/null 2>&1; echo $?)
- ##### oc get route -n quay-enterprise quay-registry-quay -o json > /dev/null 2>&1; echo $?
- while [ $EXISTS -ne 0 ]; do
- sleep 3
- echo -n "."
- EXISTS=$(oc get route quay-registry-quay -n quay-enterprise > /dev/null 2>&1; echo $?)
- done
- echo "done"
- sleep 2
-
- echo -n "Getting route for Quay application ..."
- #REGISTRY=$(oc get route -n quay-enterprise quay-registry-quay -o json | grep quay-registry-hostname | cut -d ':' -f 2 | tr -d '"' | tr -d ' ')
- REGISTRY=quay-registry-quay-quay-enterprise.apps.region.example.com
- echo "done"
- cat < /tmp/registry.json
- spec:
- registrySources:
- insecureRegistries:
- - $REGISTRY
- EOF
- oc patch --patch-file /tmp/registry.json image.config.openshift.io/cluster --type=merge
- sleep 2
-
- echo "Verify you config is updated"
- oc get image.config.openshift.io/cluster -o yaml
-
- echo "Checking to nodes for change"
-
- NODES=$(oc get nodes | grep -v NAME | awk '{print $1}')
-
- for node in $NODES; do
- echo "Checking [$node] for updates. This could take a while."
- UPDATED=$(oc debug -q node/$node -- chroot /host cat /etc/containers/registries.conf | grep location > /dev/null 2>&1;echo $?)
- while [ $UPDATED -ne 0 ]; do
- sleep 2
- UPDATED=$(oc debug -q node/$node -- chroot /host cat /etc/containers/registries.conf | grep location > /dev/null 2>&1;echo $?)
- done
- echo "[$node] has been updated"
- done
-
- # copy quay pull secret into pipeline namespace
- echo -n "Copy quay pull secret into pipeline namespace ... "
- EXISTS=$(oc get secrets | grep quay-pull-secret > /dev/null 2>&1; echo $?)
- if [ $EXISTS -ne 0 ]; then
- oc get secret quay-pull-secret --namespace=devsecops-ci -oyaml | grep -v '\s*namespace:\s' | grep -v '\s*creationTimestamp:\s' | grep -v '\s*resourceVersion:\s' | grep -v '\s*uid:\s' | oc apply --namespace=devsecops-dev -f -
- echo "done"
- else
- echo " already exists"
- fi
-
-
- echo "Updating default service account"
- cat < /tmp/default-sa-update.json
- imagePullSecrets:
- - name: quay-pull-secret
- EOF
- oc patch --patch-file /tmp/default-sa-update.json sa/default -n devsecops-dev --type=merge
- echo "Done updating default service account"
----
-# Source: all-in-one/templates/cm-copy-acs-token.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: copy-acs-token
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- copy-acs-token.sh: |
- echo "Checking for acs-api-token existence"
- EXISTS=$(oc get secret acs-api-token -n stackrox > /dev/null 2>&1;echo $?)
- while [ $EXISTS -ne 0 ]; do
- sleep 2
- # copy acs-api-token secret into pipeline namespace
- EXISTS=$(oc get secret acs-api-token -n stackrox > /dev/null 2>&1;echo $?)
- done
- EXISTS=$(oc get secret acs-api-token -n devsecops-ci > /dev/null 2>&1;echo $?)
- if [ $EXISTS -ne 0 ]; then
- oc get secret acs-api-token --namespace=stackrox -oyaml | grep -v '\s*namespace:\s' |oc apply --namespace=devsecops-ci -f -
- else
- echo "The acs-api-token secret already exists in namespace devsecops-ci"
- fi
----
-# Source: all-in-one/templates/rbac/role-all-in-one.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: all-in-one-role
-rules:
- - apiGroups:
- - "*"
- resources:
- - "*"
- verbs:
- - "*"
----
-# Source: all-in-one/templates/rbac/rolebinding-all-in-one.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: all-in-one-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: all-in-one-role
-subjects:
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: stackrox
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: devsecops-ci
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: devsecops-dev
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: quay-enterprise
----
-# Source: all-in-one/templates/job-configure-all-in-one.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: configure-all-in-one
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/configure-all-in-one.sh'
- name: configure-all-in-one
- volumeMounts:
- - mountPath: /tmp/configure-all-in-one.sh
- name: configure-all-in-one
- subPath: configure-all-in-one.sh
- volumes:
- - name: configure-all-in-one
- configMap:
- name: configure-all-in-one
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: all-in-one-sa
- terminationGracePeriodSeconds: 60
----
-# Source: all-in-one/templates/job-copy-acs-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: hub-devel-copy-acs-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/copy-acs-token.sh'
- name: copy-acs-token
- volumeMounts:
- - mountPath: /tmp/copy-acs-token.sh
- name: copy-acs-token
- subPath: copy-acs-token.sh
- volumes:
- - name: copy-acs-token
- configMap:
- name: copy-acs-token
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: all-in-one-sa
- terminationGracePeriodSeconds: 60
diff --git a/tests/all-in-one-medical-diagnosis-hub.expected.yaml b/tests/all-in-one-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 82f44b15..00000000
--- a/tests/all-in-one-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,229 +0,0 @@
----
-# Source: all-in-one/templates/rbac/serviceaccount-all-in-one.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: all-in-one-sa
- labels:
- helm.sh/chart: all-in-one-0.1.0
- app.kubernetes.io/name: all-in-one
- app.kubernetes.io/instance: all-in-one
- app.kubernetes.io/version: "1.16.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: all-in-one/templates/cm-configure-all-in-one.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: configure-all-in-one
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- configure-all-in-one.sh: |
- echo -n "Checking if quay-enterpise namespace exists ..."
- EXISTS=$(oc get ns quay-enterprise > /dev/null 2>&1; echo $?)
-
- while [ $EXISTS -ne 0 ]; do
- sleep 3
- echo -n "."
- EXISTS=$(oc get ns quay-enterprise > /dev/null 2>&1; echo $?)
- done
- echo "done"
-
- sleep 2
- echo -n "Checking if route for Quay application exists ..."
- EXISTS=$(oc get route quay-registry-quay -n quay-enterprise > /dev/null 2>&1; echo $?)
- ##### oc get route -n quay-enterprise quay-registry-quay -o json > /dev/null 2>&1; echo $?
- while [ $EXISTS -ne 0 ]; do
- sleep 3
- echo -n "."
- EXISTS=$(oc get route quay-registry-quay -n quay-enterprise > /dev/null 2>&1; echo $?)
- done
- echo "done"
- sleep 2
-
- echo -n "Getting route for Quay application ..."
- #REGISTRY=$(oc get route -n quay-enterprise quay-registry-quay -o json | grep quay-registry-hostname | cut -d ':' -f 2 | tr -d '"' | tr -d ' ')
- REGISTRY=quay-registry-quay-quay-enterprise.apps.region.example.com
- echo "done"
- cat < /tmp/registry.json
- spec:
- registrySources:
- insecureRegistries:
- - $REGISTRY
- EOF
- oc patch --patch-file /tmp/registry.json image.config.openshift.io/cluster --type=merge
- sleep 2
-
- echo "Verify you config is updated"
- oc get image.config.openshift.io/cluster -o yaml
-
- echo "Checking to nodes for change"
-
- NODES=$(oc get nodes | grep -v NAME | awk '{print $1}')
-
- for node in $NODES; do
- echo "Checking [$node] for updates. This could take a while."
- UPDATED=$(oc debug -q node/$node -- chroot /host cat /etc/containers/registries.conf | grep location > /dev/null 2>&1;echo $?)
- while [ $UPDATED -ne 0 ]; do
- sleep 2
- UPDATED=$(oc debug -q node/$node -- chroot /host cat /etc/containers/registries.conf | grep location > /dev/null 2>&1;echo $?)
- done
- echo "[$node] has been updated"
- done
-
- # copy quay pull secret into pipeline namespace
- echo -n "Copy quay pull secret into pipeline namespace ... "
- EXISTS=$(oc get secrets | grep quay-pull-secret > /dev/null 2>&1; echo $?)
- if [ $EXISTS -ne 0 ]; then
- oc get secret quay-pull-secret --namespace=devsecops-ci -oyaml | grep -v '\s*namespace:\s' | grep -v '\s*creationTimestamp:\s' | grep -v '\s*resourceVersion:\s' | grep -v '\s*uid:\s' | oc apply --namespace=devsecops-dev -f -
- echo "done"
- else
- echo " already exists"
- fi
-
-
- echo "Updating default service account"
- cat < /tmp/default-sa-update.json
- imagePullSecrets:
- - name: quay-pull-secret
- EOF
- oc patch --patch-file /tmp/default-sa-update.json sa/default -n devsecops-dev --type=merge
- echo "Done updating default service account"
----
-# Source: all-in-one/templates/cm-copy-acs-token.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: copy-acs-token
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- copy-acs-token.sh: |
- echo "Checking for acs-api-token existence"
- EXISTS=$(oc get secret acs-api-token -n stackrox > /dev/null 2>&1;echo $?)
- while [ $EXISTS -ne 0 ]; do
- sleep 2
- # copy acs-api-token secret into pipeline namespace
- EXISTS=$(oc get secret acs-api-token -n stackrox > /dev/null 2>&1;echo $?)
- done
- EXISTS=$(oc get secret acs-api-token -n devsecops-ci > /dev/null 2>&1;echo $?)
- if [ $EXISTS -ne 0 ]; then
- oc get secret acs-api-token --namespace=stackrox -oyaml | grep -v '\s*namespace:\s' |oc apply --namespace=devsecops-ci -f -
- else
- echo "The acs-api-token secret already exists in namespace devsecops-ci"
- fi
----
-# Source: all-in-one/templates/rbac/role-all-in-one.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: all-in-one-role
-rules:
- - apiGroups:
- - "*"
- resources:
- - "*"
- verbs:
- - "*"
----
-# Source: all-in-one/templates/rbac/rolebinding-all-in-one.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: all-in-one-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: all-in-one-role
-subjects:
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: stackrox
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: devsecops-ci
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: devsecops-dev
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: quay-enterprise
----
-# Source: all-in-one/templates/job-configure-all-in-one.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: configure-all-in-one
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/configure-all-in-one.sh'
- name: configure-all-in-one
- volumeMounts:
- - mountPath: /tmp/configure-all-in-one.sh
- name: configure-all-in-one
- subPath: configure-all-in-one.sh
- volumes:
- - name: configure-all-in-one
- configMap:
- name: configure-all-in-one
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: all-in-one-sa
- terminationGracePeriodSeconds: 60
----
-# Source: all-in-one/templates/job-copy-acs-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: hub-devel-copy-acs-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/copy-acs-token.sh'
- name: copy-acs-token
- volumeMounts:
- - mountPath: /tmp/copy-acs-token.sh
- name: copy-acs-token
- subPath: copy-acs-token.sh
- volumes:
- - name: copy-acs-token
- configMap:
- name: copy-acs-token
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: all-in-one-sa
- terminationGracePeriodSeconds: 60
diff --git a/tests/all-in-one-naked.expected.yaml b/tests/all-in-one-naked.expected.yaml
deleted file mode 100644
index f4364684..00000000
--- a/tests/all-in-one-naked.expected.yaml
+++ /dev/null
@@ -1,229 +0,0 @@
----
-# Source: all-in-one/templates/rbac/serviceaccount-all-in-one.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: all-in-one-sa
- labels:
- helm.sh/chart: all-in-one-0.1.0
- app.kubernetes.io/name: all-in-one
- app.kubernetes.io/instance: all-in-one
- app.kubernetes.io/version: "1.16.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: all-in-one/templates/cm-configure-all-in-one.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: configure-all-in-one
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- configure-all-in-one.sh: |
- echo -n "Checking if quay-enterpise namespace exists ..."
- EXISTS=$(oc get ns quay-enterprise > /dev/null 2>&1; echo $?)
-
- while [ $EXISTS -ne 0 ]; do
- sleep 3
- echo -n "."
- EXISTS=$(oc get ns quay-enterprise > /dev/null 2>&1; echo $?)
- done
- echo "done"
-
- sleep 2
- echo -n "Checking if route for Quay application exists ..."
- EXISTS=$(oc get route quay-registry-quay -n quay-enterprise > /dev/null 2>&1; echo $?)
- ##### oc get route -n quay-enterprise quay-registry-quay -o json > /dev/null 2>&1; echo $?
- while [ $EXISTS -ne 0 ]; do
- sleep 3
- echo -n "."
- EXISTS=$(oc get route quay-registry-quay -n quay-enterprise > /dev/null 2>&1; echo $?)
- done
- echo "done"
- sleep 2
-
- echo -n "Getting route for Quay application ..."
- #REGISTRY=$(oc get route -n quay-enterprise quay-registry-quay -o json | grep quay-registry-hostname | cut -d ':' -f 2 | tr -d '"' | tr -d ' ')
- REGISTRY=quay-registry-quay-quay-enterprise.apps.foo.com
- echo "done"
- cat < /tmp/registry.json
- spec:
- registrySources:
- insecureRegistries:
- - $REGISTRY
- EOF
- oc patch --patch-file /tmp/registry.json image.config.openshift.io/cluster --type=merge
- sleep 2
-
- echo "Verify you config is updated"
- oc get image.config.openshift.io/cluster -o yaml
-
- echo "Checking to nodes for change"
-
- NODES=$(oc get nodes | grep -v NAME | awk '{print $1}')
-
- for node in $NODES; do
- echo "Checking [$node] for updates. This could take a while."
- UPDATED=$(oc debug -q node/$node -- chroot /host cat /etc/containers/registries.conf | grep location > /dev/null 2>&1;echo $?)
- while [ $UPDATED -ne 0 ]; do
- sleep 2
- UPDATED=$(oc debug -q node/$node -- chroot /host cat /etc/containers/registries.conf | grep location > /dev/null 2>&1;echo $?)
- done
- echo "[$node] has been updated"
- done
-
- # copy quay pull secret into pipeline namespace
- echo -n "Copy quay pull secret into pipeline namespace ... "
- EXISTS=$(oc get secrets | grep quay-pull-secret > /dev/null 2>&1; echo $?)
- if [ $EXISTS -ne 0 ]; then
- oc get secret quay-pull-secret --namespace=devsecops-ci -oyaml | grep -v '\s*namespace:\s' | grep -v '\s*creationTimestamp:\s' | grep -v '\s*resourceVersion:\s' | grep -v '\s*uid:\s' | oc apply --namespace=devsecops-dev -f -
- echo "done"
- else
- echo " already exists"
- fi
-
-
- echo "Updating default service account"
- cat < /tmp/default-sa-update.json
- imagePullSecrets:
- - name: quay-pull-secret
- EOF
- oc patch --patch-file /tmp/default-sa-update.json sa/default -n devsecops-dev --type=merge
- echo "Done updating default service account"
----
-# Source: all-in-one/templates/cm-copy-acs-token.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: copy-acs-token
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- copy-acs-token.sh: |
- echo "Checking for acs-api-token existence"
- EXISTS=$(oc get secret acs-api-token -n stackrox > /dev/null 2>&1;echo $?)
- while [ $EXISTS -ne 0 ]; do
- sleep 2
- # copy acs-api-token secret into pipeline namespace
- EXISTS=$(oc get secret acs-api-token -n stackrox > /dev/null 2>&1;echo $?)
- done
- EXISTS=$(oc get secret acs-api-token -n devsecops-ci > /dev/null 2>&1;echo $?)
- if [ $EXISTS -ne 0 ]; then
- oc get secret acs-api-token --namespace=stackrox -oyaml | grep -v '\s*namespace:\s' |oc apply --namespace=devsecops-ci -f -
- else
- echo "The acs-api-token secret already exists in namespace devsecops-ci"
- fi
----
-# Source: all-in-one/templates/rbac/role-all-in-one.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: all-in-one-role
-rules:
- - apiGroups:
- - "*"
- resources:
- - "*"
- verbs:
- - "*"
----
-# Source: all-in-one/templates/rbac/rolebinding-all-in-one.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: all-in-one-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: all-in-one-role
-subjects:
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: stackrox
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: devsecops-ci
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: devsecops-dev
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: quay-enterprise
----
-# Source: all-in-one/templates/job-configure-all-in-one.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: configure-all-in-one
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/configure-all-in-one.sh'
- name: configure-all-in-one
- volumeMounts:
- - mountPath: /tmp/configure-all-in-one.sh
- name: configure-all-in-one
- subPath: configure-all-in-one.sh
- volumes:
- - name: configure-all-in-one
- configMap:
- name: configure-all-in-one
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: all-in-one-sa
- terminationGracePeriodSeconds: 60
----
-# Source: all-in-one/templates/job-copy-acs-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: hub-devel-copy-acs-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/copy-acs-token.sh'
- name: copy-acs-token
- volumeMounts:
- - mountPath: /tmp/copy-acs-token.sh
- name: copy-acs-token
- subPath: copy-acs-token.sh
- volumes:
- - name: copy-acs-token
- configMap:
- name: copy-acs-token
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: all-in-one-sa
- terminationGracePeriodSeconds: 60
diff --git a/tests/all-in-one-normal.expected.yaml b/tests/all-in-one-normal.expected.yaml
deleted file mode 100644
index 82f44b15..00000000
--- a/tests/all-in-one-normal.expected.yaml
+++ /dev/null
@@ -1,229 +0,0 @@
----
-# Source: all-in-one/templates/rbac/serviceaccount-all-in-one.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: all-in-one-sa
- labels:
- helm.sh/chart: all-in-one-0.1.0
- app.kubernetes.io/name: all-in-one
- app.kubernetes.io/instance: all-in-one
- app.kubernetes.io/version: "1.16.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: all-in-one/templates/cm-configure-all-in-one.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: configure-all-in-one
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- configure-all-in-one.sh: |
- echo -n "Checking if quay-enterpise namespace exists ..."
- EXISTS=$(oc get ns quay-enterprise > /dev/null 2>&1; echo $?)
-
- while [ $EXISTS -ne 0 ]; do
- sleep 3
- echo -n "."
- EXISTS=$(oc get ns quay-enterprise > /dev/null 2>&1; echo $?)
- done
- echo "done"
-
- sleep 2
- echo -n "Checking if route for Quay application exists ..."
- EXISTS=$(oc get route quay-registry-quay -n quay-enterprise > /dev/null 2>&1; echo $?)
- ##### oc get route -n quay-enterprise quay-registry-quay -o json > /dev/null 2>&1; echo $?
- while [ $EXISTS -ne 0 ]; do
- sleep 3
- echo -n "."
- EXISTS=$(oc get route quay-registry-quay -n quay-enterprise > /dev/null 2>&1; echo $?)
- done
- echo "done"
- sleep 2
-
- echo -n "Getting route for Quay application ..."
- #REGISTRY=$(oc get route -n quay-enterprise quay-registry-quay -o json | grep quay-registry-hostname | cut -d ':' -f 2 | tr -d '"' | tr -d ' ')
- REGISTRY=quay-registry-quay-quay-enterprise.apps.region.example.com
- echo "done"
- cat < /tmp/registry.json
- spec:
- registrySources:
- insecureRegistries:
- - $REGISTRY
- EOF
- oc patch --patch-file /tmp/registry.json image.config.openshift.io/cluster --type=merge
- sleep 2
-
- echo "Verify you config is updated"
- oc get image.config.openshift.io/cluster -o yaml
-
- echo "Checking to nodes for change"
-
- NODES=$(oc get nodes | grep -v NAME | awk '{print $1}')
-
- for node in $NODES; do
- echo "Checking [$node] for updates. This could take a while."
- UPDATED=$(oc debug -q node/$node -- chroot /host cat /etc/containers/registries.conf | grep location > /dev/null 2>&1;echo $?)
- while [ $UPDATED -ne 0 ]; do
- sleep 2
- UPDATED=$(oc debug -q node/$node -- chroot /host cat /etc/containers/registries.conf | grep location > /dev/null 2>&1;echo $?)
- done
- echo "[$node] has been updated"
- done
-
- # copy quay pull secret into pipeline namespace
- echo -n "Copy quay pull secret into pipeline namespace ... "
- EXISTS=$(oc get secrets | grep quay-pull-secret > /dev/null 2>&1; echo $?)
- if [ $EXISTS -ne 0 ]; then
- oc get secret quay-pull-secret --namespace=devsecops-ci -oyaml | grep -v '\s*namespace:\s' | grep -v '\s*creationTimestamp:\s' | grep -v '\s*resourceVersion:\s' | grep -v '\s*uid:\s' | oc apply --namespace=devsecops-dev -f -
- echo "done"
- else
- echo " already exists"
- fi
-
-
- echo "Updating default service account"
- cat < /tmp/default-sa-update.json
- imagePullSecrets:
- - name: quay-pull-secret
- EOF
- oc patch --patch-file /tmp/default-sa-update.json sa/default -n devsecops-dev --type=merge
- echo "Done updating default service account"
----
-# Source: all-in-one/templates/cm-copy-acs-token.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: copy-acs-token
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- copy-acs-token.sh: |
- echo "Checking for acs-api-token existence"
- EXISTS=$(oc get secret acs-api-token -n stackrox > /dev/null 2>&1;echo $?)
- while [ $EXISTS -ne 0 ]; do
- sleep 2
- # copy acs-api-token secret into pipeline namespace
- EXISTS=$(oc get secret acs-api-token -n stackrox > /dev/null 2>&1;echo $?)
- done
- EXISTS=$(oc get secret acs-api-token -n devsecops-ci > /dev/null 2>&1;echo $?)
- if [ $EXISTS -ne 0 ]; then
- oc get secret acs-api-token --namespace=stackrox -oyaml | grep -v '\s*namespace:\s' |oc apply --namespace=devsecops-ci -f -
- else
- echo "The acs-api-token secret already exists in namespace devsecops-ci"
- fi
----
-# Source: all-in-one/templates/rbac/role-all-in-one.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: all-in-one-role
-rules:
- - apiGroups:
- - "*"
- resources:
- - "*"
- verbs:
- - "*"
----
-# Source: all-in-one/templates/rbac/rolebinding-all-in-one.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: all-in-one-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: all-in-one-role
-subjects:
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: stackrox
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: devsecops-ci
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: devsecops-dev
- - kind: ServiceAccount
- name: all-in-one-sa
- namespace: quay-enterprise
----
-# Source: all-in-one/templates/job-configure-all-in-one.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: configure-all-in-one
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/configure-all-in-one.sh'
- name: configure-all-in-one
- volumeMounts:
- - mountPath: /tmp/configure-all-in-one.sh
- name: configure-all-in-one
- subPath: configure-all-in-one.sh
- volumes:
- - name: configure-all-in-one
- configMap:
- name: configure-all-in-one
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: all-in-one-sa
- terminationGracePeriodSeconds: 60
----
-# Source: all-in-one/templates/job-copy-acs-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: hub-devel-copy-acs-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/copy-acs-token.sh'
- name: copy-acs-token
- volumeMounts:
- - mountPath: /tmp/copy-acs-token.sh
- name: copy-acs-token
- subPath: copy-acs-token.sh
- volumes:
- - name: copy-acs-token
- configMap:
- name: copy-acs-token
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: all-in-one-sa
- terminationGracePeriodSeconds: 60
diff --git a/tests/common-acm-industrial-edge-factory.expected.yaml b/tests/common-acm-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 94c8254f..00000000
--- a/tests/common-acm-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,363 +0,0 @@
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-# This pushes out the HUB's Certificate Authorities on to the imported clusters
----
-# Source: acm/templates/policies/application-policies.yaml
-# TODO: Also create a GitOpsCluster.apps.open-cluster-management.io
----
-# Source: acm/templates/policies/private-repo-policies.yaml
-# We copy the vp-private-repo-credentials from the "openshift-gitops" namespace
-# to the "open-cluster-management" via the "private-hub-policy"
-#
-# Then we copy the secret from the "open-cluster-management" namespace to the
-# managed clusters "openshift-gitops" instance
-#
-# And we also copy the same secret to the namespaced argo's namespace
----
-# Source: acm/templates/multiclusterhub.yaml
-apiVersion: operator.open-cluster-management.io/v1
-kind: MultiClusterHub
-metadata:
- name: multiclusterhub
- namespace: open-cluster-management
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- installer.open-cluster-management.io/mce-subscription-spec: '{"source": "redhat-operators" }'
-spec: {}
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: openshift-gitops-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: openshift-gitops-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: openshift-gitops-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: openshift-gitops-placement-binding-argocd
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: openshift-gitops-placement-argocd
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: openshift-gitops-policy-argocd
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: openshift-gitops-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: openshift-gitops-placement-argocd
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: openshift-gitops-policy
- annotations:
- policy.open-cluster-management.io/standards: NIST-CSF
- policy.open-cluster-management.io/categories: PR.DS Data Security
- policy.open-cluster-management.io/controls: PR.DS-1 Data-at-rest
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: openshift-gitops-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- # This is an auto-generated file. DO NOT EDIT
- apiVersion: operators.coreos.com/v1alpha1
- kind: Subscription
- metadata:
- name: openshift-gitops-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/openshift-gitops-operator.openshift-operators: ''
- spec:
- channel: gitops-1.13
- installPlanApproval: Automatic
- name: openshift-gitops-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- config:
- env:
- - name: ARGOCD_CLUSTER_CONFIG_NAMESPACES
- value: "*"
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-ca-bundle
- namespace: openshift-gitops
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-# This policy depends on openshift-gitops-policy and the reason is that we need to be
-# certain that the trusted-ca-bundle exists before spawning the clusterwide argocd instance
-# because the initcontainer references the trusted-ca-bundle and if it starts without the
-# configmap being there we risk running an argo instances that won't trust public CAs
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: openshift-gitops-policy-argocd
- annotations:
- policy.open-cluster-management.io/standards: NIST-CSF
- policy.open-cluster-management.io/categories: PR.DS Data Security
- policy.open-cluster-management.io/controls: PR.DS-1 Data-at-rest
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- dependencies:
- - apiVersion: policy.open-cluster-management.io/v1
- compliance: Compliant
- kind: Policy
- name: openshift-gitops-policy
- namespace: open-cluster-management
- - apiVersion: policy.open-cluster-management.io/v1
- compliance: Compliant
- kind: Policy
- name: hub-argo-ca-openshift-gitops-policy
- namespace: open-cluster-management
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: openshift-gitops-config-argocd
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- apiVersion: argoproj.io/v1beta1
- kind: ArgoCD
- metadata:
- name: openshift-gitops
- namespace: openshift-gitops
- spec:
- applicationSet:
- resources:
- limits:
- cpu: "2"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 512Mi
- webhookServer:
- ingress:
- enabled: false
- route:
- enabled: false
- controller:
- processors: {}
- resources:
- limits:
- cpu: "2"
- memory: 2Gi
- requests:
- cpu: 250m
- memory: 1Gi
- sharding: {}
- grafana:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- route:
- enabled: false
- ha:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- initialSSHKnownHosts: {}
- monitoring:
- enabled: false
- notifications:
- enabled: false
- prometheus:
- enabled: false
- ingress:
- enabled: false
- route:
- enabled: false
- rbac:
- defaultPolicy: ""
- policy: |-
- g, system:cluster-admins, role:admin
- g, cluster-admins, role:admin
- scopes: '[groups]'
- redis:
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- repo:
- initContainers:
- - command:
- - bash
- - -c
- - cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt
- || true
- image: registry.redhat.io/ubi9/ubi-minimal:latest
- name: fetch-ca
- resources: {}
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 256Mi
- volumeMounts:
- - mountPath: /etc/pki/tls/certs
- name: ca-bundles
- volumes:
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - emptyDir: {}
- name: ca-bundles
- resourceExclusions: |-
- - apiGroups:
- - tekton.dev
- clusters:
- - '*'
- kinds:
- - TaskRun
- - PipelineRun
- server:
- autoscale:
- enabled: false
- grpc:
- ingress:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 125m
- memory: 128Mi
- route:
- enabled: true
- service:
- type: ""
- sso:
- dex:
- openShiftOAuth: true
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- provider: dex
- tls:
- ca: {}
diff --git a/tests/common-acm-industrial-edge-hub.expected.yaml b/tests/common-acm-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 00cf4e4d..00000000
--- a/tests/common-acm-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,733 +0,0 @@
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-# This pushes out the HUB's Certificate Authorities on to the imported clusters
----
-# Source: acm/templates/policies/private-repo-policies.yaml
-# We copy the vp-private-repo-credentials from the "openshift-gitops" namespace
-# to the "open-cluster-management" via the "private-hub-policy"
-#
-# Then we copy the secret from the "open-cluster-management" namespace to the
-# managed clusters "openshift-gitops" instance
-#
-# And we also copy the same secret to the namespaced argo's namespace
----
-# Source: acm/templates/multiclusterhub.yaml
-apiVersion: operator.open-cluster-management.io/v1
-kind: MultiClusterHub
-metadata:
- name: multiclusterhub
- namespace: open-cluster-management
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- installer.open-cluster-management.io/mce-subscription-spec: '{"source": "redhat-operators" }'
-spec: {}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acm-hub-ca-policy-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: acm-hub-ca-policy-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: acm-hub-ca-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: hub-argo-ca-openshift-gitops-policy-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: hub-argo-ca-openshift-gitops-policy-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: hub-argo-ca-openshift-gitops-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: hub-argo-ca-factory-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: hub-argo-ca-factory-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: hub-argo-ca-factory-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: factory-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: factory-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: factory-clustergroup-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: openshift-gitops-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: openshift-gitops-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: openshift-gitops-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: openshift-gitops-placement-binding-argocd
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: openshift-gitops-placement-argocd
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: openshift-gitops-policy-argocd
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acm-hub-ca-policy-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: hub-argo-ca-openshift-gitops-policy-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: hub-argo-ca-factory-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: factory-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector: {
- "matchExpressions": [
- {
- "key": "vendor",
- "operator": "In",
- "values": [
- "OpenShift"
- ]
- }
- ],
- "matchLabels": {
- "clusterGroup": "factory"
- }
-}
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: openshift-gitops-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: openshift-gitops-placement-argocd
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: acm-hub-ca-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acm-hub-ca-config-policy
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- apiVersion: v1
- type: Opaque
- metadata:
- name: hub-ca
- namespace: golang-external-secrets
- data:
- hub-kube-root-ca.crt: '{{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | base64enc hub}}'
- hub-openshift-service-ca.crt: '{{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | base64enc hub}}'
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: imperative
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: hub-argo-ca-openshift-gitops-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: hub-argo-ca-openshift-gitops-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: openshift-gitops
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: hub-argo-ca-factory-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: hub-argo-ca-factory-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: mypattern-factory
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/application-policies.yaml
-# TODO: Also create a GitOpsCluster.apps.open-cluster-management.io
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: factory-clustergroup-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: factory-clustergroup-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- apiVersion: argoproj.io/v1alpha1
- kind: Application
- metadata:
- name: mypattern-factory
- namespace: openshift-gitops
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
- spec:
- project: default
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-factory.yaml"
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}.yaml'
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}-{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}.yaml'
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}-factory.yaml'
- # We cannot use $.Values.global.clusterVersion because that gets resolved to the
- # hub's cluster version, whereas we want to include the spoke cluster version
- - '/values-{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}.yaml'
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.localClusterDomain
- value: '{{ (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain }}'
- - name: global.clusterDomain
- value: '{{ (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain | replace "apps." "" }}'
- - name: global.clusterVersion
- value: '{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}'
- - name: global.localClusterName
- value: '{{ (split "." (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain)._1 }}'
- - name: global.clusterPlatform
- value: aws
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- - name: clusterGroup.name
- value: factory
- - name: clusterGroup.isHubCluster
- value: "false"
- destination:
- server: https://kubernetes.default.svc
- namespace: mypattern-factory
- syncPolicy:
- automated:
- prune: false
- selfHeal: true
- retry:
- limit: 20
- ignoreDifferences:
- - group: apps
- kind: Deployment
- jsonPointers:
- - /spec/replicas
- - group: route.openshift.io
- kind: Route
- jsonPointers:
- - /status
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: openshift-gitops-policy
- annotations:
- policy.open-cluster-management.io/standards: NIST-CSF
- policy.open-cluster-management.io/categories: PR.DS Data Security
- policy.open-cluster-management.io/controls: PR.DS-1 Data-at-rest
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: openshift-gitops-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- # This is an auto-generated file. DO NOT EDIT
- apiVersion: operators.coreos.com/v1alpha1
- kind: Subscription
- metadata:
- name: openshift-gitops-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/openshift-gitops-operator.openshift-operators: ''
- spec:
- channel: gitops-1.13
- installPlanApproval: Automatic
- name: openshift-gitops-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- config:
- env:
- - name: ARGOCD_CLUSTER_CONFIG_NAMESPACES
- value: "*"
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-ca-bundle
- namespace: openshift-gitops
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-# This policy depends on openshift-gitops-policy and the reason is that we need to be
-# certain that the trusted-ca-bundle exists before spawning the clusterwide argocd instance
-# because the initcontainer references the trusted-ca-bundle and if it starts without the
-# configmap being there we risk running an argo instances that won't trust public CAs
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: openshift-gitops-policy-argocd
- annotations:
- policy.open-cluster-management.io/standards: NIST-CSF
- policy.open-cluster-management.io/categories: PR.DS Data Security
- policy.open-cluster-management.io/controls: PR.DS-1 Data-at-rest
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- dependencies:
- - apiVersion: policy.open-cluster-management.io/v1
- compliance: Compliant
- kind: Policy
- name: openshift-gitops-policy
- namespace: open-cluster-management
- - apiVersion: policy.open-cluster-management.io/v1
- compliance: Compliant
- kind: Policy
- name: hub-argo-ca-openshift-gitops-policy
- namespace: open-cluster-management
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: openshift-gitops-config-argocd
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- apiVersion: argoproj.io/v1beta1
- kind: ArgoCD
- metadata:
- name: openshift-gitops
- namespace: openshift-gitops
- spec:
- applicationSet:
- resources:
- limits:
- cpu: "2"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 512Mi
- webhookServer:
- ingress:
- enabled: false
- route:
- enabled: false
- controller:
- processors: {}
- resources:
- limits:
- cpu: "2"
- memory: 2Gi
- requests:
- cpu: 250m
- memory: 1Gi
- sharding: {}
- grafana:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- route:
- enabled: false
- ha:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- initialSSHKnownHosts: {}
- monitoring:
- enabled: false
- notifications:
- enabled: false
- prometheus:
- enabled: false
- ingress:
- enabled: false
- route:
- enabled: false
- rbac:
- defaultPolicy: ""
- policy: |-
- g, system:cluster-admins, role:admin
- g, cluster-admins, role:admin
- scopes: '[groups]'
- redis:
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- repo:
- initContainers:
- - command:
- - bash
- - -c
- - cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt
- || true
- image: registry.redhat.io/ubi9/ubi-minimal:latest
- name: fetch-ca
- resources: {}
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 256Mi
- volumeMounts:
- - mountPath: /etc/pki/tls/certs
- name: ca-bundles
- volumes:
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - emptyDir: {}
- name: ca-bundles
- resourceExclusions: |-
- - apiGroups:
- - tekton.dev
- clusters:
- - '*'
- kinds:
- - TaskRun
- - PipelineRun
- server:
- autoscale:
- enabled: false
- grpc:
- ingress:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 125m
- memory: 128Mi
- route:
- enabled: true
- service:
- type: ""
- sso:
- dex:
- openShiftOAuth: true
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- provider: dex
- tls:
- ca: {}
diff --git a/tests/common-acm-medical-diagnosis-hub.expected.yaml b/tests/common-acm-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 5fea58d0..00000000
--- a/tests/common-acm-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,724 +0,0 @@
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-# This pushes out the HUB's Certificate Authorities on to the imported clusters
----
-# Source: acm/templates/policies/private-repo-policies.yaml
-# We copy the vp-private-repo-credentials from the "openshift-gitops" namespace
-# to the "open-cluster-management" via the "private-hub-policy"
-#
-# Then we copy the secret from the "open-cluster-management" namespace to the
-# managed clusters "openshift-gitops" instance
-#
-# And we also copy the same secret to the namespaced argo's namespace
----
-# Source: acm/templates/multiclusterhub.yaml
-apiVersion: operator.open-cluster-management.io/v1
-kind: MultiClusterHub
-metadata:
- name: multiclusterhub
- namespace: open-cluster-management
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- installer.open-cluster-management.io/mce-subscription-spec: '{"source": "redhat-operators" }'
-spec: {}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acm-hub-ca-policy-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: acm-hub-ca-policy-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: acm-hub-ca-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: hub-argo-ca-openshift-gitops-policy-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: hub-argo-ca-openshift-gitops-policy-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: hub-argo-ca-openshift-gitops-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: hub-argo-ca-region-one-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: hub-argo-ca-region-one-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: hub-argo-ca-region-one-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: region-one-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: region-one-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: region-one-clustergroup-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: openshift-gitops-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: openshift-gitops-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: openshift-gitops-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: openshift-gitops-placement-binding-argocd
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: openshift-gitops-placement-argocd
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: openshift-gitops-policy-argocd
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acm-hub-ca-policy-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: hub-argo-ca-openshift-gitops-policy-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: hub-argo-ca-region-one-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: region-one-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector: {
- "matchLabels": {
- "clusterGroup": "region-one"
- }
-}
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: openshift-gitops-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: openshift-gitops-placement-argocd
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: acm-hub-ca-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acm-hub-ca-config-policy
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- apiVersion: v1
- type: Opaque
- metadata:
- name: hub-ca
- namespace: golang-external-secrets
- data:
- hub-kube-root-ca.crt: '{{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | base64enc hub}}'
- hub-openshift-service-ca.crt: '{{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | base64enc hub}}'
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: imperative
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: hub-argo-ca-openshift-gitops-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: hub-argo-ca-openshift-gitops-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: openshift-gitops
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: hub-argo-ca-region-one-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: hub-argo-ca-region-one-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: mypattern-region-one
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/application-policies.yaml
-# TODO: Also create a GitOpsCluster.apps.open-cluster-management.io
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: region-one-clustergroup-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: region-one-clustergroup-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- apiVersion: argoproj.io/v1alpha1
- kind: Application
- metadata:
- name: mypattern-region-one
- namespace: openshift-gitops
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
- spec:
- project: default
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-region-one.yaml"
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}.yaml'
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}-{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}.yaml'
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}-region-one.yaml'
- # We cannot use $.Values.global.clusterVersion because that gets resolved to the
- # hub's cluster version, whereas we want to include the spoke cluster version
- - '/values-{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}.yaml'
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.localClusterDomain
- value: '{{ (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain }}'
- - name: global.clusterDomain
- value: '{{ (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain | replace "apps." "" }}'
- - name: global.clusterVersion
- value: '{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}'
- - name: global.localClusterName
- value: '{{ (split "." (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain)._1 }}'
- - name: global.clusterPlatform
- value: aws
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- - name: clusterGroup.name
- value: region-one
- - name: clusterGroup.isHubCluster
- value: "false"
- destination:
- server: https://kubernetes.default.svc
- namespace: mypattern-region-one
- syncPolicy:
- automated:
- prune: false
- selfHeal: true
- retry:
- limit: 20
- ignoreDifferences:
- - group: apps
- kind: Deployment
- jsonPointers:
- - /spec/replicas
- - group: route.openshift.io
- kind: Route
- jsonPointers:
- - /status
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: openshift-gitops-policy
- annotations:
- policy.open-cluster-management.io/standards: NIST-CSF
- policy.open-cluster-management.io/categories: PR.DS Data Security
- policy.open-cluster-management.io/controls: PR.DS-1 Data-at-rest
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: openshift-gitops-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- # This is an auto-generated file. DO NOT EDIT
- apiVersion: operators.coreos.com/v1alpha1
- kind: Subscription
- metadata:
- name: openshift-gitops-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/openshift-gitops-operator.openshift-operators: ''
- spec:
- channel: gitops-1.13
- installPlanApproval: Automatic
- name: openshift-gitops-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- config:
- env:
- - name: ARGOCD_CLUSTER_CONFIG_NAMESPACES
- value: "*"
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-ca-bundle
- namespace: openshift-gitops
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-# This policy depends on openshift-gitops-policy and the reason is that we need to be
-# certain that the trusted-ca-bundle exists before spawning the clusterwide argocd instance
-# because the initcontainer references the trusted-ca-bundle and if it starts without the
-# configmap being there we risk running an argo instances that won't trust public CAs
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: openshift-gitops-policy-argocd
- annotations:
- policy.open-cluster-management.io/standards: NIST-CSF
- policy.open-cluster-management.io/categories: PR.DS Data Security
- policy.open-cluster-management.io/controls: PR.DS-1 Data-at-rest
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- dependencies:
- - apiVersion: policy.open-cluster-management.io/v1
- compliance: Compliant
- kind: Policy
- name: openshift-gitops-policy
- namespace: open-cluster-management
- - apiVersion: policy.open-cluster-management.io/v1
- compliance: Compliant
- kind: Policy
- name: hub-argo-ca-openshift-gitops-policy
- namespace: open-cluster-management
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: openshift-gitops-config-argocd
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- apiVersion: argoproj.io/v1beta1
- kind: ArgoCD
- metadata:
- name: openshift-gitops
- namespace: openshift-gitops
- spec:
- applicationSet:
- resources:
- limits:
- cpu: "2"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 512Mi
- webhookServer:
- ingress:
- enabled: false
- route:
- enabled: false
- controller:
- processors: {}
- resources:
- limits:
- cpu: "2"
- memory: 2Gi
- requests:
- cpu: 250m
- memory: 1Gi
- sharding: {}
- grafana:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- route:
- enabled: false
- ha:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- initialSSHKnownHosts: {}
- monitoring:
- enabled: false
- notifications:
- enabled: false
- prometheus:
- enabled: false
- ingress:
- enabled: false
- route:
- enabled: false
- rbac:
- defaultPolicy: ""
- policy: |-
- g, system:cluster-admins, role:admin
- g, cluster-admins, role:admin
- scopes: '[groups]'
- redis:
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- repo:
- initContainers:
- - command:
- - bash
- - -c
- - cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt
- || true
- image: registry.redhat.io/ubi9/ubi-minimal:latest
- name: fetch-ca
- resources: {}
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 256Mi
- volumeMounts:
- - mountPath: /etc/pki/tls/certs
- name: ca-bundles
- volumes:
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - emptyDir: {}
- name: ca-bundles
- resourceExclusions: |-
- - apiGroups:
- - tekton.dev
- clusters:
- - '*'
- kinds:
- - TaskRun
- - PipelineRun
- server:
- autoscale:
- enabled: false
- grpc:
- ingress:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 125m
- memory: 128Mi
- route:
- enabled: true
- service:
- type: ""
- sso:
- dex:
- openShiftOAuth: true
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- provider: dex
- tls:
- ca: {}
diff --git a/tests/common-acm-naked.expected.yaml b/tests/common-acm-naked.expected.yaml
deleted file mode 100644
index 94c8254f..00000000
--- a/tests/common-acm-naked.expected.yaml
+++ /dev/null
@@ -1,363 +0,0 @@
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-# This pushes out the HUB's Certificate Authorities on to the imported clusters
----
-# Source: acm/templates/policies/application-policies.yaml
-# TODO: Also create a GitOpsCluster.apps.open-cluster-management.io
----
-# Source: acm/templates/policies/private-repo-policies.yaml
-# We copy the vp-private-repo-credentials from the "openshift-gitops" namespace
-# to the "open-cluster-management" via the "private-hub-policy"
-#
-# Then we copy the secret from the "open-cluster-management" namespace to the
-# managed clusters "openshift-gitops" instance
-#
-# And we also copy the same secret to the namespaced argo's namespace
----
-# Source: acm/templates/multiclusterhub.yaml
-apiVersion: operator.open-cluster-management.io/v1
-kind: MultiClusterHub
-metadata:
- name: multiclusterhub
- namespace: open-cluster-management
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- installer.open-cluster-management.io/mce-subscription-spec: '{"source": "redhat-operators" }'
-spec: {}
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: openshift-gitops-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: openshift-gitops-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: openshift-gitops-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: openshift-gitops-placement-binding-argocd
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: openshift-gitops-placement-argocd
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: openshift-gitops-policy-argocd
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: openshift-gitops-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: openshift-gitops-placement-argocd
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: openshift-gitops-policy
- annotations:
- policy.open-cluster-management.io/standards: NIST-CSF
- policy.open-cluster-management.io/categories: PR.DS Data Security
- policy.open-cluster-management.io/controls: PR.DS-1 Data-at-rest
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: openshift-gitops-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- # This is an auto-generated file. DO NOT EDIT
- apiVersion: operators.coreos.com/v1alpha1
- kind: Subscription
- metadata:
- name: openshift-gitops-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/openshift-gitops-operator.openshift-operators: ''
- spec:
- channel: gitops-1.13
- installPlanApproval: Automatic
- name: openshift-gitops-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- config:
- env:
- - name: ARGOCD_CLUSTER_CONFIG_NAMESPACES
- value: "*"
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-ca-bundle
- namespace: openshift-gitops
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-# This policy depends on openshift-gitops-policy and the reason is that we need to be
-# certain that the trusted-ca-bundle exists before spawning the clusterwide argocd instance
-# because the initcontainer references the trusted-ca-bundle and if it starts without the
-# configmap being there we risk running an argo instances that won't trust public CAs
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: openshift-gitops-policy-argocd
- annotations:
- policy.open-cluster-management.io/standards: NIST-CSF
- policy.open-cluster-management.io/categories: PR.DS Data Security
- policy.open-cluster-management.io/controls: PR.DS-1 Data-at-rest
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- dependencies:
- - apiVersion: policy.open-cluster-management.io/v1
- compliance: Compliant
- kind: Policy
- name: openshift-gitops-policy
- namespace: open-cluster-management
- - apiVersion: policy.open-cluster-management.io/v1
- compliance: Compliant
- kind: Policy
- name: hub-argo-ca-openshift-gitops-policy
- namespace: open-cluster-management
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: openshift-gitops-config-argocd
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- apiVersion: argoproj.io/v1beta1
- kind: ArgoCD
- metadata:
- name: openshift-gitops
- namespace: openshift-gitops
- spec:
- applicationSet:
- resources:
- limits:
- cpu: "2"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 512Mi
- webhookServer:
- ingress:
- enabled: false
- route:
- enabled: false
- controller:
- processors: {}
- resources:
- limits:
- cpu: "2"
- memory: 2Gi
- requests:
- cpu: 250m
- memory: 1Gi
- sharding: {}
- grafana:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- route:
- enabled: false
- ha:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- initialSSHKnownHosts: {}
- monitoring:
- enabled: false
- notifications:
- enabled: false
- prometheus:
- enabled: false
- ingress:
- enabled: false
- route:
- enabled: false
- rbac:
- defaultPolicy: ""
- policy: |-
- g, system:cluster-admins, role:admin
- g, cluster-admins, role:admin
- scopes: '[groups]'
- redis:
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- repo:
- initContainers:
- - command:
- - bash
- - -c
- - cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt
- || true
- image: registry.redhat.io/ubi9/ubi-minimal:latest
- name: fetch-ca
- resources: {}
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 256Mi
- volumeMounts:
- - mountPath: /etc/pki/tls/certs
- name: ca-bundles
- volumes:
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - emptyDir: {}
- name: ca-bundles
- resourceExclusions: |-
- - apiGroups:
- - tekton.dev
- clusters:
- - '*'
- kinds:
- - TaskRun
- - PipelineRun
- server:
- autoscale:
- enabled: false
- grpc:
- ingress:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 125m
- memory: 128Mi
- route:
- enabled: true
- service:
- type: ""
- sso:
- dex:
- openShiftOAuth: true
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- provider: dex
- tls:
- ca: {}
diff --git a/tests/common-acm-normal.expected.yaml b/tests/common-acm-normal.expected.yaml
deleted file mode 100644
index 6823a01b..00000000
--- a/tests/common-acm-normal.expected.yaml
+++ /dev/null
@@ -1,1894 +0,0 @@
----
-# Source: acm/templates/provision/clusterdeployment.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: aws-cd-one-w-pool-acm-provision-edge
----
-# Source: acm/templates/provision/clusterdeployment.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: aws-ap-acm-provision-edge-install-config
-data:
- # Base64 encoding of install-config yaml
- install-config.yaml: CgphcGlWZXJzaW9uOiB2MQptZXRhZGF0YToKICBuYW1lOiAnYXdzLWFwJyAKYmFzZURvbWFpbjogYmx1ZXByaW50cy5yaGVjb2VuZy5jb20KY29udHJvbFBsYW5lOgogIGFyY2hpdGVjdHVyZTogYW1kNjQKICBoeXBlcnRocmVhZGluZzogRW5hYmxlZAogIG5hbWU6IGNvbnRyb2xQbGFuZQogIHJlcGxpY2FzOiAxCiAgcGxhdGZvcm06CiAgICBhd3M6CiAgICAgIHR5cGU6IG01LnhsYXJnZQpjb21wdXRlOgotIGh5cGVydGhyZWFkaW5nOiBFbmFibGVkCiAgYXJjaGl0ZWN0dXJlOiBhbWQ2NAogIG5hbWU6ICd3b3JrZXInCiAgcmVwbGljYXM6IDAKbmV0d29ya2luZzoKICBjbHVzdGVyTmV0d29yazoKICAtIGNpZHI6IDEwLjEyOC4wLjAvMTQKICAgIGhvc3RQcmVmaXg6IDIzCiAgbWFjaGluZU5ldHdvcms6CiAgLSBjaWRyOiAxMC4wLjAuMC8xNgogIG5ldHdvcmtUeXBlOiBPVk5LdWJlcm5ldGVzCiAgc2VydmljZU5ldHdvcms6CiAgLSAxNzIuMzAuMC4wLzE2CnBsYXRmb3JtOgogIGF3czoKICAgIHJlZ2lvbjogYXAtc291dGhlYXN0LTIKcHVsbFNlY3JldDogIiIgIyBza2lwLCBoaXZlIHdpbGwgaW5qZWN0IGJhc2VkIG9uIGl0J3Mgc2VjcmV0cwpzc2hLZXk6ICIiICAgICAjIHNraXAsIGhpdmUgd2lsbCBpbmplY3QgYmFzZWQgb24gaXQncyBzZWNyZXRz
-type: Opaque
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: azure-us-acm-provision-edge-install-config
-data:
- # Base64 encoding of install-config yaml
- install-config.yaml: CgphcGlWZXJzaW9uOiB2MQptZXRhZGF0YToKICBuYW1lOiAnYXp1cmUtdXMnIApiYXNlRG9tYWluOiBibHVlcHJpbnRzLnJoZWNvZW5nLmNvbQpjb250cm9sUGxhbmU6CiAgYXJjaGl0ZWN0dXJlOiBhbWQ2NAogIGh5cGVydGhyZWFkaW5nOiBFbmFibGVkCiAgbmFtZTogY29udHJvbFBsYW5lCiAgcmVwbGljYXM6IDMKICBwbGF0Zm9ybToKICAgIGF6dXJlOgogICAgICB0eXBlOiBTdGFuZGFyZF9EOHNfdjMKY29tcHV0ZToKLSBoeXBlcnRocmVhZGluZzogRW5hYmxlZAogIGFyY2hpdGVjdHVyZTogYW1kNjQKICBuYW1lOiAnd29ya2VyJwogIHJlcGxpY2FzOiAzCiAgcGxhdGZvcm06CiAgICBhenVyZToKICAgICAgdHlwZTogU3RhbmRhcmRfRDhzX3YzCm5ldHdvcmtpbmc6CiAgY2x1c3Rlck5ldHdvcms6CiAgLSBjaWRyOiAxMC4xMjguMC4wLzE0CiAgICBob3N0UHJlZml4OiAyMwogIG1hY2hpbmVOZXR3b3JrOgogIC0gY2lkcjogMTAuMC4wLjAvMTYKICBuZXR3b3JrVHlwZTogT1ZOS3ViZXJuZXRlcwogIHNlcnZpY2VOZXR3b3JrOgogIC0gMTcyLjMwLjAuMC8xNgpwbGF0Zm9ybToKICBhenVyZToKICAgIGJhc2VEb21haW5SZXNvdXJjZUdyb3VwTmFtZTogZG9qby1kbnMtem9uZXMKICAgIHJlZ2lvbjogZWFzdHVzCnB1bGxTZWNyZXQ6ICIiICMgc2tpcCwgaGl2ZSB3aWxsIGluamVjdCBiYXNlZCBvbiBpdCdzIHNlY3JldHMKc3NoS2V5OiAiIiAgICAgIyBza2lwLCBoaXZlIHdpbGwgaW5qZWN0IGJhc2VkIG9uIGl0J3Mgc2VjcmV0cw==
-type: Opaque
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: aws-cd-one-w-pool-acm-provision-edge-install-config
- namespace: aws-cd-one-w-pool-acm-provision-edge
-data:
- # Base64 encoding of install-config yaml
- install-config.yaml: CgphcGlWZXJzaW9uOiB2MQptZXRhZGF0YToKICBuYW1lOiAnYXdzLWNkLW9uZS13LXBvb2wnIApiYXNlRG9tYWluOiBibHVlcHJpbnRzLnJoZWNvZW5nLmNvbQpjb250cm9sUGxhbmU6CiAgYXJjaGl0ZWN0dXJlOiBhbWQ2NAogIGh5cGVydGhyZWFkaW5nOiBFbmFibGVkCiAgbmFtZTogY29udHJvbFBsYW5lCiAgcmVwbGljYXM6IDMKICBwbGF0Zm9ybToKICAgIGF3czoKICAgICAgdHlwZTogbTUueGxhcmdlCmNvbXB1dGU6Ci0gaHlwZXJ0aHJlYWRpbmc6IEVuYWJsZWQKICBhcmNoaXRlY3R1cmU6IGFtZDY0CiAgbmFtZTogJ3dvcmtlcicKICByZXBsaWNhczogMwogIHBsYXRmb3JtOgogICAgYXdzOgogICAgICB0eXBlOiBtNS54bGFyZ2UKbmV0d29ya2luZzoKICBjbHVzdGVyTmV0d29yazoKICAtIGNpZHI6IDEwLjEyOC4wLjAvMTQKICAgIGhvc3RQcmVmaXg6IDIzCiAgbWFjaGluZU5ldHdvcms6CiAgLSBjaWRyOiAxMC4wLjAuMC8xNgogIG5ldHdvcmtUeXBlOiBPVk5LdWJlcm5ldGVzCiAgc2VydmljZU5ldHdvcms6CiAgLSAxNzIuMzAuMC4wLzE2CnBsYXRmb3JtOgogIGF3czoKICAgIHJlZ2lvbjogYXAtc291dGhlYXN0LTEKcHVsbFNlY3JldDogIiIgIyBza2lwLCBoaXZlIHdpbGwgaW5qZWN0IGJhc2VkIG9uIGl0J3Mgc2VjcmV0cwpzc2hLZXk6ICIiICAgICAjIHNraXAsIGhpdmUgd2lsbCBpbmplY3QgYmFzZWQgb24gaXQncyBzZWNyZXRz
-type: Opaque
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-install-config
- namespace: aws-cd-two-wo-pool-acm-provision-on-deploy
-data:
- # Base64 encoding of install-config yaml
- install-config.yaml: CgphcGlWZXJzaW9uOiB2MQptZXRhZGF0YToKICBuYW1lOiAnYXdzLWNkLXR3by13by1wb29sJyAKYmFzZURvbWFpbjogYmx1ZXByaW50cy5yaGVjb2VuZy5jb20KY29udHJvbFBsYW5lOgogIGFyY2hpdGVjdHVyZTogYW1kNjQKICBoeXBlcnRocmVhZGluZzogRW5hYmxlZAogIG5hbWU6IGNvbnRyb2xQbGFuZQogIHJlcGxpY2FzOiAzCiAgcGxhdGZvcm06CiAgICBhd3M6CiAgICAgIHR5cGU6IG01LnhsYXJnZQpjb21wdXRlOgotIGh5cGVydGhyZWFkaW5nOiBFbmFibGVkCiAgYXJjaGl0ZWN0dXJlOiBhbWQ2NAogIG5hbWU6ICd3b3JrZXInCiAgcmVwbGljYXM6IDMKICBwbGF0Zm9ybToKICAgIGF3czoKICAgICAgdHlwZTogbTUueGxhcmdlCm5ldHdvcmtpbmc6CiAgY2x1c3Rlck5ldHdvcms6CiAgLSBjaWRyOiAxMC4xMjguMC4wLzE0CiAgICBob3N0UHJlZml4OiAyMwogIG1hY2hpbmVOZXR3b3JrOgogIC0gY2lkcjogMTAuMC4wLjAvMTYKICBuZXR3b3JrVHlwZTogT1ZOS3ViZXJuZXRlcwogIHNlcnZpY2VOZXR3b3JrOgogIC0gMTcyLjMwLjAuMC8xNgpwbGF0Zm9ybToKICBhd3M6CiAgICByZWdpb246IGFwLXNvdXRoZWFzdC0zCnB1bGxTZWNyZXQ6ICIiICMgc2tpcCwgaGl2ZSB3aWxsIGluamVjdCBiYXNlZCBvbiBpdCdzIHNlY3JldHMKc3NoS2V5OiAiIiAgICAgIyBza2lwLCBoaXZlIHdpbGwgaW5qZWN0IGJhc2VkIG9uIGl0J3Mgc2VjcmV0cw==
-type: Opaque
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-# This pushes out the HUB's Certificate Authorities on to the imported clusters
----
-# Source: acm/templates/policies/private-repo-policies.yaml
-# We copy the vp-private-repo-credentials from the "openshift-gitops" namespace
-# to the "open-cluster-management" via the "private-hub-policy"
-#
-# Then we copy the secret from the "open-cluster-management" namespace to the
-# managed clusters "openshift-gitops" instance
-#
-# And we also copy the same secret to the namespaced argo's namespace
----
-# Source: acm/templates/provision/clusterpool.yaml
-apiVersion: hive.openshift.io/v1
-kind: ClusterClaim
-metadata:
- name: 'two-acm-provision-edge'
- annotations:
- argocd.argoproj.io/sync-wave: "20"
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- cluster.open-cluster-management.io/createmanagedcluster: "true"
- labels:
- clusterClaimName: two-acm-provision-edge
- clusterGroup: region
-spec:
- clusterPoolName: azure-us-acm-provision-edge
----
-# Source: acm/templates/provision/clusterpool.yaml
-apiVersion: hive.openshift.io/v1
-kind: ClusterClaim
-metadata:
- name: 'three-acm-provision-edge'
- annotations:
- argocd.argoproj.io/sync-wave: "20"
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- cluster.open-cluster-management.io/createmanagedcluster: "true"
- labels:
- clusterClaimName: three-acm-provision-edge
- clusterGroup: region
-spec:
- clusterPoolName: azure-us-acm-provision-edge
----
-# Source: acm/templates/provision/clusterdeployment.yaml
-apiVersion: hive.openshift.io/v1
-kind: ClusterDeployment
-metadata:
- name: aws-cd-one-w-pool-acm-provision-edge
- namespace: aws-cd-one-w-pool-acm-provision-edge
- labels:
- vendor: OpenShift
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- baseDomain: blueprints.rhecoeng.com
- clusterName: aws-cd-one-w-pool-acm-provision-edge
- installAttemptsLimit: 1
- platform:
- aws:
- credentialsSecretRef:
- name: aws-cd-one-w-pool-acm-provision-edge-creds
- region: ap-southeast-1
- provisioning:
- installConfigSecretRef:
- name: aws-cd-one-w-pool-acm-provision-edge-install-config
- sshPrivateKeySecretRef:
- name: aws-cd-one-w-pool-acm-provision-edge-ssh-private-key
- imageSetRef:
- name: img4.10.18-multi-appsub
- pullSecretRef:
- name: aws-cd-one-w-pool-acm-provision-edge-pull-secret
----
-# Source: acm/templates/provision/clusterdeployment.yaml
-apiVersion: hive.openshift.io/v1
-kind: ClusterDeployment
-metadata:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy
- namespace: aws-cd-two-wo-pool-acm-provision-on-deploy
- labels:
- vendor: OpenShift
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- baseDomain: blueprints.rhecoeng.com
- clusterName: aws-cd-two-wo-pool-acm-provision-on-deploy
- installAttemptsLimit: 1
- platform:
- aws:
- credentialsSecretRef:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-creds
- region: ap-southeast-3
- provisioning:
- installConfigSecretRef:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-install-config
- sshPrivateKeySecretRef:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-ssh-private-key
- imageSetRef:
- name: img4.10.18-multi-appsub
- pullSecretRef:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-pull-secret
----
-# Source: acm/templates/provision/clusterpool.yaml
-apiVersion: hive.openshift.io/v1
-kind: ClusterPool
-metadata:
- name: "aws-ap-acm-provision-edge"
- annotations:
- argocd.argoproj.io/sync-wave: "10"
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- labels:
- cloud: aws
- region: 'ap-southeast-2'
- vendor: OpenShift
- cluster.open-cluster-management.io/clusterset: aws-ap
-spec:
- size: 3
- runningCount: 0
- baseDomain: blueprints.rhecoeng.com
- installConfigSecretTemplateRef:
- name: aws-ap-acm-provision-edge-install-config
- imageSetRef:
- name: img4.10.18-multi-appsub
- pullSecretRef:
- name: aws-ap-acm-provision-edge-pull-secret
- skipMachinePools: true # Disable MachinePool as using custom install-config
- platform:
- aws:
- credentialsSecretRef:
- name: aws-ap-acm-provision-edge-creds
- region: ap-southeast-2
----
-# Source: acm/templates/provision/clusterpool.yaml
-apiVersion: hive.openshift.io/v1
-kind: ClusterPool
-metadata:
- name: "azure-us-acm-provision-edge"
- annotations:
- argocd.argoproj.io/sync-wave: "10"
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- labels:
- cloud: azure
- region: 'eastus'
- vendor: OpenShift
- cluster.open-cluster-management.io/clusterset: azure-us
-spec:
- size: 2
- runningCount: 2
- baseDomain: blueprints.rhecoeng.com
- installConfigSecretTemplateRef:
- name: azure-us-acm-provision-edge-install-config
- imageSetRef:
- name: img4.10.18-multi-appsub
- pullSecretRef:
- name: azure-us-acm-provision-edge-pull-secret
- skipMachinePools: true # Disable MachinePool as using custom install-config
- platform:
- azure:
- credentialsSecretRef:
- name: azure-us-acm-provision-edge-creds
- region: eastus
----
-# Source: acm/templates/provision/secrets-aws.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-ap-acm-provision-edge-creds
-spec:
- dataFrom:
- - extract:
- # Expects entries called: aws_access_key_id and aws_secret_access_key
- key: secret/data/hub/aws
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-ap-acm-provision-edge-creds
- creationPolicy: Owner
- template:
- type: Opaque
----
-# Source: acm/templates/provision/secrets-aws.yaml
-# For use when manually creating clusters with ACM
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-ap-acm-provision-edge-infra-creds
-spec:
- data:
- - secretKey: openshiftPullSecret
- remoteRef:
- key: secret/data/hub/openshiftPullSecret
- property: content
- - secretKey: awsKeyId
- remoteRef:
- key: secret/data/hub/aws
- property: aws_access_key_id
- - secretKey: awsAccessKey
- remoteRef:
- key: secret/data/hub/aws
- property: aws_secret_access_key
- - secretKey: sshPublicKey
- remoteRef:
- key: secret/data/hub/publickey
- property: content
- - secretKey: sshPrivateKey
- remoteRef:
- key: secret/data/hub/privatekey
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-ap-acm-provision-edge-infra-creds
- creationPolicy: Owner
- template:
- type: Opaque
- metadata:
- labels:
- cluster.open-cluster-management.io/credentials: ""
- cluster.open-cluster-management.io/type: aws
- data:
- baseDomain: "blueprints.rhecoeng.com"
- pullSecret: |-
- {{ .openshiftPullSecret | toString }}
- aws_access_key_id: |-
- {{ .awsKeyId | toString }}
- aws_secret_access_key: |-
- {{ .awsAccessKey | toString }}
- ssh-privatekey: |-
- {{ .sshPrivateKey | toString }}
- ssh-publickey: |-
- {{ .sshPublicKey | toString }}
- httpProxy: ""
- httpsProxy: ""
- noProxy: ""
- additionalTrustBundle: ""
----
-# Source: acm/templates/provision/secrets-aws.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-cd-one-w-pool-acm-provision-edge-creds
- namespace: aws-cd-one-w-pool-acm-provision-edge
-spec:
- dataFrom:
- - extract:
- # Expects entries called: aws_access_key_id and aws_secret_access_key
- key: secret/data/hub/aws
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-cd-one-w-pool-acm-provision-edge-creds
- creationPolicy: Owner
- template:
- type: Opaque
----
-# Source: acm/templates/provision/secrets-aws.yaml
-# For use when manually creating clusters with ACM
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-cd-one-w-pool-acm-provision-edge-infra-creds
- namespace: aws-cd-one-w-pool-acm-provision-edge
-spec:
- data:
- - secretKey: openshiftPullSecret
- remoteRef:
- key: secret/data/hub/openshiftPullSecret
- property: content
- - secretKey: awsKeyId
- remoteRef:
- key: secret/data/hub/aws
- property: aws_access_key_id
- - secretKey: awsAccessKey
- remoteRef:
- key: secret/data/hub/aws
- property: aws_secret_access_key
- - secretKey: sshPublicKey
- remoteRef:
- key: secret/data/hub/publickey
- property: content
- - secretKey: sshPrivateKey
- remoteRef:
- key: secret/data/hub/privatekey
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-cd-one-w-pool-acm-provision-edge-infra-creds
- creationPolicy: Owner
- template:
- type: Opaque
- metadata:
- labels:
- cluster.open-cluster-management.io/credentials: ""
- cluster.open-cluster-management.io/type: aws
- data:
- baseDomain: "blueprints.rhecoeng.com"
- pullSecret: |-
- {{ .openshiftPullSecret | toString }}
- aws_access_key_id: |-
- {{ .awsKeyId | toString }}
- aws_secret_access_key: |-
- {{ .awsAccessKey | toString }}
- ssh-privatekey: |-
- {{ .sshPrivateKey | toString }}
- ssh-publickey: |-
- {{ .sshPublicKey | toString }}
- httpProxy: ""
- httpsProxy: ""
- noProxy: ""
- additionalTrustBundle: ""
----
-# Source: acm/templates/provision/secrets-aws.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-creds
- namespace: aws-cd-two-wo-pool-acm-provision-on-deploy
-spec:
- dataFrom:
- - extract:
- # Expects entries called: aws_access_key_id and aws_secret_access_key
- key: secret/data/hub/aws
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-creds
- creationPolicy: Owner
- template:
- type: Opaque
----
-# Source: acm/templates/provision/secrets-aws.yaml
-# For use when manually creating clusters with ACM
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-infra-creds
- namespace: aws-cd-two-wo-pool-acm-provision-on-deploy
-spec:
- data:
- - secretKey: openshiftPullSecret
- remoteRef:
- key: secret/data/hub/openshiftPullSecret
- property: content
- - secretKey: awsKeyId
- remoteRef:
- key: secret/data/hub/aws
- property: aws_access_key_id
- - secretKey: awsAccessKey
- remoteRef:
- key: secret/data/hub/aws
- property: aws_secret_access_key
- - secretKey: sshPublicKey
- remoteRef:
- key: secret/data/hub/publickey
- property: content
- - secretKey: sshPrivateKey
- remoteRef:
- key: secret/data/hub/privatekey
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-infra-creds
- creationPolicy: Owner
- template:
- type: Opaque
- metadata:
- labels:
- cluster.open-cluster-management.io/credentials: ""
- cluster.open-cluster-management.io/type: aws
- data:
- baseDomain: "blueprints.rhecoeng.com"
- pullSecret: |-
- {{ .openshiftPullSecret | toString }}
- aws_access_key_id: |-
- {{ .awsKeyId | toString }}
- aws_secret_access_key: |-
- {{ .awsAccessKey | toString }}
- ssh-privatekey: |-
- {{ .sshPrivateKey | toString }}
- ssh-publickey: |-
- {{ .sshPublicKey | toString }}
- httpProxy: ""
- httpsProxy: ""
- noProxy: ""
- additionalTrustBundle: ""
----
-# Source: acm/templates/provision/secrets-azure.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: azure-us-acm-provision-edge-creds
-spec:
- data:
- - secretKey: azureOsServicePrincipal
- remoteRef:
- key: secret/data/hub/azureOsServicePrincipal
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: azure-us-acm-provision-edge-creds
- creationPolicy: Owner
- template:
- type: Opaque
- data:
- osServicePrincipal.json: |-
- {{ .azureOsServicePrincipal | toString }}
----
-# Source: acm/templates/provision/secrets-azure.yaml
-# For use when manually creating clusters with ACM
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: azure-us-acm-provision-edge-infra-creds
-spec:
- data:
- - secretKey: openshiftPullSecret
- remoteRef:
- key: secret/data/hub/openshiftPullSecret
- property: content
- - secretKey: sshPublicKey
- remoteRef:
- key: secret/data/hub/publickey
- property: content
- - secretKey: sshPrivateKey
- remoteRef:
- key: secret/data/hub/privatekey
- property: content
- - secretKey: azureOsServicePrincipal
- remoteRef:
- key: secret/data/hub/azureOsServicePrincipal
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: azure-us-acm-provision-edge-infra-creds
- creationPolicy: Owner
- template:
- type: Opaque
- metadata:
- labels:
- cluster.open-cluster-management.io/credentials: ""
- cluster.open-cluster-management.io/type: aws
- data:
- cloudName: AzurePublicCloud
- osServicePrincipal.json: |-
- {{ .azureOsServicePrincipal | toString }}
- baseDomain: "blueprints.rhecoeng.com"
- baseDomainResourceGroupName: "dojo-dns-zones"
- pullSecret: |-
- {{ .openshiftPullSecret | toString }}
- ssh-privatekey: |-
- {{ .sshPrivateKey | toString }}
- ssh-publickey: |-
- {{ .sshPublicKey | toString }}
- httpProxy: ""
- httpsProxy: ""
- noProxy: ""
- additionalTrustBundle: ""
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-ap-acm-provision-edge-pull-secret
-spec:
- data:
- - secretKey: openshiftPullSecret
- remoteRef:
- key: secret/data/hub/openshiftPullSecret
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-ap-acm-provision-edge-pull-secret
- creationPolicy: Owner
- template:
- type: kubernetes.io/dockerconfigjson
- data:
- .dockerconfigjson: |-
- {{ .openshiftPullSecret | toString }}
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-ap-acm-provision-edge-ssh-private-key
-spec:
- data:
- - secretKey: sshPrivateKey
- remoteRef:
- key: secret/data/hub/privatekey
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-ap-acm-provision-edge-ssh-private-key
- creationPolicy: Owner
- template:
- type: Opaque
- data:
- ssh-privatekey: |-
- {{ .sshPrivateKey | toString }}
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: azure-us-acm-provision-edge-pull-secret
-spec:
- data:
- - secretKey: openshiftPullSecret
- remoteRef:
- key: secret/data/hub/openshiftPullSecret
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: azure-us-acm-provision-edge-pull-secret
- creationPolicy: Owner
- template:
- type: kubernetes.io/dockerconfigjson
- data:
- .dockerconfigjson: |-
- {{ .openshiftPullSecret | toString }}
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: azure-us-acm-provision-edge-ssh-private-key
-spec:
- data:
- - secretKey: sshPrivateKey
- remoteRef:
- key: secret/data/hub/privatekey
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: azure-us-acm-provision-edge-ssh-private-key
- creationPolicy: Owner
- template:
- type: Opaque
- data:
- ssh-privatekey: |-
- {{ .sshPrivateKey | toString }}
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-cd-one-w-pool-acm-provision-edge-pull-secret
- namespace: aws-cd-one-w-pool-acm-provision-edge
-spec:
- data:
- - secretKey: openshiftPullSecret
- remoteRef:
- key: secret/data/hub/openshiftPullSecret
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-cd-one-w-pool-acm-provision-edge-pull-secret
- creationPolicy: Owner
- template:
- type: kubernetes.io/dockerconfigjson
- data:
- .dockerconfigjson: |-
- {{ .openshiftPullSecret | toString }}
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-cd-one-w-pool-acm-provision-edge-ssh-private-key
- namespace: aws-cd-one-w-pool-acm-provision-edge
-spec:
- data:
- - secretKey: sshPrivateKey
- remoteRef:
- key: secret/data/hub/privatekey
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-cd-one-w-pool-acm-provision-edge-ssh-private-key
- creationPolicy: Owner
- template:
- type: Opaque
- data:
- ssh-privatekey: |-
- {{ .sshPrivateKey | toString }}
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-pull-secret
- namespace: aws-cd-two-wo-pool-acm-provision-on-deploy
-spec:
- data:
- - secretKey: openshiftPullSecret
- remoteRef:
- key: secret/data/hub/openshiftPullSecret
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-pull-secret
- creationPolicy: Owner
- template:
- type: kubernetes.io/dockerconfigjson
- data:
- .dockerconfigjson: |-
- {{ .openshiftPullSecret | toString }}
----
-# Source: acm/templates/provision/secrets-common.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-ssh-private-key
- namespace: aws-cd-two-wo-pool-acm-provision-on-deploy
-spec:
- data:
- - secretKey: sshPrivateKey
- remoteRef:
- key: secret/data/hub/privatekey
- property: content
- refreshInterval: 24h0m0s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: aws-cd-two-wo-pool-acm-provision-on-deploy-ssh-private-key
- creationPolicy: Owner
- template:
- type: Opaque
- data:
- ssh-privatekey: |-
- {{ .sshPrivateKey | toString }}
----
-# Source: acm/templates/provision/clusterdeployment.yaml
-apiVersion: cluster.open-cluster-management.io/v1
-kind: ManagedCluster
-metadata:
- labels:
- cluster.open-cluster-management.io/clusterset: acm-provision-edge
- clusterGroup: region
- name: aws-cd-one-w-pool-acm-provision-edge
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- hubAcceptsClient: true
----
-# Source: acm/templates/provision/clusterdeployment.yaml
-apiVersion: cluster.open-cluster-management.io/v1
-kind: ManagedCluster
-metadata:
- labels:
- cluster.open-cluster-management.io/clusterset: acm-provision-on-deploy
- clusterGroup: acm-provision-on-deploy
- name: aws-cd-two-wo-pool-acm-provision-on-deploy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- hubAcceptsClient: true
----
-# Source: acm/templates/provision/managedclusterset.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta2
-kind: ManagedClusterSet
-metadata:
- annotations:
- cluster.open-cluster-management.io/submariner-broker-ns: acm-provision-edge-broker
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- name: acm-provision-edge
----
-# Source: acm/templates/provision/managedclusterset.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta2
-kind: ManagedClusterSet
-metadata:
- annotations:
- cluster.open-cluster-management.io/submariner-broker-ns: acm-provision-on-deploy-broker
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- name: acm-provision-on-deploy
----
-# Source: acm/templates/multiclusterhub.yaml
-apiVersion: operator.open-cluster-management.io/v1
-kind: MultiClusterHub
-metadata:
- name: multiclusterhub
- namespace: open-cluster-management
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- installer.open-cluster-management.io/mce-subscription-spec: '{"source": "redhat-operators" }'
-spec: {}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acm-hub-ca-policy-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: acm-hub-ca-policy-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: acm-hub-ca-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: hub-argo-ca-openshift-gitops-policy-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: hub-argo-ca-openshift-gitops-policy-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: hub-argo-ca-openshift-gitops-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: hub-argo-ca-acm-edge-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: hub-argo-ca-acm-edge-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: hub-argo-ca-acm-edge-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: hub-argo-ca-acm-provision-edge-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: hub-argo-ca-acm-provision-edge-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: hub-argo-ca-acm-provision-edge-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: hub-argo-ca-acm-provision-on-deploy-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: hub-argo-ca-acm-provision-on-deploy-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: hub-argo-ca-acm-provision-on-deploy-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acm-edge-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: acm-edge-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: acm-edge-clustergroup-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acm-provision-edge-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: acm-provision-edge-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: acm-provision-edge-clustergroup-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acm-provision-on-deploy-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: acm-provision-on-deploy-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: acm-provision-on-deploy-clustergroup-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: openshift-gitops-placement-binding
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: openshift-gitops-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: openshift-gitops-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: openshift-gitops-placement-binding-argocd
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-placementRef:
- name: openshift-gitops-placement-argocd
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: openshift-gitops-policy-argocd
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acm-hub-ca-policy-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: hub-argo-ca-openshift-gitops-policy-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: hub-argo-ca-acm-edge-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: hub-argo-ca-acm-provision-edge-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: hub-argo-ca-acm-provision-on-deploy-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acm-edge-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchLabels:
- clusterGroup: acm-region
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acm-provision-edge-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchLabels:
- clusterGroup: region
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acm-provision-on-deploy-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchLabels:
- clusterGroup: acm-provision-on-deploy
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: openshift-gitops-placement
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: openshift-gitops-placement-argocd
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: local-cluster
- operator: NotIn
- values:
- - 'true'
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: acm-hub-ca-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acm-hub-ca-config-policy
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- apiVersion: v1
- type: Opaque
- metadata:
- name: hub-ca
- namespace: golang-external-secrets
- data:
- hub-kube-root-ca.crt: '{{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | base64enc hub}}'
- hub-openshift-service-ca.crt: '{{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | base64enc hub}}'
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: imperative
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: hub-argo-ca-openshift-gitops-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: hub-argo-ca-openshift-gitops-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: openshift-gitops
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: hub-argo-ca-acm-edge-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: hub-argo-ca-acm-edge-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: mypattern-acm-edge
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: hub-argo-ca-acm-provision-edge-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: hub-argo-ca-acm-provision-edge-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: mypattern-acm-provision-edge
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/acm-hub-ca-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: hub-argo-ca-acm-provision-on-deploy-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: hub-argo-ca-acm-provision-on-deploy-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-hub-bundle
- namespace: mypattern-acm-provision-on-deploy
- data:
- hub-kube-root-ca.crt: |
- {{hub fromConfigMap "" "kube-root-ca.crt" "ca.crt" | autoindent hub}}
- hub-openshift-service-ca.crt: |
- {{hub fromConfigMap "" "openshift-service-ca.crt" "service-ca.crt" | autoindent hub}}
----
-# Source: acm/templates/policies/application-policies.yaml
-# TODO: Also create a GitOpsCluster.apps.open-cluster-management.io
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: acm-edge-clustergroup-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acm-edge-clustergroup-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- apiVersion: argoproj.io/v1alpha1
- kind: Application
- metadata:
- name: mypattern-acm-edge
- namespace: openshift-gitops
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
- spec:
- project: default
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-acm-edge.yaml"
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}.yaml'
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}-{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}.yaml'
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}-acm-edge.yaml'
- # We cannot use $.Values.global.clusterVersion because that gets resolved to the
- # hub's cluster version, whereas we want to include the spoke cluster version
- - '/values-{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}.yaml'
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.localClusterDomain
- value: '{{ (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain }}'
- - name: global.clusterDomain
- value: '{{ (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain | replace "apps." "" }}'
- - name: global.clusterVersion
- value: '{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}'
- - name: global.localClusterName
- value: '{{ (split "." (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain)._1 }}'
- - name: global.clusterPlatform
- value: aws
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- - name: clusterGroup.name
- value: acm-edge
- - name: clusterGroup.isHubCluster
- value: "false"
- destination:
- server: https://kubernetes.default.svc
- namespace: mypattern-acm-edge
- syncPolicy:
- automated:
- prune: false
- selfHeal: true
- retry:
- limit: 20
- ignoreDifferences:
- - group: apps
- kind: Deployment
- jsonPointers:
- - /spec/replicas
- - group: route.openshift.io
- kind: Route
- jsonPointers:
- - /status
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: acm-provision-edge-clustergroup-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acm-provision-edge-clustergroup-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- apiVersion: argoproj.io/v1alpha1
- kind: Application
- metadata:
- name: mypattern-acm-provision-edge
- namespace: openshift-gitops
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
- spec:
- project: default
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-acm-provision-edge.yaml"
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}.yaml'
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}-{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}.yaml'
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}-acm-provision-edge.yaml'
- # We cannot use $.Values.global.clusterVersion because that gets resolved to the
- # hub's cluster version, whereas we want to include the spoke cluster version
- - '/values-{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}.yaml'
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.localClusterDomain
- value: '{{ (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain }}'
- - name: global.clusterDomain
- value: '{{ (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain | replace "apps." "" }}'
- - name: global.clusterVersion
- value: '{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}'
- - name: global.localClusterName
- value: '{{ (split "." (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain)._1 }}'
- - name: global.clusterPlatform
- value: aws
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- - name: clusterGroup.name
- value: acm-provision-edge
- - name: clusterGroup.isHubCluster
- value: "false"
- destination:
- server: https://kubernetes.default.svc
- namespace: mypattern-acm-provision-edge
- syncPolicy:
- automated:
- prune: false
- selfHeal: true
- retry:
- limit: 20
- ignoreDifferences:
- - group: apps
- kind: Deployment
- jsonPointers:
- - /spec/replicas
- - group: route.openshift.io
- kind: Route
- jsonPointers:
- - /status
----
-# Source: acm/templates/policies/application-policies.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: acm-provision-on-deploy-clustergroup-policy
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acm-provision-on-deploy-clustergroup-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- apiVersion: argoproj.io/v1alpha1
- kind: Application
- metadata:
- name: mypattern-acm-provision-on-deploy
- namespace: openshift-gitops
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
- spec:
- project: default
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-acm-provision-on-deploy.yaml"
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}.yaml'
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}-{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}.yaml'
- - '/values-{{ (lookup "config.openshift.io/v1" "Infrastructure" "" "cluster").spec.platformSpec.type }}-acm-provision-on-deploy.yaml'
- # We cannot use $.Values.global.clusterVersion because that gets resolved to the
- # hub's cluster version, whereas we want to include the spoke cluster version
- - '/values-{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}.yaml'
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.localClusterDomain
- value: '{{ (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain }}'
- - name: global.clusterDomain
- value: '{{ (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain | replace "apps." "" }}'
- - name: global.clusterVersion
- value: '{{ printf "%d.%d" ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Major) ((semver (index (lookup "config.openshift.io/v1" "ClusterVersion" "" "version").status.history 0).version).Minor) }}'
- - name: global.localClusterName
- value: '{{ (split "." (lookup "config.openshift.io/v1" "Ingress" "" "cluster").spec.domain)._1 }}'
- - name: global.clusterPlatform
- value: aws
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- - name: clusterGroup.name
- value: acm-provision-on-deploy
- destination:
- server: https://kubernetes.default.svc
- namespace: mypattern-acm-provision-on-deploy
- syncPolicy:
- automated:
- prune: false
- selfHeal: true
- retry:
- limit: 20
- ignoreDifferences:
- - group: apps
- kind: Deployment
- jsonPointers:
- - /spec/replicas
- - group: route.openshift.io
- kind: Route
- jsonPointers:
- - /status
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: openshift-gitops-policy
- annotations:
- policy.open-cluster-management.io/standards: NIST-CSF
- policy.open-cluster-management.io/categories: PR.DS Data Security
- policy.open-cluster-management.io/controls: PR.DS-1 Data-at-rest
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: openshift-gitops-config
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- # This is an auto-generated file. DO NOT EDIT
- apiVersion: operators.coreos.com/v1alpha1
- kind: Subscription
- metadata:
- name: openshift-gitops-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/openshift-gitops-operator.openshift-operators: ''
- spec:
- channel: gitops-1.13
- installPlanApproval: Automatic
- name: openshift-gitops-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- config:
- env:
- - name: ARGOCD_CLUSTER_CONFIG_NAMESPACES
- value: "*"
- - complianceType: mustonlyhave
- objectDefinition:
- kind: ConfigMap
- apiVersion: v1
- metadata:
- name: trusted-ca-bundle
- namespace: openshift-gitops
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: acm/templates/policies/ocp-gitops-policy.yaml
-# This policy depends on openshift-gitops-policy and the reason is that we need to be
-# certain that the trusted-ca-bundle exists before spawning the clusterwide argocd instance
-# because the initcontainer references the trusted-ca-bundle and if it starts without the
-# configmap being there we risk running an argo instances that won't trust public CAs
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: openshift-gitops-policy-argocd
- annotations:
- policy.open-cluster-management.io/standards: NIST-CSF
- policy.open-cluster-management.io/categories: PR.DS Data Security
- policy.open-cluster-management.io/controls: PR.DS-1 Data-at-rest
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- remediationAction: enforce
- disabled: false
- dependencies:
- - apiVersion: policy.open-cluster-management.io/v1
- compliance: Compliant
- kind: Policy
- name: openshift-gitops-policy
- namespace: open-cluster-management
- - apiVersion: policy.open-cluster-management.io/v1
- compliance: Compliant
- kind: Policy
- name: hub-argo-ca-openshift-gitops-policy
- namespace: open-cluster-management
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: openshift-gitops-config-argocd
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- apiVersion: argoproj.io/v1beta1
- kind: ArgoCD
- metadata:
- name: openshift-gitops
- namespace: openshift-gitops
- spec:
- applicationSet:
- resources:
- limits:
- cpu: "2"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 512Mi
- webhookServer:
- ingress:
- enabled: false
- route:
- enabled: false
- controller:
- processors: {}
- resources:
- limits:
- cpu: "2"
- memory: 2Gi
- requests:
- cpu: 250m
- memory: 1Gi
- sharding: {}
- grafana:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- route:
- enabled: false
- ha:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- initialSSHKnownHosts: {}
- monitoring:
- enabled: false
- notifications:
- enabled: false
- prometheus:
- enabled: false
- ingress:
- enabled: false
- route:
- enabled: false
- rbac:
- defaultPolicy: ""
- policy: |-
- g, system:cluster-admins, role:admin
- g, cluster-admins, role:admin
- scopes: '[groups]'
- redis:
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- repo:
- initContainers:
- - command:
- - bash
- - -c
- - cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt
- || true
- image: registry.redhat.io/ubi9/ubi-minimal:latest
- name: fetch-ca
- resources: {}
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 256Mi
- volumeMounts:
- - mountPath: /etc/pki/tls/certs
- name: ca-bundles
- volumes:
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - emptyDir: {}
- name: ca-bundles
- resourceExclusions: |-
- - apiGroups:
- - tekton.dev
- clusters:
- - '*'
- kinds:
- - TaskRun
- - PipelineRun
- server:
- autoscale:
- enabled: false
- grpc:
- ingress:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 125m
- memory: 128Mi
- route:
- enabled: true
- service:
- type: ""
- sso:
- dex:
- openShiftOAuth: true
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- provider: dex
- tls:
- ca: {}
diff --git a/tests/common-acs-secured-naked.expected.yaml b/tests/common-acs-secured-naked.expected.yaml
deleted file mode 100644
index 2007e907..00000000
--- a/tests/common-acs-secured-naked.expected.yaml
+++ /dev/null
@@ -1,26 +0,0 @@
----
-# Source: acs/templates/securedcluster-stackrox-secured-cluster-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: SecuredCluster
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: stackrox-secured-cluster-services
- namespace: stackrox
-spec:
- clusterName: acs-secured
- auditLogs:
- collection: Auto
- admissionControl:
- listenOnUpdates: true
- bypass: BreakGlassAnnotation
- contactImageScanners: DoNotScanInline
- listenOnCreates: true
- timeoutSeconds: 3
- listenOnEvents: true
- centralEndpoint: central-stackrox.:443
- perNode:
- collector:
- collection: KernelModule
- imageFlavor: Regular
- taintToleration: TolerateTaints
diff --git a/tests/common-acs-secured-normal.expected.yaml b/tests/common-acs-secured-normal.expected.yaml
deleted file mode 100644
index 3545b1a7..00000000
--- a/tests/common-acs-secured-normal.expected.yaml
+++ /dev/null
@@ -1,26 +0,0 @@
----
-# Source: acs/templates/securedcluster-stackrox-secured-cluster-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: SecuredCluster
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: stackrox-secured-cluster-services
- namespace: stackrox
-spec:
- clusterName: acs-secured
- auditLogs:
- collection: Auto
- admissionControl:
- listenOnUpdates: true
- bypass: BreakGlassAnnotation
- contactImageScanners: DoNotScanInline
- listenOnCreates: true
- timeoutSeconds: 3
- listenOnEvents: true
- centralEndpoint: central-stackrox.hub.example.com:443
- perNode:
- collector:
- collection: KernelModule
- imageFlavor: Regular
- taintToleration: TolerateTaints
diff --git a/tests/common-clustergroup-industrial-edge-factory.expected.yaml b/tests/common-clustergroup-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 57dd0de6..00000000
--- a/tests/common-clustergroup-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,986 +0,0 @@
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-factory
- name: manuela-stormshift-line-dashboard
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-factory
- name: manuela-stormshift-machine-sensor
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-factory
- name: manuela-stormshift-messaging
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-factory
- name: manuela-factory-ml-workspace
-spec:
----
-# Source: clustergroup/templates/imperative/namespace.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- name: imperative
- argocd.argoproj.io/managed-by: mypattern-factory
- name: imperative
----
-# Source: clustergroup/templates/plumbing/gitops-namespace.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- name: mypattern-factory
- # The name here needs to be consistent with
- # - acm/templates/policies/application-policies.yaml
- # - clustergroup/templates/applications.yaml
- # - any references to secrets and route URLs in documentation
- name: mypattern-factory
-spec: {}
----
-# Source: clustergroup/templates/imperative/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: imperative-admin-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: helm-values-configmap-factory
- namespace: imperative
-data:
- values.yaml: |
- clusterGroup:
- applications:
- - name: stormshift
- path: charts/factory/manuela-stormshift
- plugin:
- name: helm-with-kustomize
- project: factory
- - name: odh
- namespace: manuela-factory-ml-workspace
- path: charts/datacenter/opendatahub
- project: factory
- argoCD:
- configManagementPlugins:
- - image: quay.io/hybridcloudpatterns/utility-container:latest
- name: helm-with-kustomize
- pluginArgs:
- - --loglevel=debug
- pluginConfig: |
- apiVersion: argoproj.io/v1alpha1
- kind: ConfigManagementPlugin
- metadata:
- name: helm-with-kustomize
- spec:
- preserveFileMode: true
- init:
- command: ["/bin/sh", "-c"]
- args: ["helm dependency build"]
- generate:
- command: ["/bin/bash", "-c"]
- args: ["helm template . --name-template ${ARGOCD_APP_NAME:0:52}
- -f $(git rev-parse --show-toplevel)/values-global.yaml
- -f $(git rev-parse --show-toplevel)/values-factory.yaml
- --set global.repoURL=$ARGOCD_APP_SOURCE_REPO_URL
- --set global.targetRevision=$ARGOCD_APP_SOURCE_TARGET_REVISION
- --set global.namespace=$ARGOCD_APP_NAMESPACE
- --set global.pattern=mypattern
- --set global.clusterDomain=region.example.com
- --set global.hubClusterDomain=apps.hub.example.com
- --set global.localClusterDomain=apps.region.example.com
- --set clusterGroup.name=factory
- --post-renderer ./kustomize"]
- initContainers: []
- resourceExclusions: |
- - apiGroups:
- - tekton.dev
- kinds:
- - TaskRun
- - PipelineRun
- resourceHealthChecks:
- - check: |
- hs = {}
- if obj.status ~= nil then
- if obj.status.phase ~= nil then
- if obj.status.phase == "Pending" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- elseif obj.status.phase == "Bound" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- end
- end
- end
- hs.status = "Progressing"
- hs.message = "Waiting for PVC"
- return hs
- kind: PersistentVolumeClaim
- resourceTrackingMethod: label
- imperative:
- activeDeadlineSeconds: 3600
- adminClusterRoleName: imperative-admin-cluster-role
- adminServiceAccountCreate: true
- adminServiceAccountName: imperative-admin-sa
- clusterRoleName: imperative-cluster-role
- clusterRoleYaml: ""
- cronJobName: imperative-cronjob
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- insecureUnsealVaultInsideClusterSchedule: '*/5 * * * *'
- jobName: imperative-job
- jobs:
- - name: test
- playbook: ansible/test.yml
- namespace: imperative
- roleName: imperative-role
- roleYaml: ""
- schedule: '*/10 * * * *'
- serviceAccountCreate: true
- serviceAccountName: imperative-sa
- valuesConfigMap: helm-values-configmap
- verbosity: ""
- isHubCluster: false
- managedClusterGroups: {}
- name: factory
- namespaces:
- - manuela-stormshift-line-dashboard
- - manuela-stormshift-machine-sensor
- - manuela-stormshift-messaging
- - manuela-factory-ml-workspace
- nodes: []
- operatorgroupExcludes:
- - manuela-factory-ml-workspace
- projects:
- - factory
- sharedValueFiles: []
- subscriptions:
- - channel: stable
- name: opendatahub-operator
- source: community-operators
- - channel: stable
- name: seldon-operator
- namespace: manuela-stormshift-messaging
- source: community-operators
- - channel: stable
- name: amq-streams
- namespace: manuela-stormshift-messaging
- - channel: 7.x
- name: amq-broker-rhel8
- namespace: manuela-stormshift-messaging
- - channel: stable
- name: red-hat-camel-k
- namespace: manuela-stormshift-messaging
- targetCluster: in-cluster
- enabled: all
- global:
- cicd:
- namespace: devsecops-ci
- clusterDomain: region.example.com
- clusterPlatform: aws
- clusterVersion: "4.12"
- extraValueFiles: []
- git:
- account: PLAINTEXT
- dev_revision: main
- email: SOMEWHERE@EXAMPLE.COM
- hostname: github.com
- username: PLAINTEXT
- hubClusterDomain: apps.hub.example.com
- imageregistry:
- account: PLAINTEXT
- hostname: quay.io
- type: quay
- localClusterDomain: apps.region.example.com
- namespace: pattern-namespace
- opp: false
- options:
- applicationRetryLimit: 20
- installPlanApproval: Automatic
- syncPolicy: Automatic
- useCSV: false
- pattern: mypattern
- quay:
- org:
- email: devel@myorg.com
- name: devel
- repo: example
- repoURL: https://github.com/pattern-clone/mypattern
- secretStore:
- backend: vault
- secure-registry:
- namespace: openshift-storage
- targetRevision: main
- main:
- clusterGroupName: hub
- git:
- repoURL: https://github.com/pattern-clone/mypattern
- revision: main
- secretStore:
- kind: ClusterSecretStore
- name: vault-backend
----
-# Source: clustergroup/templates/imperative/configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: trusted-ca-bundle
- namespace: imperative
- annotations:
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: clustergroup/templates/plumbing/argocd-cmp-plugin-cms.yaml
-kind: ConfigMap
-apiVersion: v1
-metadata:
- name: "argocd-cmp-helm-with-kustomize"
- namespace: mypattern-factory
-data:
- "plugin.yaml": |
- apiVersion: argoproj.io/v1alpha1
- kind: ConfigManagementPlugin
- metadata:
- name: helm-with-kustomize
- spec:
- preserveFileMode: true
- init:
- command: ["/bin/sh", "-c"]
- args: ["helm dependency build"]
- generate:
- command: ["/bin/bash", "-c"]
- args: ["helm template . --name-template ${ARGOCD_APP_NAME:0:52}
- -f $(git rev-parse --show-toplevel)/values-global.yaml
- -f $(git rev-parse --show-toplevel)/values-factory.yaml
- --set global.repoURL=$ARGOCD_APP_SOURCE_REPO_URL
- --set global.targetRevision=$ARGOCD_APP_SOURCE_TARGET_REVISION
- --set global.namespace=$ARGOCD_APP_NAMESPACE
- --set global.pattern=mypattern
- --set global.clusterDomain=region.example.com
- --set global.hubClusterDomain=apps.hub.example.com
- --set global.localClusterDomain=apps.region.example.com
- --set clusterGroup.name=factory
- --post-renderer ./kustomize"]
----
-# Source: clustergroup/templates/plumbing/trusted-bundle-ca-configmap.yaml
-kind: ConfigMap
-apiVersion: v1
-metadata:
- name: trusted-ca-bundle
- namespace: mypattern-factory
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: clustergroup/templates/imperative/clusterrole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: imperative-cluster-role
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - get
- - list
- - watch
----
-# Source: clustergroup/templates/imperative/clusterrole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: imperative-admin-cluster-role
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - '*'
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: imperative-cluster-rolebinding
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: imperative-cluster-role
-subjects:
- - kind: ServiceAccount
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: imperative-admin-clusterrolebinding
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: imperative-admin-cluster-role
-subjects:
- - kind: ServiceAccount
- name: imperative-admin-sa
- namespace: imperative
----
-# Source: clustergroup/templates/plumbing/argocd-super-role.yaml
-# WARNING: ONLY USE THIS FOR MANAGING CLUSTERS NOT FOR REGULAR USERS
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: openshift-gitops-cluster-admin-rolebinding
- # We need to have this before anything else or the sync might get stuck forever
- # due to permission issues
- annotations:
- argocd.argoproj.io/sync-wave: "-100"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: cluster-admin
-subjects:
- - kind: ServiceAccount
- name: openshift-gitops-argocd-application-controller
- namespace: openshift-gitops
- # NOTE: THIS MUST BE FIXED FOR MULTITENANT SETUP
- - kind: ServiceAccount
- name: openshift-gitops-argocd-server
- namespace: openshift-gitops
----
-# Source: clustergroup/templates/plumbing/argocd-super-role.yaml
-# WARNING: ONLY USE THIS FOR MANAGING CLUSTERS NOT FOR REGULAR USERS
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: mypattern-factory-cluster-admin-rolebinding
- # We need to have this before anything else or the sync might get stuck forever
- # due to permission issues
- annotations:
- argocd.argoproj.io/sync-wave: "-100"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: cluster-admin
-subjects:
- - kind: ServiceAccount
- # This is the {ArgoCD.name}-argocd-application-controller
- name: factory-gitops-argocd-application-controller
- namespace: mypattern-factory
- # NOTE: THIS MUST BE FIXED FOR MULTITENANT SETUP
- - kind: ServiceAccount
- # This is the {ArgoCD.name}-argocd-server
- name: factory-gitops-argocd-server
- namespace: mypattern-factory
- # NOTE: This is needed starting with gitops-1.5.0 (see issue common#76)
- - kind: ServiceAccount
- name: factory-gitops-argocd-dex-server
- namespace: mypattern-factory
----
-# Source: clustergroup/templates/imperative/role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: imperative-role
- namespace: imperative
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - '*'
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: imperative-rolebinding
- namespace: imperative
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: imperative-role
-subjects:
- - kind: ServiceAccount
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/job.yaml
-apiVersion: batch/v1
-kind: CronJob
-metadata:
- name: imperative-cronjob
- namespace: imperative
-spec:
- schedule: "*/10 * * * *"
- # if previous Job is still running, skip execution of a new Job
- concurrencyPolicy: Forbid
- jobTemplate:
- spec:
- activeDeadlineSeconds: 3600
- template:
- metadata:
- name: imperative-job
- spec:
- serviceAccountName: imperative-sa
- initContainers:
- # git init happens in /git/repo so that we can set the folder to 0770 permissions
- # reason for that is ansible refuses to create temporary folders in there
- - name: fetch-ca
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- command:
- - 'sh'
- - '-c'
- - >-
- cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true;
- ls -l /tmp/ca-bundles/
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- - name: git-init
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: ca-bundles
- mountPath: /etc/pki/tls/certs
- command:
- - 'sh'
- - '-c'
- - >-
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials &> /dev/null; then
- URL="https://github.com/pattern-clone/mypattern";
- else
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode}}' &>/dev/null; then
- U="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.username | base64decode }}')";
- P="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.password | base64decode }}')";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1${U}:${P}@/");
- else
- S="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode }}')";
- mkdir -p --mode 0700 "${HOME}/.ssh";
- echo "${S}" > "${HOME}/.ssh/id_rsa";
- chmod 0600 "${HOME}/.ssh/id_rsa";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1git@/");
- git config --global core.sshCommand "ssh -i "${HOME}/.ssh/id_rsa" -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no";
- fi;
- fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTP_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpsProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTPS_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.noProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export NO_PROXY="${OUT}"; fi;
- if [ "main" = "HEAD" ]; then BRANCH=""; else BRANCH="--branch main"; fi;
- mkdir /git/{repo,home};
- git clone --recurse-submodules --single-branch ${BRANCH} --depth 1 -- "${URL}" /git/repo;
- chmod 0770 /git/{repo,home};
- - name: test
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- workingDir: /git/repo
- # We have a default timeout of 600s for each playbook. Can be overridden
- # on a per-job basis
- command:
- - timeout
- - "600"
- - ansible-playbook
- - -e
- - "@/values/values.yaml"
- - ansible/test.yml
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: values-volume
- mountPath: /values/values.yaml
- subPath: values.yaml
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- containers:
- - name: "done"
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- command:
- - 'sh'
- - '-c'
- - 'echo'
- - 'done'
- - '\n'
- volumes:
- - name: git
- emptyDir: {}
- - name: values-volume
- configMap:
- name: helm-values-configmap-factory
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - name: ca-bundles
- emptyDir: {}
- restartPolicy: Never
----
-# Source: clustergroup/templates/core/subscriptions.yaml
----
----
-# Source: clustergroup/templates/plumbing/projects.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: AppProject
-metadata:
- name: factory
- namespace: mypattern-factory
-spec:
- description: "Pattern factory"
- destinations:
- - namespace: '*'
- server: '*'
- clusterResourceWhitelist:
- - group: '*'
- kind: '*'
- namespaceResourceWhitelist:
- - group: '*'
- kind: '*'
- sourceRepos:
- - '*'
-status: {}
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: stormshift
- namespace: mypattern-factory
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: mypattern-factory
- project: factory
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/factory/manuela-stormshift
- plugin: {
- "name": "helm-with-kustomize"
-}
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: odh
- namespace: mypattern-factory
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: manuela-factory-ml-workspace
- project: factory
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/datacenter/opendatahub
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-factory.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-factory.yaml"
- - "/values-4.12-factory.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/argocd.yaml
-apiVersion: argoproj.io/v1beta1
-kind: ArgoCD
-metadata:
- finalizers:
- - argoproj.io/finalizer
- # Changing the name affects the ClusterRoleBinding, the generated secret,
- # route URL, and argocd.argoproj.io/managed-by annotations
- name: factory-gitops
- namespace: mypattern-factory
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
-# Adding health checks to argocd to prevent pvc resources
-# that aren't bound state from blocking deployments
- resourceHealthChecks:
- - kind: PersistentVolumeClaim
- check: |
- hs = {}
- if obj.status ~= nil then
- if obj.status.phase ~= nil then
- if obj.status.phase == "Pending" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- elseif obj.status.phase == "Bound" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- end
- end
- end
- hs.status = "Progressing"
- hs.message = "Waiting for PVC"
- return hs
-
- resourceTrackingMethod: label
- applicationInstanceLabelKey: argocd.argoproj.io/instance
- applicationSet:
- resources:
- limits:
- cpu: "2"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 512Mi
- controller:
- processors: {}
- resources:
- limits:
- cpu: "4"
- memory: 4Gi
- requests:
- cpu: 500m
- memory: 2Gi
- sso:
- provider: dex
- dex:
- openShiftOAuth: true
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- initialSSHKnownHosts: {}
- rbac:
- defaultPolicy: role:admin
- repo:
- initContainers:
- - command:
- - bash
- - -c
- - cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- name: fetch-ca
- resources: {}
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 256Mi
- volumeMounts:
- - mountPath: /etc/pki/tls/certs
- name: ca-bundles
- volumes:
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - emptyDir: {}
- name: ca-bundles
- sidecarContainers:
- - name: helm-with-kustomize
- command: [/var/run/argocd/argocd-cmp-server]
- args: [
- "--loglevel=debug"
-]
- image: quay.io/hybridcloudpatterns/utility-container:latest
- imagePullPolicy: Always
- securityContext:
- runAsNonRoot: true
- volumeMounts:
- - mountPath: /var/run/argocd
- name: var-files
- - mountPath: /home/argocd/cmp-server/plugins
- name: plugins
- - mountPath: /tmp
- name: cmp-tmp
- - mountPath: /home/argocd/cmp-server/config/plugin.yaml
- subPath: plugin.yaml
- name: helm-with-kustomize
- volumes:
- - emptyDir: {}
- name: cmp-tmp
- - configMap:
- name: "argocd-cmp-helm-with-kustomize"
- name: helm-with-kustomize
- resources:
- limits:
- cpu: "1"
- memory: 512Mi
- requests:
- cpu: 250m
- memory: 256Mi
- resourceExclusions: |
- - apiGroups:
- - tekton.dev
- kinds:
- - TaskRun
- - PipelineRun
- server:
- autoscale:
- enabled: false
- grpc:
- ingress:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 125m
- memory: 128Mi
- route:
- enabled: true
- tls:
- insecureEdgeTerminationPolicy: Redirect
- termination: reencrypt
- service:
- type: ""
- tls:
- ca: {}
-status:
----
-# Source: clustergroup/templates/plumbing/argocd.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: factory-gitops-link
- namespace: mypattern-factory
-spec:
- applicationMenu:
- section: OpenShift GitOps
- imageURL: 
- href: 'https://factory-gitops-server-mypattern-factory.apps.region.example.com'
- location: ApplicationMenu
- text: 'Factory ArgoCD'
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: manuela-stormshift-line-dashboard-operator-group
- namespace: manuela-stormshift-line-dashboard
-spec:
- targetNamespaces:
- - manuela-stormshift-line-dashboard
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: manuela-stormshift-machine-sensor-operator-group
- namespace: manuela-stormshift-machine-sensor
-spec:
- targetNamespaces:
- - manuela-stormshift-machine-sensor
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: manuela-stormshift-messaging-operator-group
- namespace: manuela-stormshift-messaging
-spec:
- targetNamespaces:
- - manuela-stormshift-messaging
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: opendatahub-operator
- namespace: openshift-operators
-spec:
- name: opendatahub-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: seldon-operator
- namespace: manuela-stormshift-messaging
-spec:
- name: seldon-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: amq-streams
- namespace: manuela-stormshift-messaging
-spec:
- name: amq-streams
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: amq-broker-rhel8
- namespace: manuela-stormshift-messaging
-spec:
- name: amq-broker-rhel8
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: 7.x
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: red-hat-camel-k
- namespace: manuela-stormshift-messaging
-spec:
- name: red-hat-camel-k
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
diff --git a/tests/common-clustergroup-industrial-edge-hub.expected.yaml b/tests/common-clustergroup-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 8857a222..00000000
--- a/tests/common-clustergroup-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,1917 +0,0 @@
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-datacenter
- name: golang-external-secrets
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-datacenter
- name: external-secrets
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-datacenter
- name: open-cluster-management
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-datacenter
- name: manuela-ml-workspace
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-datacenter
- name: manuela-tst-all
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-datacenter
- name: manuela-ci
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-datacenter
- name: manuela-data-lake
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-datacenter
- name: staging
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-datacenter
- name: vault
-spec:
----
-# Source: clustergroup/templates/imperative/namespace.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- name: imperative
- argocd.argoproj.io/managed-by: mypattern-datacenter
- name: imperative
----
-# Source: clustergroup/templates/plumbing/gitops-namespace.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- name: mypattern-datacenter
- # The name here needs to be consistent with
- # - acm/templates/policies/application-policies.yaml
- # - clustergroup/templates/applications.yaml
- # - any references to secrets and route URLs in documentation
- name: mypattern-datacenter
-spec: {}
----
-# Source: clustergroup/templates/imperative/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: imperative-admin-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: helm-values-configmap-datacenter
- namespace: imperative
-data:
- values.yaml: |
- clusterGroup:
- applications:
- acm:
- ignoreDifferences:
- - group: internal.open-cluster-management.io
- jsonPointers:
- - /spec/loggingCA
- kind: ManagedClusterInfo
- name: acm
- namespace: open-cluster-management
- path: common/acm
- project: datacenter
- odh:
- name: odh
- namespace: manuela-ml-workspace
- path: charts/datacenter/opendatahub
- project: datacenter
- pipelines:
- name: pipelines
- namespace: manuela-ci
- path: charts/datacenter/pipelines
- project: datacenter
- production-data-lake:
- ignoreDifferences:
- - group: apps
- jsonPointers:
- - /spec/replicas
- kind: Deployment
- - group: route.openshift.io
- jsonPointers:
- - /status
- kind: Route
- - group: image.openshift.io
- jsonPointers:
- - /spec/tags
- kind: ImageStream
- - group: apps.openshift.io
- jsonPointers:
- - /spec/template/spec/containers/0/image
- kind: DeploymentConfig
- name: production-data-lake
- namespace: manuela-data-lake
- path: charts/datacenter/manuela-data-lake
- project: production-datalake
- secrets:
- name: external-secrets
- namespace: external-secrets
- path: charts/datacenter/external-secrets
- project: golang-external-secrets
- secrets-operator:
- name: golang-external-secrets
- namespace: golang-external-secrets
- path: common/golang-external-secrets
- project: golang-external-secrets
- test:
- name: manuela-test
- namespace: manuela-tst-all
- path: charts/datacenter/manuela-tst
- plugin:
- name: helm-with-kustomize
- project: datacenter
- vault:
- chart: vault
- name: vault
- namespace: vault
- overrides:
- - name: global.openshift
- value: "true"
- - name: injector.enabled
- value: "false"
- - name: ui.enabled
- value: "true"
- - name: ui.serviceType
- value: LoadBalancer
- - name: server.route.enabled
- value: "true"
- - name: server.route.host
- value: null
- - name: server.route.tls.termination
- value: edge
- - name: server.image.repository
- value: registry.connect.redhat.com/hashicorp/vault
- - name: server.image.tag
- value: 1.10.3-ubi
- project: datacenter
- repoURL: https://helm.releases.hashicorp.com
- targetRevision: v0.20.1
- argoCD:
- configManagementPlugins:
- - image: quay.io/hybridcloudpatterns/utility-container:latest
- name: helm-with-kustomize
- pluginArgs:
- - --loglevel=debug
- pluginConfig: |
- apiVersion: argoproj.io/v1alpha1
- kind: ConfigManagementPlugin
- metadata:
- name: helm-with-kustomize
- spec:
- preserveFileMode: true
- init:
- command: ["/bin/sh", "-c"]
- args: ["helm dependency build"]
- generate:
- command: ["/bin/bash", "-c"]
- args: ["helm template . --name-template ${ARGOCD_APP_NAME:0:52}
- -f $(git rev-parse --show-toplevel)/values-global.yaml
- -f $(git rev-parse --show-toplevel)/values-datacenter.yaml
- --set global.repoURL=$ARGOCD_APP_SOURCE_REPO_URL
- --set global.targetRevision=$ARGOCD_APP_SOURCE_TARGET_REVISION
- --set global.namespace=$ARGOCD_APP_NAMESPACE
- --set global.pattern=mypattern
- --set global.clusterDomain=region.example.com
- --set global.hubClusterDomain=apps.hub.example.com
- --set global.localClusterDomain=apps.region.example.com
- --set clusterGroup.name=datacenter
- --post-renderer ./kustomize"]
- initContainers: []
- resourceExclusions: |
- - apiGroups:
- - tekton.dev
- kinds:
- - TaskRun
- - PipelineRun
- resourceHealthChecks:
- - check: |
- hs = {}
- if obj.status ~= nil then
- if obj.status.phase ~= nil then
- if obj.status.phase == "Pending" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- elseif obj.status.phase == "Bound" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- end
- end
- end
- hs.status = "Progressing"
- hs.message = "Waiting for PVC"
- return hs
- kind: PersistentVolumeClaim
- resourceTrackingMethod: label
- imperative:
- activeDeadlineSeconds: 3600
- adminClusterRoleName: imperative-admin-cluster-role
- adminServiceAccountCreate: true
- adminServiceAccountName: imperative-admin-sa
- clusterRoleName: imperative-cluster-role
- clusterRoleYaml: ""
- cronJobName: imperative-cronjob
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- insecureUnsealVaultInsideClusterSchedule: '*/5 * * * *'
- jobName: imperative-job
- jobs:
- - name: test
- playbook: ansible/test.yml
- namespace: imperative
- roleName: imperative-role
- roleYaml: ""
- schedule: '*/10 * * * *'
- serviceAccountCreate: true
- serviceAccountName: imperative-sa
- valuesConfigMap: helm-values-configmap
- verbosity: ""
- isHubCluster: true
- managedClusterGroups:
- factory:
- clusterSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- matchLabels:
- clusterGroup: factory
- helmOverrides:
- - name: clusterGroup.isHubCluster
- value: "false"
- name: factory
- name: datacenter
- namespaces:
- - golang-external-secrets
- - external-secrets
- - open-cluster-management
- - manuela-ml-workspace
- - manuela-tst-all
- - manuela-ci
- - manuela-data-lake
- - staging
- - vault
- nodes: []
- operatorgroupExcludes:
- - manuela-ml-workspace
- projects:
- - datacenter
- - production-datalake
- - golang-external-secrets
- - vault
- sharedValueFiles: []
- subscriptions:
- acm:
- channel: release-2.6
- name: advanced-cluster-management
- namespace: open-cluster-management
- amqbroker-prod:
- channel: 7.x
- name: amq-broker-rhel8
- namespace: manuela-tst-all
- amqstreams-prod-dev:
- channel: stable
- name: amq-streams
- namespaces:
- - manuela-data-lake
- - manuela-tst-all
- camelk-prod-dev:
- channel: stable
- name: red-hat-camel-k
- namespaces:
- - manuela-data-lake
- - manuela-tst-all
- odh:
- channel: stable
- name: opendatahub-operator
- source: community-operators
- pipelines:
- channel: latest
- name: openshift-pipelines-operator-rh
- source: redhat-operators
- seldon-prod-dev:
- channel: stable
- name: seldon-operator
- namespaces:
- - manuela-ml-workspace
- - manuela-tst-all
- source: community-operators
- targetCluster: in-cluster
- enabled: all
- global:
- cicd:
- namespace: devsecops-ci
- clusterDomain: region.example.com
- clusterPlatform: aws
- clusterVersion: "4.12"
- extraValueFiles: []
- git:
- account: PLAINTEXT
- dev_revision: main
- email: SOMEWHERE@EXAMPLE.COM
- hostname: github.com
- username: PLAINTEXT
- hubClusterDomain: apps.hub.example.com
- imageregistry:
- account: PLAINTEXT
- hostname: quay.io
- type: quay
- localClusterDomain: apps.region.example.com
- namespace: pattern-namespace
- opp: false
- options:
- applicationRetryLimit: 20
- installPlanApproval: Automatic
- syncPolicy: Automatic
- useCSV: false
- pattern: mypattern
- quay:
- org:
- email: devel@myorg.com
- name: devel
- repo: example
- repoURL: https://github.com/pattern-clone/mypattern
- secretStore:
- backend: vault
- secure-registry:
- namespace: openshift-storage
- targetRevision: main
- main:
- clusterGroupName: hub
- git:
- repoURL: https://github.com/pattern-clone/mypattern
- revision: main
- secretStore:
- kind: ClusterSecretStore
- name: vault-backend
----
-# Source: clustergroup/templates/imperative/configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: trusted-ca-bundle
- namespace: imperative
- annotations:
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: clustergroup/templates/plumbing/argocd-cmp-plugin-cms.yaml
-kind: ConfigMap
-apiVersion: v1
-metadata:
- name: "argocd-cmp-helm-with-kustomize"
- namespace: mypattern-datacenter
-data:
- "plugin.yaml": |
- apiVersion: argoproj.io/v1alpha1
- kind: ConfigManagementPlugin
- metadata:
- name: helm-with-kustomize
- spec:
- preserveFileMode: true
- init:
- command: ["/bin/sh", "-c"]
- args: ["helm dependency build"]
- generate:
- command: ["/bin/bash", "-c"]
- args: ["helm template . --name-template ${ARGOCD_APP_NAME:0:52}
- -f $(git rev-parse --show-toplevel)/values-global.yaml
- -f $(git rev-parse --show-toplevel)/values-datacenter.yaml
- --set global.repoURL=$ARGOCD_APP_SOURCE_REPO_URL
- --set global.targetRevision=$ARGOCD_APP_SOURCE_TARGET_REVISION
- --set global.namespace=$ARGOCD_APP_NAMESPACE
- --set global.pattern=mypattern
- --set global.clusterDomain=region.example.com
- --set global.hubClusterDomain=apps.hub.example.com
- --set global.localClusterDomain=apps.region.example.com
- --set clusterGroup.name=datacenter
- --post-renderer ./kustomize"]
----
-# Source: clustergroup/templates/plumbing/trusted-bundle-ca-configmap.yaml
-kind: ConfigMap
-apiVersion: v1
-metadata:
- name: trusted-ca-bundle
- namespace: mypattern-datacenter
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: clustergroup/templates/imperative/clusterrole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: imperative-cluster-role
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - get
- - list
- - watch
----
-# Source: clustergroup/templates/imperative/clusterrole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: imperative-admin-cluster-role
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - '*'
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: imperative-cluster-rolebinding
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: imperative-cluster-role
-subjects:
- - kind: ServiceAccount
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: imperative-admin-clusterrolebinding
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: imperative-admin-cluster-role
-subjects:
- - kind: ServiceAccount
- name: imperative-admin-sa
- namespace: imperative
----
-# Source: clustergroup/templates/plumbing/argocd-super-role.yaml
-# WARNING: ONLY USE THIS FOR MANAGING CLUSTERS NOT FOR REGULAR USERS
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: openshift-gitops-cluster-admin-rolebinding
- # We need to have this before anything else or the sync might get stuck forever
- # due to permission issues
- annotations:
- argocd.argoproj.io/sync-wave: "-100"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: cluster-admin
-subjects:
- - kind: ServiceAccount
- name: openshift-gitops-argocd-application-controller
- namespace: openshift-gitops
- # NOTE: THIS MUST BE FIXED FOR MULTITENANT SETUP
- - kind: ServiceAccount
- name: openshift-gitops-argocd-server
- namespace: openshift-gitops
----
-# Source: clustergroup/templates/plumbing/argocd-super-role.yaml
-# WARNING: ONLY USE THIS FOR MANAGING CLUSTERS NOT FOR REGULAR USERS
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: mypattern-datacenter-cluster-admin-rolebinding
- # We need to have this before anything else or the sync might get stuck forever
- # due to permission issues
- annotations:
- argocd.argoproj.io/sync-wave: "-100"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: cluster-admin
-subjects:
- - kind: ServiceAccount
- # This is the {ArgoCD.name}-argocd-application-controller
- name: datacenter-gitops-argocd-application-controller
- namespace: mypattern-datacenter
- # NOTE: THIS MUST BE FIXED FOR MULTITENANT SETUP
- - kind: ServiceAccount
- # This is the {ArgoCD.name}-argocd-server
- name: datacenter-gitops-argocd-server
- namespace: mypattern-datacenter
- # NOTE: This is needed starting with gitops-1.5.0 (see issue common#76)
- - kind: ServiceAccount
- name: datacenter-gitops-argocd-dex-server
- namespace: mypattern-datacenter
----
-# Source: clustergroup/templates/imperative/role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: imperative-role
- namespace: imperative
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - '*'
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: imperative-rolebinding
- namespace: imperative
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: imperative-role
-subjects:
- - kind: ServiceAccount
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/job.yaml
-apiVersion: batch/v1
-kind: CronJob
-metadata:
- name: imperative-cronjob
- namespace: imperative
-spec:
- schedule: "*/10 * * * *"
- # if previous Job is still running, skip execution of a new Job
- concurrencyPolicy: Forbid
- jobTemplate:
- spec:
- activeDeadlineSeconds: 3600
- template:
- metadata:
- name: imperative-job
- spec:
- serviceAccountName: imperative-sa
- initContainers:
- # git init happens in /git/repo so that we can set the folder to 0770 permissions
- # reason for that is ansible refuses to create temporary folders in there
- - name: fetch-ca
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- command:
- - 'sh'
- - '-c'
- - >-
- cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true;
- ls -l /tmp/ca-bundles/
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- - name: git-init
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: ca-bundles
- mountPath: /etc/pki/tls/certs
- command:
- - 'sh'
- - '-c'
- - >-
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials &> /dev/null; then
- URL="https://github.com/pattern-clone/mypattern";
- else
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode}}' &>/dev/null; then
- U="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.username | base64decode }}')";
- P="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.password | base64decode }}')";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1${U}:${P}@/");
- else
- S="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode }}')";
- mkdir -p --mode 0700 "${HOME}/.ssh";
- echo "${S}" > "${HOME}/.ssh/id_rsa";
- chmod 0600 "${HOME}/.ssh/id_rsa";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1git@/");
- git config --global core.sshCommand "ssh -i "${HOME}/.ssh/id_rsa" -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no";
- fi;
- fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTP_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpsProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTPS_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.noProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export NO_PROXY="${OUT}"; fi;
- if [ "main" = "HEAD" ]; then BRANCH=""; else BRANCH="--branch main"; fi;
- mkdir /git/{repo,home};
- git clone --recurse-submodules --single-branch ${BRANCH} --depth 1 -- "${URL}" /git/repo;
- chmod 0770 /git/{repo,home};
- - name: test
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- workingDir: /git/repo
- # We have a default timeout of 600s for each playbook. Can be overridden
- # on a per-job basis
- command:
- - timeout
- - "600"
- - ansible-playbook
- - -e
- - "@/values/values.yaml"
- - ansible/test.yml
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: values-volume
- mountPath: /values/values.yaml
- subPath: values.yaml
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- containers:
- - name: "done"
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- command:
- - 'sh'
- - '-c'
- - 'echo'
- - 'done'
- - '\n'
- volumes:
- - name: git
- emptyDir: {}
- - name: values-volume
- configMap:
- name: helm-values-configmap-datacenter
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - name: ca-bundles
- emptyDir: {}
- restartPolicy: Never
----
-# Source: clustergroup/templates/imperative/unsealjob.yaml
-apiVersion: batch/v1
-kind: CronJob
-metadata:
- name: unsealvault-cronjob
- namespace: imperative
-spec:
- schedule: "*/5 * * * *"
- # if previous Job is still running, skip execution of a new Job
- concurrencyPolicy: Forbid
- jobTemplate:
- spec:
- activeDeadlineSeconds: 3600
- template:
- metadata:
- name: unsealvault-job
- spec:
- serviceAccountName: imperative-sa
- initContainers:
- # git init happens in /git/repo so that we can set the folder to 0770 permissions
- # reason for that is ansible refuses to create temporary folders in there
- - name: fetch-ca
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- command:
- - 'sh'
- - '-c'
- - >-
- cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true;
- ls -l /tmp/ca-bundles/
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- - name: git-init
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: ca-bundles
- mountPath: /etc/pki/tls/certs
- command:
- - 'sh'
- - '-c'
- - >-
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials &> /dev/null; then
- URL="https://github.com/pattern-clone/mypattern";
- else
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode}}' &>/dev/null; then
- U="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.username | base64decode }}')";
- P="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.password | base64decode }}')";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1${U}:${P}@/");
- else
- S="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode }}')";
- mkdir -p --mode 0700 "${HOME}/.ssh";
- echo "${S}" > "${HOME}/.ssh/id_rsa";
- chmod 0600 "${HOME}/.ssh/id_rsa";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1git@/");
- git config --global core.sshCommand "ssh -i "${HOME}/.ssh/id_rsa" -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no";
- fi;
- fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTP_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpsProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTPS_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.noProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export NO_PROXY="${OUT}"; fi;
- if [ "main" = "HEAD" ]; then BRANCH=""; else BRANCH="--branch main"; fi;
- mkdir /git/{repo,home};
- git clone --recurse-submodules --single-branch ${BRANCH} --depth 1 -- "${URL}" /git/repo;
- chmod 0770 /git/{repo,home};
- - name: unseal-playbook
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- workingDir: /git/repo
- # We have a default timeout of 600s for each playbook. Can be overridden
- # on a per-job basis
- command:
- - timeout
- - "600"
- - ansible-playbook
- - -e
- - "@/values/values.yaml"
- - -t
- - 'vault_init,vault_unseal,vault_secrets_init,vault_spokes_init'
- - "common/ansible/playbooks/vault/vault.yaml"
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: values-volume
- mountPath: /values/values.yaml
- subPath: values.yaml
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- containers:
- - name: "done"
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- command:
- - 'sh'
- - '-c'
- - 'echo'
- - 'done'
- - '\n'
- volumes:
- - name: git
- emptyDir: {}
- - name: values-volume
- configMap:
- name: helm-values-configmap-datacenter
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - name: ca-bundles
- emptyDir: {}
- restartPolicy: Never
----
-# Source: clustergroup/templates/core/subscriptions.yaml
----
----
-# Source: clustergroup/templates/plumbing/projects.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: AppProject
-metadata:
- name: datacenter
- namespace: mypattern-datacenter
-spec:
- description: "Pattern datacenter"
- destinations:
- - namespace: '*'
- server: '*'
- clusterResourceWhitelist:
- - group: '*'
- kind: '*'
- namespaceResourceWhitelist:
- - group: '*'
- kind: '*'
- sourceRepos:
- - '*'
-status: {}
----
-# Source: clustergroup/templates/plumbing/projects.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: AppProject
-metadata:
- name: production-datalake
- namespace: mypattern-datacenter
-spec:
- description: "Pattern production-datalake"
- destinations:
- - namespace: '*'
- server: '*'
- clusterResourceWhitelist:
- - group: '*'
- kind: '*'
- namespaceResourceWhitelist:
- - group: '*'
- kind: '*'
- sourceRepos:
- - '*'
-status: {}
----
-# Source: clustergroup/templates/plumbing/projects.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: AppProject
-metadata:
- name: golang-external-secrets
- namespace: mypattern-datacenter
-spec:
- description: "Pattern golang-external-secrets"
- destinations:
- - namespace: '*'
- server: '*'
- clusterResourceWhitelist:
- - group: '*'
- kind: '*'
- namespaceResourceWhitelist:
- - group: '*'
- kind: '*'
- sourceRepos:
- - '*'
-status: {}
----
-# Source: clustergroup/templates/plumbing/projects.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: AppProject
-metadata:
- name: vault
- namespace: mypattern-datacenter
-spec:
- description: "Pattern vault"
- destinations:
- - namespace: '*'
- server: '*'
- clusterResourceWhitelist:
- - group: '*'
- kind: '*'
- namespaceResourceWhitelist:
- - group: '*'
- kind: '*'
- sourceRepos:
- - '*'
-status: {}
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: acm
- namespace: mypattern-datacenter
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: open-cluster-management
- project: datacenter
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/acm
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-datacenter.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-datacenter.yaml"
- - "/values-4.12-datacenter.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- ignoreDifferences: [
- {
- "group": "internal.open-cluster-management.io",
- "jsonPointers": [
- "/spec/loggingCA"
- ],
- "kind": "ManagedClusterInfo"
- }
-]
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: odh
- namespace: mypattern-datacenter
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: manuela-ml-workspace
- project: datacenter
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/datacenter/opendatahub
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-datacenter.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-datacenter.yaml"
- - "/values-4.12-datacenter.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: pipelines
- namespace: mypattern-datacenter
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: manuela-ci
- project: datacenter
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/datacenter/pipelines
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-datacenter.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-datacenter.yaml"
- - "/values-4.12-datacenter.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: production-data-lake
- namespace: mypattern-datacenter
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: manuela-data-lake
- project: production-datalake
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/datacenter/manuela-data-lake
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-datacenter.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-datacenter.yaml"
- - "/values-4.12-datacenter.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- ignoreDifferences: [
- {
- "group": "apps",
- "jsonPointers": [
- "/spec/replicas"
- ],
- "kind": "Deployment"
- },
- {
- "group": "route.openshift.io",
- "jsonPointers": [
- "/status"
- ],
- "kind": "Route"
- },
- {
- "group": "image.openshift.io",
- "jsonPointers": [
- "/spec/tags"
- ],
- "kind": "ImageStream"
- },
- {
- "group": "apps.openshift.io",
- "jsonPointers": [
- "/spec/template/spec/containers/0/image"
- ],
- "kind": "DeploymentConfig"
- }
-]
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: external-secrets
- namespace: mypattern-datacenter
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: external-secrets
- project: golang-external-secrets
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/datacenter/external-secrets
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-datacenter.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-datacenter.yaml"
- - "/values-4.12-datacenter.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: golang-external-secrets
- namespace: mypattern-datacenter
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: golang-external-secrets
- project: golang-external-secrets
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/golang-external-secrets
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-datacenter.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-datacenter.yaml"
- - "/values-4.12-datacenter.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: manuela-test
- namespace: mypattern-datacenter
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: manuela-tst-all
- project: datacenter
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/datacenter/manuela-tst
- plugin: {
- "name": "helm-with-kustomize"
-}
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: vault
- namespace: mypattern-datacenter
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: vault
- project: datacenter
- source:
- repoURL: https://helm.releases.hashicorp.com
- targetRevision: v0.20.1
- chart: vault
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-datacenter.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-datacenter.yaml"
- - "/values-4.12-datacenter.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- - name: global.openshift
- value: "true"
- - name: injector.enabled
- value: "false"
- - name: ui.enabled
- value: "true"
- - name: ui.serviceType
- value: "LoadBalancer"
- - name: server.route.enabled
- value: "true"
- - name: server.route.host
- value:
- - name: server.route.tls.termination
- value: "edge"
- - name: server.image.repository
- value: "registry.connect.redhat.com/hashicorp/vault"
- - name: server.image.tag
- value: "1.10.3-ubi"
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/argocd.yaml
-apiVersion: argoproj.io/v1beta1
-kind: ArgoCD
-metadata:
- finalizers:
- - argoproj.io/finalizer
- # Changing the name affects the ClusterRoleBinding, the generated secret,
- # route URL, and argocd.argoproj.io/managed-by annotations
- name: datacenter-gitops
- namespace: mypattern-datacenter
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
-# Adding health checks to argocd to prevent pvc resources
-# that aren't bound state from blocking deployments
- resourceHealthChecks:
- - kind: PersistentVolumeClaim
- check: |
- hs = {}
- if obj.status ~= nil then
- if obj.status.phase ~= nil then
- if obj.status.phase == "Pending" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- elseif obj.status.phase == "Bound" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- end
- end
- end
- hs.status = "Progressing"
- hs.message = "Waiting for PVC"
- return hs
-
- resourceTrackingMethod: label
- applicationInstanceLabelKey: argocd.argoproj.io/instance
- applicationSet:
- resources:
- limits:
- cpu: "2"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 512Mi
- controller:
- processors: {}
- resources:
- limits:
- cpu: "4"
- memory: 4Gi
- requests:
- cpu: 500m
- memory: 2Gi
- sso:
- provider: dex
- dex:
- openShiftOAuth: true
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- initialSSHKnownHosts: {}
- rbac:
- defaultPolicy: role:admin
- repo:
- initContainers:
- - command:
- - bash
- - -c
- - cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- name: fetch-ca
- resources: {}
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 256Mi
- volumeMounts:
- - mountPath: /etc/pki/tls/certs
- name: ca-bundles
- volumes:
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - emptyDir: {}
- name: ca-bundles
- sidecarContainers:
- - name: helm-with-kustomize
- command: [/var/run/argocd/argocd-cmp-server]
- args: [
- "--loglevel=debug"
-]
- image: quay.io/hybridcloudpatterns/utility-container:latest
- imagePullPolicy: Always
- securityContext:
- runAsNonRoot: true
- volumeMounts:
- - mountPath: /var/run/argocd
- name: var-files
- - mountPath: /home/argocd/cmp-server/plugins
- name: plugins
- - mountPath: /tmp
- name: cmp-tmp
- - mountPath: /home/argocd/cmp-server/config/plugin.yaml
- subPath: plugin.yaml
- name: helm-with-kustomize
- volumes:
- - emptyDir: {}
- name: cmp-tmp
- - configMap:
- name: "argocd-cmp-helm-with-kustomize"
- name: helm-with-kustomize
- resources:
- limits:
- cpu: "1"
- memory: 512Mi
- requests:
- cpu: 250m
- memory: 256Mi
- resourceExclusions: |
- - apiGroups:
- - tekton.dev
- kinds:
- - TaskRun
- - PipelineRun
- server:
- autoscale:
- enabled: false
- grpc:
- ingress:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 125m
- memory: 128Mi
- route:
- enabled: true
- tls:
- insecureEdgeTerminationPolicy: Redirect
- termination: reencrypt
- service:
- type: ""
- tls:
- ca: {}
-status:
----
-# Source: clustergroup/templates/plumbing/argocd.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: datacenter-gitops-link
- namespace: mypattern-datacenter
-spec:
- applicationMenu:
- section: OpenShift GitOps
- imageURL: 
- href: 'https://datacenter-gitops-server-mypattern-datacenter.apps.region.example.com'
- location: ApplicationMenu
- text: 'Datacenter ArgoCD'
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: golang-external-secrets-operator-group
- namespace: golang-external-secrets
-spec:
- targetNamespaces:
- - golang-external-secrets
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: external-secrets-operator-group
- namespace: external-secrets
-spec:
- targetNamespaces:
- - external-secrets
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: open-cluster-management-operator-group
- namespace: open-cluster-management
-spec:
- targetNamespaces:
- - open-cluster-management
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: manuela-tst-all-operator-group
- namespace: manuela-tst-all
-spec:
- targetNamespaces:
- - manuela-tst-all
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: manuela-ci-operator-group
- namespace: manuela-ci
-spec:
- targetNamespaces:
- - manuela-ci
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: manuela-data-lake-operator-group
- namespace: manuela-data-lake
-spec:
- targetNamespaces:
- - manuela-data-lake
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: staging-operator-group
- namespace: staging
-spec:
- targetNamespaces:
- - staging
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: vault-operator-group
- namespace: vault
-spec:
- targetNamespaces:
- - vault
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: advanced-cluster-management
- namespace: open-cluster-management
-spec:
- name: advanced-cluster-management
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: release-2.6
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: amq-broker-rhel8
- namespace: manuela-tst-all
-spec:
- name: amq-broker-rhel8
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: 7.x
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: amq-streams
- namespace: manuela-data-lake
-spec:
- name: amq-streams
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: amq-streams
- namespace: manuela-tst-all
-spec:
- name: amq-streams
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: red-hat-camel-k
- namespace: manuela-data-lake
-spec:
- name: red-hat-camel-k
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: red-hat-camel-k
- namespace: manuela-tst-all
-spec:
- name: red-hat-camel-k
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: opendatahub-operator
- namespace: openshift-operators
-spec:
- name: opendatahub-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: openshift-pipelines-operator-rh
- namespace: openshift-operators
-spec:
- name: openshift-pipelines-operator-rh
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: latest
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: seldon-operator
- namespace: manuela-ml-workspace
-spec:
- name: seldon-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: seldon-operator
- namespace: manuela-tst-all
-spec:
- name: seldon-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
diff --git a/tests/common-clustergroup-medical-diagnosis-hub.expected.yaml b/tests/common-clustergroup-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 0af485db..00000000
--- a/tests/common-clustergroup-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,2057 +0,0 @@
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-hub
- name: open-cluster-management
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-hub
- name: openshift-serverless
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-hub
- name: opendatahub
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-hub
- name: openshift-storage
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-hub
- name: xraylab-1
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-hub
- name: knative-serving
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-hub
- name: staging
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-hub
- name: vault
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-hub
- name: golang-external-secrets
-spec:
----
-# Source: clustergroup/templates/imperative/namespace.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- name: imperative
- argocd.argoproj.io/managed-by: mypattern-hub
- name: imperative
----
-# Source: clustergroup/templates/plumbing/gitops-namespace.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- name: mypattern-hub
- # The name here needs to be consistent with
- # - acm/templates/policies/application-policies.yaml
- # - clustergroup/templates/applications.yaml
- # - any references to secrets and route URLs in documentation
- name: mypattern-hub
-spec: {}
----
-# Source: clustergroup/templates/imperative/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: imperative-admin-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: helm-values-configmap-hub
- namespace: imperative
-data:
- values.yaml: |
- clusterGroup:
- applications:
- golang-external-secrets:
- name: golang-external-secrets
- namespace: golang-external-secrets
- path: common/golang-external-secrets
- project: hub
- kafdrop:
- name: kafdrop
- namespace: xraylab-1
- path: charts/all/kafdrop
- project: medical-diagnosis
- kafka:
- name: kafka
- namespace: xraylab-1
- path: charts/all/kafka
- project: medical-diagnosis
- opendatahub:
- name: odh
- namespace: opendatahub
- path: charts/all/opendatahub
- project: medical-diagnosis
- openshift-data-foundations:
- name: odf
- namespace: openshift-storage
- path: charts/all/openshift-data-foundations
- project: medical-diagnosis
- openshift-serverless:
- name: serverless
- namespace: xraylab-1
- path: charts/all/openshift-serverless
- project: medical-diagnosis
- service-account:
- name: xraylab-service-account
- namespace: xraylab-1
- path: charts/all/medical-diagnosis/service-account
- project: medical-diagnosis
- vault:
- chart: vault
- name: vault
- namespace: vault
- overrides:
- - name: global.openshift
- value: "true"
- - name: injector.enabled
- value: "false"
- - name: ui.enabled
- value: "true"
- - name: ui.serviceType
- value: LoadBalancer
- - name: server.route.enabled
- value: "true"
- - name: server.route.host
- value: null
- - name: server.route.tls.termination
- value: edge
- - name: server.image.repository
- value: registry.connect.redhat.com/hashicorp/vault
- - name: server.image.tag
- value: 1.10.3-ubi
- project: hub
- repoURL: https://helm.releases.hashicorp.com
- targetRevision: v0.20.1
- xraylab-database:
- name: xraylab-database
- namespace: xraylab-1
- path: charts/all/medical-diagnosis/database
- project: medical-diagnosis
- xraylab-grafana-dashboards:
- name: xraylab-grafana-dashboards
- namespace: xraylab-1
- path: charts/all/medical-diagnosis/grafana
- project: medical-diagnosis
- xraylab-image-generator:
- ignoreDifferences:
- - group: apps.openshift.io
- jqPathExpressions:
- - .spec.template.spec.containers[].image
- kind: DeploymentConfig
- name: xraylab-image-generator
- namespace: xraylab-1
- path: charts/all/medical-diagnosis/image-generator
- project: medical-diagnosis
- xraylab-image-server:
- ignoreDifferences:
- - group: apps.openshift.io
- jqPathExpressions:
- - .spec.template.spec.containers[].image
- kind: DeploymentConfig
- name: xraylab-image-server
- namespace: xraylab-1
- path: charts/all/medical-diagnosis/image-server
- project: medical-diagnosis
- xraylab-init:
- name: xraylab-init
- namespace: xraylab-1
- path: charts/all/medical-diagnosis/xray-init
- project: medical-diagnosis
- argoCD:
- configManagementPlugins: []
- initContainers: []
- resourceExclusions: |
- - apiGroups:
- - tekton.dev
- kinds:
- - TaskRun
- - PipelineRun
- resourceHealthChecks:
- - check: |
- hs = {}
- if obj.status ~= nil then
- if obj.status.phase ~= nil then
- if obj.status.phase == "Pending" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- elseif obj.status.phase == "Bound" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- end
- end
- end
- hs.status = "Progressing"
- hs.message = "Waiting for PVC"
- return hs
- kind: PersistentVolumeClaim
- resourceTrackingMethod: label
- imperative:
- activeDeadlineSeconds: 3600
- adminClusterRoleName: imperative-admin-cluster-role
- adminServiceAccountCreate: true
- adminServiceAccountName: imperative-admin-sa
- clusterRoleName: imperative-cluster-role
- clusterRoleYaml: ""
- cronJobName: imperative-cronjob
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- insecureUnsealVaultInsideClusterSchedule: '*/5 * * * *'
- jobName: imperative-job
- jobs:
- - name: test
- playbook: ansible/test.yml
- timeout: 234
- namespace: imperative
- roleName: imperative-role
- roleYaml: ""
- schedule: '*/10 * * * *'
- serviceAccountCreate: true
- serviceAccountName: imperative-sa
- valuesConfigMap: helm-values-configmap
- verbosity: ""
- isHubCluster: true
- managedClusterGroups:
- region-one:
- clusterSelector:
- matchLabels:
- clusterGroup: region-one
- helmOverrides:
- - name: clusterGroup.isHubCluster
- value: false
- name: region-one
- name: hub
- namespaces:
- - open-cluster-management
- - openshift-serverless
- - opendatahub
- - openshift-storage
- - xraylab-1
- - knative-serving
- - staging
- - vault
- - golang-external-secrets
- nodes: []
- projects:
- - hub
- - medical-diagnosis
- sharedValueFiles: []
- subscriptions:
- amq-streams:
- channel: stable
- name: amq-streams
- namespace: xraylab-1
- grafana:
- channel: v4
- name: grafana-operator
- namespace: xraylab-1
- source: community-operators
- odf:
- channel: stable-4.11
- name: odf-operator
- namespace: openshift-storage
- opendatahub:
- name: opendatahub-operator
- source: community-operators
- severless:
- channel: stable
- name: serverless-operator
- targetCluster: in-cluster
- enabled: all
- global:
- cicd:
- namespace: devsecops-ci
- clusterDomain: region.example.com
- clusterPlatform: aws
- clusterVersion: "4.12"
- extraValueFiles: []
- git:
- account: PLAINTEXT
- dev_revision: main
- email: SOMEWHERE@EXAMPLE.COM
- hostname: github.com
- username: PLAINTEXT
- hubClusterDomain: apps.hub.example.com
- imageregistry:
- account: PLAINTEXT
- hostname: quay.io
- type: quay
- localClusterDomain: apps.region.example.com
- namespace: pattern-namespace
- opp: false
- options:
- applicationRetryLimit: 20
- installPlanApproval: Automatic
- syncPolicy: Automatic
- useCSV: false
- pattern: mypattern
- quay:
- org:
- email: devel@myorg.com
- name: devel
- repo: example
- repoURL: https://github.com/pattern-clone/mypattern
- secretStore:
- backend: vault
- secure-registry:
- namespace: openshift-storage
- targetRevision: main
- main:
- clusterGroupName: hub
- git:
- repoURL: https://github.com/pattern-clone/mypattern
- revision: main
- secretStore:
- kind: ClusterSecretStore
- name: vault-backend
----
-# Source: clustergroup/templates/imperative/configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: trusted-ca-bundle
- namespace: imperative
- annotations:
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: clustergroup/templates/plumbing/trusted-bundle-ca-configmap.yaml
-kind: ConfigMap
-apiVersion: v1
-metadata:
- name: trusted-ca-bundle
- namespace: mypattern-hub
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: clustergroup/templates/imperative/clusterrole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: imperative-cluster-role
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - get
- - list
- - watch
----
-# Source: clustergroup/templates/imperative/clusterrole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: imperative-admin-cluster-role
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - '*'
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: imperative-cluster-rolebinding
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: imperative-cluster-role
-subjects:
- - kind: ServiceAccount
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: imperative-admin-clusterrolebinding
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: imperative-admin-cluster-role
-subjects:
- - kind: ServiceAccount
- name: imperative-admin-sa
- namespace: imperative
----
-# Source: clustergroup/templates/plumbing/argocd-super-role.yaml
-# WARNING: ONLY USE THIS FOR MANAGING CLUSTERS NOT FOR REGULAR USERS
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: openshift-gitops-cluster-admin-rolebinding
- # We need to have this before anything else or the sync might get stuck forever
- # due to permission issues
- annotations:
- argocd.argoproj.io/sync-wave: "-100"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: cluster-admin
-subjects:
- - kind: ServiceAccount
- name: openshift-gitops-argocd-application-controller
- namespace: openshift-gitops
- # NOTE: THIS MUST BE FIXED FOR MULTITENANT SETUP
- - kind: ServiceAccount
- name: openshift-gitops-argocd-server
- namespace: openshift-gitops
----
-# Source: clustergroup/templates/plumbing/argocd-super-role.yaml
-# WARNING: ONLY USE THIS FOR MANAGING CLUSTERS NOT FOR REGULAR USERS
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: mypattern-hub-cluster-admin-rolebinding
- # We need to have this before anything else or the sync might get stuck forever
- # due to permission issues
- annotations:
- argocd.argoproj.io/sync-wave: "-100"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: cluster-admin
-subjects:
- - kind: ServiceAccount
- # This is the {ArgoCD.name}-argocd-application-controller
- name: hub-gitops-argocd-application-controller
- namespace: mypattern-hub
- # NOTE: THIS MUST BE FIXED FOR MULTITENANT SETUP
- - kind: ServiceAccount
- # This is the {ArgoCD.name}-argocd-server
- name: hub-gitops-argocd-server
- namespace: mypattern-hub
- # NOTE: This is needed starting with gitops-1.5.0 (see issue common#76)
- - kind: ServiceAccount
- name: hub-gitops-argocd-dex-server
- namespace: mypattern-hub
----
-# Source: clustergroup/templates/imperative/role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: imperative-role
- namespace: imperative
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - '*'
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: imperative-rolebinding
- namespace: imperative
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: imperative-role
-subjects:
- - kind: ServiceAccount
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/job.yaml
-apiVersion: batch/v1
-kind: CronJob
-metadata:
- name: imperative-cronjob
- namespace: imperative
-spec:
- schedule: "*/10 * * * *"
- # if previous Job is still running, skip execution of a new Job
- concurrencyPolicy: Forbid
- jobTemplate:
- spec:
- activeDeadlineSeconds: 3600
- template:
- metadata:
- name: imperative-job
- spec:
- serviceAccountName: imperative-sa
- initContainers:
- # git init happens in /git/repo so that we can set the folder to 0770 permissions
- # reason for that is ansible refuses to create temporary folders in there
- - name: fetch-ca
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- command:
- - 'sh'
- - '-c'
- - >-
- cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true;
- ls -l /tmp/ca-bundles/
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- - name: git-init
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: ca-bundles
- mountPath: /etc/pki/tls/certs
- command:
- - 'sh'
- - '-c'
- - >-
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials &> /dev/null; then
- URL="https://github.com/pattern-clone/mypattern";
- else
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode}}' &>/dev/null; then
- U="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.username | base64decode }}')";
- P="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.password | base64decode }}')";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1${U}:${P}@/");
- else
- S="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode }}')";
- mkdir -p --mode 0700 "${HOME}/.ssh";
- echo "${S}" > "${HOME}/.ssh/id_rsa";
- chmod 0600 "${HOME}/.ssh/id_rsa";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1git@/");
- git config --global core.sshCommand "ssh -i "${HOME}/.ssh/id_rsa" -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no";
- fi;
- fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTP_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpsProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTPS_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.noProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export NO_PROXY="${OUT}"; fi;
- if [ "main" = "HEAD" ]; then BRANCH=""; else BRANCH="--branch main"; fi;
- mkdir /git/{repo,home};
- git clone --recurse-submodules --single-branch ${BRANCH} --depth 1 -- "${URL}" /git/repo;
- chmod 0770 /git/{repo,home};
- - name: test
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- workingDir: /git/repo
- # We have a default timeout of 600s for each playbook. Can be overridden
- # on a per-job basis
- command:
- - timeout
- - "234"
- - ansible-playbook
- - -e
- - "@/values/values.yaml"
- - ansible/test.yml
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: values-volume
- mountPath: /values/values.yaml
- subPath: values.yaml
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- containers:
- - name: "done"
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- command:
- - 'sh'
- - '-c'
- - 'echo'
- - 'done'
- - '\n'
- volumes:
- - name: git
- emptyDir: {}
- - name: values-volume
- configMap:
- name: helm-values-configmap-hub
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - name: ca-bundles
- emptyDir: {}
- restartPolicy: Never
----
-# Source: clustergroup/templates/imperative/unsealjob.yaml
-apiVersion: batch/v1
-kind: CronJob
-metadata:
- name: unsealvault-cronjob
- namespace: imperative
-spec:
- schedule: "*/5 * * * *"
- # if previous Job is still running, skip execution of a new Job
- concurrencyPolicy: Forbid
- jobTemplate:
- spec:
- activeDeadlineSeconds: 3600
- template:
- metadata:
- name: unsealvault-job
- spec:
- serviceAccountName: imperative-sa
- initContainers:
- # git init happens in /git/repo so that we can set the folder to 0770 permissions
- # reason for that is ansible refuses to create temporary folders in there
- - name: fetch-ca
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- command:
- - 'sh'
- - '-c'
- - >-
- cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true;
- ls -l /tmp/ca-bundles/
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- - name: git-init
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: ca-bundles
- mountPath: /etc/pki/tls/certs
- command:
- - 'sh'
- - '-c'
- - >-
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials &> /dev/null; then
- URL="https://github.com/pattern-clone/mypattern";
- else
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode}}' &>/dev/null; then
- U="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.username | base64decode }}')";
- P="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.password | base64decode }}')";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1${U}:${P}@/");
- else
- S="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode }}')";
- mkdir -p --mode 0700 "${HOME}/.ssh";
- echo "${S}" > "${HOME}/.ssh/id_rsa";
- chmod 0600 "${HOME}/.ssh/id_rsa";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1git@/");
- git config --global core.sshCommand "ssh -i "${HOME}/.ssh/id_rsa" -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no";
- fi;
- fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTP_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpsProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTPS_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.noProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export NO_PROXY="${OUT}"; fi;
- if [ "main" = "HEAD" ]; then BRANCH=""; else BRANCH="--branch main"; fi;
- mkdir /git/{repo,home};
- git clone --recurse-submodules --single-branch ${BRANCH} --depth 1 -- "${URL}" /git/repo;
- chmod 0770 /git/{repo,home};
- - name: unseal-playbook
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- workingDir: /git/repo
- # We have a default timeout of 600s for each playbook. Can be overridden
- # on a per-job basis
- command:
- - timeout
- - "600"
- - ansible-playbook
- - -e
- - "@/values/values.yaml"
- - -t
- - 'vault_init,vault_unseal,vault_secrets_init,vault_spokes_init'
- - "common/ansible/playbooks/vault/vault.yaml"
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: values-volume
- mountPath: /values/values.yaml
- subPath: values.yaml
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- containers:
- - name: "done"
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- command:
- - 'sh'
- - '-c'
- - 'echo'
- - 'done'
- - '\n'
- volumes:
- - name: git
- emptyDir: {}
- - name: values-volume
- configMap:
- name: helm-values-configmap-hub
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - name: ca-bundles
- emptyDir: {}
- restartPolicy: Never
----
-# Source: clustergroup/templates/core/subscriptions.yaml
----
----
-# Source: clustergroup/templates/plumbing/projects.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: AppProject
-metadata:
- name: hub
- namespace: mypattern-hub
-spec:
- description: "Pattern hub"
- destinations:
- - namespace: '*'
- server: '*'
- clusterResourceWhitelist:
- - group: '*'
- kind: '*'
- namespaceResourceWhitelist:
- - group: '*'
- kind: '*'
- sourceRepos:
- - '*'
-status: {}
----
-# Source: clustergroup/templates/plumbing/projects.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: AppProject
-metadata:
- name: medical-diagnosis
- namespace: mypattern-hub
-spec:
- description: "Pattern medical-diagnosis"
- destinations:
- - namespace: '*'
- server: '*'
- clusterResourceWhitelist:
- - group: '*'
- kind: '*'
- namespaceResourceWhitelist:
- - group: '*'
- kind: '*'
- sourceRepos:
- - '*'
-status: {}
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: golang-external-secrets
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: golang-external-secrets
- project: hub
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/golang-external-secrets
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: kafdrop
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: xraylab-1
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/kafdrop
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: kafka
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: xraylab-1
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/kafka
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: odh
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: opendatahub
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/opendatahub
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: odf
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: openshift-storage
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/openshift-data-foundations
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: serverless
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: xraylab-1
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/openshift-serverless
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: xraylab-service-account
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: xraylab-1
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/medical-diagnosis/service-account
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: vault
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: vault
- project: hub
- source:
- repoURL: https://helm.releases.hashicorp.com
- targetRevision: v0.20.1
- chart: vault
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- - name: global.openshift
- value: "true"
- - name: injector.enabled
- value: "false"
- - name: ui.enabled
- value: "true"
- - name: ui.serviceType
- value: "LoadBalancer"
- - name: server.route.enabled
- value: "true"
- - name: server.route.host
- value:
- - name: server.route.tls.termination
- value: "edge"
- - name: server.image.repository
- value: "registry.connect.redhat.com/hashicorp/vault"
- - name: server.image.tag
- value: "1.10.3-ubi"
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: xraylab-database
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: xraylab-1
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/medical-diagnosis/database
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: xraylab-grafana-dashboards
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: xraylab-1
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/medical-diagnosis/grafana
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: xraylab-image-generator
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: xraylab-1
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/medical-diagnosis/image-generator
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- ignoreDifferences: [
- {
- "group": "apps.openshift.io",
- "jqPathExpressions": [
- ".spec.template.spec.containers[].image"
- ],
- "kind": "DeploymentConfig"
- }
-]
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: xraylab-image-server
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: xraylab-1
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/medical-diagnosis/image-server
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- ignoreDifferences: [
- {
- "group": "apps.openshift.io",
- "jqPathExpressions": [
- ".spec.template.spec.containers[].image"
- ],
- "kind": "DeploymentConfig"
- }
-]
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: xraylab-init
- namespace: mypattern-hub
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: xraylab-1
- project: medical-diagnosis
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/all/medical-diagnosis/xray-init
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-hub.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-hub.yaml"
- - "/values-4.12-hub.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/argocd.yaml
-apiVersion: argoproj.io/v1beta1
-kind: ArgoCD
-metadata:
- finalizers:
- - argoproj.io/finalizer
- # Changing the name affects the ClusterRoleBinding, the generated secret,
- # route URL, and argocd.argoproj.io/managed-by annotations
- name: hub-gitops
- namespace: mypattern-hub
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
-# Adding health checks to argocd to prevent pvc resources
-# that aren't bound state from blocking deployments
- resourceHealthChecks:
- - kind: PersistentVolumeClaim
- check: |
- hs = {}
- if obj.status ~= nil then
- if obj.status.phase ~= nil then
- if obj.status.phase == "Pending" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- elseif obj.status.phase == "Bound" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- end
- end
- end
- hs.status = "Progressing"
- hs.message = "Waiting for PVC"
- return hs
-
- resourceTrackingMethod: label
- applicationInstanceLabelKey: argocd.argoproj.io/instance
- applicationSet:
- resources:
- limits:
- cpu: "2"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 512Mi
- controller:
- processors: {}
- resources:
- limits:
- cpu: "4"
- memory: 4Gi
- requests:
- cpu: 500m
- memory: 2Gi
- sso:
- provider: dex
- dex:
- openShiftOAuth: true
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- initialSSHKnownHosts: {}
- rbac:
- defaultPolicy: role:admin
- repo:
- initContainers:
- - command:
- - bash
- - -c
- - cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- name: fetch-ca
- resources: {}
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 256Mi
- volumeMounts:
- - mountPath: /etc/pki/tls/certs
- name: ca-bundles
- volumes:
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - emptyDir: {}
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 512Mi
- requests:
- cpu: 250m
- memory: 256Mi
- resourceExclusions: |
- - apiGroups:
- - tekton.dev
- kinds:
- - TaskRun
- - PipelineRun
- server:
- autoscale:
- enabled: false
- grpc:
- ingress:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 125m
- memory: 128Mi
- route:
- enabled: true
- tls:
- insecureEdgeTerminationPolicy: Redirect
- termination: reencrypt
- service:
- type: ""
- tls:
- ca: {}
-status:
----
-# Source: clustergroup/templates/plumbing/argocd.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: hub-gitops-link
- namespace: mypattern-hub
-spec:
- applicationMenu:
- section: OpenShift GitOps
- imageURL: 
- href: 'https://hub-gitops-server-mypattern-hub.apps.region.example.com'
- location: ApplicationMenu
- text: 'Hub ArgoCD'
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: open-cluster-management-operator-group
- namespace: open-cluster-management
-spec:
- targetNamespaces:
- - open-cluster-management
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: openshift-serverless-operator-group
- namespace: openshift-serverless
-spec:
- targetNamespaces:
- - openshift-serverless
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: opendatahub-operator-group
- namespace: opendatahub
-spec:
- targetNamespaces:
- - opendatahub
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: openshift-storage-operator-group
- namespace: openshift-storage
-spec:
- targetNamespaces:
- - openshift-storage
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: xraylab-1-operator-group
- namespace: xraylab-1
-spec:
- targetNamespaces:
- - xraylab-1
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: knative-serving-operator-group
- namespace: knative-serving
-spec:
- targetNamespaces:
- - knative-serving
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: staging-operator-group
- namespace: staging
-spec:
- targetNamespaces:
- - staging
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: vault-operator-group
- namespace: vault
-spec:
- targetNamespaces:
- - vault
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: golang-external-secrets-operator-group
- namespace: golang-external-secrets
-spec:
- targetNamespaces:
- - golang-external-secrets
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: amq-streams
- namespace: xraylab-1
-spec:
- name: amq-streams
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: grafana-operator
- namespace: xraylab-1
-spec:
- name: grafana-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
- channel: v4
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: odf-operator
- namespace: openshift-storage
-spec:
- name: odf-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: stable-4.11
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: opendatahub-operator
- namespace: openshift-operators
-spec:
- name: opendatahub-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
- installPlanApproval: Automatic
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: serverless-operator
- namespace: openshift-operators
-spec:
- name: serverless-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: stable
- installPlanApproval: Automatic
diff --git a/tests/common-clustergroup-naked.expected.yaml b/tests/common-clustergroup-naked.expected.yaml
deleted file mode 100644
index 7a9f94b2..00000000
--- a/tests/common-clustergroup-naked.expected.yaml
+++ /dev/null
@@ -1,588 +0,0 @@
----
-# Source: clustergroup/templates/imperative/namespace.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- name: imperative
- argocd.argoproj.io/managed-by: common-example
- name: imperative
----
-# Source: clustergroup/templates/plumbing/gitops-namespace.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- name: common-example
- # The name here needs to be consistent with
- # - acm/templates/policies/application-policies.yaml
- # - clustergroup/templates/applications.yaml
- # - any references to secrets and route URLs in documentation
- name: common-example
-spec: {}
----
-# Source: clustergroup/templates/imperative/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: imperative-admin-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: helm-values-configmap-example
- namespace: imperative
-data:
- values.yaml: |
- clusterGroup:
- applications: {}
- argoCD:
- configManagementPlugins: []
- initContainers: []
- resourceExclusions: |
- - apiGroups:
- - tekton.dev
- kinds:
- - TaskRun
- - PipelineRun
- resourceHealthChecks:
- - check: |
- hs = {}
- if obj.status ~= nil then
- if obj.status.phase ~= nil then
- if obj.status.phase == "Pending" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- elseif obj.status.phase == "Bound" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- end
- end
- end
- hs.status = "Progressing"
- hs.message = "Waiting for PVC"
- return hs
- kind: PersistentVolumeClaim
- resourceTrackingMethod: label
- imperative:
- activeDeadlineSeconds: 3600
- adminClusterRoleName: imperative-admin-cluster-role
- adminServiceAccountCreate: true
- adminServiceAccountName: imperative-admin-sa
- clusterRoleName: imperative-cluster-role
- clusterRoleYaml: ""
- cronJobName: imperative-cronjob
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- insecureUnsealVaultInsideClusterSchedule: '*/5 * * * *'
- jobName: imperative-job
- jobs: []
- namespace: imperative
- roleName: imperative-role
- roleYaml: ""
- schedule: '*/10 * * * *'
- serviceAccountCreate: true
- serviceAccountName: imperative-sa
- valuesConfigMap: helm-values-configmap
- verbosity: ""
- isHubCluster: true
- managedClusterGroups: {}
- name: example
- namespaces: []
- nodes: []
- projects: []
- sharedValueFiles: []
- subscriptions: {}
- targetCluster: in-cluster
- enabled: all
- global:
- extraValueFiles: []
- options:
- applicationRetryLimit: 20
- installPlanApproval: Automatic
- syncPolicy: Automatic
- useCSV: true
- pattern: common
- secretStore:
- backend: vault
- targetRevision: main
- secretStore:
- kind: ClusterSecretStore
- name: vault-backend
----
-# Source: clustergroup/templates/imperative/configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: trusted-ca-bundle
- namespace: imperative
- annotations:
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: clustergroup/templates/plumbing/trusted-bundle-ca-configmap.yaml
-kind: ConfigMap
-apiVersion: v1
-metadata:
- name: trusted-ca-bundle
- namespace: common-example
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: clustergroup/templates/imperative/clusterrole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: imperative-cluster-role
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - get
- - list
- - watch
----
-# Source: clustergroup/templates/imperative/clusterrole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: imperative-admin-cluster-role
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - '*'
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: imperative-cluster-rolebinding
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: imperative-cluster-role
-subjects:
- - kind: ServiceAccount
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: imperative-admin-clusterrolebinding
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: imperative-admin-cluster-role
-subjects:
- - kind: ServiceAccount
- name: imperative-admin-sa
- namespace: imperative
----
-# Source: clustergroup/templates/plumbing/argocd-super-role.yaml
-# WARNING: ONLY USE THIS FOR MANAGING CLUSTERS NOT FOR REGULAR USERS
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: openshift-gitops-cluster-admin-rolebinding
- # We need to have this before anything else or the sync might get stuck forever
- # due to permission issues
- annotations:
- argocd.argoproj.io/sync-wave: "-100"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: cluster-admin
-subjects:
- - kind: ServiceAccount
- name: openshift-gitops-argocd-application-controller
- namespace: openshift-gitops
- # NOTE: THIS MUST BE FIXED FOR MULTITENANT SETUP
- - kind: ServiceAccount
- name: openshift-gitops-argocd-server
- namespace: openshift-gitops
----
-# Source: clustergroup/templates/plumbing/argocd-super-role.yaml
-# WARNING: ONLY USE THIS FOR MANAGING CLUSTERS NOT FOR REGULAR USERS
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-example-cluster-admin-rolebinding
- # We need to have this before anything else or the sync might get stuck forever
- # due to permission issues
- annotations:
- argocd.argoproj.io/sync-wave: "-100"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: cluster-admin
-subjects:
- - kind: ServiceAccount
- # This is the {ArgoCD.name}-argocd-application-controller
- name: example-gitops-argocd-application-controller
- namespace: common-example
- # NOTE: THIS MUST BE FIXED FOR MULTITENANT SETUP
- - kind: ServiceAccount
- # This is the {ArgoCD.name}-argocd-server
- name: example-gitops-argocd-server
- namespace: common-example
- # NOTE: This is needed starting with gitops-1.5.0 (see issue common#76)
- - kind: ServiceAccount
- name: example-gitops-argocd-dex-server
- namespace: common-example
----
-# Source: clustergroup/templates/imperative/role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: imperative-role
- namespace: imperative
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - '*'
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: imperative-rolebinding
- namespace: imperative
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: imperative-role
-subjects:
- - kind: ServiceAccount
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/unsealjob.yaml
-apiVersion: batch/v1
-kind: CronJob
-metadata:
- name: unsealvault-cronjob
- namespace: imperative
-spec:
- schedule: "*/5 * * * *"
- # if previous Job is still running, skip execution of a new Job
- concurrencyPolicy: Forbid
- jobTemplate:
- spec:
- activeDeadlineSeconds: 3600
- template:
- metadata:
- name: unsealvault-job
- spec:
- serviceAccountName: imperative-sa
- initContainers:
- # git init happens in /git/repo so that we can set the folder to 0770 permissions
- # reason for that is ansible refuses to create temporary folders in there
- - name: fetch-ca
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- command:
- - 'sh'
- - '-c'
- - >-
- cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true;
- ls -l /tmp/ca-bundles/
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- - name: git-init
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: ca-bundles
- mountPath: /etc/pki/tls/certs
- command:
- - 'sh'
- - '-c'
- - >-
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials &> /dev/null; then
- URL="";
- else
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode}}' &>/dev/null; then
- U="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.username | base64decode }}')";
- P="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.password | base64decode }}')";
- URL=$(echo | sed -E "s/(https?:\/\/)/\1${U}:${P}@/");
- else
- S="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode }}')";
- mkdir -p --mode 0700 "${HOME}/.ssh";
- echo "${S}" > "${HOME}/.ssh/id_rsa";
- chmod 0600 "${HOME}/.ssh/id_rsa";
- URL=$(echo | sed -E "s/(https?:\/\/)/\1git@/");
- git config --global core.sshCommand "ssh -i "${HOME}/.ssh/id_rsa" -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no";
- fi;
- fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTP_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpsProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTPS_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.noProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export NO_PROXY="${OUT}"; fi;
- if [ "main" = "HEAD" ]; then BRANCH=""; else BRANCH="--branch main"; fi;
- mkdir /git/{repo,home};
- git clone --recurse-submodules --single-branch ${BRANCH} --depth 1 -- "${URL}" /git/repo;
- chmod 0770 /git/{repo,home};
- - name: unseal-playbook
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- workingDir: /git/repo
- # We have a default timeout of 600s for each playbook. Can be overridden
- # on a per-job basis
- command:
- - timeout
- - "600"
- - ansible-playbook
- - -e
- - "@/values/values.yaml"
- - -t
- - 'vault_init,vault_unseal,vault_secrets_init,vault_spokes_init'
- - "common/ansible/playbooks/vault/vault.yaml"
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: values-volume
- mountPath: /values/values.yaml
- subPath: values.yaml
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- containers:
- - name: "done"
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- command:
- - 'sh'
- - '-c'
- - 'echo'
- - 'done'
- - '\n'
- volumes:
- - name: git
- emptyDir: {}
- - name: values-volume
- configMap:
- name: helm-values-configmap-example
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - name: ca-bundles
- emptyDir: {}
- restartPolicy: Never
----
-# Source: clustergroup/templates/plumbing/argocd.yaml
-apiVersion: argoproj.io/v1beta1
-kind: ArgoCD
-metadata:
- finalizers:
- - argoproj.io/finalizer
- # Changing the name affects the ClusterRoleBinding, the generated secret,
- # route URL, and argocd.argoproj.io/managed-by annotations
- name: example-gitops
- namespace: common-example
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
-# Adding health checks to argocd to prevent pvc resources
-# that aren't bound state from blocking deployments
- resourceHealthChecks:
- - kind: PersistentVolumeClaim
- check: |
- hs = {}
- if obj.status ~= nil then
- if obj.status.phase ~= nil then
- if obj.status.phase == "Pending" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- elseif obj.status.phase == "Bound" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- end
- end
- end
- hs.status = "Progressing"
- hs.message = "Waiting for PVC"
- return hs
-
- resourceTrackingMethod: label
- applicationInstanceLabelKey: argocd.argoproj.io/instance
- applicationSet:
- resources:
- limits:
- cpu: "2"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 512Mi
- controller:
- processors: {}
- resources:
- limits:
- cpu: "4"
- memory: 4Gi
- requests:
- cpu: 500m
- memory: 2Gi
- sso:
- provider: dex
- dex:
- openShiftOAuth: true
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- initialSSHKnownHosts: {}
- rbac:
- defaultPolicy: role:admin
- repo:
- initContainers:
- - command:
- - bash
- - -c
- - cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- name: fetch-ca
- resources: {}
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 256Mi
- volumeMounts:
- - mountPath: /etc/pki/tls/certs
- name: ca-bundles
- volumes:
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - emptyDir: {}
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 512Mi
- requests:
- cpu: 250m
- memory: 256Mi
- resourceExclusions: |
- - apiGroups:
- - tekton.dev
- kinds:
- - TaskRun
- - PipelineRun
- server:
- autoscale:
- enabled: false
- grpc:
- ingress:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 125m
- memory: 128Mi
- route:
- enabled: true
- tls:
- insecureEdgeTerminationPolicy: Redirect
- termination: reencrypt
- service:
- type: ""
- tls:
- ca: {}
-status:
----
-# Source: clustergroup/templates/plumbing/argocd.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: example-gitops-link
- namespace: common-example
-spec:
- applicationMenu:
- section: OpenShift GitOps
- imageURL: 
- href: 'https://example-gitops-server-common-example.'
- location: ApplicationMenu
- text: 'Example ArgoCD'
diff --git a/tests/common-clustergroup-normal.expected.yaml b/tests/common-clustergroup-normal.expected.yaml
deleted file mode 100644
index 70b29c07..00000000
--- a/tests/common-clustergroup-normal.expected.yaml
+++ /dev/null
@@ -1,1505 +0,0 @@
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: open-cluster-management
- labels:
- argocd.argoproj.io/managed-by: mypattern-example
- kubernetes.io/os: "linux"
- openshift.io/node-selector: ""
- annotations:
- openshift.io/cluster-monitoring: "true"
- owner: "namespace owner"
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: application-ci
- labels:
- argocd.argoproj.io/managed-by: mypattern-example
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: exclude-targetns
- labels:
- argocd.argoproj.io/managed-by: mypattern-example
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-example
- name: include-ci
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- argocd.argoproj.io/managed-by: mypattern-example
- name: exclude-og
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: totally-exclude-og
- labels:
- argocd.argoproj.io/managed-by: mypattern-example
-spec:
----
-# Source: clustergroup/templates/core/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: include-default-og
- labels:
- argocd.argoproj.io/managed-by: mypattern-example
-spec:
----
-# Source: clustergroup/templates/imperative/namespace.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- name: imperative
- argocd.argoproj.io/managed-by: mypattern-example
- name: imperative
----
-# Source: clustergroup/templates/plumbing/gitops-namespace.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- labels:
- name: mypattern-example
- # The name here needs to be consistent with
- # - acm/templates/policies/application-policies.yaml
- # - clustergroup/templates/applications.yaml
- # - any references to secrets and route URLs in documentation
- name: mypattern-example
-spec: {}
----
-# Source: clustergroup/templates/imperative/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: imperative-admin-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: helm-values-configmap-example
- namespace: imperative
-data:
- values.yaml: |
- clusterGroup:
- applications:
- acm:
- ignoreDifferences:
- - group: internal.open-cluster-management.io
- jsonPointers:
- - /spec/loggingCA
- kind: ManagedClusterInfo
- name: acm
- namespace: open-cluster-management
- path: common/acm
- project: datacenter
- pipe:
- extraValueFiles:
- - /values/4.12/aws.yaml
- name: pipelines
- namespace: application-ci
- path: charts/datacenter/pipelines
- project: datacenter
- argoCD:
- configManagementPlugins: []
- initContainers: []
- resourceExclusions: |
- - apiGroups:
- - tekton.dev
- kinds:
- - TaskRun
- - PipelineRun
- resourceHealthChecks:
- - check: |
- hs = {}
- if obj.status ~= nil then
- if obj.status.phase ~= nil then
- if obj.status.phase == "Pending" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- elseif obj.status.phase == "Bound" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- end
- end
- end
- hs.status = "Progressing"
- hs.message = "Waiting for PVC"
- return hs
- kind: PersistentVolumeClaim
- resourceTrackingMethod: label
- imperative:
- activeDeadlineSeconds: 3600
- adminClusterRoleName: imperative-admin-cluster-role
- adminServiceAccountCreate: true
- adminServiceAccountName: imperative-admin-sa
- clusterRoleName: imperative-cluster-role
- clusterRoleYaml: ""
- cronJobName: imperative-cronjob
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- insecureUnsealVaultInsideClusterSchedule: '*/5 * * * *'
- jobName: imperative-job
- jobs:
- - name: test
- playbook: ansible/test.yml
- timeout: 234
- namespace: imperative
- roleName: imperative-role
- roleYaml: ""
- schedule: '*/10 * * * *'
- serviceAccountCreate: true
- serviceAccountName: imperative-sa
- valuesConfigMap: helm-values-configmap
- verbosity: ""
- isHubCluster: true
- managedClusterGroups:
- - acmlabels:
- - name: clusterGroup
- value: acm-region
- helmOverrides:
- - name: clusterGroup.isHubCluster
- value: "false"
- name: acm-edge
- targetRevision: main
- - acmlabels:
- - name: clusterGroup
- value: region
- clusterDeployments:
- myFirstCluster:
- baseDomain: blueprints.rhecoeng.com
- name: aws-cd-one-w-pool
- openshiftVersion: 4.10.18
- platform:
- aws:
- region: ap-southeast-1
- clusterPools:
- exampleAWSPool:
- baseDomain: blueprints.rhecoeng.com
- controlPlane:
- count: 1
- platform:
- aws:
- type: m5.xlarge
- name: aws-ap
- openshiftVersion: 4.10.18
- platform:
- aws:
- region: ap-southeast-2
- size: 3
- workers:
- count: 0
- exampleAzurePool:
- baseDomain: blueprints.rhecoeng.com
- clusters:
- - Two
- - three
- name: azure-us
- openshiftVersion: 4.10.18
- platform:
- azure:
- baseDomainResourceGroupName: dojo-dns-zones
- region: eastus
- helmOverrides:
- - name: clusterGroup.isHubCluster
- value: "false"
- name: acm-provision-edge
- targetRevision: main
- - clusterDeployments:
- mySecondCluster:
- baseDomain: blueprints.rhecoeng.com
- name: aws-cd-two-wo-pool
- openshiftVersion: 4.10.18
- platform:
- aws:
- region: ap-southeast-3
- name: acm-provision-on-deploy
- - helmOverrides:
- - name: clusterGroup.isHubCluster
- value: "false"
- hostedArgoSites:
- - domain: perth1.beekhof.net
- name: perth
- - domain: syd.beekhof.net
- name: sydney
- name: argo-edge
- name: example
- namespaces:
- - open-cluster-management:
- annotations:
- openshift.io/cluster-monitoring: "true"
- owner: namespace owner
- labels:
- kubernetes.io/os: linux
- openshift.io/node-selector: ""
- - application-ci:
- operatorGroup: true
- targetNamespaces:
- - application-ci
- - other-namespace
- - exclude-targetns:
- operatorGroup: true
- targetNamespaces: null
- - include-ci
- - exclude-og
- - totally-exclude-og:
- operatorGroup: false
- - include-default-og:
- operatorGroup: true
- nodes:
- - m-m00.cluster.example.tld:
- labels:
- cluster.ocs.openshift.io/openshift-storage: ""
- - m-m01.cluster.example.tld:
- labels:
- cluster.ocs.openshift.io/openshift-storage: ""
- - m-m02.cluster.example.tld:
- labels:
- cluster.ocs.openshift.io/openshift-storage: ""
- operatorgroupExcludes:
- - exclude-og
- projects:
- - datacenter
- scheduler:
- mastersSchedulable: true
- sharedValueFiles:
- - /values/aws.yaml
- - /values/4.12.yaml
- subscriptions:
- acm:
- channel: release-2.4
- csv: advanced-cluster-management.v2.4.1
- name: advanced-cluster-management
- namespace: open-cluster-management
- odh:
- csv: opendatahub-operator.v1.1.0
- disabled: true
- name: opendatahub-operator
- source: community-operators
- pipelines:
- csv: redhat-openshift-pipelines.v1.5.2
- name: openshift-pipelines-operator-rh
- targetCluster: in-cluster
- enabled: all
- global:
- cicd:
- namespace: devsecops-ci
- clusterDomain: region.example.com
- clusterPlatform: aws
- clusterVersion: "4.12"
- extraValueFiles: []
- git:
- account: PLAINTEXT
- dev_revision: main
- email: SOMEWHERE@EXAMPLE.COM
- hostname: github.com
- username: PLAINTEXT
- hubClusterDomain: apps.hub.example.com
- imageregistry:
- account: PLAINTEXT
- hostname: quay.io
- type: quay
- localClusterDomain: apps.region.example.com
- multiClusterTarget: all
- namespace: pattern-namespace
- opp: false
- options:
- applicationRetryLimit: 20
- installPlanApproval: Automatic
- syncPolicy: Automatic
- useCSV: false
- pattern: mypattern
- quay:
- org:
- email: devel@myorg.com
- name: devel
- repo: example
- repoURL: https://github.com/pattern-clone/mypattern
- secretStore:
- backend: vault
- secure-registry:
- namespace: openshift-storage
- targetRevision: main
- main:
- clusterGroupName: hub
- git:
- repoURL: https://github.com/pattern-clone/mypattern
- revision: main
- secretStore:
- kind: ClusterSecretStore
- name: vault-backend
----
-# Source: clustergroup/templates/imperative/configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: trusted-ca-bundle
- namespace: imperative
- annotations:
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: clustergroup/templates/plumbing/trusted-bundle-ca-configmap.yaml
-kind: ConfigMap
-apiVersion: v1
-metadata:
- name: trusted-ca-bundle
- namespace: mypattern-example
- labels:
- config.openshift.io/inject-trusted-cabundle: 'true'
----
-# Source: clustergroup/templates/imperative/clusterrole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: imperative-cluster-role
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - get
- - list
- - watch
----
-# Source: clustergroup/templates/imperative/clusterrole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: imperative-admin-cluster-role
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - '*'
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: imperative-cluster-rolebinding
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: imperative-cluster-role
-subjects:
- - kind: ServiceAccount
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: imperative-admin-clusterrolebinding
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: imperative-admin-cluster-role
-subjects:
- - kind: ServiceAccount
- name: imperative-admin-sa
- namespace: imperative
----
-# Source: clustergroup/templates/plumbing/argocd-super-role.yaml
-# WARNING: ONLY USE THIS FOR MANAGING CLUSTERS NOT FOR REGULAR USERS
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: openshift-gitops-cluster-admin-rolebinding
- # We need to have this before anything else or the sync might get stuck forever
- # due to permission issues
- annotations:
- argocd.argoproj.io/sync-wave: "-100"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: cluster-admin
-subjects:
- - kind: ServiceAccount
- name: openshift-gitops-argocd-application-controller
- namespace: openshift-gitops
- # NOTE: THIS MUST BE FIXED FOR MULTITENANT SETUP
- - kind: ServiceAccount
- name: openshift-gitops-argocd-server
- namespace: openshift-gitops
----
-# Source: clustergroup/templates/plumbing/argocd-super-role.yaml
-# WARNING: ONLY USE THIS FOR MANAGING CLUSTERS NOT FOR REGULAR USERS
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: mypattern-example-cluster-admin-rolebinding
- # We need to have this before anything else or the sync might get stuck forever
- # due to permission issues
- annotations:
- argocd.argoproj.io/sync-wave: "-100"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: cluster-admin
-subjects:
- - kind: ServiceAccount
- # This is the {ArgoCD.name}-argocd-application-controller
- name: example-gitops-argocd-application-controller
- namespace: mypattern-example
- # NOTE: THIS MUST BE FIXED FOR MULTITENANT SETUP
- - kind: ServiceAccount
- # This is the {ArgoCD.name}-argocd-server
- name: example-gitops-argocd-server
- namespace: mypattern-example
- # NOTE: This is needed starting with gitops-1.5.0 (see issue common#76)
- - kind: ServiceAccount
- name: example-gitops-argocd-dex-server
- namespace: mypattern-example
----
-# Source: clustergroup/templates/imperative/role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: imperative-role
- namespace: imperative
-rules:
- - apiGroups:
- - '*'
- resources:
- - '*'
- verbs:
- - '*'
----
-# Source: clustergroup/templates/imperative/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: imperative-rolebinding
- namespace: imperative
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: imperative-role
-subjects:
- - kind: ServiceAccount
- name: imperative-sa
- namespace: imperative
----
-# Source: clustergroup/templates/imperative/job.yaml
-apiVersion: batch/v1
-kind: CronJob
-metadata:
- name: imperative-cronjob
- namespace: imperative
-spec:
- schedule: "*/10 * * * *"
- # if previous Job is still running, skip execution of a new Job
- concurrencyPolicy: Forbid
- jobTemplate:
- spec:
- activeDeadlineSeconds: 3600
- template:
- metadata:
- name: imperative-job
- spec:
- serviceAccountName: imperative-sa
- initContainers:
- # git init happens in /git/repo so that we can set the folder to 0770 permissions
- # reason for that is ansible refuses to create temporary folders in there
- - name: fetch-ca
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- command:
- - 'sh'
- - '-c'
- - >-
- cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true;
- ls -l /tmp/ca-bundles/
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- - name: git-init
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: ca-bundles
- mountPath: /etc/pki/tls/certs
- command:
- - 'sh'
- - '-c'
- - >-
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials &> /dev/null; then
- URL="https://github.com/pattern-clone/mypattern";
- else
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode}}' &>/dev/null; then
- U="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.username | base64decode }}')";
- P="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.password | base64decode }}')";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1${U}:${P}@/");
- else
- S="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode }}')";
- mkdir -p --mode 0700 "${HOME}/.ssh";
- echo "${S}" > "${HOME}/.ssh/id_rsa";
- chmod 0600 "${HOME}/.ssh/id_rsa";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1git@/");
- git config --global core.sshCommand "ssh -i "${HOME}/.ssh/id_rsa" -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no";
- fi;
- fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTP_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpsProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTPS_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.noProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export NO_PROXY="${OUT}"; fi;
- if [ "main" = "HEAD" ]; then BRANCH=""; else BRANCH="--branch main"; fi;
- mkdir /git/{repo,home};
- git clone --recurse-submodules --single-branch ${BRANCH} --depth 1 -- "${URL}" /git/repo;
- chmod 0770 /git/{repo,home};
- - name: test
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- workingDir: /git/repo
- # We have a default timeout of 600s for each playbook. Can be overridden
- # on a per-job basis
- command:
- - timeout
- - "234"
- - ansible-playbook
- - -e
- - "@/values/values.yaml"
- - ansible/test.yml
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: values-volume
- mountPath: /values/values.yaml
- subPath: values.yaml
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- containers:
- - name: "done"
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- command:
- - 'sh'
- - '-c'
- - 'echo'
- - 'done'
- - '\n'
- volumes:
- - name: git
- emptyDir: {}
- - name: values-volume
- configMap:
- name: helm-values-configmap-example
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - name: ca-bundles
- emptyDir: {}
- restartPolicy: Never
----
-# Source: clustergroup/templates/imperative/unsealjob.yaml
-apiVersion: batch/v1
-kind: CronJob
-metadata:
- name: unsealvault-cronjob
- namespace: imperative
-spec:
- schedule: "*/5 * * * *"
- # if previous Job is still running, skip execution of a new Job
- concurrencyPolicy: Forbid
- jobTemplate:
- spec:
- activeDeadlineSeconds: 3600
- template:
- metadata:
- name: unsealvault-job
- spec:
- serviceAccountName: imperative-sa
- initContainers:
- # git init happens in /git/repo so that we can set the folder to 0770 permissions
- # reason for that is ansible refuses to create temporary folders in there
- - name: fetch-ca
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- command:
- - 'sh'
- - '-c'
- - >-
- cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true;
- ls -l /tmp/ca-bundles/
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- - name: git-init
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: ca-bundles
- mountPath: /etc/pki/tls/certs
- command:
- - 'sh'
- - '-c'
- - >-
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials &> /dev/null; then
- URL="https://github.com/pattern-clone/mypattern";
- else
- if ! oc get secrets -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode}}' &>/dev/null; then
- U="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.username | base64decode }}')";
- P="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.password | base64decode }}')";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1${U}:${P}@/");
- else
- S="$(oc get secret -n openshift-gitops vp-private-repo-credentials -o go-template='{{index .data.sshPrivateKey | base64decode }}')";
- mkdir -p --mode 0700 "${HOME}/.ssh";
- echo "${S}" > "${HOME}/.ssh/id_rsa";
- chmod 0600 "${HOME}/.ssh/id_rsa";
- URL=$(echo https://github.com/pattern-clone/mypattern | sed -E "s/(https?:\/\/)/\1git@/");
- git config --global core.sshCommand "ssh -i "${HOME}/.ssh/id_rsa" -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no";
- fi;
- fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTP_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.httpsProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export HTTPS_PROXY="${OUT}"; fi;
- OUT="$(oc get proxy.config.openshift.io/cluster -o jsonpath='{.spec.noProxy}' 2>/dev/null)";
- if [ -n "${OUT}" ]; then export NO_PROXY="${OUT}"; fi;
- if [ "main" = "HEAD" ]; then BRANCH=""; else BRANCH="--branch main"; fi;
- mkdir /git/{repo,home};
- git clone --recurse-submodules --single-branch ${BRANCH} --depth 1 -- "${URL}" /git/repo;
- chmod 0770 /git/{repo,home};
- - name: unseal-playbook
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- env:
- - name: HOME
- value: /git/home
- workingDir: /git/repo
- # We have a default timeout of 600s for each playbook. Can be overridden
- # on a per-job basis
- command:
- - timeout
- - "600"
- - ansible-playbook
- - -e
- - "@/values/values.yaml"
- - -t
- - 'vault_init,vault_unseal,vault_secrets_init,vault_spokes_init'
- - "common/ansible/playbooks/vault/vault.yaml"
- volumeMounts:
- - name: git
- mountPath: "/git"
- - name: values-volume
- mountPath: /values/values.yaml
- subPath: values.yaml
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- containers:
- - name: "done"
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- imagePullPolicy: Always
- command:
- - 'sh'
- - '-c'
- - 'echo'
- - 'done'
- - '\n'
- volumes:
- - name: git
- emptyDir: {}
- - name: values-volume
- configMap:
- name: helm-values-configmap-example
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - name: ca-bundles
- emptyDir: {}
- restartPolicy: Never
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
----
-# Source: clustergroup/templates/core/subscriptions.yaml
----
----
-# Source: clustergroup/templates/plumbing/hosted-sites.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: AppProject
-metadata:
- name: argo-edge
- namespace: openshift-gitops
-spec:
- description: "Cluster Group argo-edge"
- destinations:
- - namespace: '*'
- server: '*'
- clusterResourceWhitelist:
- - group: '*'
- kind: '*'
- namespaceResourceWhitelist:
- - group: '*'
- kind: '*'
- sourceRepos:
- - '*'
-status: {}
----
-# Source: clustergroup/templates/plumbing/projects.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: AppProject
-metadata:
- name: datacenter
- namespace: mypattern-example
-spec:
- description: "Pattern datacenter"
- destinations:
- - namespace: '*'
- server: '*'
- clusterResourceWhitelist:
- - group: '*'
- kind: '*'
- namespaceResourceWhitelist:
- - group: '*'
- kind: '*'
- sourceRepos:
- - '*'
-status: {}
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: acm
- namespace: mypattern-example
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: open-cluster-management
- project: datacenter
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/acm
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-example.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-example.yaml"
- - "/values-4.12-example.yaml"
- - "/values/aws.yaml"
- - "/values/4.12.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- ignoreDifferences: [
- {
- "group": "internal.open-cluster-management.io",
- "jsonPointers": [
- "/spec/loggingCA"
- ],
- "kind": "ManagedClusterInfo"
- }
-]
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/applications.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: pipelines
- namespace: mypattern-example
- labels:
- validatedpatterns.io/pattern: mypattern
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- destination:
- name: in-cluster
- namespace: application-ci
- project: datacenter
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: charts/datacenter/pipelines
- helm:
- ignoreMissingValueFiles: true
- values: |
- extraParametersNested:
- valueFiles:
- - "/values-global.yaml"
- - "/values-example.yaml"
- - "/values-aws.yaml"
- - "/values-aws-4.12.yaml"
- - "/values-aws-example.yaml"
- - "/values-4.12-example.yaml"
- - "/values/aws.yaml"
- - "/values/4.12.yaml"
- - "/values/4.12/aws.yaml"
- parameters:
- - name: global.repoURL
- value: https://github.com/pattern-clone/mypattern
- - name: global.targetRevision
- value: main
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.clusterDomain
- value: region.example.com
- - name: global.clusterVersion
- value: "4.12"
- - name: global.clusterPlatform
- value: "aws"
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.multiSourceSupport
- value:
- - name: global.multiSourceRepoUrl
- value:
- - name: global.multiSourceTargetRevision
- value:
- - name: global.localClusterDomain
- value: apps.region.example.com
- - name: global.privateRepo
- value:
- - name: global.experimentalCapabilities
- value:
- syncPolicy:
- automated: {}
- retry:
- limit: 20
----
-# Source: clustergroup/templates/plumbing/hosted-sites.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: mypattern-argo-edge-perth
- namespace: openshift-gitops
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- project: argo-edge
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- ignoreMissingValueFiles: true
- valueFiles:
- - "/values-global.yaml"
- - "/values-argo-edge.yaml"
- parameters:
- - name: global.repoURL
- value: $ARGOCD_APP_SOURCE_REPO_URL
- - name: global.targetRevision
- value: $ARGOCD_APP_SOURCE_TARGET_REVISION
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.localClusterDomain
- value: apps.perth1.beekhof.net
- - name: global.clusterDomain
- value: perth1.beekhof.net
- - name: enabled
- value: core
- - name: clusterGroup.name
- value: argo-edge
- - name: clusterGroup.targetCluster
- value: perth
- - name: clusterGroup.hostedSite.secretsPath
- value: secret/data/hub/cluster_perth
- - name: clusterGroup.isHubCluster
- value: "false"
- destination:
- name: perth
- namespace: mypattern-argo-edge
- syncPolicy:
- automated:
- selfHeal: true
- ignoreDifferences:
- - group: apps
- kind: Deployment
- jsonPointers:
- - /spec/replicas
- - group: route.openshift.io
- kind: Route
- jsonPointers:
- - /status
----
-# Source: clustergroup/templates/plumbing/hosted-sites.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: mypattern-argo-edge-perth-plumbing
- namespace: openshift-gitops
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- project: argo-edge
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- ignoreMissingValueFiles: true
- valueFiles:
- - "/values-global.yaml"
- - "/values-argo-edge.yaml"
- parameters:
- - name: global.repoURL
- value: $ARGOCD_APP_SOURCE_REPO_URL
- - name: global.targetRevision
- value: $ARGOCD_APP_SOURCE_TARGET_REVISION
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.localClusterDomain
- value: apps.perth1.beekhof.net
- - name: global.clusterDomain
- value: perth1.beekhof.net
- - name: enabled
- value: plumbing
- - name: clusterGroup.name
- value: argo-edge
- - name: clusterGroup.targetCluster
- value: perth
- - name: clusterGroup.hostedSite.secretsPath
- value: secret/data/hub/cluster_perth
- - name: clusterGroup.isHubCluster
- value: "false"
- destination:
- name: in-cluster
- namespace: openshift-gitops
- syncPolicy:
- automated:
- selfHeal: true
- ignoreDifferences:
- - group: apps
- kind: Deployment
- jsonPointers:
- - /spec/replicas
- - group: route.openshift.io
- kind: Route
- jsonPointers:
- - /status
----
-# Source: clustergroup/templates/plumbing/hosted-sites.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: mypattern-argo-edge-sydney
- namespace: openshift-gitops
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- project: argo-edge
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- ignoreMissingValueFiles: true
- valueFiles:
- - "/values-global.yaml"
- - "/values-argo-edge.yaml"
- parameters:
- - name: global.repoURL
- value: $ARGOCD_APP_SOURCE_REPO_URL
- - name: global.targetRevision
- value: $ARGOCD_APP_SOURCE_TARGET_REVISION
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.localClusterDomain
- value: apps.syd.beekhof.net
- - name: global.clusterDomain
- value: syd.beekhof.net
- - name: enabled
- value: core
- - name: clusterGroup.name
- value: argo-edge
- - name: clusterGroup.targetCluster
- value: sydney
- - name: clusterGroup.hostedSite.secretsPath
- value: secret/data/hub/cluster_sydney
- - name: clusterGroup.isHubCluster
- value: "false"
- destination:
- name: sydney
- namespace: mypattern-argo-edge
- syncPolicy:
- automated:
- selfHeal: true
- ignoreDifferences:
- - group: apps
- kind: Deployment
- jsonPointers:
- - /spec/replicas
- - group: route.openshift.io
- kind: Route
- jsonPointers:
- - /status
----
-# Source: clustergroup/templates/plumbing/hosted-sites.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: mypattern-argo-edge-sydney-plumbing
- namespace: openshift-gitops
- finalizers:
- - resources-finalizer.argocd.argoproj.io/foreground
-spec:
- project: argo-edge
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- ignoreMissingValueFiles: true
- valueFiles:
- - "/values-global.yaml"
- - "/values-argo-edge.yaml"
- parameters:
- - name: global.repoURL
- value: $ARGOCD_APP_SOURCE_REPO_URL
- - name: global.targetRevision
- value: $ARGOCD_APP_SOURCE_TARGET_REVISION
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.pattern
- value: mypattern
- - name: global.hubClusterDomain
- value: apps.hub.example.com
- - name: global.localClusterDomain
- value: apps.syd.beekhof.net
- - name: global.clusterDomain
- value: syd.beekhof.net
- - name: enabled
- value: plumbing
- - name: clusterGroup.name
- value: argo-edge
- - name: clusterGroup.targetCluster
- value: sydney
- - name: clusterGroup.hostedSite.secretsPath
- value: secret/data/hub/cluster_sydney
- - name: clusterGroup.isHubCluster
- value: "false"
- destination:
- name: in-cluster
- namespace: openshift-gitops
- syncPolicy:
- automated:
- selfHeal: true
- ignoreDifferences:
- - group: apps
- kind: Deployment
- jsonPointers:
- - /spec/replicas
- - group: route.openshift.io
- kind: Route
- jsonPointers:
- - /status
----
-# Source: clustergroup/templates/plumbing/argocd.yaml
-apiVersion: argoproj.io/v1beta1
-kind: ArgoCD
-metadata:
- finalizers:
- - argoproj.io/finalizer
- # Changing the name affects the ClusterRoleBinding, the generated secret,
- # route URL, and argocd.argoproj.io/managed-by annotations
- name: example-gitops
- namespace: mypattern-example
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
-# Adding health checks to argocd to prevent pvc resources
-# that aren't bound state from blocking deployments
- resourceHealthChecks:
- - kind: PersistentVolumeClaim
- check: |
- hs = {}
- if obj.status ~= nil then
- if obj.status.phase ~= nil then
- if obj.status.phase == "Pending" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- elseif obj.status.phase == "Bound" then
- hs.status = "Healthy"
- hs.message = obj.status.phase
- return hs
- end
- end
- end
- hs.status = "Progressing"
- hs.message = "Waiting for PVC"
- return hs
-
- resourceTrackingMethod: label
- applicationInstanceLabelKey: argocd.argoproj.io/instance
- applicationSet:
- resources:
- limits:
- cpu: "2"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 512Mi
- controller:
- processors: {}
- resources:
- limits:
- cpu: "4"
- memory: 4Gi
- requests:
- cpu: 500m
- memory: 2Gi
- sso:
- provider: dex
- dex:
- openShiftOAuth: true
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 250m
- memory: 128Mi
- initialSSHKnownHosts: {}
- rbac:
- defaultPolicy: role:admin
- repo:
- initContainers:
- - command:
- - bash
- - -c
- - cat /var/run/kube-root-ca/ca.crt /var/run/trusted-ca/ca-bundle.crt /var/run/trusted-hub/hub-kube-root-ca.crt > /tmp/ca-bundles/ca-bundle.crt || true
- image: registry.redhat.io/ansible-automation-platform-24/ee-supported-rhel9:latest
- name: fetch-ca
- resources: {}
- volumeMounts:
- - mountPath: /var/run/kube-root-ca
- name: kube-root-ca
- - mountPath: /var/run/trusted-ca
- name: trusted-ca-bundle
- - mountPath: /var/run/trusted-hub
- name: trusted-hub-bundle
- - mountPath: /tmp/ca-bundles
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 1Gi
- requests:
- cpu: 250m
- memory: 256Mi
- volumeMounts:
- - mountPath: /etc/pki/tls/certs
- name: ca-bundles
- volumes:
- - configMap:
- name: kube-root-ca.crt
- name: kube-root-ca
- - configMap:
- name: trusted-ca-bundle
- optional: true
- name: trusted-ca-bundle
- - configMap:
- name: trusted-hub-bundle
- optional: true
- name: trusted-hub-bundle
- - emptyDir: {}
- name: ca-bundles
- resources:
- limits:
- cpu: "1"
- memory: 512Mi
- requests:
- cpu: 250m
- memory: 256Mi
- resourceExclusions: |
- - apiGroups:
- - tekton.dev
- kinds:
- - TaskRun
- - PipelineRun
- server:
- autoscale:
- enabled: false
- grpc:
- ingress:
- enabled: false
- ingress:
- enabled: false
- resources:
- limits:
- cpu: 500m
- memory: 256Mi
- requests:
- cpu: 125m
- memory: 128Mi
- route:
- enabled: true
- tls:
- insecureEdgeTerminationPolicy: Redirect
- termination: reencrypt
- service:
- type: ""
- tls:
- ca: {}
-status:
----
-# Source: clustergroup/templates/plumbing/argocd.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: example-gitops-link
- namespace: mypattern-example
-spec:
- applicationMenu:
- section: OpenShift GitOps
- imageURL: 
- href: 'https://example-gitops-server-mypattern-example.apps.region.example.com'
- location: ApplicationMenu
- text: 'Example ArgoCD'
----
-# Source: clustergroup/templates/core/nodes.yaml
-apiVersion: v1
-kind: Node
-metadata:
- name: m-m00.cluster.example.tld
- labels:
- argocd.argoproj.io/managed-by: mypattern-example
- cluster.ocs.openshift.io/openshift-storage: ""
----
-# Source: clustergroup/templates/core/nodes.yaml
-apiVersion: v1
-kind: Node
-metadata:
- name: m-m01.cluster.example.tld
- labels:
- argocd.argoproj.io/managed-by: mypattern-example
- cluster.ocs.openshift.io/openshift-storage: ""
----
-# Source: clustergroup/templates/core/nodes.yaml
-apiVersion: v1
-kind: Node
-metadata:
- name: m-m02.cluster.example.tld
- labels:
- argocd.argoproj.io/managed-by: mypattern-example
- cluster.ocs.openshift.io/openshift-storage: ""
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: application-ci-operator-group
- namespace: application-ci
-spec:
- targetNamespaces:
- - application-ci
- - other-namespace
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: exclude-targetns-operator-group
- namespace: exclude-targetns
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
----
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: include-ci-operator-group
- namespace: include-ci
-spec:
- targetNamespaces:
- - include-ci
----
-# Source: clustergroup/templates/core/operatorgroup.yaml
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: include-default-og-operator-group
- namespace: include-default-og
-spec:
- targetNamespaces:
- - include-default-og
----
-# Source: clustergroup/templates/core/scheduler.yaml
-apiVersion: config.openshift.io/v1
-kind: Scheduler
-metadata:
- name: cluster
-spec:
- mastersSchedulable: true
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: advanced-cluster-management
- namespace: open-cluster-management
-spec:
- name: advanced-cluster-management
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- channel: release-2.4
- installPlanApproval: Automatic
- startingCSV: advanced-cluster-management.v2.4.1
----
-# Source: clustergroup/templates/core/subscriptions.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: openshift-pipelines-operator-rh
- namespace: openshift-operators
-spec:
- name: openshift-pipelines-operator-rh
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- installPlanApproval: Automatic
- startingCSV: redhat-openshift-pipelines.v1.5.2
diff --git a/tests/common-examples-kustomize-renderer-naked.expected.yaml b/tests/common-examples-kustomize-renderer-naked.expected.yaml
deleted file mode 100644
index 0aa7ee5d..00000000
--- a/tests/common-examples-kustomize-renderer-naked.expected.yaml
+++ /dev/null
@@ -1,36 +0,0 @@
----
-# Source: example/templates/environment.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: environment
-data:
- IMAGE_PROVIDER:
- IMAGE_ACCOUNT: PLAINTEXT
- GIT_EMAIL: SOMEWHERE@EXAMPLE.COM
- GIT_DEV_REPO_URL: https:///PLAINTEXT/manuela-dev.git
- GIT_DEV_REPO_REVISION: main
- GIT_OPS_REPO_TEST_URL:
- GIT_OPS_REPO_TEST_REVISION:
- GIT_OPS_REPO_PROD_URL:
- GIT_OPS_REPO_PROD_REVISION:
- IOT_CONSUMER_IMAGE: iot-consumer
- IOT_CONSUMER_YAML_PATH: images.(name==messaging).newTag
- IOT_CONSUMER_TEST_KUSTOMIZATION_PATH: charts/datacenter/manuela-tst/kustomization.yaml
- IOT_CONSUMER_PROD_KUSTOMIZATION_PATH: charts/factory/manuela-stormshift/messaging/kustomization.yaml
- IOT_CONSUMER_PROD_IMAGESTREAM_PATH: charts/factory/manuela-stormshift/messaging/messaging-is.yaml
- IOT_FRONTEND_IMAGE: iot-frontend
- IOT_FRONTEND_YAML_PATH: images.(name==line-dashboard).newTag
- IOT_FRONTEND_TEST_KUSTOMIZATION_PATH: charts/datacenter/manuela-tst/kustomization.yaml
- IOT_FRONTEND_PROD_KUSTOMIZATION_PATH: charts/factory/manuela-stormshift/line-dashboard/kustomization.yaml
- IOT_FRONTEND_PROD_IMAGESTREAM_PATH: charts/factory/manuela-stormshift/line-dashboard/line-dashboard-is.yaml
- IOT_SWSENSOR_IMAGE: iot-software-sensor
- IOT_SWSENSOR_YAML_PATH: images.(name==machine-sensor).newTag
- IOT_SWSENSOR_TEST_KUSTOMIZATION_PATH: charts/datacenter/manuela-tst/kustomization.yaml
- IOT_SWSENSOR_PROD_KUSTOMIZATION_PATH: charts/factory/manuela-stormshift/machine-sensor/kustomization.yaml
- IOT_SWSENSOR_PROD_IMAGESTREAM_PATH: charts/factory/manuela-stormshift/machine-sensor/machine-sensor-is.yaml
- IOT_ANOMALY_IMAGE: iot-anomaly-detection
- IOT_ANOMALY_YAML_PATH: images.(name==anomaly-detection).newTag
- IOT_ANOMALY_TEST_KUSTOMIZATION_PATH: charts/datacenter/manuela-tst/kustomization.yaml
- IOT_ANOMALY_PROD_KUSTOMIZATION_PATH: charts/factory/manuela-stormshift/anomaly-detection/kustomization.yaml
- IOT_ANOMALY_PROD_IMAGESTREAM_PATH: charts/factory/manuela-stormshift/anomaly-detection/anomaly-detection-is.yaml
diff --git a/tests/common-examples-kustomize-renderer-normal.expected.yaml b/tests/common-examples-kustomize-renderer-normal.expected.yaml
deleted file mode 100644
index 09783ca3..00000000
--- a/tests/common-examples-kustomize-renderer-normal.expected.yaml
+++ /dev/null
@@ -1,36 +0,0 @@
----
-# Source: example/templates/environment.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: environment
-data:
- IMAGE_PROVIDER: quay.io
- IMAGE_ACCOUNT: PLAINTEXT
- GIT_EMAIL: SOMEWHERE@EXAMPLE.COM
- GIT_DEV_REPO_URL: https://github.com/PLAINTEXT/manuela-dev.git
- GIT_DEV_REPO_REVISION: main
- GIT_OPS_REPO_TEST_URL: https://github.com/pattern-clone/mypattern
- GIT_OPS_REPO_TEST_REVISION:
- GIT_OPS_REPO_PROD_URL: https://github.com/pattern-clone/mypattern
- GIT_OPS_REPO_PROD_REVISION:
- IOT_CONSUMER_IMAGE: iot-consumer
- IOT_CONSUMER_YAML_PATH: images.(name==messaging).newTag
- IOT_CONSUMER_TEST_KUSTOMIZATION_PATH: charts/datacenter/manuela-tst/kustomization.yaml
- IOT_CONSUMER_PROD_KUSTOMIZATION_PATH: charts/factory/manuela-stormshift/messaging/kustomization.yaml
- IOT_CONSUMER_PROD_IMAGESTREAM_PATH: charts/factory/manuela-stormshift/messaging/messaging-is.yaml
- IOT_FRONTEND_IMAGE: iot-frontend
- IOT_FRONTEND_YAML_PATH: images.(name==line-dashboard).newTag
- IOT_FRONTEND_TEST_KUSTOMIZATION_PATH: charts/datacenter/manuela-tst/kustomization.yaml
- IOT_FRONTEND_PROD_KUSTOMIZATION_PATH: charts/factory/manuela-stormshift/line-dashboard/kustomization.yaml
- IOT_FRONTEND_PROD_IMAGESTREAM_PATH: charts/factory/manuela-stormshift/line-dashboard/line-dashboard-is.yaml
- IOT_SWSENSOR_IMAGE: iot-software-sensor
- IOT_SWSENSOR_YAML_PATH: images.(name==machine-sensor).newTag
- IOT_SWSENSOR_TEST_KUSTOMIZATION_PATH: charts/datacenter/manuela-tst/kustomization.yaml
- IOT_SWSENSOR_PROD_KUSTOMIZATION_PATH: charts/factory/manuela-stormshift/machine-sensor/kustomization.yaml
- IOT_SWSENSOR_PROD_IMAGESTREAM_PATH: charts/factory/manuela-stormshift/machine-sensor/machine-sensor-is.yaml
- IOT_ANOMALY_IMAGE: iot-anomaly-detection
- IOT_ANOMALY_YAML_PATH: images.(name==anomaly-detection).newTag
- IOT_ANOMALY_TEST_KUSTOMIZATION_PATH: charts/datacenter/manuela-tst/kustomization.yaml
- IOT_ANOMALY_PROD_KUSTOMIZATION_PATH: charts/factory/manuela-stormshift/anomaly-detection/kustomization.yaml
- IOT_ANOMALY_PROD_IMAGESTREAM_PATH: charts/factory/manuela-stormshift/anomaly-detection/anomaly-detection-is.yaml
diff --git a/tests/common-golang-external-secrets-industrial-edge-factory.expected.yaml b/tests/common-golang-external-secrets-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 19c1f8c0..00000000
--- a/tests/common-golang-external-secrets-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,13143 +0,0 @@
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: external-secrets-cert-controller
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: common-golang-external-secrets
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- external-secrets.io/component: webhook
----
-# Source: golang-external-secrets/templates/golang-external-secrets-hub-clusterrolebinding.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: golang-external-secrets
- namespace: golang-external-secrets
- annotations:
- kubernetes.io/service-account.name: golang-external-secrets
-type: kubernetes.io/service-account-token
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/acraccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: acraccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - acraccesstoken
- kind: ACRAccessToken
- listKind: ACRAccessTokenList
- plural: acraccesstokens
- shortNames:
- - acraccesstoken
- singular: acraccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- ACRAccessToken returns a Azure Container Registry token
- that can be used for pushing/pulling images.
- Note: by default it will return an ACR Refresh Token with full access
- (depending on the identity).
- This can be scoped down to the repository level using .spec.scope.
- In case scope is defined it will return an ACR Access Token.
-
-
- See docs: https://github.com/Azure/acr/blob/main/docs/AAD-OAuth.md
- 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: |-
- ACRAccessTokenSpec defines how to generate the access token
- e.g. how to authenticate and which registry to use.
- see: https://github.com/Azure/acr/blob/main/docs/AAD-OAuth.md#overview
- properties:
- auth:
- properties:
- managedIdentity:
- description: ManagedIdentity uses Azure Managed Identity to authenticate with Azure.
- properties:
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- type: object
- servicePrincipal:
- description: ServicePrincipal uses Azure Service Principal credentials to authenticate with Azure.
- properties:
- secretRef:
- description: |-
- Configuration used to authenticate with Azure using static
- credentials stored in a Kind=Secret.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- workloadIdentity:
- description: WorkloadIdentity uses Azure Workload Identity to authenticate with Azure.
- properties:
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- registry:
- description: |-
- the domain name of the ACR registry
- e.g. foobarexample.azurecr.io
- type: string
- scope:
- description: |-
- Define the scope for the access token, e.g. pull/push access for a repository.
- if not provided it will return a refresh token that has full scope.
- Note: you need to pin it down to the repository level, there is no wildcard available.
-
-
- examples:
- repository:my-repository:pull,push
- repository:my-repository:pull
-
-
- see docs for details: https://docs.docker.com/registry/spec/auth/scope/
- type: string
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- required:
- - auth
- - registry
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/clusterexternalsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: clusterexternalsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ClusterExternalSecret
- listKind: ClusterExternalSecretList
- plural: clusterexternalsecrets
- shortNames:
- - ces
- singular: clusterexternalsecret
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - jsonPath: .spec.externalSecretSpec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshTime
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ClusterExternalSecret is the Schema for the clusterexternalsecrets 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: ClusterExternalSecretSpec defines the desired state of ClusterExternalSecret.
- properties:
- externalSecretMetadata:
- description: The metadata of the external secrets to be created
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- externalSecretName:
- description: The name of the external secrets to be created defaults to the name of the ClusterExternalSecret
- type: string
- externalSecretSpec:
- description: The spec for the ExternalSecrets to be created
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: |-
- RemoteRef points to the remote secret and defines
- which secret (version/property/..) to fetch.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- description: |-
- SecretKey defines the key in which the controller stores
- the value. This is the key in the Kind=Secret
- type: string
- sourceRef:
- description: |-
- SourceRef allows you to override the source
- from which the value will pulled from.
- maxProperties: 1
- properties:
- generatorRef:
- description: |-
- GeneratorRef points to a generator custom resource.
-
-
- Deprecated: The generatorRef is not implemented in .data[].
- this will be removed with v1.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- properties:
- extract:
- description: |-
- Used to extract multiple key/value pairs from one secret
- Note: Extract does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- find:
- description: |-
- Used to find secrets based on tags or regular expressions
- Note: Find does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- name:
- description: Finds secrets based on the name.
- properties:
- regexp:
- description: Finds secrets base
- type: string
- type: object
- path:
- description: A root path to start the find operations.
- type: string
- tags:
- additionalProperties:
- type: string
- description: Find secrets based on tags.
- type: object
- type: object
- rewrite:
- description: |-
- Used to rewrite secret Keys after getting them from the secret Provider
- Multiple Rewrite operations can be provided. They are applied in a layered order (first to last)
- items:
- properties:
- regexp:
- description: |-
- Used to rewrite with regular expressions.
- The resulting key will be the output of a regexp.ReplaceAll operation.
- properties:
- source:
- description: Used to define the regular expression of a re.Compiler.
- type: string
- target:
- description: Used to define the target pattern of a ReplaceAll operation.
- type: string
- required:
- - source
- - target
- type: object
- transform:
- description: |-
- Used to apply string transformation on the secrets.
- The resulting key will be the output of the template applied by the operation.
- properties:
- template:
- description: |-
- Used to define the template to apply on the secret name.
- `.value ` will specify the secret name in the template.
- type: string
- required:
- - template
- type: object
- type: object
- type: array
- sourceRef:
- description: |-
- SourceRef points to a store or generator
- which contains secret values ready to use.
- Use this in combination with Extract or Find pull values out of
- a specific SecretStore.
- When sourceRef points to a generator Extract or Find is not supported.
- The generator returns a static map of values
- maxProperties: 1
- properties:
- generatorRef:
- description: GeneratorRef points to a generator custom resource.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- default:
- creationPolicy: Owner
- deletionPolicy: Retain
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Orphan
- - Merge
- - None
- type: string
- deletionPolicy:
- default: Retain
- description: |-
- DeletionPolicy defines rules on how to delete the resulting Secret
- Defaults to 'Retain'
- enum:
- - Delete
- - Merge
- - Retain
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- type: object
- namespaceSelector:
- description: |-
- The labels to select by to find the Namespaces to create the ExternalSecrets in.
- Deprecated: Use NamespaceSelectors instead.
- 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
- namespaceSelectors:
- description: A list of labels to select by to find the Namespaces to create the ExternalSecrets in. The selectors are ORed.
- items:
- description: |-
- A label selector is a label query over a set of resources. The result of matchLabels and
- matchExpressions are ANDed. An empty label selector matches all objects. A null
- label selector matches no objects.
- 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
- type: array
- namespaces:
- description: Choose namespaces by name. This field is ORed with anything that NamespaceSelectors ends up choosing.
- items:
- type: string
- type: array
- refreshTime:
- description: The time in which the controller should reconcile its objects and recheck namespaces for labels.
- type: string
- required:
- - externalSecretSpec
- type: object
- status:
- description: ClusterExternalSecretStatus defines the observed state of ClusterExternalSecret.
- properties:
- conditions:
- items:
- properties:
- message:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- externalSecretName:
- description: ExternalSecretName is the name of the ExternalSecrets created by the ClusterExternalSecret
- type: string
- failedNamespaces:
- description: Failed namespaces are the namespaces that failed to apply an ExternalSecret
- items:
- description: ClusterExternalSecretNamespaceFailure represents a failed namespace deployment and it's reason.
- properties:
- namespace:
- description: Namespace is the namespace that failed when trying to apply an ExternalSecret
- type: string
- reason:
- description: Reason is why the ExternalSecret failed to apply to the namespace
- type: string
- required:
- - namespace
- type: object
- type: array
- provisionedNamespaces:
- description: ProvisionedNamespaces are the namespaces where the ClusterExternalSecret has secrets
- items:
- type: string
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/clustersecretstore.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: clustersecretstores.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ClusterSecretStore
- listKind: ClusterSecretStoreList
- plural: clustersecretstores
- shortNames:
- - css
- singular: clustersecretstore
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: ClusterSecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the SecretManager provider will assume
- type: string
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- properties:
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- serviceAccount:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- required:
- - auth
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, instance principal is used. Optionally, the authenticating principal type
- and/or user data may be supplied for the use of workload identity and user principal.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - roleId
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.capabilities
- name: Capabilities
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ClusterSecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- conditions:
- description: Used to constraint a ClusterSecretStore to specific namespaces. Relevant only to ClusterSecretStore
- items:
- description: |-
- ClusterSecretStoreCondition describes a condition by which to choose namespaces to process ExternalSecrets in
- for a ClusterSecretStore instance.
- properties:
- namespaceRegexes:
- description: Choose namespaces by using regex matching
- items:
- type: string
- type: array
- namespaceSelector:
- description: Choose namespace using a labelSelector
- 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
- namespaces:
- description: Choose namespaces by name
- items:
- type: string
- type: array
- type: object
- type: array
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- additionalRoles:
- description: AdditionalRoles is a chained list of Role ARNs which the provider will sequentially assume before assuming the Role
- items:
- type: string
- type: array
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- prefix:
- description: Prefix adds a prefix to all retrieved values.
- type: string
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the provider will assume
- type: string
- secretsManager:
- description: SecretsManager defines how the provider behaves when interacting with AWS SecretsManager
- properties:
- forceDeleteWithoutRecovery:
- description: |-
- Specifies whether to delete the secret without any recovery window. You
- can't use both this parameter and RecoveryWindowInDays in the same call.
- If you don't use either, then by default Secrets Manager uses a 30 day
- recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-ForceDeleteWithoutRecovery
- type: boolean
- recoveryWindowInDays:
- description: |-
- The number of days from 7 to 30 that Secrets Manager waits before
- permanently deleting the secret. You can't use both this parameter and
- ForceDeleteWithoutRecovery in the same call. If you don't use either,
- then by default Secrets Manager uses a 30 day recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-RecoveryWindowInDays
- format: int64
- type: integer
- type: object
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- sessionTags:
- description: AWS STS assume role session tags
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- transitiveTagKeys:
- description: AWS STS assume role transitive session tags. Required when multiple rules are used with the provider
- items:
- type: string
- type: array
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- properties:
- clientCertificate:
- description: The Azure ClientCertificate of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientId:
- description: The Azure clientId of the service principle or managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- tenantId:
- description: The Azure tenantId of the managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- bitwardensecretsmanager:
- description: BitwardenSecretsManager configures this store to sync secrets using BitwardenSecretsManager provider
- properties:
- apiURL:
- type: string
- auth:
- description: |-
- Auth configures how secret-manager authenticates with a bitwarden machine account instance.
- Make sure that the token being used has permissions on the given secret.
- properties:
- secretRef:
- description: BitwardenSecretsManagerSecretRef contains the credential ref to the bitwarden instance.
- properties:
- credentials:
- description: AccessToken used for the bitwarden instance.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - credentials
- type: object
- required:
- - secretRef
- type: object
- bitwardenServerSDKURL:
- type: string
- caBundle:
- description: |-
- Base64 encoded certificate for the bitwarden server sdk. The sdk MUST run with HTTPS to make sure no MITM attack
- can be performed.
- type: string
- identityURL:
- type: string
- organizationID:
- description: OrganizationID determines which organization this secret store manages.
- type: string
- projectID:
- description: ProjectID determines which project this secret store manages.
- type: string
- required:
- - auth
- - caBundle
- - organizationID
- - projectID
- type: object
- chef:
- description: Chef configures this store to sync secrets with chef server
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against chef Server
- properties:
- secretRef:
- description: ChefAuthSecretRef holds secret references for chef server login credentials.
- properties:
- privateKeySecretRef:
- description: SecretKey is the Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - privateKeySecretRef
- type: object
- required:
- - secretRef
- type: object
- serverUrl:
- description: ServerURL is the chef server URL used to connect to. If using orgs you should include your org in the url and terminate the url with a "/"
- type: string
- username:
- description: UserName should be the user ID on the chef server
- type: string
- required:
- - auth
- - serverUrl
- - username
- type: object
- conjur:
- description: Conjur configures this store to sync secrets using conjur provider
- properties:
- auth:
- properties:
- apikey:
- properties:
- account:
- type: string
- apiKeyRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - account
- - apiKeyRef
- - userRef
- type: object
- jwt:
- properties:
- account:
- type: string
- hostId:
- description: |-
- Optional HostID for JWT authentication. This may be used depending
- on how the Conjur JWT authenticator policy is configured.
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Conjur using the JWT authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional ServiceAccountRef specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- serviceID:
- description: The conjur authn jwt webservice id
- type: string
- required:
- - account
- - serviceID
- type: object
- type: object
- caBundle:
- type: string
- caProvider:
- description: |-
- Used to provide custom certificate authority (CA) certificates
- for a secret store. The CAProvider points to a Secret or ConfigMap resource
- that contains a PEM-encoded certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- type: string
- required:
- - auth
- - url
- type: object
- delinea:
- description: |-
- Delinea DevOps Secrets Vault
- https://docs.delinea.com/online-help/products/devops-secrets-vault/current
- properties:
- clientId:
- description: ClientID is the non-secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- clientSecret:
- description: ClientSecret is the secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- tenant:
- description: Tenant is the chosen hostname / site name.
- type: string
- tld:
- description: |-
- TLD is based on the server location that was chosen during provisioning.
- If unset, defaults to "com".
- type: string
- urlTemplate:
- description: |-
- URLTemplate
- If unset, defaults to "https://%s.secretsvaultcloud.%s/v1/%s%s".
- type: string
- required:
- - clientId
- - clientSecret
- - tenant
- type: object
- device42:
- description: Device42 configures this store to sync secrets using the Device42 provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Device42 instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- host:
- description: URL configures the Device42 instance URL.
- type: string
- required:
- - auth
- - host
- type: object
- doppler:
- description: Doppler configures this store to sync secrets using the Doppler provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Doppler API
- properties:
- secretRef:
- properties:
- dopplerToken:
- description: |-
- The DopplerToken is used for authentication.
- See https://docs.doppler.com/reference/api#authentication for auth token types.
- The Key attribute defaults to dopplerToken if not specified.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - dopplerToken
- type: object
- required:
- - secretRef
- type: object
- config:
- description: Doppler config (required if not using a Service Token)
- type: string
- format:
- description: Format enables the downloading of secrets as a file (string)
- enum:
- - json
- - dotnet-json
- - env
- - yaml
- - docker
- type: string
- nameTransformer:
- description: Environment variable compatible name transforms that change secret names to a different format
- enum:
- - upper-camel
- - camel
- - lower-snake
- - tf-var
- - dotnet-env
- - lower-kebab
- type: string
- project:
- description: Doppler project (required if not using a Service Token)
- type: string
- required:
- - auth
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- description: 'Deprecated: ValueMap is deprecated and is intended to be removed in the future, use the `value` field instead.'
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- fortanix:
- description: Fortanix configures this store to sync secrets using the Fortanix provider
- properties:
- apiKey:
- description: APIKey is the API token to access SDKMS Applications.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the SDKMS API Key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- description: APIURL is the URL of SDKMS API. Defaults to `sdkms.fortanix.com`.
- type: string
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- location:
- description: Location optionally defines a location for a secret
- type: string
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- environment:
- description: Environment environment_scope of gitlab CI/CD variables (Please see https://docs.gitlab.com/ee/ci/environments/#create-a-static-environment on how to create environments)
- type: string
- groupIDs:
- description: GroupIDs specify, which gitlab groups to pull secrets from. Group secrets are read from left to right followed by the project variables.
- items:
- type: string
- type: array
- inheritFromGroups:
- description: InheritFromGroups specifies whether parent groups should be discovered and checked for secrets.
- type: boolean
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- maxProperties: 1
- minProperties: 1
- properties:
- containerAuth:
- description: IBM Container-based auth with IAM Trusted Profile.
- properties:
- iamEndpoint:
- type: string
- profile:
- description: the IBM Trusted Profile
- type: string
- tokenLocation:
- description: Location the token is mounted on the pod
- type: string
- required:
- - profile
- type: object
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- infisical:
- description: Infisical configures this store to sync secrets using the Infisical provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Infisical API
- properties:
- universalAuthCredentials:
- properties:
- clientId:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecret
- type: object
- type: object
- hostAPI:
- default: https://app.infisical.com/api
- type: string
- secretsScope:
- properties:
- environmentSlug:
- type: string
- projectSlug:
- type: string
- secretsPath:
- default: /
- type: string
- required:
- - environmentSlug
- - projectSlug
- type: object
- required:
- - auth
- - secretsScope
- type: object
- keepersecurity:
- description: KeeperSecurity configures this store to sync secrets using the KeeperSecurity provider
- properties:
- authRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- folderID:
- type: string
- required:
- - authRef
- - folderID
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- authRef:
- description: A reference to a secret that contains the auth information.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- type: object
- onboardbase:
- description: Onboardbase configures this store to sync secrets using the Onboardbase provider
- properties:
- apiHost:
- default: https://public.onboardbase.com/api/v1/
- description: APIHost use this to configure the host url for the API for selfhosted installation, default is https://public.onboardbase.com/api/v1/
- type: string
- auth:
- description: Auth configures how the Operator authenticates with the Onboardbase API
- properties:
- apiKeyRef:
- description: |-
- OnboardbaseAPIKey is the APIKey generated by an admin account.
- It is used to recognize and authorize access to a project and environment within onboardbase
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- passcodeRef:
- description: OnboardbasePasscode is the passcode attached to the API Key
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - apiKeyRef
- - passcodeRef
- type: object
- environment:
- default: development
- description: Environment is the name of an environmnent within a project to pull the secrets from
- type: string
- project:
- default: development
- description: Project is an onboardbase project that the secrets should be pulled from
- type: string
- required:
- - apiHost
- - auth
- - environment
- - project
- type: object
- onepassword:
- description: OnePassword configures this store to sync secrets using the 1Password Cloud provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against OnePassword Connect Server
- properties:
- secretRef:
- description: OnePasswordAuthSecretRef holds secret references for 1Password credentials.
- properties:
- connectTokenSecretRef:
- description: The ConnectToken is used for authentication to a 1Password Connect Server.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - connectTokenSecretRef
- type: object
- required:
- - secretRef
- type: object
- connectHost:
- description: ConnectHost defines the OnePassword Connect Server to connect to
- type: string
- vaults:
- additionalProperties:
- type: integer
- description: Vaults defines which OnePassword vaults to search in which order
- type: object
- required:
- - auth
- - connectHost
- - vaults
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, use the instance principal, otherwise the user credentials specified in Auth.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passbolt:
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against Passbolt Server
- properties:
- passwordSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privateKeySecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - passwordSecretRef
- - privateKeySecretRef
- type: object
- host:
- description: Host defines the Passbolt Server to connect to
- type: string
- required:
- - auth
- - host
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- pulumi:
- description: Pulumi configures this store to sync secrets using the Pulumi provider
- properties:
- accessToken:
- description: AccessToken is the access tokens to sign in to the Pulumi Cloud Console.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the Pulumi API token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- default: https://api.pulumi.com/api/preview
- description: APIURL is the URL of the Pulumi API.
- type: string
- environment:
- description: |-
- Environment are YAML documents composed of static key-value pairs, programmatic expressions,
- dynamically retrieved values from supported providers including all major clouds,
- and other Pulumi ESC environments.
- To create a new environment, visit https://www.pulumi.com/docs/esc/environments/ for more information.
- type: string
- organization:
- description: |-
- Organization are a space to collaborate on shared projects and stacks.
- To create a new organization, visit https://app.pulumi.com/ and click "New Organization".
- type: string
- required:
- - accessToken
- - environment
- - organization
- type: object
- scaleway:
- description: Scaleway
- properties:
- accessKey:
- description: AccessKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- apiUrl:
- description: APIURL is the url of the api to use. Defaults to https://api.scaleway.com
- type: string
- projectId:
- description: 'ProjectID is the id of your project, which you can find in the console: https://console.scaleway.com/project/settings'
- type: string
- region:
- description: 'Region where your secrets are located: https://developers.scaleway.com/en/quickstart/#region-and-zone'
- type: string
- secretKey:
- description: SecretKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - accessKey
- - projectId
- - region
- - secretKey
- type: object
- secretserver:
- description: |-
- SecretServer configures this store to sync secrets using SecretServer provider
- https://docs.delinea.com/online-help/secret-server/start.htm
- properties:
- password:
- description: Password is the secret server account password.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- serverURL:
- description: |-
- ServerURL
- URL to your secret server installation
- type: string
- username:
- description: Username is the secret server account username.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - password
- - serverURL
- - username
- type: object
- senhasegura:
- description: Senhasegura configures this store to sync secrets using senhasegura provider
- properties:
- auth:
- description: Auth defines parameters to authenticate in senhasegura
- properties:
- clientId:
- type: string
- clientSecretSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecretSecretRef
- type: object
- ignoreSslCertificate:
- default: false
- description: IgnoreSslCertificate defines if SSL certificate must be ignored
- type: boolean
- module:
- description: Module defines which senhasegura module should be used to get secrets
- type: string
- url:
- description: URL of senhasegura
- type: string
- required:
- - auth
- - module
- - url
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexcertificatemanager:
- description: YandexCertificateManager configures this store to sync secrets using Yandex Certificate Manager provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Certificate Manager
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- refreshInterval:
- description: Used to configure store refresh interval in seconds. Empty or 0 will default to the controller config.
- type: integer
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- capabilities:
- description: SecretStoreCapabilities defines the possible operations a SecretStore can do.
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/ecrauthorizationtoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: ecrauthorizationtokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - ecrauthorizationtoken
- kind: ECRAuthorizationToken
- listKind: ECRAuthorizationTokenList
- plural: ecrauthorizationtokens
- shortNames:
- - ecrauthorizationtoken
- singular: ecrauthorizationtoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- ECRAuthorizationTokenSpec uses the GetAuthorizationToken API to retrieve an
- authorization token.
- The authorization token is valid for 12 hours.
- The authorizationToken returned is a base64 encoded string that can be decoded
- and used in a docker login command to authenticate to a registry.
- For more information, see Registry authentication (https://docs.aws.amazon.com/AmazonECR/latest/userguide/Registries.html#registry_auth) in the Amazon Elastic Container Registry User Guide.
- 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:
- properties:
- auth:
- description: Auth defines how to authenticate with AWS
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: Region specifies the region to operate in.
- type: string
- role:
- description: |-
- You can assume a role before making calls to the
- desired AWS service.
- type: string
- required:
- - region
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/externalsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: externalsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ExternalSecret
- listKind: ExternalSecretList
- plural: externalsecrets
- shortNames:
- - es
- singular: externalsecret
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .spec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshInterval
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: ExternalSecret is the Schema for the external-secrets 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: ExternalSecretSpec defines the desired state of ExternalSecret.
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: ExternalSecretDataRemoteRef defines Provider data location.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- type: string
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- description: ExternalSecretDataRemoteRef defines Provider data location.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Merge
- - None
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v1
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- maxProperties: 1
- minProperties: 1
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- required:
- - secretStoreRef
- - target
- type: object
- status:
- properties:
- binding:
- description: Binding represents a servicebinding.io Provisioned Service reference to the secret
- properties:
- name:
- default: ""
- description: |-
- Name of the referent.
- This field is effectively required, but due to backwards compatibility is
- allowed to be empty. Instances of this type with an empty value here are
- almost certainly wrong.
- TODO: Add other useful fields. apiVersion, kind, uid?
- More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
- TODO: Drop `kubebuilder:default` when controller-gen doesn't need it https://github.com/kubernetes-sigs/kubebuilder/issues/3896.
- type: string
- type: object
- x-kubernetes-map-type: atomic
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version
- type: string
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .spec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshInterval
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ExternalSecret is the Schema for the external-secrets 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: ExternalSecretSpec defines the desired state of ExternalSecret.
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: |-
- RemoteRef points to the remote secret and defines
- which secret (version/property/..) to fetch.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- description: |-
- SecretKey defines the key in which the controller stores
- the value. This is the key in the Kind=Secret
- type: string
- sourceRef:
- description: |-
- SourceRef allows you to override the source
- from which the value will pulled from.
- maxProperties: 1
- properties:
- generatorRef:
- description: |-
- GeneratorRef points to a generator custom resource.
-
-
- Deprecated: The generatorRef is not implemented in .data[].
- this will be removed with v1.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- properties:
- extract:
- description: |-
- Used to extract multiple key/value pairs from one secret
- Note: Extract does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- find:
- description: |-
- Used to find secrets based on tags or regular expressions
- Note: Find does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- name:
- description: Finds secrets based on the name.
- properties:
- regexp:
- description: Finds secrets base
- type: string
- type: object
- path:
- description: A root path to start the find operations.
- type: string
- tags:
- additionalProperties:
- type: string
- description: Find secrets based on tags.
- type: object
- type: object
- rewrite:
- description: |-
- Used to rewrite secret Keys after getting them from the secret Provider
- Multiple Rewrite operations can be provided. They are applied in a layered order (first to last)
- items:
- properties:
- regexp:
- description: |-
- Used to rewrite with regular expressions.
- The resulting key will be the output of a regexp.ReplaceAll operation.
- properties:
- source:
- description: Used to define the regular expression of a re.Compiler.
- type: string
- target:
- description: Used to define the target pattern of a ReplaceAll operation.
- type: string
- required:
- - source
- - target
- type: object
- transform:
- description: |-
- Used to apply string transformation on the secrets.
- The resulting key will be the output of the template applied by the operation.
- properties:
- template:
- description: |-
- Used to define the template to apply on the secret name.
- `.value ` will specify the secret name in the template.
- type: string
- required:
- - template
- type: object
- type: object
- type: array
- sourceRef:
- description: |-
- SourceRef points to a store or generator
- which contains secret values ready to use.
- Use this in combination with Extract or Find pull values out of
- a specific SecretStore.
- When sourceRef points to a generator Extract or Find is not supported.
- The generator returns a static map of values
- maxProperties: 1
- properties:
- generatorRef:
- description: GeneratorRef points to a generator custom resource.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- default:
- creationPolicy: Owner
- deletionPolicy: Retain
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Orphan
- - Merge
- - None
- type: string
- deletionPolicy:
- default: Retain
- description: |-
- DeletionPolicy defines rules on how to delete the resulting Secret
- Defaults to 'Retain'
- enum:
- - Delete
- - Merge
- - Retain
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- type: object
- status:
- properties:
- binding:
- description: Binding represents a servicebinding.io Provisioned Service reference to the secret
- properties:
- name:
- default: ""
- description: |-
- Name of the referent.
- This field is effectively required, but due to backwards compatibility is
- allowed to be empty. Instances of this type with an empty value here are
- almost certainly wrong.
- TODO: Add other useful fields. apiVersion, kind, uid?
- More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
- TODO: Drop `kubebuilder:default` when controller-gen doesn't need it https://github.com/kubernetes-sigs/kubebuilder/issues/3896.
- type: string
- type: object
- x-kubernetes-map-type: atomic
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version
- type: string
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/fake.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: fakes.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - fake
- kind: Fake
- listKind: FakeList
- plural: fakes
- shortNames:
- - fake
- singular: fake
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Fake generator is used for testing. It lets you define
- a static set of credentials that is always returned.
- 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: FakeSpec contains the static data.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters VDS based on this property
- type: string
- data:
- additionalProperties:
- type: string
- description: |-
- Data defines the static data returned
- by this generator.
- type: object
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/gcraccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: gcraccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - gcraccesstoken
- kind: GCRAccessToken
- listKind: GCRAccessTokenList
- plural: gcraccesstokens
- shortNames:
- - gcraccesstoken
- singular: gcraccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- GCRAccessToken generates an GCP access token
- that can be used to authenticate with GCR.
- 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:
- properties:
- auth:
- description: Auth defines the means for authenticating with GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID defines which project to use to authenticate with
- type: string
- required:
- - auth
- - projectID
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/githubaccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: githubaccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - githubaccesstoken
- kind: GithubAccessToken
- listKind: GithubAccessTokenList
- plural: githubaccesstokens
- shortNames:
- - githubaccesstoken
- singular: githubaccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: GithubAccessToken generates ghs_ accessToken
- 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:
- properties:
- appID:
- type: string
- auth:
- description: Auth configures how ESO authenticates with a Github instance.
- properties:
- privateKey:
- properties:
- secretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - secretRef
- type: object
- required:
- - privateKey
- type: object
- installID:
- type: string
- url:
- description: URL configures the Github instance URL. Defaults to https://github.com/.
- type: string
- required:
- - appID
- - auth
- - installID
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/password.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: passwords.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - password
- kind: Password
- listKind: PasswordList
- plural: passwords
- shortNames:
- - password
- singular: password
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Password generates a random password based on the
- configuration parameters in spec.
- You can specify the length, characterset and other attributes.
- 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: PasswordSpec controls the behavior of the password generator.
- properties:
- allowRepeat:
- default: false
- description: set AllowRepeat to true to allow repeating characters.
- type: boolean
- digits:
- description: |-
- Digits specifies the number of digits in the generated
- password. If omitted it defaults to 25% of the length of the password
- type: integer
- length:
- default: 24
- description: |-
- Length of the password to be generated.
- Defaults to 24
- type: integer
- noUpper:
- default: false
- description: Set NoUpper to disable uppercase characters
- type: boolean
- symbolCharacters:
- description: |-
- SymbolCharacters specifies the special characters that should be used
- in the generated password.
- type: string
- symbols:
- description: |-
- Symbols specifies the number of symbol characters in the generated
- password. If omitted it defaults to 25% of the length of the password
- type: integer
- required:
- - allowRepeat
- - length
- - noUpper
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/pushsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- name: pushsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - pushsecrets
- kind: PushSecret
- listKind: PushSecretList
- plural: pushsecrets
- singular: pushsecret
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- name: v1alpha1
- schema:
- openAPIV3Schema:
- 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: PushSecretSpec configures the behavior of the PushSecret.
- properties:
- data:
- description: Secret Data that should be pushed to providers
- items:
- properties:
- conversionStrategy:
- default: None
- description: Used to define a conversion Strategy for the secret keys
- enum:
- - None
- - ReverseUnicode
- type: string
- match:
- description: Match a given Secret Key to be pushed to the provider.
- properties:
- remoteRef:
- description: Remote Refs to push to providers.
- properties:
- property:
- description: Name of the property in the resulting secret
- type: string
- remoteKey:
- description: Name of the resulting provider secret.
- type: string
- required:
- - remoteKey
- type: object
- secretKey:
- description: Secret Key to be pushed
- type: string
- required:
- - remoteRef
- type: object
- metadata:
- description: |-
- Metadata is metadata attached to the secret.
- The structure of metadata is provider specific, please look it up in the provider documentation.
- x-kubernetes-preserve-unknown-fields: true
- required:
- - match
- type: object
- type: array
- deletionPolicy:
- default: None
- description: 'Deletion Policy to handle Secrets in the provider. Possible Values: "Delete/None". Defaults to "None".'
- enum:
- - Delete
- - None
- type: string
- refreshInterval:
- description: The Interval to which External Secrets will try to push a secret definition
- type: string
- secretStoreRefs:
- items:
- properties:
- kind:
- default: SecretStore
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- labelSelector:
- description: Optionally, sync to secret stores with label selector
- 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
- name:
- description: Optionally, sync to the SecretStore of the given name
- type: string
- type: object
- type: array
- selector:
- description: The Secret Selector (k8s source) for the Push Secret
- properties:
- secret:
- description: Select a Secret to Push.
- properties:
- name:
- description: Name of the Secret. The Secret must exist in the same namespace as the PushSecret manifest.
- type: string
- required:
- - name
- type: object
- required:
- - secret
- type: object
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- updatePolicy:
- default: Replace
- description: 'UpdatePolicy to handle Secrets in the provider. Possible Values: "Replace/IfNotExists". Defaults to "Replace".'
- enum:
- - Replace
- - IfNotExists
- type: string
- required:
- - secretStoreRefs
- - selector
- type: object
- status:
- description: PushSecretStatus indicates the history of the status of PushSecret.
- properties:
- conditions:
- items:
- description: PushSecretStatusCondition indicates the status of the PushSecret.
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- description: PushSecretConditionType indicates the condition of the PushSecret.
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedPushSecrets:
- additionalProperties:
- additionalProperties:
- properties:
- conversionStrategy:
- default: None
- description: Used to define a conversion Strategy for the secret keys
- enum:
- - None
- - ReverseUnicode
- type: string
- match:
- description: Match a given Secret Key to be pushed to the provider.
- properties:
- remoteRef:
- description: Remote Refs to push to providers.
- properties:
- property:
- description: Name of the property in the resulting secret
- type: string
- remoteKey:
- description: Name of the resulting provider secret.
- type: string
- required:
- - remoteKey
- type: object
- secretKey:
- description: Secret Key to be pushed
- type: string
- required:
- - remoteRef
- type: object
- metadata:
- description: |-
- Metadata is metadata attached to the secret.
- The structure of metadata is provider specific, please look it up in the provider documentation.
- x-kubernetes-preserve-unknown-fields: true
- required:
- - match
- type: object
- type: object
- description: |-
- Synced PushSecrets, including secrets that already exist in provider.
- Matches secret stores to PushSecretData that was stored to that secret store.
- type: object
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version.
- type: string
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/secretstore.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: secretstores.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: SecretStore
- listKind: SecretStoreList
- plural: secretstores
- shortNames:
- - ss
- singular: secretstore
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: SecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the SecretManager provider will assume
- type: string
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- properties:
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- serviceAccount:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- required:
- - auth
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, instance principal is used. Optionally, the authenticating principal type
- and/or user data may be supplied for the use of workload identity and user principal.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - roleId
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.capabilities
- name: Capabilities
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: SecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- conditions:
- description: Used to constraint a ClusterSecretStore to specific namespaces. Relevant only to ClusterSecretStore
- items:
- description: |-
- ClusterSecretStoreCondition describes a condition by which to choose namespaces to process ExternalSecrets in
- for a ClusterSecretStore instance.
- properties:
- namespaceRegexes:
- description: Choose namespaces by using regex matching
- items:
- type: string
- type: array
- namespaceSelector:
- description: Choose namespace using a labelSelector
- 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
- namespaces:
- description: Choose namespaces by name
- items:
- type: string
- type: array
- type: object
- type: array
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- additionalRoles:
- description: AdditionalRoles is a chained list of Role ARNs which the provider will sequentially assume before assuming the Role
- items:
- type: string
- type: array
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- prefix:
- description: Prefix adds a prefix to all retrieved values.
- type: string
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the provider will assume
- type: string
- secretsManager:
- description: SecretsManager defines how the provider behaves when interacting with AWS SecretsManager
- properties:
- forceDeleteWithoutRecovery:
- description: |-
- Specifies whether to delete the secret without any recovery window. You
- can't use both this parameter and RecoveryWindowInDays in the same call.
- If you don't use either, then by default Secrets Manager uses a 30 day
- recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-ForceDeleteWithoutRecovery
- type: boolean
- recoveryWindowInDays:
- description: |-
- The number of days from 7 to 30 that Secrets Manager waits before
- permanently deleting the secret. You can't use both this parameter and
- ForceDeleteWithoutRecovery in the same call. If you don't use either,
- then by default Secrets Manager uses a 30 day recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-RecoveryWindowInDays
- format: int64
- type: integer
- type: object
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- sessionTags:
- description: AWS STS assume role session tags
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- transitiveTagKeys:
- description: AWS STS assume role transitive session tags. Required when multiple rules are used with the provider
- items:
- type: string
- type: array
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- properties:
- clientCertificate:
- description: The Azure ClientCertificate of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientId:
- description: The Azure clientId of the service principle or managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- tenantId:
- description: The Azure tenantId of the managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- bitwardensecretsmanager:
- description: BitwardenSecretsManager configures this store to sync secrets using BitwardenSecretsManager provider
- properties:
- apiURL:
- type: string
- auth:
- description: |-
- Auth configures how secret-manager authenticates with a bitwarden machine account instance.
- Make sure that the token being used has permissions on the given secret.
- properties:
- secretRef:
- description: BitwardenSecretsManagerSecretRef contains the credential ref to the bitwarden instance.
- properties:
- credentials:
- description: AccessToken used for the bitwarden instance.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - credentials
- type: object
- required:
- - secretRef
- type: object
- bitwardenServerSDKURL:
- type: string
- caBundle:
- description: |-
- Base64 encoded certificate for the bitwarden server sdk. The sdk MUST run with HTTPS to make sure no MITM attack
- can be performed.
- type: string
- identityURL:
- type: string
- organizationID:
- description: OrganizationID determines which organization this secret store manages.
- type: string
- projectID:
- description: ProjectID determines which project this secret store manages.
- type: string
- required:
- - auth
- - caBundle
- - organizationID
- - projectID
- type: object
- chef:
- description: Chef configures this store to sync secrets with chef server
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against chef Server
- properties:
- secretRef:
- description: ChefAuthSecretRef holds secret references for chef server login credentials.
- properties:
- privateKeySecretRef:
- description: SecretKey is the Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - privateKeySecretRef
- type: object
- required:
- - secretRef
- type: object
- serverUrl:
- description: ServerURL is the chef server URL used to connect to. If using orgs you should include your org in the url and terminate the url with a "/"
- type: string
- username:
- description: UserName should be the user ID on the chef server
- type: string
- required:
- - auth
- - serverUrl
- - username
- type: object
- conjur:
- description: Conjur configures this store to sync secrets using conjur provider
- properties:
- auth:
- properties:
- apikey:
- properties:
- account:
- type: string
- apiKeyRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - account
- - apiKeyRef
- - userRef
- type: object
- jwt:
- properties:
- account:
- type: string
- hostId:
- description: |-
- Optional HostID for JWT authentication. This may be used depending
- on how the Conjur JWT authenticator policy is configured.
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Conjur using the JWT authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional ServiceAccountRef specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- serviceID:
- description: The conjur authn jwt webservice id
- type: string
- required:
- - account
- - serviceID
- type: object
- type: object
- caBundle:
- type: string
- caProvider:
- description: |-
- Used to provide custom certificate authority (CA) certificates
- for a secret store. The CAProvider points to a Secret or ConfigMap resource
- that contains a PEM-encoded certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- type: string
- required:
- - auth
- - url
- type: object
- delinea:
- description: |-
- Delinea DevOps Secrets Vault
- https://docs.delinea.com/online-help/products/devops-secrets-vault/current
- properties:
- clientId:
- description: ClientID is the non-secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- clientSecret:
- description: ClientSecret is the secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- tenant:
- description: Tenant is the chosen hostname / site name.
- type: string
- tld:
- description: |-
- TLD is based on the server location that was chosen during provisioning.
- If unset, defaults to "com".
- type: string
- urlTemplate:
- description: |-
- URLTemplate
- If unset, defaults to "https://%s.secretsvaultcloud.%s/v1/%s%s".
- type: string
- required:
- - clientId
- - clientSecret
- - tenant
- type: object
- device42:
- description: Device42 configures this store to sync secrets using the Device42 provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Device42 instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- host:
- description: URL configures the Device42 instance URL.
- type: string
- required:
- - auth
- - host
- type: object
- doppler:
- description: Doppler configures this store to sync secrets using the Doppler provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Doppler API
- properties:
- secretRef:
- properties:
- dopplerToken:
- description: |-
- The DopplerToken is used for authentication.
- See https://docs.doppler.com/reference/api#authentication for auth token types.
- The Key attribute defaults to dopplerToken if not specified.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - dopplerToken
- type: object
- required:
- - secretRef
- type: object
- config:
- description: Doppler config (required if not using a Service Token)
- type: string
- format:
- description: Format enables the downloading of secrets as a file (string)
- enum:
- - json
- - dotnet-json
- - env
- - yaml
- - docker
- type: string
- nameTransformer:
- description: Environment variable compatible name transforms that change secret names to a different format
- enum:
- - upper-camel
- - camel
- - lower-snake
- - tf-var
- - dotnet-env
- - lower-kebab
- type: string
- project:
- description: Doppler project (required if not using a Service Token)
- type: string
- required:
- - auth
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- description: 'Deprecated: ValueMap is deprecated and is intended to be removed in the future, use the `value` field instead.'
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- fortanix:
- description: Fortanix configures this store to sync secrets using the Fortanix provider
- properties:
- apiKey:
- description: APIKey is the API token to access SDKMS Applications.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the SDKMS API Key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- description: APIURL is the URL of SDKMS API. Defaults to `sdkms.fortanix.com`.
- type: string
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- location:
- description: Location optionally defines a location for a secret
- type: string
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- environment:
- description: Environment environment_scope of gitlab CI/CD variables (Please see https://docs.gitlab.com/ee/ci/environments/#create-a-static-environment on how to create environments)
- type: string
- groupIDs:
- description: GroupIDs specify, which gitlab groups to pull secrets from. Group secrets are read from left to right followed by the project variables.
- items:
- type: string
- type: array
- inheritFromGroups:
- description: InheritFromGroups specifies whether parent groups should be discovered and checked for secrets.
- type: boolean
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- maxProperties: 1
- minProperties: 1
- properties:
- containerAuth:
- description: IBM Container-based auth with IAM Trusted Profile.
- properties:
- iamEndpoint:
- type: string
- profile:
- description: the IBM Trusted Profile
- type: string
- tokenLocation:
- description: Location the token is mounted on the pod
- type: string
- required:
- - profile
- type: object
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- infisical:
- description: Infisical configures this store to sync secrets using the Infisical provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Infisical API
- properties:
- universalAuthCredentials:
- properties:
- clientId:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecret
- type: object
- type: object
- hostAPI:
- default: https://app.infisical.com/api
- type: string
- secretsScope:
- properties:
- environmentSlug:
- type: string
- projectSlug:
- type: string
- secretsPath:
- default: /
- type: string
- required:
- - environmentSlug
- - projectSlug
- type: object
- required:
- - auth
- - secretsScope
- type: object
- keepersecurity:
- description: KeeperSecurity configures this store to sync secrets using the KeeperSecurity provider
- properties:
- authRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- folderID:
- type: string
- required:
- - authRef
- - folderID
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- authRef:
- description: A reference to a secret that contains the auth information.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- type: object
- onboardbase:
- description: Onboardbase configures this store to sync secrets using the Onboardbase provider
- properties:
- apiHost:
- default: https://public.onboardbase.com/api/v1/
- description: APIHost use this to configure the host url for the API for selfhosted installation, default is https://public.onboardbase.com/api/v1/
- type: string
- auth:
- description: Auth configures how the Operator authenticates with the Onboardbase API
- properties:
- apiKeyRef:
- description: |-
- OnboardbaseAPIKey is the APIKey generated by an admin account.
- It is used to recognize and authorize access to a project and environment within onboardbase
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- passcodeRef:
- description: OnboardbasePasscode is the passcode attached to the API Key
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - apiKeyRef
- - passcodeRef
- type: object
- environment:
- default: development
- description: Environment is the name of an environmnent within a project to pull the secrets from
- type: string
- project:
- default: development
- description: Project is an onboardbase project that the secrets should be pulled from
- type: string
- required:
- - apiHost
- - auth
- - environment
- - project
- type: object
- onepassword:
- description: OnePassword configures this store to sync secrets using the 1Password Cloud provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against OnePassword Connect Server
- properties:
- secretRef:
- description: OnePasswordAuthSecretRef holds secret references for 1Password credentials.
- properties:
- connectTokenSecretRef:
- description: The ConnectToken is used for authentication to a 1Password Connect Server.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - connectTokenSecretRef
- type: object
- required:
- - secretRef
- type: object
- connectHost:
- description: ConnectHost defines the OnePassword Connect Server to connect to
- type: string
- vaults:
- additionalProperties:
- type: integer
- description: Vaults defines which OnePassword vaults to search in which order
- type: object
- required:
- - auth
- - connectHost
- - vaults
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, use the instance principal, otherwise the user credentials specified in Auth.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passbolt:
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against Passbolt Server
- properties:
- passwordSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privateKeySecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - passwordSecretRef
- - privateKeySecretRef
- type: object
- host:
- description: Host defines the Passbolt Server to connect to
- type: string
- required:
- - auth
- - host
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- pulumi:
- description: Pulumi configures this store to sync secrets using the Pulumi provider
- properties:
- accessToken:
- description: AccessToken is the access tokens to sign in to the Pulumi Cloud Console.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the Pulumi API token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- default: https://api.pulumi.com/api/preview
- description: APIURL is the URL of the Pulumi API.
- type: string
- environment:
- description: |-
- Environment are YAML documents composed of static key-value pairs, programmatic expressions,
- dynamically retrieved values from supported providers including all major clouds,
- and other Pulumi ESC environments.
- To create a new environment, visit https://www.pulumi.com/docs/esc/environments/ for more information.
- type: string
- organization:
- description: |-
- Organization are a space to collaborate on shared projects and stacks.
- To create a new organization, visit https://app.pulumi.com/ and click "New Organization".
- type: string
- required:
- - accessToken
- - environment
- - organization
- type: object
- scaleway:
- description: Scaleway
- properties:
- accessKey:
- description: AccessKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- apiUrl:
- description: APIURL is the url of the api to use. Defaults to https://api.scaleway.com
- type: string
- projectId:
- description: 'ProjectID is the id of your project, which you can find in the console: https://console.scaleway.com/project/settings'
- type: string
- region:
- description: 'Region where your secrets are located: https://developers.scaleway.com/en/quickstart/#region-and-zone'
- type: string
- secretKey:
- description: SecretKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - accessKey
- - projectId
- - region
- - secretKey
- type: object
- secretserver:
- description: |-
- SecretServer configures this store to sync secrets using SecretServer provider
- https://docs.delinea.com/online-help/secret-server/start.htm
- properties:
- password:
- description: Password is the secret server account password.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- serverURL:
- description: |-
- ServerURL
- URL to your secret server installation
- type: string
- username:
- description: Username is the secret server account username.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - password
- - serverURL
- - username
- type: object
- senhasegura:
- description: Senhasegura configures this store to sync secrets using senhasegura provider
- properties:
- auth:
- description: Auth defines parameters to authenticate in senhasegura
- properties:
- clientId:
- type: string
- clientSecretSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecretSecretRef
- type: object
- ignoreSslCertificate:
- default: false
- description: IgnoreSslCertificate defines if SSL certificate must be ignored
- type: boolean
- module:
- description: Module defines which senhasegura module should be used to get secrets
- type: string
- url:
- description: URL of senhasegura
- type: string
- required:
- - auth
- - module
- - url
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexcertificatemanager:
- description: YandexCertificateManager configures this store to sync secrets using Yandex Certificate Manager provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Certificate Manager
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- refreshInterval:
- description: Used to configure store refresh interval in seconds. Empty or 0 will default to the controller config.
- type: integer
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- capabilities:
- description: SecretStoreCapabilities defines the possible operations a SecretStore can do.
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/vaultdynamicsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: vaultdynamicsecrets.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - vaultdynamicsecret
- kind: VaultDynamicSecret
- listKind: VaultDynamicSecretList
- plural: vaultdynamicsecrets
- shortNames:
- - vaultdynamicsecret
- singular: vaultdynamicsecret
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- 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:
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters VDS based on this property
- type: string
- method:
- description: Vault API method to use (GET/POST/other)
- type: string
- parameters:
- description: Parameters to pass to Vault write (for non-GET methods)
- x-kubernetes-preserve-unknown-fields: true
- path:
- description: Vault path to obtain the dynamic secret from
- type: string
- provider:
- description: Vault provider common spec
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- resultType:
- default: Data
- description: |-
- Result type defines which data is returned from the generator.
- By default it is the "data" section of the Vault API response.
- When using e.g. /auth/token/create the "data" section is empty but
- the "auth" section contains the generated token.
- Please refer to the vault docs regarding the result data structure.
- enum:
- - Data
- - Auth
- type: string
- required:
- - path
- - provider
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/webhook.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: webhooks.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - webhook
- kind: Webhook
- listKind: WebhookList
- plural: webhooks
- shortNames:
- - webhookl
- singular: webhook
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Webhook connects to a third party API server to handle the secrets generation
- configuration parameters in spec.
- You can specify the server, the token, and additional body parameters.
- See documentation for the full API specification for requests and responses.
- 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: WebhookSpec controls the behavior of the external generator. Any body parameters should be passed to the server through the parameters field.
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: The key where the token is found.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-cert-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "apiextensions.k8s.io"
- resources:
- - "customresourcedefinitions"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - "admissionregistration.k8s.io"
- resources:
- - "validatingwebhookconfigurations"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "endpoints"
- verbs:
- - "list"
- - "get"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "events"
- verbs:
- - "create"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "secrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - "coordination.k8s.io"
- resources:
- - "leases"
- verbs:
- - "get"
- - "create"
- - "update"
- - "patch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "secretstores"
- - "clustersecretstores"
- - "externalsecrets"
- - "clusterexternalsecrets"
- - "pushsecrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "externalsecrets/status"
- - "externalsecrets/finalizers"
- - "secretstores"
- - "secretstores/status"
- - "secretstores/finalizers"
- - "clustersecretstores"
- - "clustersecretstores/status"
- - "clustersecretstores/finalizers"
- - "clusterexternalsecrets"
- - "clusterexternalsecrets/status"
- - "clusterexternalsecrets/finalizers"
- - "pushsecrets"
- - "pushsecrets/status"
- - "pushsecrets/finalizers"
- verbs:
- - "get"
- - "update"
- - "patch"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "serviceaccounts"
- - "namespaces"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "secrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "create"
- - "update"
- - "delete"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "serviceaccounts/token"
- verbs:
- - "create"
- - apiGroups:
- - ""
- resources:
- - "events"
- verbs:
- - "create"
- - "patch"
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- verbs:
- - "create"
- - "update"
- - "delete"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-view
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- rbac.authorization.k8s.io/aggregate-to-view: "true"
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "secretstores"
- - "clustersecretstores"
- - "pushsecrets"
- verbs:
- - "get"
- - "watch"
- - "list"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "get"
- - "watch"
- - "list"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-edit
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "secretstores"
- - "clustersecretstores"
- - "pushsecrets"
- verbs:
- - "create"
- - "delete"
- - "deletecollection"
- - "patch"
- - "update"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "create"
- - "delete"
- - "deletecollection"
- - "patch"
- - "update"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-servicebindings
- labels:
- servicebinding.io/controller: "true"
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- verbs:
- - "get"
- - "list"
- - "watch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-golang-external-secrets-cert-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: common-golang-external-secrets-cert-controller
-subjects:
- - name: external-secrets-cert-controller
- namespace: default
- kind: ServiceAccount
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-golang-external-secrets-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: common-golang-external-secrets-controller
-subjects:
- - name: common-golang-external-secrets
- namespace: default
- kind: ServiceAccount
----
-# Source: golang-external-secrets/templates/golang-external-secrets-hub-clusterrolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: role-tokenreview-binding
- namespace: default
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: golang-external-secrets
- namespace: golang-external-secrets
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: common-golang-external-secrets-leaderelection
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- resourceNames:
- - "external-secrets-controller"
- verbs:
- - "get"
- - "update"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- verbs:
- - "create"
- - apiGroups:
- - "coordination.k8s.io"
- resources:
- - "leases"
- verbs:
- - "get"
- - "create"
- - "update"
- - "patch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: common-golang-external-secrets-leaderelection
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: common-golang-external-secrets-leaderelection
-subjects:
- - kind: ServiceAccount
- name: common-golang-external-secrets
- namespace: default
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- external-secrets.io/component: webhook
-spec:
- type: ClusterIP
- ports:
- - port: 443
- targetPort: 10250
- protocol: TCP
- name: webhook
- selector:
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets-cert-controller
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- serviceAccountName: external-secrets-cert-controller
- automountServiceAccountToken: true
- hostNetwork: false
- containers:
- - name: cert-controller
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - certcontroller
- - --crd-requeue-interval=5m
- - --service-name=common-golang-external-secrets-webhook
- - --service-namespace=default
- - --secret-name=common-golang-external-secrets-webhook
- - --secret-namespace=default
- - --metrics-addr=:8080
- - --healthz-addr=:8081
- - --loglevel=info
- - --zap-time-encoding=epoch
- - --enable-partial-cache=true
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- readinessProbe:
- httpGet:
- port: 8081
- path: /readyz
- initialDelaySeconds: 20
- periodSeconds: 5
----
-# Source: golang-external-secrets/charts/external-secrets/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- serviceAccountName: common-golang-external-secrets
- automountServiceAccountToken: true
- hostNetwork: false
- containers:
- - name: external-secrets
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - --concurrent=1
- - --metrics-addr=:8080
- - --loglevel=info
- - --zap-time-encoding=epoch
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- dnsPolicy: ClusterFirst
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- hostNetwork: false
- serviceAccountName: external-secrets-webhook
- automountServiceAccountToken: true
- containers:
- - name: webhook
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - webhook
- - --port=10250
- - --dns-name=common-golang-external-secrets-webhook.default.svc
- - --cert-dir=/tmp/certs
- - --check-interval=5m
- - --metrics-addr=:8080
- - --healthz-addr=:8081
- - --loglevel=info
- - --zap-time-encoding=epoch
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- - containerPort: 10250
- protocol: TCP
- name: webhook
- readinessProbe:
- httpGet:
- port: 8081
- path: /readyz
- initialDelaySeconds: 20
- periodSeconds: 5
- volumeMounts:
- - name: certs
- mountPath: /tmp/certs
- readOnly: true
- volumes:
- - name: certs
- secret:
- secretName: common-golang-external-secrets-webhook
----
-# Source: golang-external-secrets/templates/vault/golang-external-secrets-hub-secretstore.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ClusterSecretStore
-metadata:
- name: vault-backend
- namespace: golang-external-secrets
-spec:
- provider:
- vault:
- server: https://vault-vault.apps.hub.example.com
- path: secret
- # Version of KV backend
- version: v2
-
- caProvider:
- type: Secret
- name: hub-ca
- key: hub-kube-root-ca.crt
- namespace: golang-external-secrets
-
- auth:
- kubernetes:
-
- mountPath: region.example.com
- role: region.example.com-role
-
- secretRef:
- name: golang-external-secrets
- namespace: golang-external-secrets
- key: "token"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/validatingwebhook.yaml
-apiVersion: admissionregistration.k8s.io/v1
-kind: ValidatingWebhookConfiguration
-metadata:
- name: secretstore-validate
- labels:
- external-secrets.io/component: webhook
-webhooks:
-- name: "validate.secretstore.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["secretstores"]
- scope: "Namespaced"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-secretstore
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
-
-- name: "validate.clustersecretstore.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["clustersecretstores"]
- scope: "Cluster"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-clustersecretstore
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
----
-# Source: golang-external-secrets/charts/external-secrets/templates/validatingwebhook.yaml
-apiVersion: admissionregistration.k8s.io/v1
-kind: ValidatingWebhookConfiguration
-metadata:
- name: externalsecret-validate
- labels:
- external-secrets.io/component: webhook
-webhooks:
-- name: "validate.externalsecret.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["externalsecrets"]
- scope: "Namespaced"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-externalsecret
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
- failurePolicy: Fail
diff --git a/tests/common-golang-external-secrets-industrial-edge-hub.expected.yaml b/tests/common-golang-external-secrets-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 056054ba..00000000
--- a/tests/common-golang-external-secrets-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,13143 +0,0 @@
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: external-secrets-cert-controller
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: common-golang-external-secrets
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- external-secrets.io/component: webhook
----
-# Source: golang-external-secrets/templates/golang-external-secrets-hub-clusterrolebinding.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: golang-external-secrets
- namespace: golang-external-secrets
- annotations:
- kubernetes.io/service-account.name: golang-external-secrets
-type: kubernetes.io/service-account-token
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/acraccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: acraccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - acraccesstoken
- kind: ACRAccessToken
- listKind: ACRAccessTokenList
- plural: acraccesstokens
- shortNames:
- - acraccesstoken
- singular: acraccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- ACRAccessToken returns a Azure Container Registry token
- that can be used for pushing/pulling images.
- Note: by default it will return an ACR Refresh Token with full access
- (depending on the identity).
- This can be scoped down to the repository level using .spec.scope.
- In case scope is defined it will return an ACR Access Token.
-
-
- See docs: https://github.com/Azure/acr/blob/main/docs/AAD-OAuth.md
- 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: |-
- ACRAccessTokenSpec defines how to generate the access token
- e.g. how to authenticate and which registry to use.
- see: https://github.com/Azure/acr/blob/main/docs/AAD-OAuth.md#overview
- properties:
- auth:
- properties:
- managedIdentity:
- description: ManagedIdentity uses Azure Managed Identity to authenticate with Azure.
- properties:
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- type: object
- servicePrincipal:
- description: ServicePrincipal uses Azure Service Principal credentials to authenticate with Azure.
- properties:
- secretRef:
- description: |-
- Configuration used to authenticate with Azure using static
- credentials stored in a Kind=Secret.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- workloadIdentity:
- description: WorkloadIdentity uses Azure Workload Identity to authenticate with Azure.
- properties:
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- registry:
- description: |-
- the domain name of the ACR registry
- e.g. foobarexample.azurecr.io
- type: string
- scope:
- description: |-
- Define the scope for the access token, e.g. pull/push access for a repository.
- if not provided it will return a refresh token that has full scope.
- Note: you need to pin it down to the repository level, there is no wildcard available.
-
-
- examples:
- repository:my-repository:pull,push
- repository:my-repository:pull
-
-
- see docs for details: https://docs.docker.com/registry/spec/auth/scope/
- type: string
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- required:
- - auth
- - registry
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/clusterexternalsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: clusterexternalsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ClusterExternalSecret
- listKind: ClusterExternalSecretList
- plural: clusterexternalsecrets
- shortNames:
- - ces
- singular: clusterexternalsecret
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - jsonPath: .spec.externalSecretSpec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshTime
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ClusterExternalSecret is the Schema for the clusterexternalsecrets 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: ClusterExternalSecretSpec defines the desired state of ClusterExternalSecret.
- properties:
- externalSecretMetadata:
- description: The metadata of the external secrets to be created
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- externalSecretName:
- description: The name of the external secrets to be created defaults to the name of the ClusterExternalSecret
- type: string
- externalSecretSpec:
- description: The spec for the ExternalSecrets to be created
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: |-
- RemoteRef points to the remote secret and defines
- which secret (version/property/..) to fetch.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- description: |-
- SecretKey defines the key in which the controller stores
- the value. This is the key in the Kind=Secret
- type: string
- sourceRef:
- description: |-
- SourceRef allows you to override the source
- from which the value will pulled from.
- maxProperties: 1
- properties:
- generatorRef:
- description: |-
- GeneratorRef points to a generator custom resource.
-
-
- Deprecated: The generatorRef is not implemented in .data[].
- this will be removed with v1.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- properties:
- extract:
- description: |-
- Used to extract multiple key/value pairs from one secret
- Note: Extract does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- find:
- description: |-
- Used to find secrets based on tags or regular expressions
- Note: Find does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- name:
- description: Finds secrets based on the name.
- properties:
- regexp:
- description: Finds secrets base
- type: string
- type: object
- path:
- description: A root path to start the find operations.
- type: string
- tags:
- additionalProperties:
- type: string
- description: Find secrets based on tags.
- type: object
- type: object
- rewrite:
- description: |-
- Used to rewrite secret Keys after getting them from the secret Provider
- Multiple Rewrite operations can be provided. They are applied in a layered order (first to last)
- items:
- properties:
- regexp:
- description: |-
- Used to rewrite with regular expressions.
- The resulting key will be the output of a regexp.ReplaceAll operation.
- properties:
- source:
- description: Used to define the regular expression of a re.Compiler.
- type: string
- target:
- description: Used to define the target pattern of a ReplaceAll operation.
- type: string
- required:
- - source
- - target
- type: object
- transform:
- description: |-
- Used to apply string transformation on the secrets.
- The resulting key will be the output of the template applied by the operation.
- properties:
- template:
- description: |-
- Used to define the template to apply on the secret name.
- `.value ` will specify the secret name in the template.
- type: string
- required:
- - template
- type: object
- type: object
- type: array
- sourceRef:
- description: |-
- SourceRef points to a store or generator
- which contains secret values ready to use.
- Use this in combination with Extract or Find pull values out of
- a specific SecretStore.
- When sourceRef points to a generator Extract or Find is not supported.
- The generator returns a static map of values
- maxProperties: 1
- properties:
- generatorRef:
- description: GeneratorRef points to a generator custom resource.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- default:
- creationPolicy: Owner
- deletionPolicy: Retain
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Orphan
- - Merge
- - None
- type: string
- deletionPolicy:
- default: Retain
- description: |-
- DeletionPolicy defines rules on how to delete the resulting Secret
- Defaults to 'Retain'
- enum:
- - Delete
- - Merge
- - Retain
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- type: object
- namespaceSelector:
- description: |-
- The labels to select by to find the Namespaces to create the ExternalSecrets in.
- Deprecated: Use NamespaceSelectors instead.
- 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
- namespaceSelectors:
- description: A list of labels to select by to find the Namespaces to create the ExternalSecrets in. The selectors are ORed.
- items:
- description: |-
- A label selector is a label query over a set of resources. The result of matchLabels and
- matchExpressions are ANDed. An empty label selector matches all objects. A null
- label selector matches no objects.
- 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
- type: array
- namespaces:
- description: Choose namespaces by name. This field is ORed with anything that NamespaceSelectors ends up choosing.
- items:
- type: string
- type: array
- refreshTime:
- description: The time in which the controller should reconcile its objects and recheck namespaces for labels.
- type: string
- required:
- - externalSecretSpec
- type: object
- status:
- description: ClusterExternalSecretStatus defines the observed state of ClusterExternalSecret.
- properties:
- conditions:
- items:
- properties:
- message:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- externalSecretName:
- description: ExternalSecretName is the name of the ExternalSecrets created by the ClusterExternalSecret
- type: string
- failedNamespaces:
- description: Failed namespaces are the namespaces that failed to apply an ExternalSecret
- items:
- description: ClusterExternalSecretNamespaceFailure represents a failed namespace deployment and it's reason.
- properties:
- namespace:
- description: Namespace is the namespace that failed when trying to apply an ExternalSecret
- type: string
- reason:
- description: Reason is why the ExternalSecret failed to apply to the namespace
- type: string
- required:
- - namespace
- type: object
- type: array
- provisionedNamespaces:
- description: ProvisionedNamespaces are the namespaces where the ClusterExternalSecret has secrets
- items:
- type: string
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/clustersecretstore.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: clustersecretstores.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ClusterSecretStore
- listKind: ClusterSecretStoreList
- plural: clustersecretstores
- shortNames:
- - css
- singular: clustersecretstore
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: ClusterSecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the SecretManager provider will assume
- type: string
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- properties:
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- serviceAccount:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- required:
- - auth
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, instance principal is used. Optionally, the authenticating principal type
- and/or user data may be supplied for the use of workload identity and user principal.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - roleId
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.capabilities
- name: Capabilities
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ClusterSecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- conditions:
- description: Used to constraint a ClusterSecretStore to specific namespaces. Relevant only to ClusterSecretStore
- items:
- description: |-
- ClusterSecretStoreCondition describes a condition by which to choose namespaces to process ExternalSecrets in
- for a ClusterSecretStore instance.
- properties:
- namespaceRegexes:
- description: Choose namespaces by using regex matching
- items:
- type: string
- type: array
- namespaceSelector:
- description: Choose namespace using a labelSelector
- 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
- namespaces:
- description: Choose namespaces by name
- items:
- type: string
- type: array
- type: object
- type: array
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- additionalRoles:
- description: AdditionalRoles is a chained list of Role ARNs which the provider will sequentially assume before assuming the Role
- items:
- type: string
- type: array
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- prefix:
- description: Prefix adds a prefix to all retrieved values.
- type: string
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the provider will assume
- type: string
- secretsManager:
- description: SecretsManager defines how the provider behaves when interacting with AWS SecretsManager
- properties:
- forceDeleteWithoutRecovery:
- description: |-
- Specifies whether to delete the secret without any recovery window. You
- can't use both this parameter and RecoveryWindowInDays in the same call.
- If you don't use either, then by default Secrets Manager uses a 30 day
- recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-ForceDeleteWithoutRecovery
- type: boolean
- recoveryWindowInDays:
- description: |-
- The number of days from 7 to 30 that Secrets Manager waits before
- permanently deleting the secret. You can't use both this parameter and
- ForceDeleteWithoutRecovery in the same call. If you don't use either,
- then by default Secrets Manager uses a 30 day recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-RecoveryWindowInDays
- format: int64
- type: integer
- type: object
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- sessionTags:
- description: AWS STS assume role session tags
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- transitiveTagKeys:
- description: AWS STS assume role transitive session tags. Required when multiple rules are used with the provider
- items:
- type: string
- type: array
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- properties:
- clientCertificate:
- description: The Azure ClientCertificate of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientId:
- description: The Azure clientId of the service principle or managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- tenantId:
- description: The Azure tenantId of the managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- bitwardensecretsmanager:
- description: BitwardenSecretsManager configures this store to sync secrets using BitwardenSecretsManager provider
- properties:
- apiURL:
- type: string
- auth:
- description: |-
- Auth configures how secret-manager authenticates with a bitwarden machine account instance.
- Make sure that the token being used has permissions on the given secret.
- properties:
- secretRef:
- description: BitwardenSecretsManagerSecretRef contains the credential ref to the bitwarden instance.
- properties:
- credentials:
- description: AccessToken used for the bitwarden instance.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - credentials
- type: object
- required:
- - secretRef
- type: object
- bitwardenServerSDKURL:
- type: string
- caBundle:
- description: |-
- Base64 encoded certificate for the bitwarden server sdk. The sdk MUST run with HTTPS to make sure no MITM attack
- can be performed.
- type: string
- identityURL:
- type: string
- organizationID:
- description: OrganizationID determines which organization this secret store manages.
- type: string
- projectID:
- description: ProjectID determines which project this secret store manages.
- type: string
- required:
- - auth
- - caBundle
- - organizationID
- - projectID
- type: object
- chef:
- description: Chef configures this store to sync secrets with chef server
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against chef Server
- properties:
- secretRef:
- description: ChefAuthSecretRef holds secret references for chef server login credentials.
- properties:
- privateKeySecretRef:
- description: SecretKey is the Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - privateKeySecretRef
- type: object
- required:
- - secretRef
- type: object
- serverUrl:
- description: ServerURL is the chef server URL used to connect to. If using orgs you should include your org in the url and terminate the url with a "/"
- type: string
- username:
- description: UserName should be the user ID on the chef server
- type: string
- required:
- - auth
- - serverUrl
- - username
- type: object
- conjur:
- description: Conjur configures this store to sync secrets using conjur provider
- properties:
- auth:
- properties:
- apikey:
- properties:
- account:
- type: string
- apiKeyRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - account
- - apiKeyRef
- - userRef
- type: object
- jwt:
- properties:
- account:
- type: string
- hostId:
- description: |-
- Optional HostID for JWT authentication. This may be used depending
- on how the Conjur JWT authenticator policy is configured.
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Conjur using the JWT authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional ServiceAccountRef specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- serviceID:
- description: The conjur authn jwt webservice id
- type: string
- required:
- - account
- - serviceID
- type: object
- type: object
- caBundle:
- type: string
- caProvider:
- description: |-
- Used to provide custom certificate authority (CA) certificates
- for a secret store. The CAProvider points to a Secret or ConfigMap resource
- that contains a PEM-encoded certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- type: string
- required:
- - auth
- - url
- type: object
- delinea:
- description: |-
- Delinea DevOps Secrets Vault
- https://docs.delinea.com/online-help/products/devops-secrets-vault/current
- properties:
- clientId:
- description: ClientID is the non-secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- clientSecret:
- description: ClientSecret is the secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- tenant:
- description: Tenant is the chosen hostname / site name.
- type: string
- tld:
- description: |-
- TLD is based on the server location that was chosen during provisioning.
- If unset, defaults to "com".
- type: string
- urlTemplate:
- description: |-
- URLTemplate
- If unset, defaults to "https://%s.secretsvaultcloud.%s/v1/%s%s".
- type: string
- required:
- - clientId
- - clientSecret
- - tenant
- type: object
- device42:
- description: Device42 configures this store to sync secrets using the Device42 provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Device42 instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- host:
- description: URL configures the Device42 instance URL.
- type: string
- required:
- - auth
- - host
- type: object
- doppler:
- description: Doppler configures this store to sync secrets using the Doppler provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Doppler API
- properties:
- secretRef:
- properties:
- dopplerToken:
- description: |-
- The DopplerToken is used for authentication.
- See https://docs.doppler.com/reference/api#authentication for auth token types.
- The Key attribute defaults to dopplerToken if not specified.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - dopplerToken
- type: object
- required:
- - secretRef
- type: object
- config:
- description: Doppler config (required if not using a Service Token)
- type: string
- format:
- description: Format enables the downloading of secrets as a file (string)
- enum:
- - json
- - dotnet-json
- - env
- - yaml
- - docker
- type: string
- nameTransformer:
- description: Environment variable compatible name transforms that change secret names to a different format
- enum:
- - upper-camel
- - camel
- - lower-snake
- - tf-var
- - dotnet-env
- - lower-kebab
- type: string
- project:
- description: Doppler project (required if not using a Service Token)
- type: string
- required:
- - auth
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- description: 'Deprecated: ValueMap is deprecated and is intended to be removed in the future, use the `value` field instead.'
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- fortanix:
- description: Fortanix configures this store to sync secrets using the Fortanix provider
- properties:
- apiKey:
- description: APIKey is the API token to access SDKMS Applications.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the SDKMS API Key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- description: APIURL is the URL of SDKMS API. Defaults to `sdkms.fortanix.com`.
- type: string
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- location:
- description: Location optionally defines a location for a secret
- type: string
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- environment:
- description: Environment environment_scope of gitlab CI/CD variables (Please see https://docs.gitlab.com/ee/ci/environments/#create-a-static-environment on how to create environments)
- type: string
- groupIDs:
- description: GroupIDs specify, which gitlab groups to pull secrets from. Group secrets are read from left to right followed by the project variables.
- items:
- type: string
- type: array
- inheritFromGroups:
- description: InheritFromGroups specifies whether parent groups should be discovered and checked for secrets.
- type: boolean
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- maxProperties: 1
- minProperties: 1
- properties:
- containerAuth:
- description: IBM Container-based auth with IAM Trusted Profile.
- properties:
- iamEndpoint:
- type: string
- profile:
- description: the IBM Trusted Profile
- type: string
- tokenLocation:
- description: Location the token is mounted on the pod
- type: string
- required:
- - profile
- type: object
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- infisical:
- description: Infisical configures this store to sync secrets using the Infisical provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Infisical API
- properties:
- universalAuthCredentials:
- properties:
- clientId:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecret
- type: object
- type: object
- hostAPI:
- default: https://app.infisical.com/api
- type: string
- secretsScope:
- properties:
- environmentSlug:
- type: string
- projectSlug:
- type: string
- secretsPath:
- default: /
- type: string
- required:
- - environmentSlug
- - projectSlug
- type: object
- required:
- - auth
- - secretsScope
- type: object
- keepersecurity:
- description: KeeperSecurity configures this store to sync secrets using the KeeperSecurity provider
- properties:
- authRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- folderID:
- type: string
- required:
- - authRef
- - folderID
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- authRef:
- description: A reference to a secret that contains the auth information.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- type: object
- onboardbase:
- description: Onboardbase configures this store to sync secrets using the Onboardbase provider
- properties:
- apiHost:
- default: https://public.onboardbase.com/api/v1/
- description: APIHost use this to configure the host url for the API for selfhosted installation, default is https://public.onboardbase.com/api/v1/
- type: string
- auth:
- description: Auth configures how the Operator authenticates with the Onboardbase API
- properties:
- apiKeyRef:
- description: |-
- OnboardbaseAPIKey is the APIKey generated by an admin account.
- It is used to recognize and authorize access to a project and environment within onboardbase
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- passcodeRef:
- description: OnboardbasePasscode is the passcode attached to the API Key
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - apiKeyRef
- - passcodeRef
- type: object
- environment:
- default: development
- description: Environment is the name of an environmnent within a project to pull the secrets from
- type: string
- project:
- default: development
- description: Project is an onboardbase project that the secrets should be pulled from
- type: string
- required:
- - apiHost
- - auth
- - environment
- - project
- type: object
- onepassword:
- description: OnePassword configures this store to sync secrets using the 1Password Cloud provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against OnePassword Connect Server
- properties:
- secretRef:
- description: OnePasswordAuthSecretRef holds secret references for 1Password credentials.
- properties:
- connectTokenSecretRef:
- description: The ConnectToken is used for authentication to a 1Password Connect Server.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - connectTokenSecretRef
- type: object
- required:
- - secretRef
- type: object
- connectHost:
- description: ConnectHost defines the OnePassword Connect Server to connect to
- type: string
- vaults:
- additionalProperties:
- type: integer
- description: Vaults defines which OnePassword vaults to search in which order
- type: object
- required:
- - auth
- - connectHost
- - vaults
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, use the instance principal, otherwise the user credentials specified in Auth.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passbolt:
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against Passbolt Server
- properties:
- passwordSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privateKeySecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - passwordSecretRef
- - privateKeySecretRef
- type: object
- host:
- description: Host defines the Passbolt Server to connect to
- type: string
- required:
- - auth
- - host
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- pulumi:
- description: Pulumi configures this store to sync secrets using the Pulumi provider
- properties:
- accessToken:
- description: AccessToken is the access tokens to sign in to the Pulumi Cloud Console.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the Pulumi API token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- default: https://api.pulumi.com/api/preview
- description: APIURL is the URL of the Pulumi API.
- type: string
- environment:
- description: |-
- Environment are YAML documents composed of static key-value pairs, programmatic expressions,
- dynamically retrieved values from supported providers including all major clouds,
- and other Pulumi ESC environments.
- To create a new environment, visit https://www.pulumi.com/docs/esc/environments/ for more information.
- type: string
- organization:
- description: |-
- Organization are a space to collaborate on shared projects and stacks.
- To create a new organization, visit https://app.pulumi.com/ and click "New Organization".
- type: string
- required:
- - accessToken
- - environment
- - organization
- type: object
- scaleway:
- description: Scaleway
- properties:
- accessKey:
- description: AccessKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- apiUrl:
- description: APIURL is the url of the api to use. Defaults to https://api.scaleway.com
- type: string
- projectId:
- description: 'ProjectID is the id of your project, which you can find in the console: https://console.scaleway.com/project/settings'
- type: string
- region:
- description: 'Region where your secrets are located: https://developers.scaleway.com/en/quickstart/#region-and-zone'
- type: string
- secretKey:
- description: SecretKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - accessKey
- - projectId
- - region
- - secretKey
- type: object
- secretserver:
- description: |-
- SecretServer configures this store to sync secrets using SecretServer provider
- https://docs.delinea.com/online-help/secret-server/start.htm
- properties:
- password:
- description: Password is the secret server account password.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- serverURL:
- description: |-
- ServerURL
- URL to your secret server installation
- type: string
- username:
- description: Username is the secret server account username.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - password
- - serverURL
- - username
- type: object
- senhasegura:
- description: Senhasegura configures this store to sync secrets using senhasegura provider
- properties:
- auth:
- description: Auth defines parameters to authenticate in senhasegura
- properties:
- clientId:
- type: string
- clientSecretSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecretSecretRef
- type: object
- ignoreSslCertificate:
- default: false
- description: IgnoreSslCertificate defines if SSL certificate must be ignored
- type: boolean
- module:
- description: Module defines which senhasegura module should be used to get secrets
- type: string
- url:
- description: URL of senhasegura
- type: string
- required:
- - auth
- - module
- - url
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexcertificatemanager:
- description: YandexCertificateManager configures this store to sync secrets using Yandex Certificate Manager provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Certificate Manager
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- refreshInterval:
- description: Used to configure store refresh interval in seconds. Empty or 0 will default to the controller config.
- type: integer
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- capabilities:
- description: SecretStoreCapabilities defines the possible operations a SecretStore can do.
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/ecrauthorizationtoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: ecrauthorizationtokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - ecrauthorizationtoken
- kind: ECRAuthorizationToken
- listKind: ECRAuthorizationTokenList
- plural: ecrauthorizationtokens
- shortNames:
- - ecrauthorizationtoken
- singular: ecrauthorizationtoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- ECRAuthorizationTokenSpec uses the GetAuthorizationToken API to retrieve an
- authorization token.
- The authorization token is valid for 12 hours.
- The authorizationToken returned is a base64 encoded string that can be decoded
- and used in a docker login command to authenticate to a registry.
- For more information, see Registry authentication (https://docs.aws.amazon.com/AmazonECR/latest/userguide/Registries.html#registry_auth) in the Amazon Elastic Container Registry User Guide.
- 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:
- properties:
- auth:
- description: Auth defines how to authenticate with AWS
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: Region specifies the region to operate in.
- type: string
- role:
- description: |-
- You can assume a role before making calls to the
- desired AWS service.
- type: string
- required:
- - region
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/externalsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: externalsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ExternalSecret
- listKind: ExternalSecretList
- plural: externalsecrets
- shortNames:
- - es
- singular: externalsecret
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .spec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshInterval
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: ExternalSecret is the Schema for the external-secrets 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: ExternalSecretSpec defines the desired state of ExternalSecret.
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: ExternalSecretDataRemoteRef defines Provider data location.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- type: string
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- description: ExternalSecretDataRemoteRef defines Provider data location.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Merge
- - None
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v1
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- maxProperties: 1
- minProperties: 1
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- required:
- - secretStoreRef
- - target
- type: object
- status:
- properties:
- binding:
- description: Binding represents a servicebinding.io Provisioned Service reference to the secret
- properties:
- name:
- default: ""
- description: |-
- Name of the referent.
- This field is effectively required, but due to backwards compatibility is
- allowed to be empty. Instances of this type with an empty value here are
- almost certainly wrong.
- TODO: Add other useful fields. apiVersion, kind, uid?
- More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
- TODO: Drop `kubebuilder:default` when controller-gen doesn't need it https://github.com/kubernetes-sigs/kubebuilder/issues/3896.
- type: string
- type: object
- x-kubernetes-map-type: atomic
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version
- type: string
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .spec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshInterval
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ExternalSecret is the Schema for the external-secrets 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: ExternalSecretSpec defines the desired state of ExternalSecret.
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: |-
- RemoteRef points to the remote secret and defines
- which secret (version/property/..) to fetch.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- description: |-
- SecretKey defines the key in which the controller stores
- the value. This is the key in the Kind=Secret
- type: string
- sourceRef:
- description: |-
- SourceRef allows you to override the source
- from which the value will pulled from.
- maxProperties: 1
- properties:
- generatorRef:
- description: |-
- GeneratorRef points to a generator custom resource.
-
-
- Deprecated: The generatorRef is not implemented in .data[].
- this will be removed with v1.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- properties:
- extract:
- description: |-
- Used to extract multiple key/value pairs from one secret
- Note: Extract does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- find:
- description: |-
- Used to find secrets based on tags or regular expressions
- Note: Find does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- name:
- description: Finds secrets based on the name.
- properties:
- regexp:
- description: Finds secrets base
- type: string
- type: object
- path:
- description: A root path to start the find operations.
- type: string
- tags:
- additionalProperties:
- type: string
- description: Find secrets based on tags.
- type: object
- type: object
- rewrite:
- description: |-
- Used to rewrite secret Keys after getting them from the secret Provider
- Multiple Rewrite operations can be provided. They are applied in a layered order (first to last)
- items:
- properties:
- regexp:
- description: |-
- Used to rewrite with regular expressions.
- The resulting key will be the output of a regexp.ReplaceAll operation.
- properties:
- source:
- description: Used to define the regular expression of a re.Compiler.
- type: string
- target:
- description: Used to define the target pattern of a ReplaceAll operation.
- type: string
- required:
- - source
- - target
- type: object
- transform:
- description: |-
- Used to apply string transformation on the secrets.
- The resulting key will be the output of the template applied by the operation.
- properties:
- template:
- description: |-
- Used to define the template to apply on the secret name.
- `.value ` will specify the secret name in the template.
- type: string
- required:
- - template
- type: object
- type: object
- type: array
- sourceRef:
- description: |-
- SourceRef points to a store or generator
- which contains secret values ready to use.
- Use this in combination with Extract or Find pull values out of
- a specific SecretStore.
- When sourceRef points to a generator Extract or Find is not supported.
- The generator returns a static map of values
- maxProperties: 1
- properties:
- generatorRef:
- description: GeneratorRef points to a generator custom resource.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- default:
- creationPolicy: Owner
- deletionPolicy: Retain
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Orphan
- - Merge
- - None
- type: string
- deletionPolicy:
- default: Retain
- description: |-
- DeletionPolicy defines rules on how to delete the resulting Secret
- Defaults to 'Retain'
- enum:
- - Delete
- - Merge
- - Retain
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- type: object
- status:
- properties:
- binding:
- description: Binding represents a servicebinding.io Provisioned Service reference to the secret
- properties:
- name:
- default: ""
- description: |-
- Name of the referent.
- This field is effectively required, but due to backwards compatibility is
- allowed to be empty. Instances of this type with an empty value here are
- almost certainly wrong.
- TODO: Add other useful fields. apiVersion, kind, uid?
- More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
- TODO: Drop `kubebuilder:default` when controller-gen doesn't need it https://github.com/kubernetes-sigs/kubebuilder/issues/3896.
- type: string
- type: object
- x-kubernetes-map-type: atomic
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version
- type: string
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/fake.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: fakes.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - fake
- kind: Fake
- listKind: FakeList
- plural: fakes
- shortNames:
- - fake
- singular: fake
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Fake generator is used for testing. It lets you define
- a static set of credentials that is always returned.
- 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: FakeSpec contains the static data.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters VDS based on this property
- type: string
- data:
- additionalProperties:
- type: string
- description: |-
- Data defines the static data returned
- by this generator.
- type: object
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/gcraccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: gcraccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - gcraccesstoken
- kind: GCRAccessToken
- listKind: GCRAccessTokenList
- plural: gcraccesstokens
- shortNames:
- - gcraccesstoken
- singular: gcraccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- GCRAccessToken generates an GCP access token
- that can be used to authenticate with GCR.
- 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:
- properties:
- auth:
- description: Auth defines the means for authenticating with GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID defines which project to use to authenticate with
- type: string
- required:
- - auth
- - projectID
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/githubaccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: githubaccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - githubaccesstoken
- kind: GithubAccessToken
- listKind: GithubAccessTokenList
- plural: githubaccesstokens
- shortNames:
- - githubaccesstoken
- singular: githubaccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: GithubAccessToken generates ghs_ accessToken
- 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:
- properties:
- appID:
- type: string
- auth:
- description: Auth configures how ESO authenticates with a Github instance.
- properties:
- privateKey:
- properties:
- secretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - secretRef
- type: object
- required:
- - privateKey
- type: object
- installID:
- type: string
- url:
- description: URL configures the Github instance URL. Defaults to https://github.com/.
- type: string
- required:
- - appID
- - auth
- - installID
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/password.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: passwords.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - password
- kind: Password
- listKind: PasswordList
- plural: passwords
- shortNames:
- - password
- singular: password
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Password generates a random password based on the
- configuration parameters in spec.
- You can specify the length, characterset and other attributes.
- 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: PasswordSpec controls the behavior of the password generator.
- properties:
- allowRepeat:
- default: false
- description: set AllowRepeat to true to allow repeating characters.
- type: boolean
- digits:
- description: |-
- Digits specifies the number of digits in the generated
- password. If omitted it defaults to 25% of the length of the password
- type: integer
- length:
- default: 24
- description: |-
- Length of the password to be generated.
- Defaults to 24
- type: integer
- noUpper:
- default: false
- description: Set NoUpper to disable uppercase characters
- type: boolean
- symbolCharacters:
- description: |-
- SymbolCharacters specifies the special characters that should be used
- in the generated password.
- type: string
- symbols:
- description: |-
- Symbols specifies the number of symbol characters in the generated
- password. If omitted it defaults to 25% of the length of the password
- type: integer
- required:
- - allowRepeat
- - length
- - noUpper
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/pushsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- name: pushsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - pushsecrets
- kind: PushSecret
- listKind: PushSecretList
- plural: pushsecrets
- singular: pushsecret
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- name: v1alpha1
- schema:
- openAPIV3Schema:
- 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: PushSecretSpec configures the behavior of the PushSecret.
- properties:
- data:
- description: Secret Data that should be pushed to providers
- items:
- properties:
- conversionStrategy:
- default: None
- description: Used to define a conversion Strategy for the secret keys
- enum:
- - None
- - ReverseUnicode
- type: string
- match:
- description: Match a given Secret Key to be pushed to the provider.
- properties:
- remoteRef:
- description: Remote Refs to push to providers.
- properties:
- property:
- description: Name of the property in the resulting secret
- type: string
- remoteKey:
- description: Name of the resulting provider secret.
- type: string
- required:
- - remoteKey
- type: object
- secretKey:
- description: Secret Key to be pushed
- type: string
- required:
- - remoteRef
- type: object
- metadata:
- description: |-
- Metadata is metadata attached to the secret.
- The structure of metadata is provider specific, please look it up in the provider documentation.
- x-kubernetes-preserve-unknown-fields: true
- required:
- - match
- type: object
- type: array
- deletionPolicy:
- default: None
- description: 'Deletion Policy to handle Secrets in the provider. Possible Values: "Delete/None". Defaults to "None".'
- enum:
- - Delete
- - None
- type: string
- refreshInterval:
- description: The Interval to which External Secrets will try to push a secret definition
- type: string
- secretStoreRefs:
- items:
- properties:
- kind:
- default: SecretStore
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- labelSelector:
- description: Optionally, sync to secret stores with label selector
- 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
- name:
- description: Optionally, sync to the SecretStore of the given name
- type: string
- type: object
- type: array
- selector:
- description: The Secret Selector (k8s source) for the Push Secret
- properties:
- secret:
- description: Select a Secret to Push.
- properties:
- name:
- description: Name of the Secret. The Secret must exist in the same namespace as the PushSecret manifest.
- type: string
- required:
- - name
- type: object
- required:
- - secret
- type: object
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- updatePolicy:
- default: Replace
- description: 'UpdatePolicy to handle Secrets in the provider. Possible Values: "Replace/IfNotExists". Defaults to "Replace".'
- enum:
- - Replace
- - IfNotExists
- type: string
- required:
- - secretStoreRefs
- - selector
- type: object
- status:
- description: PushSecretStatus indicates the history of the status of PushSecret.
- properties:
- conditions:
- items:
- description: PushSecretStatusCondition indicates the status of the PushSecret.
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- description: PushSecretConditionType indicates the condition of the PushSecret.
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedPushSecrets:
- additionalProperties:
- additionalProperties:
- properties:
- conversionStrategy:
- default: None
- description: Used to define a conversion Strategy for the secret keys
- enum:
- - None
- - ReverseUnicode
- type: string
- match:
- description: Match a given Secret Key to be pushed to the provider.
- properties:
- remoteRef:
- description: Remote Refs to push to providers.
- properties:
- property:
- description: Name of the property in the resulting secret
- type: string
- remoteKey:
- description: Name of the resulting provider secret.
- type: string
- required:
- - remoteKey
- type: object
- secretKey:
- description: Secret Key to be pushed
- type: string
- required:
- - remoteRef
- type: object
- metadata:
- description: |-
- Metadata is metadata attached to the secret.
- The structure of metadata is provider specific, please look it up in the provider documentation.
- x-kubernetes-preserve-unknown-fields: true
- required:
- - match
- type: object
- type: object
- description: |-
- Synced PushSecrets, including secrets that already exist in provider.
- Matches secret stores to PushSecretData that was stored to that secret store.
- type: object
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version.
- type: string
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/secretstore.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: secretstores.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: SecretStore
- listKind: SecretStoreList
- plural: secretstores
- shortNames:
- - ss
- singular: secretstore
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: SecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the SecretManager provider will assume
- type: string
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- properties:
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- serviceAccount:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- required:
- - auth
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, instance principal is used. Optionally, the authenticating principal type
- and/or user data may be supplied for the use of workload identity and user principal.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - roleId
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.capabilities
- name: Capabilities
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: SecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- conditions:
- description: Used to constraint a ClusterSecretStore to specific namespaces. Relevant only to ClusterSecretStore
- items:
- description: |-
- ClusterSecretStoreCondition describes a condition by which to choose namespaces to process ExternalSecrets in
- for a ClusterSecretStore instance.
- properties:
- namespaceRegexes:
- description: Choose namespaces by using regex matching
- items:
- type: string
- type: array
- namespaceSelector:
- description: Choose namespace using a labelSelector
- 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
- namespaces:
- description: Choose namespaces by name
- items:
- type: string
- type: array
- type: object
- type: array
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- additionalRoles:
- description: AdditionalRoles is a chained list of Role ARNs which the provider will sequentially assume before assuming the Role
- items:
- type: string
- type: array
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- prefix:
- description: Prefix adds a prefix to all retrieved values.
- type: string
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the provider will assume
- type: string
- secretsManager:
- description: SecretsManager defines how the provider behaves when interacting with AWS SecretsManager
- properties:
- forceDeleteWithoutRecovery:
- description: |-
- Specifies whether to delete the secret without any recovery window. You
- can't use both this parameter and RecoveryWindowInDays in the same call.
- If you don't use either, then by default Secrets Manager uses a 30 day
- recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-ForceDeleteWithoutRecovery
- type: boolean
- recoveryWindowInDays:
- description: |-
- The number of days from 7 to 30 that Secrets Manager waits before
- permanently deleting the secret. You can't use both this parameter and
- ForceDeleteWithoutRecovery in the same call. If you don't use either,
- then by default Secrets Manager uses a 30 day recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-RecoveryWindowInDays
- format: int64
- type: integer
- type: object
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- sessionTags:
- description: AWS STS assume role session tags
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- transitiveTagKeys:
- description: AWS STS assume role transitive session tags. Required when multiple rules are used with the provider
- items:
- type: string
- type: array
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- properties:
- clientCertificate:
- description: The Azure ClientCertificate of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientId:
- description: The Azure clientId of the service principle or managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- tenantId:
- description: The Azure tenantId of the managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- bitwardensecretsmanager:
- description: BitwardenSecretsManager configures this store to sync secrets using BitwardenSecretsManager provider
- properties:
- apiURL:
- type: string
- auth:
- description: |-
- Auth configures how secret-manager authenticates with a bitwarden machine account instance.
- Make sure that the token being used has permissions on the given secret.
- properties:
- secretRef:
- description: BitwardenSecretsManagerSecretRef contains the credential ref to the bitwarden instance.
- properties:
- credentials:
- description: AccessToken used for the bitwarden instance.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - credentials
- type: object
- required:
- - secretRef
- type: object
- bitwardenServerSDKURL:
- type: string
- caBundle:
- description: |-
- Base64 encoded certificate for the bitwarden server sdk. The sdk MUST run with HTTPS to make sure no MITM attack
- can be performed.
- type: string
- identityURL:
- type: string
- organizationID:
- description: OrganizationID determines which organization this secret store manages.
- type: string
- projectID:
- description: ProjectID determines which project this secret store manages.
- type: string
- required:
- - auth
- - caBundle
- - organizationID
- - projectID
- type: object
- chef:
- description: Chef configures this store to sync secrets with chef server
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against chef Server
- properties:
- secretRef:
- description: ChefAuthSecretRef holds secret references for chef server login credentials.
- properties:
- privateKeySecretRef:
- description: SecretKey is the Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - privateKeySecretRef
- type: object
- required:
- - secretRef
- type: object
- serverUrl:
- description: ServerURL is the chef server URL used to connect to. If using orgs you should include your org in the url and terminate the url with a "/"
- type: string
- username:
- description: UserName should be the user ID on the chef server
- type: string
- required:
- - auth
- - serverUrl
- - username
- type: object
- conjur:
- description: Conjur configures this store to sync secrets using conjur provider
- properties:
- auth:
- properties:
- apikey:
- properties:
- account:
- type: string
- apiKeyRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - account
- - apiKeyRef
- - userRef
- type: object
- jwt:
- properties:
- account:
- type: string
- hostId:
- description: |-
- Optional HostID for JWT authentication. This may be used depending
- on how the Conjur JWT authenticator policy is configured.
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Conjur using the JWT authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional ServiceAccountRef specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- serviceID:
- description: The conjur authn jwt webservice id
- type: string
- required:
- - account
- - serviceID
- type: object
- type: object
- caBundle:
- type: string
- caProvider:
- description: |-
- Used to provide custom certificate authority (CA) certificates
- for a secret store. The CAProvider points to a Secret or ConfigMap resource
- that contains a PEM-encoded certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- type: string
- required:
- - auth
- - url
- type: object
- delinea:
- description: |-
- Delinea DevOps Secrets Vault
- https://docs.delinea.com/online-help/products/devops-secrets-vault/current
- properties:
- clientId:
- description: ClientID is the non-secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- clientSecret:
- description: ClientSecret is the secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- tenant:
- description: Tenant is the chosen hostname / site name.
- type: string
- tld:
- description: |-
- TLD is based on the server location that was chosen during provisioning.
- If unset, defaults to "com".
- type: string
- urlTemplate:
- description: |-
- URLTemplate
- If unset, defaults to "https://%s.secretsvaultcloud.%s/v1/%s%s".
- type: string
- required:
- - clientId
- - clientSecret
- - tenant
- type: object
- device42:
- description: Device42 configures this store to sync secrets using the Device42 provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Device42 instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- host:
- description: URL configures the Device42 instance URL.
- type: string
- required:
- - auth
- - host
- type: object
- doppler:
- description: Doppler configures this store to sync secrets using the Doppler provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Doppler API
- properties:
- secretRef:
- properties:
- dopplerToken:
- description: |-
- The DopplerToken is used for authentication.
- See https://docs.doppler.com/reference/api#authentication for auth token types.
- The Key attribute defaults to dopplerToken if not specified.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - dopplerToken
- type: object
- required:
- - secretRef
- type: object
- config:
- description: Doppler config (required if not using a Service Token)
- type: string
- format:
- description: Format enables the downloading of secrets as a file (string)
- enum:
- - json
- - dotnet-json
- - env
- - yaml
- - docker
- type: string
- nameTransformer:
- description: Environment variable compatible name transforms that change secret names to a different format
- enum:
- - upper-camel
- - camel
- - lower-snake
- - tf-var
- - dotnet-env
- - lower-kebab
- type: string
- project:
- description: Doppler project (required if not using a Service Token)
- type: string
- required:
- - auth
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- description: 'Deprecated: ValueMap is deprecated and is intended to be removed in the future, use the `value` field instead.'
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- fortanix:
- description: Fortanix configures this store to sync secrets using the Fortanix provider
- properties:
- apiKey:
- description: APIKey is the API token to access SDKMS Applications.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the SDKMS API Key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- description: APIURL is the URL of SDKMS API. Defaults to `sdkms.fortanix.com`.
- type: string
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- location:
- description: Location optionally defines a location for a secret
- type: string
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- environment:
- description: Environment environment_scope of gitlab CI/CD variables (Please see https://docs.gitlab.com/ee/ci/environments/#create-a-static-environment on how to create environments)
- type: string
- groupIDs:
- description: GroupIDs specify, which gitlab groups to pull secrets from. Group secrets are read from left to right followed by the project variables.
- items:
- type: string
- type: array
- inheritFromGroups:
- description: InheritFromGroups specifies whether parent groups should be discovered and checked for secrets.
- type: boolean
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- maxProperties: 1
- minProperties: 1
- properties:
- containerAuth:
- description: IBM Container-based auth with IAM Trusted Profile.
- properties:
- iamEndpoint:
- type: string
- profile:
- description: the IBM Trusted Profile
- type: string
- tokenLocation:
- description: Location the token is mounted on the pod
- type: string
- required:
- - profile
- type: object
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- infisical:
- description: Infisical configures this store to sync secrets using the Infisical provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Infisical API
- properties:
- universalAuthCredentials:
- properties:
- clientId:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecret
- type: object
- type: object
- hostAPI:
- default: https://app.infisical.com/api
- type: string
- secretsScope:
- properties:
- environmentSlug:
- type: string
- projectSlug:
- type: string
- secretsPath:
- default: /
- type: string
- required:
- - environmentSlug
- - projectSlug
- type: object
- required:
- - auth
- - secretsScope
- type: object
- keepersecurity:
- description: KeeperSecurity configures this store to sync secrets using the KeeperSecurity provider
- properties:
- authRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- folderID:
- type: string
- required:
- - authRef
- - folderID
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- authRef:
- description: A reference to a secret that contains the auth information.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- type: object
- onboardbase:
- description: Onboardbase configures this store to sync secrets using the Onboardbase provider
- properties:
- apiHost:
- default: https://public.onboardbase.com/api/v1/
- description: APIHost use this to configure the host url for the API for selfhosted installation, default is https://public.onboardbase.com/api/v1/
- type: string
- auth:
- description: Auth configures how the Operator authenticates with the Onboardbase API
- properties:
- apiKeyRef:
- description: |-
- OnboardbaseAPIKey is the APIKey generated by an admin account.
- It is used to recognize and authorize access to a project and environment within onboardbase
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- passcodeRef:
- description: OnboardbasePasscode is the passcode attached to the API Key
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - apiKeyRef
- - passcodeRef
- type: object
- environment:
- default: development
- description: Environment is the name of an environmnent within a project to pull the secrets from
- type: string
- project:
- default: development
- description: Project is an onboardbase project that the secrets should be pulled from
- type: string
- required:
- - apiHost
- - auth
- - environment
- - project
- type: object
- onepassword:
- description: OnePassword configures this store to sync secrets using the 1Password Cloud provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against OnePassword Connect Server
- properties:
- secretRef:
- description: OnePasswordAuthSecretRef holds secret references for 1Password credentials.
- properties:
- connectTokenSecretRef:
- description: The ConnectToken is used for authentication to a 1Password Connect Server.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - connectTokenSecretRef
- type: object
- required:
- - secretRef
- type: object
- connectHost:
- description: ConnectHost defines the OnePassword Connect Server to connect to
- type: string
- vaults:
- additionalProperties:
- type: integer
- description: Vaults defines which OnePassword vaults to search in which order
- type: object
- required:
- - auth
- - connectHost
- - vaults
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, use the instance principal, otherwise the user credentials specified in Auth.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passbolt:
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against Passbolt Server
- properties:
- passwordSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privateKeySecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - passwordSecretRef
- - privateKeySecretRef
- type: object
- host:
- description: Host defines the Passbolt Server to connect to
- type: string
- required:
- - auth
- - host
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- pulumi:
- description: Pulumi configures this store to sync secrets using the Pulumi provider
- properties:
- accessToken:
- description: AccessToken is the access tokens to sign in to the Pulumi Cloud Console.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the Pulumi API token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- default: https://api.pulumi.com/api/preview
- description: APIURL is the URL of the Pulumi API.
- type: string
- environment:
- description: |-
- Environment are YAML documents composed of static key-value pairs, programmatic expressions,
- dynamically retrieved values from supported providers including all major clouds,
- and other Pulumi ESC environments.
- To create a new environment, visit https://www.pulumi.com/docs/esc/environments/ for more information.
- type: string
- organization:
- description: |-
- Organization are a space to collaborate on shared projects and stacks.
- To create a new organization, visit https://app.pulumi.com/ and click "New Organization".
- type: string
- required:
- - accessToken
- - environment
- - organization
- type: object
- scaleway:
- description: Scaleway
- properties:
- accessKey:
- description: AccessKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- apiUrl:
- description: APIURL is the url of the api to use. Defaults to https://api.scaleway.com
- type: string
- projectId:
- description: 'ProjectID is the id of your project, which you can find in the console: https://console.scaleway.com/project/settings'
- type: string
- region:
- description: 'Region where your secrets are located: https://developers.scaleway.com/en/quickstart/#region-and-zone'
- type: string
- secretKey:
- description: SecretKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - accessKey
- - projectId
- - region
- - secretKey
- type: object
- secretserver:
- description: |-
- SecretServer configures this store to sync secrets using SecretServer provider
- https://docs.delinea.com/online-help/secret-server/start.htm
- properties:
- password:
- description: Password is the secret server account password.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- serverURL:
- description: |-
- ServerURL
- URL to your secret server installation
- type: string
- username:
- description: Username is the secret server account username.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - password
- - serverURL
- - username
- type: object
- senhasegura:
- description: Senhasegura configures this store to sync secrets using senhasegura provider
- properties:
- auth:
- description: Auth defines parameters to authenticate in senhasegura
- properties:
- clientId:
- type: string
- clientSecretSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecretSecretRef
- type: object
- ignoreSslCertificate:
- default: false
- description: IgnoreSslCertificate defines if SSL certificate must be ignored
- type: boolean
- module:
- description: Module defines which senhasegura module should be used to get secrets
- type: string
- url:
- description: URL of senhasegura
- type: string
- required:
- - auth
- - module
- - url
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexcertificatemanager:
- description: YandexCertificateManager configures this store to sync secrets using Yandex Certificate Manager provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Certificate Manager
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- refreshInterval:
- description: Used to configure store refresh interval in seconds. Empty or 0 will default to the controller config.
- type: integer
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- capabilities:
- description: SecretStoreCapabilities defines the possible operations a SecretStore can do.
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/vaultdynamicsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: vaultdynamicsecrets.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - vaultdynamicsecret
- kind: VaultDynamicSecret
- listKind: VaultDynamicSecretList
- plural: vaultdynamicsecrets
- shortNames:
- - vaultdynamicsecret
- singular: vaultdynamicsecret
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- 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:
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters VDS based on this property
- type: string
- method:
- description: Vault API method to use (GET/POST/other)
- type: string
- parameters:
- description: Parameters to pass to Vault write (for non-GET methods)
- x-kubernetes-preserve-unknown-fields: true
- path:
- description: Vault path to obtain the dynamic secret from
- type: string
- provider:
- description: Vault provider common spec
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- resultType:
- default: Data
- description: |-
- Result type defines which data is returned from the generator.
- By default it is the "data" section of the Vault API response.
- When using e.g. /auth/token/create the "data" section is empty but
- the "auth" section contains the generated token.
- Please refer to the vault docs regarding the result data structure.
- enum:
- - Data
- - Auth
- type: string
- required:
- - path
- - provider
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/webhook.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: webhooks.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - webhook
- kind: Webhook
- listKind: WebhookList
- plural: webhooks
- shortNames:
- - webhookl
- singular: webhook
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Webhook connects to a third party API server to handle the secrets generation
- configuration parameters in spec.
- You can specify the server, the token, and additional body parameters.
- See documentation for the full API specification for requests and responses.
- 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: WebhookSpec controls the behavior of the external generator. Any body parameters should be passed to the server through the parameters field.
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: The key where the token is found.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-cert-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "apiextensions.k8s.io"
- resources:
- - "customresourcedefinitions"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - "admissionregistration.k8s.io"
- resources:
- - "validatingwebhookconfigurations"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "endpoints"
- verbs:
- - "list"
- - "get"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "events"
- verbs:
- - "create"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "secrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - "coordination.k8s.io"
- resources:
- - "leases"
- verbs:
- - "get"
- - "create"
- - "update"
- - "patch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "secretstores"
- - "clustersecretstores"
- - "externalsecrets"
- - "clusterexternalsecrets"
- - "pushsecrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "externalsecrets/status"
- - "externalsecrets/finalizers"
- - "secretstores"
- - "secretstores/status"
- - "secretstores/finalizers"
- - "clustersecretstores"
- - "clustersecretstores/status"
- - "clustersecretstores/finalizers"
- - "clusterexternalsecrets"
- - "clusterexternalsecrets/status"
- - "clusterexternalsecrets/finalizers"
- - "pushsecrets"
- - "pushsecrets/status"
- - "pushsecrets/finalizers"
- verbs:
- - "get"
- - "update"
- - "patch"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "serviceaccounts"
- - "namespaces"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "secrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "create"
- - "update"
- - "delete"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "serviceaccounts/token"
- verbs:
- - "create"
- - apiGroups:
- - ""
- resources:
- - "events"
- verbs:
- - "create"
- - "patch"
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- verbs:
- - "create"
- - "update"
- - "delete"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-view
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- rbac.authorization.k8s.io/aggregate-to-view: "true"
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "secretstores"
- - "clustersecretstores"
- - "pushsecrets"
- verbs:
- - "get"
- - "watch"
- - "list"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "get"
- - "watch"
- - "list"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-edit
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "secretstores"
- - "clustersecretstores"
- - "pushsecrets"
- verbs:
- - "create"
- - "delete"
- - "deletecollection"
- - "patch"
- - "update"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "create"
- - "delete"
- - "deletecollection"
- - "patch"
- - "update"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-servicebindings
- labels:
- servicebinding.io/controller: "true"
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- verbs:
- - "get"
- - "list"
- - "watch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-golang-external-secrets-cert-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: common-golang-external-secrets-cert-controller
-subjects:
- - name: external-secrets-cert-controller
- namespace: default
- kind: ServiceAccount
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-golang-external-secrets-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: common-golang-external-secrets-controller
-subjects:
- - name: common-golang-external-secrets
- namespace: default
- kind: ServiceAccount
----
-# Source: golang-external-secrets/templates/golang-external-secrets-hub-clusterrolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: role-tokenreview-binding
- namespace: default
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: golang-external-secrets
- namespace: golang-external-secrets
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: common-golang-external-secrets-leaderelection
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- resourceNames:
- - "external-secrets-controller"
- verbs:
- - "get"
- - "update"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- verbs:
- - "create"
- - apiGroups:
- - "coordination.k8s.io"
- resources:
- - "leases"
- verbs:
- - "get"
- - "create"
- - "update"
- - "patch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: common-golang-external-secrets-leaderelection
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: common-golang-external-secrets-leaderelection
-subjects:
- - kind: ServiceAccount
- name: common-golang-external-secrets
- namespace: default
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- external-secrets.io/component: webhook
-spec:
- type: ClusterIP
- ports:
- - port: 443
- targetPort: 10250
- protocol: TCP
- name: webhook
- selector:
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets-cert-controller
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- serviceAccountName: external-secrets-cert-controller
- automountServiceAccountToken: true
- hostNetwork: false
- containers:
- - name: cert-controller
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - certcontroller
- - --crd-requeue-interval=5m
- - --service-name=common-golang-external-secrets-webhook
- - --service-namespace=default
- - --secret-name=common-golang-external-secrets-webhook
- - --secret-namespace=default
- - --metrics-addr=:8080
- - --healthz-addr=:8081
- - --loglevel=info
- - --zap-time-encoding=epoch
- - --enable-partial-cache=true
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- readinessProbe:
- httpGet:
- port: 8081
- path: /readyz
- initialDelaySeconds: 20
- periodSeconds: 5
----
-# Source: golang-external-secrets/charts/external-secrets/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- serviceAccountName: common-golang-external-secrets
- automountServiceAccountToken: true
- hostNetwork: false
- containers:
- - name: external-secrets
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - --concurrent=1
- - --metrics-addr=:8080
- - --loglevel=info
- - --zap-time-encoding=epoch
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- dnsPolicy: ClusterFirst
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- hostNetwork: false
- serviceAccountName: external-secrets-webhook
- automountServiceAccountToken: true
- containers:
- - name: webhook
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - webhook
- - --port=10250
- - --dns-name=common-golang-external-secrets-webhook.default.svc
- - --cert-dir=/tmp/certs
- - --check-interval=5m
- - --metrics-addr=:8080
- - --healthz-addr=:8081
- - --loglevel=info
- - --zap-time-encoding=epoch
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- - containerPort: 10250
- protocol: TCP
- name: webhook
- readinessProbe:
- httpGet:
- port: 8081
- path: /readyz
- initialDelaySeconds: 20
- periodSeconds: 5
- volumeMounts:
- - name: certs
- mountPath: /tmp/certs
- readOnly: true
- volumes:
- - name: certs
- secret:
- secretName: common-golang-external-secrets-webhook
----
-# Source: golang-external-secrets/templates/vault/golang-external-secrets-hub-secretstore.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ClusterSecretStore
-metadata:
- name: vault-backend
- namespace: golang-external-secrets
-spec:
- provider:
- vault:
- server: https://vault-vault.apps.hub.example.com
- path: secret
- # Version of KV backend
- version: v2
-
- caProvider:
- type: ConfigMap
- name: kube-root-ca.crt
- key: ca.crt
- namespace: golang-external-secrets
-
- auth:
- kubernetes:
-
- mountPath: hub
- role: hub-role
-
- secretRef:
- name: golang-external-secrets
- namespace: golang-external-secrets
- key: "token"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/validatingwebhook.yaml
-apiVersion: admissionregistration.k8s.io/v1
-kind: ValidatingWebhookConfiguration
-metadata:
- name: secretstore-validate
- labels:
- external-secrets.io/component: webhook
-webhooks:
-- name: "validate.secretstore.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["secretstores"]
- scope: "Namespaced"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-secretstore
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
-
-- name: "validate.clustersecretstore.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["clustersecretstores"]
- scope: "Cluster"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-clustersecretstore
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
----
-# Source: golang-external-secrets/charts/external-secrets/templates/validatingwebhook.yaml
-apiVersion: admissionregistration.k8s.io/v1
-kind: ValidatingWebhookConfiguration
-metadata:
- name: externalsecret-validate
- labels:
- external-secrets.io/component: webhook
-webhooks:
-- name: "validate.externalsecret.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["externalsecrets"]
- scope: "Namespaced"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-externalsecret
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
- failurePolicy: Fail
diff --git a/tests/common-golang-external-secrets-medical-diagnosis-hub.expected.yaml b/tests/common-golang-external-secrets-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 056054ba..00000000
--- a/tests/common-golang-external-secrets-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,13143 +0,0 @@
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: external-secrets-cert-controller
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: common-golang-external-secrets
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- external-secrets.io/component: webhook
----
-# Source: golang-external-secrets/templates/golang-external-secrets-hub-clusterrolebinding.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: golang-external-secrets
- namespace: golang-external-secrets
- annotations:
- kubernetes.io/service-account.name: golang-external-secrets
-type: kubernetes.io/service-account-token
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/acraccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: acraccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - acraccesstoken
- kind: ACRAccessToken
- listKind: ACRAccessTokenList
- plural: acraccesstokens
- shortNames:
- - acraccesstoken
- singular: acraccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- ACRAccessToken returns a Azure Container Registry token
- that can be used for pushing/pulling images.
- Note: by default it will return an ACR Refresh Token with full access
- (depending on the identity).
- This can be scoped down to the repository level using .spec.scope.
- In case scope is defined it will return an ACR Access Token.
-
-
- See docs: https://github.com/Azure/acr/blob/main/docs/AAD-OAuth.md
- 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: |-
- ACRAccessTokenSpec defines how to generate the access token
- e.g. how to authenticate and which registry to use.
- see: https://github.com/Azure/acr/blob/main/docs/AAD-OAuth.md#overview
- properties:
- auth:
- properties:
- managedIdentity:
- description: ManagedIdentity uses Azure Managed Identity to authenticate with Azure.
- properties:
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- type: object
- servicePrincipal:
- description: ServicePrincipal uses Azure Service Principal credentials to authenticate with Azure.
- properties:
- secretRef:
- description: |-
- Configuration used to authenticate with Azure using static
- credentials stored in a Kind=Secret.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- workloadIdentity:
- description: WorkloadIdentity uses Azure Workload Identity to authenticate with Azure.
- properties:
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- registry:
- description: |-
- the domain name of the ACR registry
- e.g. foobarexample.azurecr.io
- type: string
- scope:
- description: |-
- Define the scope for the access token, e.g. pull/push access for a repository.
- if not provided it will return a refresh token that has full scope.
- Note: you need to pin it down to the repository level, there is no wildcard available.
-
-
- examples:
- repository:my-repository:pull,push
- repository:my-repository:pull
-
-
- see docs for details: https://docs.docker.com/registry/spec/auth/scope/
- type: string
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- required:
- - auth
- - registry
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/clusterexternalsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: clusterexternalsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ClusterExternalSecret
- listKind: ClusterExternalSecretList
- plural: clusterexternalsecrets
- shortNames:
- - ces
- singular: clusterexternalsecret
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - jsonPath: .spec.externalSecretSpec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshTime
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ClusterExternalSecret is the Schema for the clusterexternalsecrets 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: ClusterExternalSecretSpec defines the desired state of ClusterExternalSecret.
- properties:
- externalSecretMetadata:
- description: The metadata of the external secrets to be created
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- externalSecretName:
- description: The name of the external secrets to be created defaults to the name of the ClusterExternalSecret
- type: string
- externalSecretSpec:
- description: The spec for the ExternalSecrets to be created
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: |-
- RemoteRef points to the remote secret and defines
- which secret (version/property/..) to fetch.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- description: |-
- SecretKey defines the key in which the controller stores
- the value. This is the key in the Kind=Secret
- type: string
- sourceRef:
- description: |-
- SourceRef allows you to override the source
- from which the value will pulled from.
- maxProperties: 1
- properties:
- generatorRef:
- description: |-
- GeneratorRef points to a generator custom resource.
-
-
- Deprecated: The generatorRef is not implemented in .data[].
- this will be removed with v1.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- properties:
- extract:
- description: |-
- Used to extract multiple key/value pairs from one secret
- Note: Extract does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- find:
- description: |-
- Used to find secrets based on tags or regular expressions
- Note: Find does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- name:
- description: Finds secrets based on the name.
- properties:
- regexp:
- description: Finds secrets base
- type: string
- type: object
- path:
- description: A root path to start the find operations.
- type: string
- tags:
- additionalProperties:
- type: string
- description: Find secrets based on tags.
- type: object
- type: object
- rewrite:
- description: |-
- Used to rewrite secret Keys after getting them from the secret Provider
- Multiple Rewrite operations can be provided. They are applied in a layered order (first to last)
- items:
- properties:
- regexp:
- description: |-
- Used to rewrite with regular expressions.
- The resulting key will be the output of a regexp.ReplaceAll operation.
- properties:
- source:
- description: Used to define the regular expression of a re.Compiler.
- type: string
- target:
- description: Used to define the target pattern of a ReplaceAll operation.
- type: string
- required:
- - source
- - target
- type: object
- transform:
- description: |-
- Used to apply string transformation on the secrets.
- The resulting key will be the output of the template applied by the operation.
- properties:
- template:
- description: |-
- Used to define the template to apply on the secret name.
- `.value ` will specify the secret name in the template.
- type: string
- required:
- - template
- type: object
- type: object
- type: array
- sourceRef:
- description: |-
- SourceRef points to a store or generator
- which contains secret values ready to use.
- Use this in combination with Extract or Find pull values out of
- a specific SecretStore.
- When sourceRef points to a generator Extract or Find is not supported.
- The generator returns a static map of values
- maxProperties: 1
- properties:
- generatorRef:
- description: GeneratorRef points to a generator custom resource.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- default:
- creationPolicy: Owner
- deletionPolicy: Retain
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Orphan
- - Merge
- - None
- type: string
- deletionPolicy:
- default: Retain
- description: |-
- DeletionPolicy defines rules on how to delete the resulting Secret
- Defaults to 'Retain'
- enum:
- - Delete
- - Merge
- - Retain
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- type: object
- namespaceSelector:
- description: |-
- The labels to select by to find the Namespaces to create the ExternalSecrets in.
- Deprecated: Use NamespaceSelectors instead.
- 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
- namespaceSelectors:
- description: A list of labels to select by to find the Namespaces to create the ExternalSecrets in. The selectors are ORed.
- items:
- description: |-
- A label selector is a label query over a set of resources. The result of matchLabels and
- matchExpressions are ANDed. An empty label selector matches all objects. A null
- label selector matches no objects.
- 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
- type: array
- namespaces:
- description: Choose namespaces by name. This field is ORed with anything that NamespaceSelectors ends up choosing.
- items:
- type: string
- type: array
- refreshTime:
- description: The time in which the controller should reconcile its objects and recheck namespaces for labels.
- type: string
- required:
- - externalSecretSpec
- type: object
- status:
- description: ClusterExternalSecretStatus defines the observed state of ClusterExternalSecret.
- properties:
- conditions:
- items:
- properties:
- message:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- externalSecretName:
- description: ExternalSecretName is the name of the ExternalSecrets created by the ClusterExternalSecret
- type: string
- failedNamespaces:
- description: Failed namespaces are the namespaces that failed to apply an ExternalSecret
- items:
- description: ClusterExternalSecretNamespaceFailure represents a failed namespace deployment and it's reason.
- properties:
- namespace:
- description: Namespace is the namespace that failed when trying to apply an ExternalSecret
- type: string
- reason:
- description: Reason is why the ExternalSecret failed to apply to the namespace
- type: string
- required:
- - namespace
- type: object
- type: array
- provisionedNamespaces:
- description: ProvisionedNamespaces are the namespaces where the ClusterExternalSecret has secrets
- items:
- type: string
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/clustersecretstore.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: clustersecretstores.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ClusterSecretStore
- listKind: ClusterSecretStoreList
- plural: clustersecretstores
- shortNames:
- - css
- singular: clustersecretstore
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: ClusterSecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the SecretManager provider will assume
- type: string
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- properties:
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- serviceAccount:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- required:
- - auth
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, instance principal is used. Optionally, the authenticating principal type
- and/or user data may be supplied for the use of workload identity and user principal.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - roleId
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.capabilities
- name: Capabilities
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ClusterSecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- conditions:
- description: Used to constraint a ClusterSecretStore to specific namespaces. Relevant only to ClusterSecretStore
- items:
- description: |-
- ClusterSecretStoreCondition describes a condition by which to choose namespaces to process ExternalSecrets in
- for a ClusterSecretStore instance.
- properties:
- namespaceRegexes:
- description: Choose namespaces by using regex matching
- items:
- type: string
- type: array
- namespaceSelector:
- description: Choose namespace using a labelSelector
- 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
- namespaces:
- description: Choose namespaces by name
- items:
- type: string
- type: array
- type: object
- type: array
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- additionalRoles:
- description: AdditionalRoles is a chained list of Role ARNs which the provider will sequentially assume before assuming the Role
- items:
- type: string
- type: array
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- prefix:
- description: Prefix adds a prefix to all retrieved values.
- type: string
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the provider will assume
- type: string
- secretsManager:
- description: SecretsManager defines how the provider behaves when interacting with AWS SecretsManager
- properties:
- forceDeleteWithoutRecovery:
- description: |-
- Specifies whether to delete the secret without any recovery window. You
- can't use both this parameter and RecoveryWindowInDays in the same call.
- If you don't use either, then by default Secrets Manager uses a 30 day
- recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-ForceDeleteWithoutRecovery
- type: boolean
- recoveryWindowInDays:
- description: |-
- The number of days from 7 to 30 that Secrets Manager waits before
- permanently deleting the secret. You can't use both this parameter and
- ForceDeleteWithoutRecovery in the same call. If you don't use either,
- then by default Secrets Manager uses a 30 day recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-RecoveryWindowInDays
- format: int64
- type: integer
- type: object
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- sessionTags:
- description: AWS STS assume role session tags
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- transitiveTagKeys:
- description: AWS STS assume role transitive session tags. Required when multiple rules are used with the provider
- items:
- type: string
- type: array
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- properties:
- clientCertificate:
- description: The Azure ClientCertificate of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientId:
- description: The Azure clientId of the service principle or managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- tenantId:
- description: The Azure tenantId of the managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- bitwardensecretsmanager:
- description: BitwardenSecretsManager configures this store to sync secrets using BitwardenSecretsManager provider
- properties:
- apiURL:
- type: string
- auth:
- description: |-
- Auth configures how secret-manager authenticates with a bitwarden machine account instance.
- Make sure that the token being used has permissions on the given secret.
- properties:
- secretRef:
- description: BitwardenSecretsManagerSecretRef contains the credential ref to the bitwarden instance.
- properties:
- credentials:
- description: AccessToken used for the bitwarden instance.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - credentials
- type: object
- required:
- - secretRef
- type: object
- bitwardenServerSDKURL:
- type: string
- caBundle:
- description: |-
- Base64 encoded certificate for the bitwarden server sdk. The sdk MUST run with HTTPS to make sure no MITM attack
- can be performed.
- type: string
- identityURL:
- type: string
- organizationID:
- description: OrganizationID determines which organization this secret store manages.
- type: string
- projectID:
- description: ProjectID determines which project this secret store manages.
- type: string
- required:
- - auth
- - caBundle
- - organizationID
- - projectID
- type: object
- chef:
- description: Chef configures this store to sync secrets with chef server
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against chef Server
- properties:
- secretRef:
- description: ChefAuthSecretRef holds secret references for chef server login credentials.
- properties:
- privateKeySecretRef:
- description: SecretKey is the Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - privateKeySecretRef
- type: object
- required:
- - secretRef
- type: object
- serverUrl:
- description: ServerURL is the chef server URL used to connect to. If using orgs you should include your org in the url and terminate the url with a "/"
- type: string
- username:
- description: UserName should be the user ID on the chef server
- type: string
- required:
- - auth
- - serverUrl
- - username
- type: object
- conjur:
- description: Conjur configures this store to sync secrets using conjur provider
- properties:
- auth:
- properties:
- apikey:
- properties:
- account:
- type: string
- apiKeyRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - account
- - apiKeyRef
- - userRef
- type: object
- jwt:
- properties:
- account:
- type: string
- hostId:
- description: |-
- Optional HostID for JWT authentication. This may be used depending
- on how the Conjur JWT authenticator policy is configured.
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Conjur using the JWT authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional ServiceAccountRef specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- serviceID:
- description: The conjur authn jwt webservice id
- type: string
- required:
- - account
- - serviceID
- type: object
- type: object
- caBundle:
- type: string
- caProvider:
- description: |-
- Used to provide custom certificate authority (CA) certificates
- for a secret store. The CAProvider points to a Secret or ConfigMap resource
- that contains a PEM-encoded certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- type: string
- required:
- - auth
- - url
- type: object
- delinea:
- description: |-
- Delinea DevOps Secrets Vault
- https://docs.delinea.com/online-help/products/devops-secrets-vault/current
- properties:
- clientId:
- description: ClientID is the non-secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- clientSecret:
- description: ClientSecret is the secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- tenant:
- description: Tenant is the chosen hostname / site name.
- type: string
- tld:
- description: |-
- TLD is based on the server location that was chosen during provisioning.
- If unset, defaults to "com".
- type: string
- urlTemplate:
- description: |-
- URLTemplate
- If unset, defaults to "https://%s.secretsvaultcloud.%s/v1/%s%s".
- type: string
- required:
- - clientId
- - clientSecret
- - tenant
- type: object
- device42:
- description: Device42 configures this store to sync secrets using the Device42 provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Device42 instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- host:
- description: URL configures the Device42 instance URL.
- type: string
- required:
- - auth
- - host
- type: object
- doppler:
- description: Doppler configures this store to sync secrets using the Doppler provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Doppler API
- properties:
- secretRef:
- properties:
- dopplerToken:
- description: |-
- The DopplerToken is used for authentication.
- See https://docs.doppler.com/reference/api#authentication for auth token types.
- The Key attribute defaults to dopplerToken if not specified.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - dopplerToken
- type: object
- required:
- - secretRef
- type: object
- config:
- description: Doppler config (required if not using a Service Token)
- type: string
- format:
- description: Format enables the downloading of secrets as a file (string)
- enum:
- - json
- - dotnet-json
- - env
- - yaml
- - docker
- type: string
- nameTransformer:
- description: Environment variable compatible name transforms that change secret names to a different format
- enum:
- - upper-camel
- - camel
- - lower-snake
- - tf-var
- - dotnet-env
- - lower-kebab
- type: string
- project:
- description: Doppler project (required if not using a Service Token)
- type: string
- required:
- - auth
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- description: 'Deprecated: ValueMap is deprecated and is intended to be removed in the future, use the `value` field instead.'
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- fortanix:
- description: Fortanix configures this store to sync secrets using the Fortanix provider
- properties:
- apiKey:
- description: APIKey is the API token to access SDKMS Applications.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the SDKMS API Key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- description: APIURL is the URL of SDKMS API. Defaults to `sdkms.fortanix.com`.
- type: string
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- location:
- description: Location optionally defines a location for a secret
- type: string
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- environment:
- description: Environment environment_scope of gitlab CI/CD variables (Please see https://docs.gitlab.com/ee/ci/environments/#create-a-static-environment on how to create environments)
- type: string
- groupIDs:
- description: GroupIDs specify, which gitlab groups to pull secrets from. Group secrets are read from left to right followed by the project variables.
- items:
- type: string
- type: array
- inheritFromGroups:
- description: InheritFromGroups specifies whether parent groups should be discovered and checked for secrets.
- type: boolean
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- maxProperties: 1
- minProperties: 1
- properties:
- containerAuth:
- description: IBM Container-based auth with IAM Trusted Profile.
- properties:
- iamEndpoint:
- type: string
- profile:
- description: the IBM Trusted Profile
- type: string
- tokenLocation:
- description: Location the token is mounted on the pod
- type: string
- required:
- - profile
- type: object
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- infisical:
- description: Infisical configures this store to sync secrets using the Infisical provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Infisical API
- properties:
- universalAuthCredentials:
- properties:
- clientId:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecret
- type: object
- type: object
- hostAPI:
- default: https://app.infisical.com/api
- type: string
- secretsScope:
- properties:
- environmentSlug:
- type: string
- projectSlug:
- type: string
- secretsPath:
- default: /
- type: string
- required:
- - environmentSlug
- - projectSlug
- type: object
- required:
- - auth
- - secretsScope
- type: object
- keepersecurity:
- description: KeeperSecurity configures this store to sync secrets using the KeeperSecurity provider
- properties:
- authRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- folderID:
- type: string
- required:
- - authRef
- - folderID
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- authRef:
- description: A reference to a secret that contains the auth information.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- type: object
- onboardbase:
- description: Onboardbase configures this store to sync secrets using the Onboardbase provider
- properties:
- apiHost:
- default: https://public.onboardbase.com/api/v1/
- description: APIHost use this to configure the host url for the API for selfhosted installation, default is https://public.onboardbase.com/api/v1/
- type: string
- auth:
- description: Auth configures how the Operator authenticates with the Onboardbase API
- properties:
- apiKeyRef:
- description: |-
- OnboardbaseAPIKey is the APIKey generated by an admin account.
- It is used to recognize and authorize access to a project and environment within onboardbase
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- passcodeRef:
- description: OnboardbasePasscode is the passcode attached to the API Key
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - apiKeyRef
- - passcodeRef
- type: object
- environment:
- default: development
- description: Environment is the name of an environmnent within a project to pull the secrets from
- type: string
- project:
- default: development
- description: Project is an onboardbase project that the secrets should be pulled from
- type: string
- required:
- - apiHost
- - auth
- - environment
- - project
- type: object
- onepassword:
- description: OnePassword configures this store to sync secrets using the 1Password Cloud provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against OnePassword Connect Server
- properties:
- secretRef:
- description: OnePasswordAuthSecretRef holds secret references for 1Password credentials.
- properties:
- connectTokenSecretRef:
- description: The ConnectToken is used for authentication to a 1Password Connect Server.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - connectTokenSecretRef
- type: object
- required:
- - secretRef
- type: object
- connectHost:
- description: ConnectHost defines the OnePassword Connect Server to connect to
- type: string
- vaults:
- additionalProperties:
- type: integer
- description: Vaults defines which OnePassword vaults to search in which order
- type: object
- required:
- - auth
- - connectHost
- - vaults
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, use the instance principal, otherwise the user credentials specified in Auth.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passbolt:
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against Passbolt Server
- properties:
- passwordSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privateKeySecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - passwordSecretRef
- - privateKeySecretRef
- type: object
- host:
- description: Host defines the Passbolt Server to connect to
- type: string
- required:
- - auth
- - host
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- pulumi:
- description: Pulumi configures this store to sync secrets using the Pulumi provider
- properties:
- accessToken:
- description: AccessToken is the access tokens to sign in to the Pulumi Cloud Console.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the Pulumi API token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- default: https://api.pulumi.com/api/preview
- description: APIURL is the URL of the Pulumi API.
- type: string
- environment:
- description: |-
- Environment are YAML documents composed of static key-value pairs, programmatic expressions,
- dynamically retrieved values from supported providers including all major clouds,
- and other Pulumi ESC environments.
- To create a new environment, visit https://www.pulumi.com/docs/esc/environments/ for more information.
- type: string
- organization:
- description: |-
- Organization are a space to collaborate on shared projects and stacks.
- To create a new organization, visit https://app.pulumi.com/ and click "New Organization".
- type: string
- required:
- - accessToken
- - environment
- - organization
- type: object
- scaleway:
- description: Scaleway
- properties:
- accessKey:
- description: AccessKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- apiUrl:
- description: APIURL is the url of the api to use. Defaults to https://api.scaleway.com
- type: string
- projectId:
- description: 'ProjectID is the id of your project, which you can find in the console: https://console.scaleway.com/project/settings'
- type: string
- region:
- description: 'Region where your secrets are located: https://developers.scaleway.com/en/quickstart/#region-and-zone'
- type: string
- secretKey:
- description: SecretKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - accessKey
- - projectId
- - region
- - secretKey
- type: object
- secretserver:
- description: |-
- SecretServer configures this store to sync secrets using SecretServer provider
- https://docs.delinea.com/online-help/secret-server/start.htm
- properties:
- password:
- description: Password is the secret server account password.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- serverURL:
- description: |-
- ServerURL
- URL to your secret server installation
- type: string
- username:
- description: Username is the secret server account username.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - password
- - serverURL
- - username
- type: object
- senhasegura:
- description: Senhasegura configures this store to sync secrets using senhasegura provider
- properties:
- auth:
- description: Auth defines parameters to authenticate in senhasegura
- properties:
- clientId:
- type: string
- clientSecretSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecretSecretRef
- type: object
- ignoreSslCertificate:
- default: false
- description: IgnoreSslCertificate defines if SSL certificate must be ignored
- type: boolean
- module:
- description: Module defines which senhasegura module should be used to get secrets
- type: string
- url:
- description: URL of senhasegura
- type: string
- required:
- - auth
- - module
- - url
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexcertificatemanager:
- description: YandexCertificateManager configures this store to sync secrets using Yandex Certificate Manager provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Certificate Manager
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- refreshInterval:
- description: Used to configure store refresh interval in seconds. Empty or 0 will default to the controller config.
- type: integer
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- capabilities:
- description: SecretStoreCapabilities defines the possible operations a SecretStore can do.
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/ecrauthorizationtoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: ecrauthorizationtokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - ecrauthorizationtoken
- kind: ECRAuthorizationToken
- listKind: ECRAuthorizationTokenList
- plural: ecrauthorizationtokens
- shortNames:
- - ecrauthorizationtoken
- singular: ecrauthorizationtoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- ECRAuthorizationTokenSpec uses the GetAuthorizationToken API to retrieve an
- authorization token.
- The authorization token is valid for 12 hours.
- The authorizationToken returned is a base64 encoded string that can be decoded
- and used in a docker login command to authenticate to a registry.
- For more information, see Registry authentication (https://docs.aws.amazon.com/AmazonECR/latest/userguide/Registries.html#registry_auth) in the Amazon Elastic Container Registry User Guide.
- 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:
- properties:
- auth:
- description: Auth defines how to authenticate with AWS
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: Region specifies the region to operate in.
- type: string
- role:
- description: |-
- You can assume a role before making calls to the
- desired AWS service.
- type: string
- required:
- - region
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/externalsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: externalsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ExternalSecret
- listKind: ExternalSecretList
- plural: externalsecrets
- shortNames:
- - es
- singular: externalsecret
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .spec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshInterval
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: ExternalSecret is the Schema for the external-secrets 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: ExternalSecretSpec defines the desired state of ExternalSecret.
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: ExternalSecretDataRemoteRef defines Provider data location.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- type: string
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- description: ExternalSecretDataRemoteRef defines Provider data location.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Merge
- - None
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v1
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- maxProperties: 1
- minProperties: 1
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- required:
- - secretStoreRef
- - target
- type: object
- status:
- properties:
- binding:
- description: Binding represents a servicebinding.io Provisioned Service reference to the secret
- properties:
- name:
- default: ""
- description: |-
- Name of the referent.
- This field is effectively required, but due to backwards compatibility is
- allowed to be empty. Instances of this type with an empty value here are
- almost certainly wrong.
- TODO: Add other useful fields. apiVersion, kind, uid?
- More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
- TODO: Drop `kubebuilder:default` when controller-gen doesn't need it https://github.com/kubernetes-sigs/kubebuilder/issues/3896.
- type: string
- type: object
- x-kubernetes-map-type: atomic
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version
- type: string
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .spec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshInterval
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ExternalSecret is the Schema for the external-secrets 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: ExternalSecretSpec defines the desired state of ExternalSecret.
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: |-
- RemoteRef points to the remote secret and defines
- which secret (version/property/..) to fetch.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- description: |-
- SecretKey defines the key in which the controller stores
- the value. This is the key in the Kind=Secret
- type: string
- sourceRef:
- description: |-
- SourceRef allows you to override the source
- from which the value will pulled from.
- maxProperties: 1
- properties:
- generatorRef:
- description: |-
- GeneratorRef points to a generator custom resource.
-
-
- Deprecated: The generatorRef is not implemented in .data[].
- this will be removed with v1.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- properties:
- extract:
- description: |-
- Used to extract multiple key/value pairs from one secret
- Note: Extract does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- find:
- description: |-
- Used to find secrets based on tags or regular expressions
- Note: Find does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- name:
- description: Finds secrets based on the name.
- properties:
- regexp:
- description: Finds secrets base
- type: string
- type: object
- path:
- description: A root path to start the find operations.
- type: string
- tags:
- additionalProperties:
- type: string
- description: Find secrets based on tags.
- type: object
- type: object
- rewrite:
- description: |-
- Used to rewrite secret Keys after getting them from the secret Provider
- Multiple Rewrite operations can be provided. They are applied in a layered order (first to last)
- items:
- properties:
- regexp:
- description: |-
- Used to rewrite with regular expressions.
- The resulting key will be the output of a regexp.ReplaceAll operation.
- properties:
- source:
- description: Used to define the regular expression of a re.Compiler.
- type: string
- target:
- description: Used to define the target pattern of a ReplaceAll operation.
- type: string
- required:
- - source
- - target
- type: object
- transform:
- description: |-
- Used to apply string transformation on the secrets.
- The resulting key will be the output of the template applied by the operation.
- properties:
- template:
- description: |-
- Used to define the template to apply on the secret name.
- `.value ` will specify the secret name in the template.
- type: string
- required:
- - template
- type: object
- type: object
- type: array
- sourceRef:
- description: |-
- SourceRef points to a store or generator
- which contains secret values ready to use.
- Use this in combination with Extract or Find pull values out of
- a specific SecretStore.
- When sourceRef points to a generator Extract or Find is not supported.
- The generator returns a static map of values
- maxProperties: 1
- properties:
- generatorRef:
- description: GeneratorRef points to a generator custom resource.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- default:
- creationPolicy: Owner
- deletionPolicy: Retain
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Orphan
- - Merge
- - None
- type: string
- deletionPolicy:
- default: Retain
- description: |-
- DeletionPolicy defines rules on how to delete the resulting Secret
- Defaults to 'Retain'
- enum:
- - Delete
- - Merge
- - Retain
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- type: object
- status:
- properties:
- binding:
- description: Binding represents a servicebinding.io Provisioned Service reference to the secret
- properties:
- name:
- default: ""
- description: |-
- Name of the referent.
- This field is effectively required, but due to backwards compatibility is
- allowed to be empty. Instances of this type with an empty value here are
- almost certainly wrong.
- TODO: Add other useful fields. apiVersion, kind, uid?
- More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
- TODO: Drop `kubebuilder:default` when controller-gen doesn't need it https://github.com/kubernetes-sigs/kubebuilder/issues/3896.
- type: string
- type: object
- x-kubernetes-map-type: atomic
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version
- type: string
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/fake.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: fakes.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - fake
- kind: Fake
- listKind: FakeList
- plural: fakes
- shortNames:
- - fake
- singular: fake
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Fake generator is used for testing. It lets you define
- a static set of credentials that is always returned.
- 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: FakeSpec contains the static data.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters VDS based on this property
- type: string
- data:
- additionalProperties:
- type: string
- description: |-
- Data defines the static data returned
- by this generator.
- type: object
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/gcraccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: gcraccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - gcraccesstoken
- kind: GCRAccessToken
- listKind: GCRAccessTokenList
- plural: gcraccesstokens
- shortNames:
- - gcraccesstoken
- singular: gcraccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- GCRAccessToken generates an GCP access token
- that can be used to authenticate with GCR.
- 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:
- properties:
- auth:
- description: Auth defines the means for authenticating with GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID defines which project to use to authenticate with
- type: string
- required:
- - auth
- - projectID
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/githubaccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: githubaccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - githubaccesstoken
- kind: GithubAccessToken
- listKind: GithubAccessTokenList
- plural: githubaccesstokens
- shortNames:
- - githubaccesstoken
- singular: githubaccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: GithubAccessToken generates ghs_ accessToken
- 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:
- properties:
- appID:
- type: string
- auth:
- description: Auth configures how ESO authenticates with a Github instance.
- properties:
- privateKey:
- properties:
- secretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - secretRef
- type: object
- required:
- - privateKey
- type: object
- installID:
- type: string
- url:
- description: URL configures the Github instance URL. Defaults to https://github.com/.
- type: string
- required:
- - appID
- - auth
- - installID
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/password.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: passwords.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - password
- kind: Password
- listKind: PasswordList
- plural: passwords
- shortNames:
- - password
- singular: password
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Password generates a random password based on the
- configuration parameters in spec.
- You can specify the length, characterset and other attributes.
- 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: PasswordSpec controls the behavior of the password generator.
- properties:
- allowRepeat:
- default: false
- description: set AllowRepeat to true to allow repeating characters.
- type: boolean
- digits:
- description: |-
- Digits specifies the number of digits in the generated
- password. If omitted it defaults to 25% of the length of the password
- type: integer
- length:
- default: 24
- description: |-
- Length of the password to be generated.
- Defaults to 24
- type: integer
- noUpper:
- default: false
- description: Set NoUpper to disable uppercase characters
- type: boolean
- symbolCharacters:
- description: |-
- SymbolCharacters specifies the special characters that should be used
- in the generated password.
- type: string
- symbols:
- description: |-
- Symbols specifies the number of symbol characters in the generated
- password. If omitted it defaults to 25% of the length of the password
- type: integer
- required:
- - allowRepeat
- - length
- - noUpper
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/pushsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- name: pushsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - pushsecrets
- kind: PushSecret
- listKind: PushSecretList
- plural: pushsecrets
- singular: pushsecret
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- name: v1alpha1
- schema:
- openAPIV3Schema:
- 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: PushSecretSpec configures the behavior of the PushSecret.
- properties:
- data:
- description: Secret Data that should be pushed to providers
- items:
- properties:
- conversionStrategy:
- default: None
- description: Used to define a conversion Strategy for the secret keys
- enum:
- - None
- - ReverseUnicode
- type: string
- match:
- description: Match a given Secret Key to be pushed to the provider.
- properties:
- remoteRef:
- description: Remote Refs to push to providers.
- properties:
- property:
- description: Name of the property in the resulting secret
- type: string
- remoteKey:
- description: Name of the resulting provider secret.
- type: string
- required:
- - remoteKey
- type: object
- secretKey:
- description: Secret Key to be pushed
- type: string
- required:
- - remoteRef
- type: object
- metadata:
- description: |-
- Metadata is metadata attached to the secret.
- The structure of metadata is provider specific, please look it up in the provider documentation.
- x-kubernetes-preserve-unknown-fields: true
- required:
- - match
- type: object
- type: array
- deletionPolicy:
- default: None
- description: 'Deletion Policy to handle Secrets in the provider. Possible Values: "Delete/None". Defaults to "None".'
- enum:
- - Delete
- - None
- type: string
- refreshInterval:
- description: The Interval to which External Secrets will try to push a secret definition
- type: string
- secretStoreRefs:
- items:
- properties:
- kind:
- default: SecretStore
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- labelSelector:
- description: Optionally, sync to secret stores with label selector
- 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
- name:
- description: Optionally, sync to the SecretStore of the given name
- type: string
- type: object
- type: array
- selector:
- description: The Secret Selector (k8s source) for the Push Secret
- properties:
- secret:
- description: Select a Secret to Push.
- properties:
- name:
- description: Name of the Secret. The Secret must exist in the same namespace as the PushSecret manifest.
- type: string
- required:
- - name
- type: object
- required:
- - secret
- type: object
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- updatePolicy:
- default: Replace
- description: 'UpdatePolicy to handle Secrets in the provider. Possible Values: "Replace/IfNotExists". Defaults to "Replace".'
- enum:
- - Replace
- - IfNotExists
- type: string
- required:
- - secretStoreRefs
- - selector
- type: object
- status:
- description: PushSecretStatus indicates the history of the status of PushSecret.
- properties:
- conditions:
- items:
- description: PushSecretStatusCondition indicates the status of the PushSecret.
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- description: PushSecretConditionType indicates the condition of the PushSecret.
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedPushSecrets:
- additionalProperties:
- additionalProperties:
- properties:
- conversionStrategy:
- default: None
- description: Used to define a conversion Strategy for the secret keys
- enum:
- - None
- - ReverseUnicode
- type: string
- match:
- description: Match a given Secret Key to be pushed to the provider.
- properties:
- remoteRef:
- description: Remote Refs to push to providers.
- properties:
- property:
- description: Name of the property in the resulting secret
- type: string
- remoteKey:
- description: Name of the resulting provider secret.
- type: string
- required:
- - remoteKey
- type: object
- secretKey:
- description: Secret Key to be pushed
- type: string
- required:
- - remoteRef
- type: object
- metadata:
- description: |-
- Metadata is metadata attached to the secret.
- The structure of metadata is provider specific, please look it up in the provider documentation.
- x-kubernetes-preserve-unknown-fields: true
- required:
- - match
- type: object
- type: object
- description: |-
- Synced PushSecrets, including secrets that already exist in provider.
- Matches secret stores to PushSecretData that was stored to that secret store.
- type: object
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version.
- type: string
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/secretstore.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: secretstores.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: SecretStore
- listKind: SecretStoreList
- plural: secretstores
- shortNames:
- - ss
- singular: secretstore
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: SecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the SecretManager provider will assume
- type: string
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- properties:
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- serviceAccount:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- required:
- - auth
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, instance principal is used. Optionally, the authenticating principal type
- and/or user data may be supplied for the use of workload identity and user principal.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - roleId
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.capabilities
- name: Capabilities
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: SecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- conditions:
- description: Used to constraint a ClusterSecretStore to specific namespaces. Relevant only to ClusterSecretStore
- items:
- description: |-
- ClusterSecretStoreCondition describes a condition by which to choose namespaces to process ExternalSecrets in
- for a ClusterSecretStore instance.
- properties:
- namespaceRegexes:
- description: Choose namespaces by using regex matching
- items:
- type: string
- type: array
- namespaceSelector:
- description: Choose namespace using a labelSelector
- 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
- namespaces:
- description: Choose namespaces by name
- items:
- type: string
- type: array
- type: object
- type: array
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- additionalRoles:
- description: AdditionalRoles is a chained list of Role ARNs which the provider will sequentially assume before assuming the Role
- items:
- type: string
- type: array
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- prefix:
- description: Prefix adds a prefix to all retrieved values.
- type: string
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the provider will assume
- type: string
- secretsManager:
- description: SecretsManager defines how the provider behaves when interacting with AWS SecretsManager
- properties:
- forceDeleteWithoutRecovery:
- description: |-
- Specifies whether to delete the secret without any recovery window. You
- can't use both this parameter and RecoveryWindowInDays in the same call.
- If you don't use either, then by default Secrets Manager uses a 30 day
- recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-ForceDeleteWithoutRecovery
- type: boolean
- recoveryWindowInDays:
- description: |-
- The number of days from 7 to 30 that Secrets Manager waits before
- permanently deleting the secret. You can't use both this parameter and
- ForceDeleteWithoutRecovery in the same call. If you don't use either,
- then by default Secrets Manager uses a 30 day recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-RecoveryWindowInDays
- format: int64
- type: integer
- type: object
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- sessionTags:
- description: AWS STS assume role session tags
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- transitiveTagKeys:
- description: AWS STS assume role transitive session tags. Required when multiple rules are used with the provider
- items:
- type: string
- type: array
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- properties:
- clientCertificate:
- description: The Azure ClientCertificate of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientId:
- description: The Azure clientId of the service principle or managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- tenantId:
- description: The Azure tenantId of the managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- bitwardensecretsmanager:
- description: BitwardenSecretsManager configures this store to sync secrets using BitwardenSecretsManager provider
- properties:
- apiURL:
- type: string
- auth:
- description: |-
- Auth configures how secret-manager authenticates with a bitwarden machine account instance.
- Make sure that the token being used has permissions on the given secret.
- properties:
- secretRef:
- description: BitwardenSecretsManagerSecretRef contains the credential ref to the bitwarden instance.
- properties:
- credentials:
- description: AccessToken used for the bitwarden instance.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - credentials
- type: object
- required:
- - secretRef
- type: object
- bitwardenServerSDKURL:
- type: string
- caBundle:
- description: |-
- Base64 encoded certificate for the bitwarden server sdk. The sdk MUST run with HTTPS to make sure no MITM attack
- can be performed.
- type: string
- identityURL:
- type: string
- organizationID:
- description: OrganizationID determines which organization this secret store manages.
- type: string
- projectID:
- description: ProjectID determines which project this secret store manages.
- type: string
- required:
- - auth
- - caBundle
- - organizationID
- - projectID
- type: object
- chef:
- description: Chef configures this store to sync secrets with chef server
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against chef Server
- properties:
- secretRef:
- description: ChefAuthSecretRef holds secret references for chef server login credentials.
- properties:
- privateKeySecretRef:
- description: SecretKey is the Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - privateKeySecretRef
- type: object
- required:
- - secretRef
- type: object
- serverUrl:
- description: ServerURL is the chef server URL used to connect to. If using orgs you should include your org in the url and terminate the url with a "/"
- type: string
- username:
- description: UserName should be the user ID on the chef server
- type: string
- required:
- - auth
- - serverUrl
- - username
- type: object
- conjur:
- description: Conjur configures this store to sync secrets using conjur provider
- properties:
- auth:
- properties:
- apikey:
- properties:
- account:
- type: string
- apiKeyRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - account
- - apiKeyRef
- - userRef
- type: object
- jwt:
- properties:
- account:
- type: string
- hostId:
- description: |-
- Optional HostID for JWT authentication. This may be used depending
- on how the Conjur JWT authenticator policy is configured.
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Conjur using the JWT authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional ServiceAccountRef specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- serviceID:
- description: The conjur authn jwt webservice id
- type: string
- required:
- - account
- - serviceID
- type: object
- type: object
- caBundle:
- type: string
- caProvider:
- description: |-
- Used to provide custom certificate authority (CA) certificates
- for a secret store. The CAProvider points to a Secret or ConfigMap resource
- that contains a PEM-encoded certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- type: string
- required:
- - auth
- - url
- type: object
- delinea:
- description: |-
- Delinea DevOps Secrets Vault
- https://docs.delinea.com/online-help/products/devops-secrets-vault/current
- properties:
- clientId:
- description: ClientID is the non-secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- clientSecret:
- description: ClientSecret is the secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- tenant:
- description: Tenant is the chosen hostname / site name.
- type: string
- tld:
- description: |-
- TLD is based on the server location that was chosen during provisioning.
- If unset, defaults to "com".
- type: string
- urlTemplate:
- description: |-
- URLTemplate
- If unset, defaults to "https://%s.secretsvaultcloud.%s/v1/%s%s".
- type: string
- required:
- - clientId
- - clientSecret
- - tenant
- type: object
- device42:
- description: Device42 configures this store to sync secrets using the Device42 provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Device42 instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- host:
- description: URL configures the Device42 instance URL.
- type: string
- required:
- - auth
- - host
- type: object
- doppler:
- description: Doppler configures this store to sync secrets using the Doppler provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Doppler API
- properties:
- secretRef:
- properties:
- dopplerToken:
- description: |-
- The DopplerToken is used for authentication.
- See https://docs.doppler.com/reference/api#authentication for auth token types.
- The Key attribute defaults to dopplerToken if not specified.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - dopplerToken
- type: object
- required:
- - secretRef
- type: object
- config:
- description: Doppler config (required if not using a Service Token)
- type: string
- format:
- description: Format enables the downloading of secrets as a file (string)
- enum:
- - json
- - dotnet-json
- - env
- - yaml
- - docker
- type: string
- nameTransformer:
- description: Environment variable compatible name transforms that change secret names to a different format
- enum:
- - upper-camel
- - camel
- - lower-snake
- - tf-var
- - dotnet-env
- - lower-kebab
- type: string
- project:
- description: Doppler project (required if not using a Service Token)
- type: string
- required:
- - auth
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- description: 'Deprecated: ValueMap is deprecated and is intended to be removed in the future, use the `value` field instead.'
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- fortanix:
- description: Fortanix configures this store to sync secrets using the Fortanix provider
- properties:
- apiKey:
- description: APIKey is the API token to access SDKMS Applications.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the SDKMS API Key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- description: APIURL is the URL of SDKMS API. Defaults to `sdkms.fortanix.com`.
- type: string
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- location:
- description: Location optionally defines a location for a secret
- type: string
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- environment:
- description: Environment environment_scope of gitlab CI/CD variables (Please see https://docs.gitlab.com/ee/ci/environments/#create-a-static-environment on how to create environments)
- type: string
- groupIDs:
- description: GroupIDs specify, which gitlab groups to pull secrets from. Group secrets are read from left to right followed by the project variables.
- items:
- type: string
- type: array
- inheritFromGroups:
- description: InheritFromGroups specifies whether parent groups should be discovered and checked for secrets.
- type: boolean
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- maxProperties: 1
- minProperties: 1
- properties:
- containerAuth:
- description: IBM Container-based auth with IAM Trusted Profile.
- properties:
- iamEndpoint:
- type: string
- profile:
- description: the IBM Trusted Profile
- type: string
- tokenLocation:
- description: Location the token is mounted on the pod
- type: string
- required:
- - profile
- type: object
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- infisical:
- description: Infisical configures this store to sync secrets using the Infisical provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Infisical API
- properties:
- universalAuthCredentials:
- properties:
- clientId:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecret
- type: object
- type: object
- hostAPI:
- default: https://app.infisical.com/api
- type: string
- secretsScope:
- properties:
- environmentSlug:
- type: string
- projectSlug:
- type: string
- secretsPath:
- default: /
- type: string
- required:
- - environmentSlug
- - projectSlug
- type: object
- required:
- - auth
- - secretsScope
- type: object
- keepersecurity:
- description: KeeperSecurity configures this store to sync secrets using the KeeperSecurity provider
- properties:
- authRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- folderID:
- type: string
- required:
- - authRef
- - folderID
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- authRef:
- description: A reference to a secret that contains the auth information.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- type: object
- onboardbase:
- description: Onboardbase configures this store to sync secrets using the Onboardbase provider
- properties:
- apiHost:
- default: https://public.onboardbase.com/api/v1/
- description: APIHost use this to configure the host url for the API for selfhosted installation, default is https://public.onboardbase.com/api/v1/
- type: string
- auth:
- description: Auth configures how the Operator authenticates with the Onboardbase API
- properties:
- apiKeyRef:
- description: |-
- OnboardbaseAPIKey is the APIKey generated by an admin account.
- It is used to recognize and authorize access to a project and environment within onboardbase
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- passcodeRef:
- description: OnboardbasePasscode is the passcode attached to the API Key
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - apiKeyRef
- - passcodeRef
- type: object
- environment:
- default: development
- description: Environment is the name of an environmnent within a project to pull the secrets from
- type: string
- project:
- default: development
- description: Project is an onboardbase project that the secrets should be pulled from
- type: string
- required:
- - apiHost
- - auth
- - environment
- - project
- type: object
- onepassword:
- description: OnePassword configures this store to sync secrets using the 1Password Cloud provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against OnePassword Connect Server
- properties:
- secretRef:
- description: OnePasswordAuthSecretRef holds secret references for 1Password credentials.
- properties:
- connectTokenSecretRef:
- description: The ConnectToken is used for authentication to a 1Password Connect Server.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - connectTokenSecretRef
- type: object
- required:
- - secretRef
- type: object
- connectHost:
- description: ConnectHost defines the OnePassword Connect Server to connect to
- type: string
- vaults:
- additionalProperties:
- type: integer
- description: Vaults defines which OnePassword vaults to search in which order
- type: object
- required:
- - auth
- - connectHost
- - vaults
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, use the instance principal, otherwise the user credentials specified in Auth.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passbolt:
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against Passbolt Server
- properties:
- passwordSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privateKeySecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - passwordSecretRef
- - privateKeySecretRef
- type: object
- host:
- description: Host defines the Passbolt Server to connect to
- type: string
- required:
- - auth
- - host
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- pulumi:
- description: Pulumi configures this store to sync secrets using the Pulumi provider
- properties:
- accessToken:
- description: AccessToken is the access tokens to sign in to the Pulumi Cloud Console.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the Pulumi API token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- default: https://api.pulumi.com/api/preview
- description: APIURL is the URL of the Pulumi API.
- type: string
- environment:
- description: |-
- Environment are YAML documents composed of static key-value pairs, programmatic expressions,
- dynamically retrieved values from supported providers including all major clouds,
- and other Pulumi ESC environments.
- To create a new environment, visit https://www.pulumi.com/docs/esc/environments/ for more information.
- type: string
- organization:
- description: |-
- Organization are a space to collaborate on shared projects and stacks.
- To create a new organization, visit https://app.pulumi.com/ and click "New Organization".
- type: string
- required:
- - accessToken
- - environment
- - organization
- type: object
- scaleway:
- description: Scaleway
- properties:
- accessKey:
- description: AccessKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- apiUrl:
- description: APIURL is the url of the api to use. Defaults to https://api.scaleway.com
- type: string
- projectId:
- description: 'ProjectID is the id of your project, which you can find in the console: https://console.scaleway.com/project/settings'
- type: string
- region:
- description: 'Region where your secrets are located: https://developers.scaleway.com/en/quickstart/#region-and-zone'
- type: string
- secretKey:
- description: SecretKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - accessKey
- - projectId
- - region
- - secretKey
- type: object
- secretserver:
- description: |-
- SecretServer configures this store to sync secrets using SecretServer provider
- https://docs.delinea.com/online-help/secret-server/start.htm
- properties:
- password:
- description: Password is the secret server account password.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- serverURL:
- description: |-
- ServerURL
- URL to your secret server installation
- type: string
- username:
- description: Username is the secret server account username.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - password
- - serverURL
- - username
- type: object
- senhasegura:
- description: Senhasegura configures this store to sync secrets using senhasegura provider
- properties:
- auth:
- description: Auth defines parameters to authenticate in senhasegura
- properties:
- clientId:
- type: string
- clientSecretSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecretSecretRef
- type: object
- ignoreSslCertificate:
- default: false
- description: IgnoreSslCertificate defines if SSL certificate must be ignored
- type: boolean
- module:
- description: Module defines which senhasegura module should be used to get secrets
- type: string
- url:
- description: URL of senhasegura
- type: string
- required:
- - auth
- - module
- - url
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexcertificatemanager:
- description: YandexCertificateManager configures this store to sync secrets using Yandex Certificate Manager provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Certificate Manager
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- refreshInterval:
- description: Used to configure store refresh interval in seconds. Empty or 0 will default to the controller config.
- type: integer
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- capabilities:
- description: SecretStoreCapabilities defines the possible operations a SecretStore can do.
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/vaultdynamicsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: vaultdynamicsecrets.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - vaultdynamicsecret
- kind: VaultDynamicSecret
- listKind: VaultDynamicSecretList
- plural: vaultdynamicsecrets
- shortNames:
- - vaultdynamicsecret
- singular: vaultdynamicsecret
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- 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:
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters VDS based on this property
- type: string
- method:
- description: Vault API method to use (GET/POST/other)
- type: string
- parameters:
- description: Parameters to pass to Vault write (for non-GET methods)
- x-kubernetes-preserve-unknown-fields: true
- path:
- description: Vault path to obtain the dynamic secret from
- type: string
- provider:
- description: Vault provider common spec
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- resultType:
- default: Data
- description: |-
- Result type defines which data is returned from the generator.
- By default it is the "data" section of the Vault API response.
- When using e.g. /auth/token/create the "data" section is empty but
- the "auth" section contains the generated token.
- Please refer to the vault docs regarding the result data structure.
- enum:
- - Data
- - Auth
- type: string
- required:
- - path
- - provider
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/webhook.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: webhooks.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - webhook
- kind: Webhook
- listKind: WebhookList
- plural: webhooks
- shortNames:
- - webhookl
- singular: webhook
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Webhook connects to a third party API server to handle the secrets generation
- configuration parameters in spec.
- You can specify the server, the token, and additional body parameters.
- See documentation for the full API specification for requests and responses.
- 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: WebhookSpec controls the behavior of the external generator. Any body parameters should be passed to the server through the parameters field.
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: The key where the token is found.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-cert-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "apiextensions.k8s.io"
- resources:
- - "customresourcedefinitions"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - "admissionregistration.k8s.io"
- resources:
- - "validatingwebhookconfigurations"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "endpoints"
- verbs:
- - "list"
- - "get"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "events"
- verbs:
- - "create"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "secrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - "coordination.k8s.io"
- resources:
- - "leases"
- verbs:
- - "get"
- - "create"
- - "update"
- - "patch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "secretstores"
- - "clustersecretstores"
- - "externalsecrets"
- - "clusterexternalsecrets"
- - "pushsecrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "externalsecrets/status"
- - "externalsecrets/finalizers"
- - "secretstores"
- - "secretstores/status"
- - "secretstores/finalizers"
- - "clustersecretstores"
- - "clustersecretstores/status"
- - "clustersecretstores/finalizers"
- - "clusterexternalsecrets"
- - "clusterexternalsecrets/status"
- - "clusterexternalsecrets/finalizers"
- - "pushsecrets"
- - "pushsecrets/status"
- - "pushsecrets/finalizers"
- verbs:
- - "get"
- - "update"
- - "patch"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "serviceaccounts"
- - "namespaces"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "secrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "create"
- - "update"
- - "delete"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "serviceaccounts/token"
- verbs:
- - "create"
- - apiGroups:
- - ""
- resources:
- - "events"
- verbs:
- - "create"
- - "patch"
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- verbs:
- - "create"
- - "update"
- - "delete"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-view
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- rbac.authorization.k8s.io/aggregate-to-view: "true"
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "secretstores"
- - "clustersecretstores"
- - "pushsecrets"
- verbs:
- - "get"
- - "watch"
- - "list"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "get"
- - "watch"
- - "list"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-edit
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "secretstores"
- - "clustersecretstores"
- - "pushsecrets"
- verbs:
- - "create"
- - "delete"
- - "deletecollection"
- - "patch"
- - "update"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "create"
- - "delete"
- - "deletecollection"
- - "patch"
- - "update"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-servicebindings
- labels:
- servicebinding.io/controller: "true"
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- verbs:
- - "get"
- - "list"
- - "watch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-golang-external-secrets-cert-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: common-golang-external-secrets-cert-controller
-subjects:
- - name: external-secrets-cert-controller
- namespace: default
- kind: ServiceAccount
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-golang-external-secrets-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: common-golang-external-secrets-controller
-subjects:
- - name: common-golang-external-secrets
- namespace: default
- kind: ServiceAccount
----
-# Source: golang-external-secrets/templates/golang-external-secrets-hub-clusterrolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: role-tokenreview-binding
- namespace: default
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: golang-external-secrets
- namespace: golang-external-secrets
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: common-golang-external-secrets-leaderelection
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- resourceNames:
- - "external-secrets-controller"
- verbs:
- - "get"
- - "update"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- verbs:
- - "create"
- - apiGroups:
- - "coordination.k8s.io"
- resources:
- - "leases"
- verbs:
- - "get"
- - "create"
- - "update"
- - "patch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: common-golang-external-secrets-leaderelection
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: common-golang-external-secrets-leaderelection
-subjects:
- - kind: ServiceAccount
- name: common-golang-external-secrets
- namespace: default
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- external-secrets.io/component: webhook
-spec:
- type: ClusterIP
- ports:
- - port: 443
- targetPort: 10250
- protocol: TCP
- name: webhook
- selector:
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets-cert-controller
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- serviceAccountName: external-secrets-cert-controller
- automountServiceAccountToken: true
- hostNetwork: false
- containers:
- - name: cert-controller
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - certcontroller
- - --crd-requeue-interval=5m
- - --service-name=common-golang-external-secrets-webhook
- - --service-namespace=default
- - --secret-name=common-golang-external-secrets-webhook
- - --secret-namespace=default
- - --metrics-addr=:8080
- - --healthz-addr=:8081
- - --loglevel=info
- - --zap-time-encoding=epoch
- - --enable-partial-cache=true
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- readinessProbe:
- httpGet:
- port: 8081
- path: /readyz
- initialDelaySeconds: 20
- periodSeconds: 5
----
-# Source: golang-external-secrets/charts/external-secrets/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- serviceAccountName: common-golang-external-secrets
- automountServiceAccountToken: true
- hostNetwork: false
- containers:
- - name: external-secrets
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - --concurrent=1
- - --metrics-addr=:8080
- - --loglevel=info
- - --zap-time-encoding=epoch
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- dnsPolicy: ClusterFirst
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- hostNetwork: false
- serviceAccountName: external-secrets-webhook
- automountServiceAccountToken: true
- containers:
- - name: webhook
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - webhook
- - --port=10250
- - --dns-name=common-golang-external-secrets-webhook.default.svc
- - --cert-dir=/tmp/certs
- - --check-interval=5m
- - --metrics-addr=:8080
- - --healthz-addr=:8081
- - --loglevel=info
- - --zap-time-encoding=epoch
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- - containerPort: 10250
- protocol: TCP
- name: webhook
- readinessProbe:
- httpGet:
- port: 8081
- path: /readyz
- initialDelaySeconds: 20
- periodSeconds: 5
- volumeMounts:
- - name: certs
- mountPath: /tmp/certs
- readOnly: true
- volumes:
- - name: certs
- secret:
- secretName: common-golang-external-secrets-webhook
----
-# Source: golang-external-secrets/templates/vault/golang-external-secrets-hub-secretstore.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ClusterSecretStore
-metadata:
- name: vault-backend
- namespace: golang-external-secrets
-spec:
- provider:
- vault:
- server: https://vault-vault.apps.hub.example.com
- path: secret
- # Version of KV backend
- version: v2
-
- caProvider:
- type: ConfigMap
- name: kube-root-ca.crt
- key: ca.crt
- namespace: golang-external-secrets
-
- auth:
- kubernetes:
-
- mountPath: hub
- role: hub-role
-
- secretRef:
- name: golang-external-secrets
- namespace: golang-external-secrets
- key: "token"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/validatingwebhook.yaml
-apiVersion: admissionregistration.k8s.io/v1
-kind: ValidatingWebhookConfiguration
-metadata:
- name: secretstore-validate
- labels:
- external-secrets.io/component: webhook
-webhooks:
-- name: "validate.secretstore.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["secretstores"]
- scope: "Namespaced"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-secretstore
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
-
-- name: "validate.clustersecretstore.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["clustersecretstores"]
- scope: "Cluster"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-clustersecretstore
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
----
-# Source: golang-external-secrets/charts/external-secrets/templates/validatingwebhook.yaml
-apiVersion: admissionregistration.k8s.io/v1
-kind: ValidatingWebhookConfiguration
-metadata:
- name: externalsecret-validate
- labels:
- external-secrets.io/component: webhook
-webhooks:
-- name: "validate.externalsecret.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["externalsecrets"]
- scope: "Namespaced"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-externalsecret
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
- failurePolicy: Fail
diff --git a/tests/common-golang-external-secrets-naked.expected.yaml b/tests/common-golang-external-secrets-naked.expected.yaml
deleted file mode 100644
index 3d12586b..00000000
--- a/tests/common-golang-external-secrets-naked.expected.yaml
+++ /dev/null
@@ -1,13143 +0,0 @@
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: external-secrets-cert-controller
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: common-golang-external-secrets
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- external-secrets.io/component: webhook
----
-# Source: golang-external-secrets/templates/golang-external-secrets-hub-clusterrolebinding.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: golang-external-secrets
- namespace: golang-external-secrets
- annotations:
- kubernetes.io/service-account.name: golang-external-secrets
-type: kubernetes.io/service-account-token
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/acraccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: acraccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - acraccesstoken
- kind: ACRAccessToken
- listKind: ACRAccessTokenList
- plural: acraccesstokens
- shortNames:
- - acraccesstoken
- singular: acraccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- ACRAccessToken returns a Azure Container Registry token
- that can be used for pushing/pulling images.
- Note: by default it will return an ACR Refresh Token with full access
- (depending on the identity).
- This can be scoped down to the repository level using .spec.scope.
- In case scope is defined it will return an ACR Access Token.
-
-
- See docs: https://github.com/Azure/acr/blob/main/docs/AAD-OAuth.md
- 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: |-
- ACRAccessTokenSpec defines how to generate the access token
- e.g. how to authenticate and which registry to use.
- see: https://github.com/Azure/acr/blob/main/docs/AAD-OAuth.md#overview
- properties:
- auth:
- properties:
- managedIdentity:
- description: ManagedIdentity uses Azure Managed Identity to authenticate with Azure.
- properties:
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- type: object
- servicePrincipal:
- description: ServicePrincipal uses Azure Service Principal credentials to authenticate with Azure.
- properties:
- secretRef:
- description: |-
- Configuration used to authenticate with Azure using static
- credentials stored in a Kind=Secret.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- workloadIdentity:
- description: WorkloadIdentity uses Azure Workload Identity to authenticate with Azure.
- properties:
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- registry:
- description: |-
- the domain name of the ACR registry
- e.g. foobarexample.azurecr.io
- type: string
- scope:
- description: |-
- Define the scope for the access token, e.g. pull/push access for a repository.
- if not provided it will return a refresh token that has full scope.
- Note: you need to pin it down to the repository level, there is no wildcard available.
-
-
- examples:
- repository:my-repository:pull,push
- repository:my-repository:pull
-
-
- see docs for details: https://docs.docker.com/registry/spec/auth/scope/
- type: string
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- required:
- - auth
- - registry
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/clusterexternalsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: clusterexternalsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ClusterExternalSecret
- listKind: ClusterExternalSecretList
- plural: clusterexternalsecrets
- shortNames:
- - ces
- singular: clusterexternalsecret
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - jsonPath: .spec.externalSecretSpec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshTime
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ClusterExternalSecret is the Schema for the clusterexternalsecrets 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: ClusterExternalSecretSpec defines the desired state of ClusterExternalSecret.
- properties:
- externalSecretMetadata:
- description: The metadata of the external secrets to be created
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- externalSecretName:
- description: The name of the external secrets to be created defaults to the name of the ClusterExternalSecret
- type: string
- externalSecretSpec:
- description: The spec for the ExternalSecrets to be created
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: |-
- RemoteRef points to the remote secret and defines
- which secret (version/property/..) to fetch.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- description: |-
- SecretKey defines the key in which the controller stores
- the value. This is the key in the Kind=Secret
- type: string
- sourceRef:
- description: |-
- SourceRef allows you to override the source
- from which the value will pulled from.
- maxProperties: 1
- properties:
- generatorRef:
- description: |-
- GeneratorRef points to a generator custom resource.
-
-
- Deprecated: The generatorRef is not implemented in .data[].
- this will be removed with v1.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- properties:
- extract:
- description: |-
- Used to extract multiple key/value pairs from one secret
- Note: Extract does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- find:
- description: |-
- Used to find secrets based on tags or regular expressions
- Note: Find does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- name:
- description: Finds secrets based on the name.
- properties:
- regexp:
- description: Finds secrets base
- type: string
- type: object
- path:
- description: A root path to start the find operations.
- type: string
- tags:
- additionalProperties:
- type: string
- description: Find secrets based on tags.
- type: object
- type: object
- rewrite:
- description: |-
- Used to rewrite secret Keys after getting them from the secret Provider
- Multiple Rewrite operations can be provided. They are applied in a layered order (first to last)
- items:
- properties:
- regexp:
- description: |-
- Used to rewrite with regular expressions.
- The resulting key will be the output of a regexp.ReplaceAll operation.
- properties:
- source:
- description: Used to define the regular expression of a re.Compiler.
- type: string
- target:
- description: Used to define the target pattern of a ReplaceAll operation.
- type: string
- required:
- - source
- - target
- type: object
- transform:
- description: |-
- Used to apply string transformation on the secrets.
- The resulting key will be the output of the template applied by the operation.
- properties:
- template:
- description: |-
- Used to define the template to apply on the secret name.
- `.value ` will specify the secret name in the template.
- type: string
- required:
- - template
- type: object
- type: object
- type: array
- sourceRef:
- description: |-
- SourceRef points to a store or generator
- which contains secret values ready to use.
- Use this in combination with Extract or Find pull values out of
- a specific SecretStore.
- When sourceRef points to a generator Extract or Find is not supported.
- The generator returns a static map of values
- maxProperties: 1
- properties:
- generatorRef:
- description: GeneratorRef points to a generator custom resource.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- default:
- creationPolicy: Owner
- deletionPolicy: Retain
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Orphan
- - Merge
- - None
- type: string
- deletionPolicy:
- default: Retain
- description: |-
- DeletionPolicy defines rules on how to delete the resulting Secret
- Defaults to 'Retain'
- enum:
- - Delete
- - Merge
- - Retain
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- type: object
- namespaceSelector:
- description: |-
- The labels to select by to find the Namespaces to create the ExternalSecrets in.
- Deprecated: Use NamespaceSelectors instead.
- 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
- namespaceSelectors:
- description: A list of labels to select by to find the Namespaces to create the ExternalSecrets in. The selectors are ORed.
- items:
- description: |-
- A label selector is a label query over a set of resources. The result of matchLabels and
- matchExpressions are ANDed. An empty label selector matches all objects. A null
- label selector matches no objects.
- 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
- type: array
- namespaces:
- description: Choose namespaces by name. This field is ORed with anything that NamespaceSelectors ends up choosing.
- items:
- type: string
- type: array
- refreshTime:
- description: The time in which the controller should reconcile its objects and recheck namespaces for labels.
- type: string
- required:
- - externalSecretSpec
- type: object
- status:
- description: ClusterExternalSecretStatus defines the observed state of ClusterExternalSecret.
- properties:
- conditions:
- items:
- properties:
- message:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- externalSecretName:
- description: ExternalSecretName is the name of the ExternalSecrets created by the ClusterExternalSecret
- type: string
- failedNamespaces:
- description: Failed namespaces are the namespaces that failed to apply an ExternalSecret
- items:
- description: ClusterExternalSecretNamespaceFailure represents a failed namespace deployment and it's reason.
- properties:
- namespace:
- description: Namespace is the namespace that failed when trying to apply an ExternalSecret
- type: string
- reason:
- description: Reason is why the ExternalSecret failed to apply to the namespace
- type: string
- required:
- - namespace
- type: object
- type: array
- provisionedNamespaces:
- description: ProvisionedNamespaces are the namespaces where the ClusterExternalSecret has secrets
- items:
- type: string
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/clustersecretstore.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: clustersecretstores.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ClusterSecretStore
- listKind: ClusterSecretStoreList
- plural: clustersecretstores
- shortNames:
- - css
- singular: clustersecretstore
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: ClusterSecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the SecretManager provider will assume
- type: string
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- properties:
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- serviceAccount:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- required:
- - auth
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, instance principal is used. Optionally, the authenticating principal type
- and/or user data may be supplied for the use of workload identity and user principal.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - roleId
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.capabilities
- name: Capabilities
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ClusterSecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- conditions:
- description: Used to constraint a ClusterSecretStore to specific namespaces. Relevant only to ClusterSecretStore
- items:
- description: |-
- ClusterSecretStoreCondition describes a condition by which to choose namespaces to process ExternalSecrets in
- for a ClusterSecretStore instance.
- properties:
- namespaceRegexes:
- description: Choose namespaces by using regex matching
- items:
- type: string
- type: array
- namespaceSelector:
- description: Choose namespace using a labelSelector
- 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
- namespaces:
- description: Choose namespaces by name
- items:
- type: string
- type: array
- type: object
- type: array
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- additionalRoles:
- description: AdditionalRoles is a chained list of Role ARNs which the provider will sequentially assume before assuming the Role
- items:
- type: string
- type: array
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- prefix:
- description: Prefix adds a prefix to all retrieved values.
- type: string
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the provider will assume
- type: string
- secretsManager:
- description: SecretsManager defines how the provider behaves when interacting with AWS SecretsManager
- properties:
- forceDeleteWithoutRecovery:
- description: |-
- Specifies whether to delete the secret without any recovery window. You
- can't use both this parameter and RecoveryWindowInDays in the same call.
- If you don't use either, then by default Secrets Manager uses a 30 day
- recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-ForceDeleteWithoutRecovery
- type: boolean
- recoveryWindowInDays:
- description: |-
- The number of days from 7 to 30 that Secrets Manager waits before
- permanently deleting the secret. You can't use both this parameter and
- ForceDeleteWithoutRecovery in the same call. If you don't use either,
- then by default Secrets Manager uses a 30 day recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-RecoveryWindowInDays
- format: int64
- type: integer
- type: object
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- sessionTags:
- description: AWS STS assume role session tags
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- transitiveTagKeys:
- description: AWS STS assume role transitive session tags. Required when multiple rules are used with the provider
- items:
- type: string
- type: array
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- properties:
- clientCertificate:
- description: The Azure ClientCertificate of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientId:
- description: The Azure clientId of the service principle or managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- tenantId:
- description: The Azure tenantId of the managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- bitwardensecretsmanager:
- description: BitwardenSecretsManager configures this store to sync secrets using BitwardenSecretsManager provider
- properties:
- apiURL:
- type: string
- auth:
- description: |-
- Auth configures how secret-manager authenticates with a bitwarden machine account instance.
- Make sure that the token being used has permissions on the given secret.
- properties:
- secretRef:
- description: BitwardenSecretsManagerSecretRef contains the credential ref to the bitwarden instance.
- properties:
- credentials:
- description: AccessToken used for the bitwarden instance.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - credentials
- type: object
- required:
- - secretRef
- type: object
- bitwardenServerSDKURL:
- type: string
- caBundle:
- description: |-
- Base64 encoded certificate for the bitwarden server sdk. The sdk MUST run with HTTPS to make sure no MITM attack
- can be performed.
- type: string
- identityURL:
- type: string
- organizationID:
- description: OrganizationID determines which organization this secret store manages.
- type: string
- projectID:
- description: ProjectID determines which project this secret store manages.
- type: string
- required:
- - auth
- - caBundle
- - organizationID
- - projectID
- type: object
- chef:
- description: Chef configures this store to sync secrets with chef server
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against chef Server
- properties:
- secretRef:
- description: ChefAuthSecretRef holds secret references for chef server login credentials.
- properties:
- privateKeySecretRef:
- description: SecretKey is the Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - privateKeySecretRef
- type: object
- required:
- - secretRef
- type: object
- serverUrl:
- description: ServerURL is the chef server URL used to connect to. If using orgs you should include your org in the url and terminate the url with a "/"
- type: string
- username:
- description: UserName should be the user ID on the chef server
- type: string
- required:
- - auth
- - serverUrl
- - username
- type: object
- conjur:
- description: Conjur configures this store to sync secrets using conjur provider
- properties:
- auth:
- properties:
- apikey:
- properties:
- account:
- type: string
- apiKeyRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - account
- - apiKeyRef
- - userRef
- type: object
- jwt:
- properties:
- account:
- type: string
- hostId:
- description: |-
- Optional HostID for JWT authentication. This may be used depending
- on how the Conjur JWT authenticator policy is configured.
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Conjur using the JWT authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional ServiceAccountRef specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- serviceID:
- description: The conjur authn jwt webservice id
- type: string
- required:
- - account
- - serviceID
- type: object
- type: object
- caBundle:
- type: string
- caProvider:
- description: |-
- Used to provide custom certificate authority (CA) certificates
- for a secret store. The CAProvider points to a Secret or ConfigMap resource
- that contains a PEM-encoded certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- type: string
- required:
- - auth
- - url
- type: object
- delinea:
- description: |-
- Delinea DevOps Secrets Vault
- https://docs.delinea.com/online-help/products/devops-secrets-vault/current
- properties:
- clientId:
- description: ClientID is the non-secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- clientSecret:
- description: ClientSecret is the secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- tenant:
- description: Tenant is the chosen hostname / site name.
- type: string
- tld:
- description: |-
- TLD is based on the server location that was chosen during provisioning.
- If unset, defaults to "com".
- type: string
- urlTemplate:
- description: |-
- URLTemplate
- If unset, defaults to "https://%s.secretsvaultcloud.%s/v1/%s%s".
- type: string
- required:
- - clientId
- - clientSecret
- - tenant
- type: object
- device42:
- description: Device42 configures this store to sync secrets using the Device42 provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Device42 instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- host:
- description: URL configures the Device42 instance URL.
- type: string
- required:
- - auth
- - host
- type: object
- doppler:
- description: Doppler configures this store to sync secrets using the Doppler provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Doppler API
- properties:
- secretRef:
- properties:
- dopplerToken:
- description: |-
- The DopplerToken is used for authentication.
- See https://docs.doppler.com/reference/api#authentication for auth token types.
- The Key attribute defaults to dopplerToken if not specified.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - dopplerToken
- type: object
- required:
- - secretRef
- type: object
- config:
- description: Doppler config (required if not using a Service Token)
- type: string
- format:
- description: Format enables the downloading of secrets as a file (string)
- enum:
- - json
- - dotnet-json
- - env
- - yaml
- - docker
- type: string
- nameTransformer:
- description: Environment variable compatible name transforms that change secret names to a different format
- enum:
- - upper-camel
- - camel
- - lower-snake
- - tf-var
- - dotnet-env
- - lower-kebab
- type: string
- project:
- description: Doppler project (required if not using a Service Token)
- type: string
- required:
- - auth
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- description: 'Deprecated: ValueMap is deprecated and is intended to be removed in the future, use the `value` field instead.'
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- fortanix:
- description: Fortanix configures this store to sync secrets using the Fortanix provider
- properties:
- apiKey:
- description: APIKey is the API token to access SDKMS Applications.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the SDKMS API Key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- description: APIURL is the URL of SDKMS API. Defaults to `sdkms.fortanix.com`.
- type: string
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- location:
- description: Location optionally defines a location for a secret
- type: string
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- environment:
- description: Environment environment_scope of gitlab CI/CD variables (Please see https://docs.gitlab.com/ee/ci/environments/#create-a-static-environment on how to create environments)
- type: string
- groupIDs:
- description: GroupIDs specify, which gitlab groups to pull secrets from. Group secrets are read from left to right followed by the project variables.
- items:
- type: string
- type: array
- inheritFromGroups:
- description: InheritFromGroups specifies whether parent groups should be discovered and checked for secrets.
- type: boolean
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- maxProperties: 1
- minProperties: 1
- properties:
- containerAuth:
- description: IBM Container-based auth with IAM Trusted Profile.
- properties:
- iamEndpoint:
- type: string
- profile:
- description: the IBM Trusted Profile
- type: string
- tokenLocation:
- description: Location the token is mounted on the pod
- type: string
- required:
- - profile
- type: object
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- infisical:
- description: Infisical configures this store to sync secrets using the Infisical provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Infisical API
- properties:
- universalAuthCredentials:
- properties:
- clientId:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecret
- type: object
- type: object
- hostAPI:
- default: https://app.infisical.com/api
- type: string
- secretsScope:
- properties:
- environmentSlug:
- type: string
- projectSlug:
- type: string
- secretsPath:
- default: /
- type: string
- required:
- - environmentSlug
- - projectSlug
- type: object
- required:
- - auth
- - secretsScope
- type: object
- keepersecurity:
- description: KeeperSecurity configures this store to sync secrets using the KeeperSecurity provider
- properties:
- authRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- folderID:
- type: string
- required:
- - authRef
- - folderID
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- authRef:
- description: A reference to a secret that contains the auth information.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- type: object
- onboardbase:
- description: Onboardbase configures this store to sync secrets using the Onboardbase provider
- properties:
- apiHost:
- default: https://public.onboardbase.com/api/v1/
- description: APIHost use this to configure the host url for the API for selfhosted installation, default is https://public.onboardbase.com/api/v1/
- type: string
- auth:
- description: Auth configures how the Operator authenticates with the Onboardbase API
- properties:
- apiKeyRef:
- description: |-
- OnboardbaseAPIKey is the APIKey generated by an admin account.
- It is used to recognize and authorize access to a project and environment within onboardbase
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- passcodeRef:
- description: OnboardbasePasscode is the passcode attached to the API Key
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - apiKeyRef
- - passcodeRef
- type: object
- environment:
- default: development
- description: Environment is the name of an environmnent within a project to pull the secrets from
- type: string
- project:
- default: development
- description: Project is an onboardbase project that the secrets should be pulled from
- type: string
- required:
- - apiHost
- - auth
- - environment
- - project
- type: object
- onepassword:
- description: OnePassword configures this store to sync secrets using the 1Password Cloud provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against OnePassword Connect Server
- properties:
- secretRef:
- description: OnePasswordAuthSecretRef holds secret references for 1Password credentials.
- properties:
- connectTokenSecretRef:
- description: The ConnectToken is used for authentication to a 1Password Connect Server.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - connectTokenSecretRef
- type: object
- required:
- - secretRef
- type: object
- connectHost:
- description: ConnectHost defines the OnePassword Connect Server to connect to
- type: string
- vaults:
- additionalProperties:
- type: integer
- description: Vaults defines which OnePassword vaults to search in which order
- type: object
- required:
- - auth
- - connectHost
- - vaults
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, use the instance principal, otherwise the user credentials specified in Auth.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passbolt:
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against Passbolt Server
- properties:
- passwordSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privateKeySecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - passwordSecretRef
- - privateKeySecretRef
- type: object
- host:
- description: Host defines the Passbolt Server to connect to
- type: string
- required:
- - auth
- - host
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- pulumi:
- description: Pulumi configures this store to sync secrets using the Pulumi provider
- properties:
- accessToken:
- description: AccessToken is the access tokens to sign in to the Pulumi Cloud Console.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the Pulumi API token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- default: https://api.pulumi.com/api/preview
- description: APIURL is the URL of the Pulumi API.
- type: string
- environment:
- description: |-
- Environment are YAML documents composed of static key-value pairs, programmatic expressions,
- dynamically retrieved values from supported providers including all major clouds,
- and other Pulumi ESC environments.
- To create a new environment, visit https://www.pulumi.com/docs/esc/environments/ for more information.
- type: string
- organization:
- description: |-
- Organization are a space to collaborate on shared projects and stacks.
- To create a new organization, visit https://app.pulumi.com/ and click "New Organization".
- type: string
- required:
- - accessToken
- - environment
- - organization
- type: object
- scaleway:
- description: Scaleway
- properties:
- accessKey:
- description: AccessKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- apiUrl:
- description: APIURL is the url of the api to use. Defaults to https://api.scaleway.com
- type: string
- projectId:
- description: 'ProjectID is the id of your project, which you can find in the console: https://console.scaleway.com/project/settings'
- type: string
- region:
- description: 'Region where your secrets are located: https://developers.scaleway.com/en/quickstart/#region-and-zone'
- type: string
- secretKey:
- description: SecretKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - accessKey
- - projectId
- - region
- - secretKey
- type: object
- secretserver:
- description: |-
- SecretServer configures this store to sync secrets using SecretServer provider
- https://docs.delinea.com/online-help/secret-server/start.htm
- properties:
- password:
- description: Password is the secret server account password.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- serverURL:
- description: |-
- ServerURL
- URL to your secret server installation
- type: string
- username:
- description: Username is the secret server account username.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - password
- - serverURL
- - username
- type: object
- senhasegura:
- description: Senhasegura configures this store to sync secrets using senhasegura provider
- properties:
- auth:
- description: Auth defines parameters to authenticate in senhasegura
- properties:
- clientId:
- type: string
- clientSecretSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecretSecretRef
- type: object
- ignoreSslCertificate:
- default: false
- description: IgnoreSslCertificate defines if SSL certificate must be ignored
- type: boolean
- module:
- description: Module defines which senhasegura module should be used to get secrets
- type: string
- url:
- description: URL of senhasegura
- type: string
- required:
- - auth
- - module
- - url
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexcertificatemanager:
- description: YandexCertificateManager configures this store to sync secrets using Yandex Certificate Manager provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Certificate Manager
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- refreshInterval:
- description: Used to configure store refresh interval in seconds. Empty or 0 will default to the controller config.
- type: integer
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- capabilities:
- description: SecretStoreCapabilities defines the possible operations a SecretStore can do.
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/ecrauthorizationtoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: ecrauthorizationtokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - ecrauthorizationtoken
- kind: ECRAuthorizationToken
- listKind: ECRAuthorizationTokenList
- plural: ecrauthorizationtokens
- shortNames:
- - ecrauthorizationtoken
- singular: ecrauthorizationtoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- ECRAuthorizationTokenSpec uses the GetAuthorizationToken API to retrieve an
- authorization token.
- The authorization token is valid for 12 hours.
- The authorizationToken returned is a base64 encoded string that can be decoded
- and used in a docker login command to authenticate to a registry.
- For more information, see Registry authentication (https://docs.aws.amazon.com/AmazonECR/latest/userguide/Registries.html#registry_auth) in the Amazon Elastic Container Registry User Guide.
- 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:
- properties:
- auth:
- description: Auth defines how to authenticate with AWS
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: Region specifies the region to operate in.
- type: string
- role:
- description: |-
- You can assume a role before making calls to the
- desired AWS service.
- type: string
- required:
- - region
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/externalsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: externalsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ExternalSecret
- listKind: ExternalSecretList
- plural: externalsecrets
- shortNames:
- - es
- singular: externalsecret
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .spec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshInterval
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: ExternalSecret is the Schema for the external-secrets 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: ExternalSecretSpec defines the desired state of ExternalSecret.
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: ExternalSecretDataRemoteRef defines Provider data location.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- type: string
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- description: ExternalSecretDataRemoteRef defines Provider data location.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Merge
- - None
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v1
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- maxProperties: 1
- minProperties: 1
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- required:
- - secretStoreRef
- - target
- type: object
- status:
- properties:
- binding:
- description: Binding represents a servicebinding.io Provisioned Service reference to the secret
- properties:
- name:
- default: ""
- description: |-
- Name of the referent.
- This field is effectively required, but due to backwards compatibility is
- allowed to be empty. Instances of this type with an empty value here are
- almost certainly wrong.
- TODO: Add other useful fields. apiVersion, kind, uid?
- More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
- TODO: Drop `kubebuilder:default` when controller-gen doesn't need it https://github.com/kubernetes-sigs/kubebuilder/issues/3896.
- type: string
- type: object
- x-kubernetes-map-type: atomic
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version
- type: string
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .spec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshInterval
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ExternalSecret is the Schema for the external-secrets 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: ExternalSecretSpec defines the desired state of ExternalSecret.
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: |-
- RemoteRef points to the remote secret and defines
- which secret (version/property/..) to fetch.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- description: |-
- SecretKey defines the key in which the controller stores
- the value. This is the key in the Kind=Secret
- type: string
- sourceRef:
- description: |-
- SourceRef allows you to override the source
- from which the value will pulled from.
- maxProperties: 1
- properties:
- generatorRef:
- description: |-
- GeneratorRef points to a generator custom resource.
-
-
- Deprecated: The generatorRef is not implemented in .data[].
- this will be removed with v1.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- properties:
- extract:
- description: |-
- Used to extract multiple key/value pairs from one secret
- Note: Extract does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- find:
- description: |-
- Used to find secrets based on tags or regular expressions
- Note: Find does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- name:
- description: Finds secrets based on the name.
- properties:
- regexp:
- description: Finds secrets base
- type: string
- type: object
- path:
- description: A root path to start the find operations.
- type: string
- tags:
- additionalProperties:
- type: string
- description: Find secrets based on tags.
- type: object
- type: object
- rewrite:
- description: |-
- Used to rewrite secret Keys after getting them from the secret Provider
- Multiple Rewrite operations can be provided. They are applied in a layered order (first to last)
- items:
- properties:
- regexp:
- description: |-
- Used to rewrite with regular expressions.
- The resulting key will be the output of a regexp.ReplaceAll operation.
- properties:
- source:
- description: Used to define the regular expression of a re.Compiler.
- type: string
- target:
- description: Used to define the target pattern of a ReplaceAll operation.
- type: string
- required:
- - source
- - target
- type: object
- transform:
- description: |-
- Used to apply string transformation on the secrets.
- The resulting key will be the output of the template applied by the operation.
- properties:
- template:
- description: |-
- Used to define the template to apply on the secret name.
- `.value ` will specify the secret name in the template.
- type: string
- required:
- - template
- type: object
- type: object
- type: array
- sourceRef:
- description: |-
- SourceRef points to a store or generator
- which contains secret values ready to use.
- Use this in combination with Extract or Find pull values out of
- a specific SecretStore.
- When sourceRef points to a generator Extract or Find is not supported.
- The generator returns a static map of values
- maxProperties: 1
- properties:
- generatorRef:
- description: GeneratorRef points to a generator custom resource.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- default:
- creationPolicy: Owner
- deletionPolicy: Retain
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Orphan
- - Merge
- - None
- type: string
- deletionPolicy:
- default: Retain
- description: |-
- DeletionPolicy defines rules on how to delete the resulting Secret
- Defaults to 'Retain'
- enum:
- - Delete
- - Merge
- - Retain
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- type: object
- status:
- properties:
- binding:
- description: Binding represents a servicebinding.io Provisioned Service reference to the secret
- properties:
- name:
- default: ""
- description: |-
- Name of the referent.
- This field is effectively required, but due to backwards compatibility is
- allowed to be empty. Instances of this type with an empty value here are
- almost certainly wrong.
- TODO: Add other useful fields. apiVersion, kind, uid?
- More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
- TODO: Drop `kubebuilder:default` when controller-gen doesn't need it https://github.com/kubernetes-sigs/kubebuilder/issues/3896.
- type: string
- type: object
- x-kubernetes-map-type: atomic
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version
- type: string
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/fake.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: fakes.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - fake
- kind: Fake
- listKind: FakeList
- plural: fakes
- shortNames:
- - fake
- singular: fake
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Fake generator is used for testing. It lets you define
- a static set of credentials that is always returned.
- 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: FakeSpec contains the static data.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters VDS based on this property
- type: string
- data:
- additionalProperties:
- type: string
- description: |-
- Data defines the static data returned
- by this generator.
- type: object
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/gcraccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: gcraccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - gcraccesstoken
- kind: GCRAccessToken
- listKind: GCRAccessTokenList
- plural: gcraccesstokens
- shortNames:
- - gcraccesstoken
- singular: gcraccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- GCRAccessToken generates an GCP access token
- that can be used to authenticate with GCR.
- 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:
- properties:
- auth:
- description: Auth defines the means for authenticating with GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID defines which project to use to authenticate with
- type: string
- required:
- - auth
- - projectID
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/githubaccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: githubaccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - githubaccesstoken
- kind: GithubAccessToken
- listKind: GithubAccessTokenList
- plural: githubaccesstokens
- shortNames:
- - githubaccesstoken
- singular: githubaccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: GithubAccessToken generates ghs_ accessToken
- 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:
- properties:
- appID:
- type: string
- auth:
- description: Auth configures how ESO authenticates with a Github instance.
- properties:
- privateKey:
- properties:
- secretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - secretRef
- type: object
- required:
- - privateKey
- type: object
- installID:
- type: string
- url:
- description: URL configures the Github instance URL. Defaults to https://github.com/.
- type: string
- required:
- - appID
- - auth
- - installID
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/password.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: passwords.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - password
- kind: Password
- listKind: PasswordList
- plural: passwords
- shortNames:
- - password
- singular: password
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Password generates a random password based on the
- configuration parameters in spec.
- You can specify the length, characterset and other attributes.
- 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: PasswordSpec controls the behavior of the password generator.
- properties:
- allowRepeat:
- default: false
- description: set AllowRepeat to true to allow repeating characters.
- type: boolean
- digits:
- description: |-
- Digits specifies the number of digits in the generated
- password. If omitted it defaults to 25% of the length of the password
- type: integer
- length:
- default: 24
- description: |-
- Length of the password to be generated.
- Defaults to 24
- type: integer
- noUpper:
- default: false
- description: Set NoUpper to disable uppercase characters
- type: boolean
- symbolCharacters:
- description: |-
- SymbolCharacters specifies the special characters that should be used
- in the generated password.
- type: string
- symbols:
- description: |-
- Symbols specifies the number of symbol characters in the generated
- password. If omitted it defaults to 25% of the length of the password
- type: integer
- required:
- - allowRepeat
- - length
- - noUpper
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/pushsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- name: pushsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - pushsecrets
- kind: PushSecret
- listKind: PushSecretList
- plural: pushsecrets
- singular: pushsecret
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- name: v1alpha1
- schema:
- openAPIV3Schema:
- 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: PushSecretSpec configures the behavior of the PushSecret.
- properties:
- data:
- description: Secret Data that should be pushed to providers
- items:
- properties:
- conversionStrategy:
- default: None
- description: Used to define a conversion Strategy for the secret keys
- enum:
- - None
- - ReverseUnicode
- type: string
- match:
- description: Match a given Secret Key to be pushed to the provider.
- properties:
- remoteRef:
- description: Remote Refs to push to providers.
- properties:
- property:
- description: Name of the property in the resulting secret
- type: string
- remoteKey:
- description: Name of the resulting provider secret.
- type: string
- required:
- - remoteKey
- type: object
- secretKey:
- description: Secret Key to be pushed
- type: string
- required:
- - remoteRef
- type: object
- metadata:
- description: |-
- Metadata is metadata attached to the secret.
- The structure of metadata is provider specific, please look it up in the provider documentation.
- x-kubernetes-preserve-unknown-fields: true
- required:
- - match
- type: object
- type: array
- deletionPolicy:
- default: None
- description: 'Deletion Policy to handle Secrets in the provider. Possible Values: "Delete/None". Defaults to "None".'
- enum:
- - Delete
- - None
- type: string
- refreshInterval:
- description: The Interval to which External Secrets will try to push a secret definition
- type: string
- secretStoreRefs:
- items:
- properties:
- kind:
- default: SecretStore
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- labelSelector:
- description: Optionally, sync to secret stores with label selector
- 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
- name:
- description: Optionally, sync to the SecretStore of the given name
- type: string
- type: object
- type: array
- selector:
- description: The Secret Selector (k8s source) for the Push Secret
- properties:
- secret:
- description: Select a Secret to Push.
- properties:
- name:
- description: Name of the Secret. The Secret must exist in the same namespace as the PushSecret manifest.
- type: string
- required:
- - name
- type: object
- required:
- - secret
- type: object
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- updatePolicy:
- default: Replace
- description: 'UpdatePolicy to handle Secrets in the provider. Possible Values: "Replace/IfNotExists". Defaults to "Replace".'
- enum:
- - Replace
- - IfNotExists
- type: string
- required:
- - secretStoreRefs
- - selector
- type: object
- status:
- description: PushSecretStatus indicates the history of the status of PushSecret.
- properties:
- conditions:
- items:
- description: PushSecretStatusCondition indicates the status of the PushSecret.
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- description: PushSecretConditionType indicates the condition of the PushSecret.
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedPushSecrets:
- additionalProperties:
- additionalProperties:
- properties:
- conversionStrategy:
- default: None
- description: Used to define a conversion Strategy for the secret keys
- enum:
- - None
- - ReverseUnicode
- type: string
- match:
- description: Match a given Secret Key to be pushed to the provider.
- properties:
- remoteRef:
- description: Remote Refs to push to providers.
- properties:
- property:
- description: Name of the property in the resulting secret
- type: string
- remoteKey:
- description: Name of the resulting provider secret.
- type: string
- required:
- - remoteKey
- type: object
- secretKey:
- description: Secret Key to be pushed
- type: string
- required:
- - remoteRef
- type: object
- metadata:
- description: |-
- Metadata is metadata attached to the secret.
- The structure of metadata is provider specific, please look it up in the provider documentation.
- x-kubernetes-preserve-unknown-fields: true
- required:
- - match
- type: object
- type: object
- description: |-
- Synced PushSecrets, including secrets that already exist in provider.
- Matches secret stores to PushSecretData that was stored to that secret store.
- type: object
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version.
- type: string
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/secretstore.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: secretstores.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: SecretStore
- listKind: SecretStoreList
- plural: secretstores
- shortNames:
- - ss
- singular: secretstore
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: SecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the SecretManager provider will assume
- type: string
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- properties:
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- serviceAccount:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- required:
- - auth
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, instance principal is used. Optionally, the authenticating principal type
- and/or user data may be supplied for the use of workload identity and user principal.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - roleId
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.capabilities
- name: Capabilities
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: SecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- conditions:
- description: Used to constraint a ClusterSecretStore to specific namespaces. Relevant only to ClusterSecretStore
- items:
- description: |-
- ClusterSecretStoreCondition describes a condition by which to choose namespaces to process ExternalSecrets in
- for a ClusterSecretStore instance.
- properties:
- namespaceRegexes:
- description: Choose namespaces by using regex matching
- items:
- type: string
- type: array
- namespaceSelector:
- description: Choose namespace using a labelSelector
- 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
- namespaces:
- description: Choose namespaces by name
- items:
- type: string
- type: array
- type: object
- type: array
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- additionalRoles:
- description: AdditionalRoles is a chained list of Role ARNs which the provider will sequentially assume before assuming the Role
- items:
- type: string
- type: array
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- prefix:
- description: Prefix adds a prefix to all retrieved values.
- type: string
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the provider will assume
- type: string
- secretsManager:
- description: SecretsManager defines how the provider behaves when interacting with AWS SecretsManager
- properties:
- forceDeleteWithoutRecovery:
- description: |-
- Specifies whether to delete the secret without any recovery window. You
- can't use both this parameter and RecoveryWindowInDays in the same call.
- If you don't use either, then by default Secrets Manager uses a 30 day
- recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-ForceDeleteWithoutRecovery
- type: boolean
- recoveryWindowInDays:
- description: |-
- The number of days from 7 to 30 that Secrets Manager waits before
- permanently deleting the secret. You can't use both this parameter and
- ForceDeleteWithoutRecovery in the same call. If you don't use either,
- then by default Secrets Manager uses a 30 day recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-RecoveryWindowInDays
- format: int64
- type: integer
- type: object
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- sessionTags:
- description: AWS STS assume role session tags
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- transitiveTagKeys:
- description: AWS STS assume role transitive session tags. Required when multiple rules are used with the provider
- items:
- type: string
- type: array
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- properties:
- clientCertificate:
- description: The Azure ClientCertificate of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientId:
- description: The Azure clientId of the service principle or managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- tenantId:
- description: The Azure tenantId of the managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- bitwardensecretsmanager:
- description: BitwardenSecretsManager configures this store to sync secrets using BitwardenSecretsManager provider
- properties:
- apiURL:
- type: string
- auth:
- description: |-
- Auth configures how secret-manager authenticates with a bitwarden machine account instance.
- Make sure that the token being used has permissions on the given secret.
- properties:
- secretRef:
- description: BitwardenSecretsManagerSecretRef contains the credential ref to the bitwarden instance.
- properties:
- credentials:
- description: AccessToken used for the bitwarden instance.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - credentials
- type: object
- required:
- - secretRef
- type: object
- bitwardenServerSDKURL:
- type: string
- caBundle:
- description: |-
- Base64 encoded certificate for the bitwarden server sdk. The sdk MUST run with HTTPS to make sure no MITM attack
- can be performed.
- type: string
- identityURL:
- type: string
- organizationID:
- description: OrganizationID determines which organization this secret store manages.
- type: string
- projectID:
- description: ProjectID determines which project this secret store manages.
- type: string
- required:
- - auth
- - caBundle
- - organizationID
- - projectID
- type: object
- chef:
- description: Chef configures this store to sync secrets with chef server
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against chef Server
- properties:
- secretRef:
- description: ChefAuthSecretRef holds secret references for chef server login credentials.
- properties:
- privateKeySecretRef:
- description: SecretKey is the Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - privateKeySecretRef
- type: object
- required:
- - secretRef
- type: object
- serverUrl:
- description: ServerURL is the chef server URL used to connect to. If using orgs you should include your org in the url and terminate the url with a "/"
- type: string
- username:
- description: UserName should be the user ID on the chef server
- type: string
- required:
- - auth
- - serverUrl
- - username
- type: object
- conjur:
- description: Conjur configures this store to sync secrets using conjur provider
- properties:
- auth:
- properties:
- apikey:
- properties:
- account:
- type: string
- apiKeyRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - account
- - apiKeyRef
- - userRef
- type: object
- jwt:
- properties:
- account:
- type: string
- hostId:
- description: |-
- Optional HostID for JWT authentication. This may be used depending
- on how the Conjur JWT authenticator policy is configured.
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Conjur using the JWT authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional ServiceAccountRef specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- serviceID:
- description: The conjur authn jwt webservice id
- type: string
- required:
- - account
- - serviceID
- type: object
- type: object
- caBundle:
- type: string
- caProvider:
- description: |-
- Used to provide custom certificate authority (CA) certificates
- for a secret store. The CAProvider points to a Secret or ConfigMap resource
- that contains a PEM-encoded certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- type: string
- required:
- - auth
- - url
- type: object
- delinea:
- description: |-
- Delinea DevOps Secrets Vault
- https://docs.delinea.com/online-help/products/devops-secrets-vault/current
- properties:
- clientId:
- description: ClientID is the non-secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- clientSecret:
- description: ClientSecret is the secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- tenant:
- description: Tenant is the chosen hostname / site name.
- type: string
- tld:
- description: |-
- TLD is based on the server location that was chosen during provisioning.
- If unset, defaults to "com".
- type: string
- urlTemplate:
- description: |-
- URLTemplate
- If unset, defaults to "https://%s.secretsvaultcloud.%s/v1/%s%s".
- type: string
- required:
- - clientId
- - clientSecret
- - tenant
- type: object
- device42:
- description: Device42 configures this store to sync secrets using the Device42 provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Device42 instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- host:
- description: URL configures the Device42 instance URL.
- type: string
- required:
- - auth
- - host
- type: object
- doppler:
- description: Doppler configures this store to sync secrets using the Doppler provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Doppler API
- properties:
- secretRef:
- properties:
- dopplerToken:
- description: |-
- The DopplerToken is used for authentication.
- See https://docs.doppler.com/reference/api#authentication for auth token types.
- The Key attribute defaults to dopplerToken if not specified.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - dopplerToken
- type: object
- required:
- - secretRef
- type: object
- config:
- description: Doppler config (required if not using a Service Token)
- type: string
- format:
- description: Format enables the downloading of secrets as a file (string)
- enum:
- - json
- - dotnet-json
- - env
- - yaml
- - docker
- type: string
- nameTransformer:
- description: Environment variable compatible name transforms that change secret names to a different format
- enum:
- - upper-camel
- - camel
- - lower-snake
- - tf-var
- - dotnet-env
- - lower-kebab
- type: string
- project:
- description: Doppler project (required if not using a Service Token)
- type: string
- required:
- - auth
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- description: 'Deprecated: ValueMap is deprecated and is intended to be removed in the future, use the `value` field instead.'
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- fortanix:
- description: Fortanix configures this store to sync secrets using the Fortanix provider
- properties:
- apiKey:
- description: APIKey is the API token to access SDKMS Applications.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the SDKMS API Key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- description: APIURL is the URL of SDKMS API. Defaults to `sdkms.fortanix.com`.
- type: string
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- location:
- description: Location optionally defines a location for a secret
- type: string
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- environment:
- description: Environment environment_scope of gitlab CI/CD variables (Please see https://docs.gitlab.com/ee/ci/environments/#create-a-static-environment on how to create environments)
- type: string
- groupIDs:
- description: GroupIDs specify, which gitlab groups to pull secrets from. Group secrets are read from left to right followed by the project variables.
- items:
- type: string
- type: array
- inheritFromGroups:
- description: InheritFromGroups specifies whether parent groups should be discovered and checked for secrets.
- type: boolean
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- maxProperties: 1
- minProperties: 1
- properties:
- containerAuth:
- description: IBM Container-based auth with IAM Trusted Profile.
- properties:
- iamEndpoint:
- type: string
- profile:
- description: the IBM Trusted Profile
- type: string
- tokenLocation:
- description: Location the token is mounted on the pod
- type: string
- required:
- - profile
- type: object
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- infisical:
- description: Infisical configures this store to sync secrets using the Infisical provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Infisical API
- properties:
- universalAuthCredentials:
- properties:
- clientId:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecret
- type: object
- type: object
- hostAPI:
- default: https://app.infisical.com/api
- type: string
- secretsScope:
- properties:
- environmentSlug:
- type: string
- projectSlug:
- type: string
- secretsPath:
- default: /
- type: string
- required:
- - environmentSlug
- - projectSlug
- type: object
- required:
- - auth
- - secretsScope
- type: object
- keepersecurity:
- description: KeeperSecurity configures this store to sync secrets using the KeeperSecurity provider
- properties:
- authRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- folderID:
- type: string
- required:
- - authRef
- - folderID
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- authRef:
- description: A reference to a secret that contains the auth information.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- type: object
- onboardbase:
- description: Onboardbase configures this store to sync secrets using the Onboardbase provider
- properties:
- apiHost:
- default: https://public.onboardbase.com/api/v1/
- description: APIHost use this to configure the host url for the API for selfhosted installation, default is https://public.onboardbase.com/api/v1/
- type: string
- auth:
- description: Auth configures how the Operator authenticates with the Onboardbase API
- properties:
- apiKeyRef:
- description: |-
- OnboardbaseAPIKey is the APIKey generated by an admin account.
- It is used to recognize and authorize access to a project and environment within onboardbase
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- passcodeRef:
- description: OnboardbasePasscode is the passcode attached to the API Key
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - apiKeyRef
- - passcodeRef
- type: object
- environment:
- default: development
- description: Environment is the name of an environmnent within a project to pull the secrets from
- type: string
- project:
- default: development
- description: Project is an onboardbase project that the secrets should be pulled from
- type: string
- required:
- - apiHost
- - auth
- - environment
- - project
- type: object
- onepassword:
- description: OnePassword configures this store to sync secrets using the 1Password Cloud provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against OnePassword Connect Server
- properties:
- secretRef:
- description: OnePasswordAuthSecretRef holds secret references for 1Password credentials.
- properties:
- connectTokenSecretRef:
- description: The ConnectToken is used for authentication to a 1Password Connect Server.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - connectTokenSecretRef
- type: object
- required:
- - secretRef
- type: object
- connectHost:
- description: ConnectHost defines the OnePassword Connect Server to connect to
- type: string
- vaults:
- additionalProperties:
- type: integer
- description: Vaults defines which OnePassword vaults to search in which order
- type: object
- required:
- - auth
- - connectHost
- - vaults
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, use the instance principal, otherwise the user credentials specified in Auth.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passbolt:
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against Passbolt Server
- properties:
- passwordSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privateKeySecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - passwordSecretRef
- - privateKeySecretRef
- type: object
- host:
- description: Host defines the Passbolt Server to connect to
- type: string
- required:
- - auth
- - host
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- pulumi:
- description: Pulumi configures this store to sync secrets using the Pulumi provider
- properties:
- accessToken:
- description: AccessToken is the access tokens to sign in to the Pulumi Cloud Console.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the Pulumi API token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- default: https://api.pulumi.com/api/preview
- description: APIURL is the URL of the Pulumi API.
- type: string
- environment:
- description: |-
- Environment are YAML documents composed of static key-value pairs, programmatic expressions,
- dynamically retrieved values from supported providers including all major clouds,
- and other Pulumi ESC environments.
- To create a new environment, visit https://www.pulumi.com/docs/esc/environments/ for more information.
- type: string
- organization:
- description: |-
- Organization are a space to collaborate on shared projects and stacks.
- To create a new organization, visit https://app.pulumi.com/ and click "New Organization".
- type: string
- required:
- - accessToken
- - environment
- - organization
- type: object
- scaleway:
- description: Scaleway
- properties:
- accessKey:
- description: AccessKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- apiUrl:
- description: APIURL is the url of the api to use. Defaults to https://api.scaleway.com
- type: string
- projectId:
- description: 'ProjectID is the id of your project, which you can find in the console: https://console.scaleway.com/project/settings'
- type: string
- region:
- description: 'Region where your secrets are located: https://developers.scaleway.com/en/quickstart/#region-and-zone'
- type: string
- secretKey:
- description: SecretKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - accessKey
- - projectId
- - region
- - secretKey
- type: object
- secretserver:
- description: |-
- SecretServer configures this store to sync secrets using SecretServer provider
- https://docs.delinea.com/online-help/secret-server/start.htm
- properties:
- password:
- description: Password is the secret server account password.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- serverURL:
- description: |-
- ServerURL
- URL to your secret server installation
- type: string
- username:
- description: Username is the secret server account username.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - password
- - serverURL
- - username
- type: object
- senhasegura:
- description: Senhasegura configures this store to sync secrets using senhasegura provider
- properties:
- auth:
- description: Auth defines parameters to authenticate in senhasegura
- properties:
- clientId:
- type: string
- clientSecretSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecretSecretRef
- type: object
- ignoreSslCertificate:
- default: false
- description: IgnoreSslCertificate defines if SSL certificate must be ignored
- type: boolean
- module:
- description: Module defines which senhasegura module should be used to get secrets
- type: string
- url:
- description: URL of senhasegura
- type: string
- required:
- - auth
- - module
- - url
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexcertificatemanager:
- description: YandexCertificateManager configures this store to sync secrets using Yandex Certificate Manager provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Certificate Manager
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- refreshInterval:
- description: Used to configure store refresh interval in seconds. Empty or 0 will default to the controller config.
- type: integer
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- capabilities:
- description: SecretStoreCapabilities defines the possible operations a SecretStore can do.
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/vaultdynamicsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: vaultdynamicsecrets.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - vaultdynamicsecret
- kind: VaultDynamicSecret
- listKind: VaultDynamicSecretList
- plural: vaultdynamicsecrets
- shortNames:
- - vaultdynamicsecret
- singular: vaultdynamicsecret
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- 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:
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters VDS based on this property
- type: string
- method:
- description: Vault API method to use (GET/POST/other)
- type: string
- parameters:
- description: Parameters to pass to Vault write (for non-GET methods)
- x-kubernetes-preserve-unknown-fields: true
- path:
- description: Vault path to obtain the dynamic secret from
- type: string
- provider:
- description: Vault provider common spec
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- resultType:
- default: Data
- description: |-
- Result type defines which data is returned from the generator.
- By default it is the "data" section of the Vault API response.
- When using e.g. /auth/token/create the "data" section is empty but
- the "auth" section contains the generated token.
- Please refer to the vault docs regarding the result data structure.
- enum:
- - Data
- - Auth
- type: string
- required:
- - path
- - provider
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/webhook.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: webhooks.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - webhook
- kind: Webhook
- listKind: WebhookList
- plural: webhooks
- shortNames:
- - webhookl
- singular: webhook
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Webhook connects to a third party API server to handle the secrets generation
- configuration parameters in spec.
- You can specify the server, the token, and additional body parameters.
- See documentation for the full API specification for requests and responses.
- 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: WebhookSpec controls the behavior of the external generator. Any body parameters should be passed to the server through the parameters field.
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: The key where the token is found.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-cert-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "apiextensions.k8s.io"
- resources:
- - "customresourcedefinitions"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - "admissionregistration.k8s.io"
- resources:
- - "validatingwebhookconfigurations"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "endpoints"
- verbs:
- - "list"
- - "get"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "events"
- verbs:
- - "create"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "secrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - "coordination.k8s.io"
- resources:
- - "leases"
- verbs:
- - "get"
- - "create"
- - "update"
- - "patch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "secretstores"
- - "clustersecretstores"
- - "externalsecrets"
- - "clusterexternalsecrets"
- - "pushsecrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "externalsecrets/status"
- - "externalsecrets/finalizers"
- - "secretstores"
- - "secretstores/status"
- - "secretstores/finalizers"
- - "clustersecretstores"
- - "clustersecretstores/status"
- - "clustersecretstores/finalizers"
- - "clusterexternalsecrets"
- - "clusterexternalsecrets/status"
- - "clusterexternalsecrets/finalizers"
- - "pushsecrets"
- - "pushsecrets/status"
- - "pushsecrets/finalizers"
- verbs:
- - "get"
- - "update"
- - "patch"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "serviceaccounts"
- - "namespaces"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "secrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "create"
- - "update"
- - "delete"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "serviceaccounts/token"
- verbs:
- - "create"
- - apiGroups:
- - ""
- resources:
- - "events"
- verbs:
- - "create"
- - "patch"
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- verbs:
- - "create"
- - "update"
- - "delete"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-view
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- rbac.authorization.k8s.io/aggregate-to-view: "true"
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "secretstores"
- - "clustersecretstores"
- - "pushsecrets"
- verbs:
- - "get"
- - "watch"
- - "list"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "get"
- - "watch"
- - "list"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-edit
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "secretstores"
- - "clustersecretstores"
- - "pushsecrets"
- verbs:
- - "create"
- - "delete"
- - "deletecollection"
- - "patch"
- - "update"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "create"
- - "delete"
- - "deletecollection"
- - "patch"
- - "update"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-servicebindings
- labels:
- servicebinding.io/controller: "true"
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- verbs:
- - "get"
- - "list"
- - "watch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-golang-external-secrets-cert-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: common-golang-external-secrets-cert-controller
-subjects:
- - name: external-secrets-cert-controller
- namespace: default
- kind: ServiceAccount
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-golang-external-secrets-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: common-golang-external-secrets-controller
-subjects:
- - name: common-golang-external-secrets
- namespace: default
- kind: ServiceAccount
----
-# Source: golang-external-secrets/templates/golang-external-secrets-hub-clusterrolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: role-tokenreview-binding
- namespace: default
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: golang-external-secrets
- namespace: golang-external-secrets
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: common-golang-external-secrets-leaderelection
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- resourceNames:
- - "external-secrets-controller"
- verbs:
- - "get"
- - "update"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- verbs:
- - "create"
- - apiGroups:
- - "coordination.k8s.io"
- resources:
- - "leases"
- verbs:
- - "get"
- - "create"
- - "update"
- - "patch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: common-golang-external-secrets-leaderelection
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: common-golang-external-secrets-leaderelection
-subjects:
- - kind: ServiceAccount
- name: common-golang-external-secrets
- namespace: default
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- external-secrets.io/component: webhook
-spec:
- type: ClusterIP
- ports:
- - port: 443
- targetPort: 10250
- protocol: TCP
- name: webhook
- selector:
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets-cert-controller
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- serviceAccountName: external-secrets-cert-controller
- automountServiceAccountToken: true
- hostNetwork: false
- containers:
- - name: cert-controller
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - certcontroller
- - --crd-requeue-interval=5m
- - --service-name=common-golang-external-secrets-webhook
- - --service-namespace=default
- - --secret-name=common-golang-external-secrets-webhook
- - --secret-namespace=default
- - --metrics-addr=:8080
- - --healthz-addr=:8081
- - --loglevel=info
- - --zap-time-encoding=epoch
- - --enable-partial-cache=true
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- readinessProbe:
- httpGet:
- port: 8081
- path: /readyz
- initialDelaySeconds: 20
- periodSeconds: 5
----
-# Source: golang-external-secrets/charts/external-secrets/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- serviceAccountName: common-golang-external-secrets
- automountServiceAccountToken: true
- hostNetwork: false
- containers:
- - name: external-secrets
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - --concurrent=1
- - --metrics-addr=:8080
- - --loglevel=info
- - --zap-time-encoding=epoch
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- dnsPolicy: ClusterFirst
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- hostNetwork: false
- serviceAccountName: external-secrets-webhook
- automountServiceAccountToken: true
- containers:
- - name: webhook
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - webhook
- - --port=10250
- - --dns-name=common-golang-external-secrets-webhook.default.svc
- - --cert-dir=/tmp/certs
- - --check-interval=5m
- - --metrics-addr=:8080
- - --healthz-addr=:8081
- - --loglevel=info
- - --zap-time-encoding=epoch
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- - containerPort: 10250
- protocol: TCP
- name: webhook
- readinessProbe:
- httpGet:
- port: 8081
- path: /readyz
- initialDelaySeconds: 20
- periodSeconds: 5
- volumeMounts:
- - name: certs
- mountPath: /tmp/certs
- readOnly: true
- volumes:
- - name: certs
- secret:
- secretName: common-golang-external-secrets-webhook
----
-# Source: golang-external-secrets/templates/vault/golang-external-secrets-hub-secretstore.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ClusterSecretStore
-metadata:
- name: vault-backend
- namespace: golang-external-secrets
-spec:
- provider:
- vault:
- server: https://vault-vault.hub.example.com
- path: secret
- # Version of KV backend
- version: v2
-
- caProvider:
- type: ConfigMap
- name: kube-root-ca.crt
- key: ca.crt
- namespace: golang-external-secrets
-
- auth:
- kubernetes:
-
- mountPath: hub
- role: hub-role
-
- secretRef:
- name: golang-external-secrets
- namespace: golang-external-secrets
- key: "token"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/validatingwebhook.yaml
-apiVersion: admissionregistration.k8s.io/v1
-kind: ValidatingWebhookConfiguration
-metadata:
- name: secretstore-validate
- labels:
- external-secrets.io/component: webhook
-webhooks:
-- name: "validate.secretstore.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["secretstores"]
- scope: "Namespaced"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-secretstore
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
-
-- name: "validate.clustersecretstore.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["clustersecretstores"]
- scope: "Cluster"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-clustersecretstore
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
----
-# Source: golang-external-secrets/charts/external-secrets/templates/validatingwebhook.yaml
-apiVersion: admissionregistration.k8s.io/v1
-kind: ValidatingWebhookConfiguration
-metadata:
- name: externalsecret-validate
- labels:
- external-secrets.io/component: webhook
-webhooks:
-- name: "validate.externalsecret.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["externalsecrets"]
- scope: "Namespaced"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-externalsecret
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
- failurePolicy: Fail
diff --git a/tests/common-golang-external-secrets-normal.expected.yaml b/tests/common-golang-external-secrets-normal.expected.yaml
deleted file mode 100644
index 056054ba..00000000
--- a/tests/common-golang-external-secrets-normal.expected.yaml
+++ /dev/null
@@ -1,13143 +0,0 @@
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: external-secrets-cert-controller
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: common-golang-external-secrets
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- external-secrets.io/component: webhook
----
-# Source: golang-external-secrets/templates/golang-external-secrets-hub-clusterrolebinding.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: golang-external-secrets
- namespace: golang-external-secrets
- annotations:
- kubernetes.io/service-account.name: golang-external-secrets
-type: kubernetes.io/service-account-token
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/acraccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: acraccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - acraccesstoken
- kind: ACRAccessToken
- listKind: ACRAccessTokenList
- plural: acraccesstokens
- shortNames:
- - acraccesstoken
- singular: acraccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- ACRAccessToken returns a Azure Container Registry token
- that can be used for pushing/pulling images.
- Note: by default it will return an ACR Refresh Token with full access
- (depending on the identity).
- This can be scoped down to the repository level using .spec.scope.
- In case scope is defined it will return an ACR Access Token.
-
-
- See docs: https://github.com/Azure/acr/blob/main/docs/AAD-OAuth.md
- 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: |-
- ACRAccessTokenSpec defines how to generate the access token
- e.g. how to authenticate and which registry to use.
- see: https://github.com/Azure/acr/blob/main/docs/AAD-OAuth.md#overview
- properties:
- auth:
- properties:
- managedIdentity:
- description: ManagedIdentity uses Azure Managed Identity to authenticate with Azure.
- properties:
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- type: object
- servicePrincipal:
- description: ServicePrincipal uses Azure Service Principal credentials to authenticate with Azure.
- properties:
- secretRef:
- description: |-
- Configuration used to authenticate with Azure using static
- credentials stored in a Kind=Secret.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- workloadIdentity:
- description: WorkloadIdentity uses Azure Workload Identity to authenticate with Azure.
- properties:
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- registry:
- description: |-
- the domain name of the ACR registry
- e.g. foobarexample.azurecr.io
- type: string
- scope:
- description: |-
- Define the scope for the access token, e.g. pull/push access for a repository.
- if not provided it will return a refresh token that has full scope.
- Note: you need to pin it down to the repository level, there is no wildcard available.
-
-
- examples:
- repository:my-repository:pull,push
- repository:my-repository:pull
-
-
- see docs for details: https://docs.docker.com/registry/spec/auth/scope/
- type: string
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- required:
- - auth
- - registry
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/clusterexternalsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: clusterexternalsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ClusterExternalSecret
- listKind: ClusterExternalSecretList
- plural: clusterexternalsecrets
- shortNames:
- - ces
- singular: clusterexternalsecret
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - jsonPath: .spec.externalSecretSpec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshTime
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ClusterExternalSecret is the Schema for the clusterexternalsecrets 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: ClusterExternalSecretSpec defines the desired state of ClusterExternalSecret.
- properties:
- externalSecretMetadata:
- description: The metadata of the external secrets to be created
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- externalSecretName:
- description: The name of the external secrets to be created defaults to the name of the ClusterExternalSecret
- type: string
- externalSecretSpec:
- description: The spec for the ExternalSecrets to be created
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: |-
- RemoteRef points to the remote secret and defines
- which secret (version/property/..) to fetch.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- description: |-
- SecretKey defines the key in which the controller stores
- the value. This is the key in the Kind=Secret
- type: string
- sourceRef:
- description: |-
- SourceRef allows you to override the source
- from which the value will pulled from.
- maxProperties: 1
- properties:
- generatorRef:
- description: |-
- GeneratorRef points to a generator custom resource.
-
-
- Deprecated: The generatorRef is not implemented in .data[].
- this will be removed with v1.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- properties:
- extract:
- description: |-
- Used to extract multiple key/value pairs from one secret
- Note: Extract does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- find:
- description: |-
- Used to find secrets based on tags or regular expressions
- Note: Find does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- name:
- description: Finds secrets based on the name.
- properties:
- regexp:
- description: Finds secrets base
- type: string
- type: object
- path:
- description: A root path to start the find operations.
- type: string
- tags:
- additionalProperties:
- type: string
- description: Find secrets based on tags.
- type: object
- type: object
- rewrite:
- description: |-
- Used to rewrite secret Keys after getting them from the secret Provider
- Multiple Rewrite operations can be provided. They are applied in a layered order (first to last)
- items:
- properties:
- regexp:
- description: |-
- Used to rewrite with regular expressions.
- The resulting key will be the output of a regexp.ReplaceAll operation.
- properties:
- source:
- description: Used to define the regular expression of a re.Compiler.
- type: string
- target:
- description: Used to define the target pattern of a ReplaceAll operation.
- type: string
- required:
- - source
- - target
- type: object
- transform:
- description: |-
- Used to apply string transformation on the secrets.
- The resulting key will be the output of the template applied by the operation.
- properties:
- template:
- description: |-
- Used to define the template to apply on the secret name.
- `.value ` will specify the secret name in the template.
- type: string
- required:
- - template
- type: object
- type: object
- type: array
- sourceRef:
- description: |-
- SourceRef points to a store or generator
- which contains secret values ready to use.
- Use this in combination with Extract or Find pull values out of
- a specific SecretStore.
- When sourceRef points to a generator Extract or Find is not supported.
- The generator returns a static map of values
- maxProperties: 1
- properties:
- generatorRef:
- description: GeneratorRef points to a generator custom resource.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- default:
- creationPolicy: Owner
- deletionPolicy: Retain
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Orphan
- - Merge
- - None
- type: string
- deletionPolicy:
- default: Retain
- description: |-
- DeletionPolicy defines rules on how to delete the resulting Secret
- Defaults to 'Retain'
- enum:
- - Delete
- - Merge
- - Retain
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- type: object
- namespaceSelector:
- description: |-
- The labels to select by to find the Namespaces to create the ExternalSecrets in.
- Deprecated: Use NamespaceSelectors instead.
- 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
- namespaceSelectors:
- description: A list of labels to select by to find the Namespaces to create the ExternalSecrets in. The selectors are ORed.
- items:
- description: |-
- A label selector is a label query over a set of resources. The result of matchLabels and
- matchExpressions are ANDed. An empty label selector matches all objects. A null
- label selector matches no objects.
- 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
- type: array
- namespaces:
- description: Choose namespaces by name. This field is ORed with anything that NamespaceSelectors ends up choosing.
- items:
- type: string
- type: array
- refreshTime:
- description: The time in which the controller should reconcile its objects and recheck namespaces for labels.
- type: string
- required:
- - externalSecretSpec
- type: object
- status:
- description: ClusterExternalSecretStatus defines the observed state of ClusterExternalSecret.
- properties:
- conditions:
- items:
- properties:
- message:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- externalSecretName:
- description: ExternalSecretName is the name of the ExternalSecrets created by the ClusterExternalSecret
- type: string
- failedNamespaces:
- description: Failed namespaces are the namespaces that failed to apply an ExternalSecret
- items:
- description: ClusterExternalSecretNamespaceFailure represents a failed namespace deployment and it's reason.
- properties:
- namespace:
- description: Namespace is the namespace that failed when trying to apply an ExternalSecret
- type: string
- reason:
- description: Reason is why the ExternalSecret failed to apply to the namespace
- type: string
- required:
- - namespace
- type: object
- type: array
- provisionedNamespaces:
- description: ProvisionedNamespaces are the namespaces where the ClusterExternalSecret has secrets
- items:
- type: string
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/clustersecretstore.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: clustersecretstores.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ClusterSecretStore
- listKind: ClusterSecretStoreList
- plural: clustersecretstores
- shortNames:
- - css
- singular: clustersecretstore
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: ClusterSecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the SecretManager provider will assume
- type: string
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- properties:
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- serviceAccount:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- required:
- - auth
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, instance principal is used. Optionally, the authenticating principal type
- and/or user data may be supplied for the use of workload identity and user principal.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - roleId
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.capabilities
- name: Capabilities
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ClusterSecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- conditions:
- description: Used to constraint a ClusterSecretStore to specific namespaces. Relevant only to ClusterSecretStore
- items:
- description: |-
- ClusterSecretStoreCondition describes a condition by which to choose namespaces to process ExternalSecrets in
- for a ClusterSecretStore instance.
- properties:
- namespaceRegexes:
- description: Choose namespaces by using regex matching
- items:
- type: string
- type: array
- namespaceSelector:
- description: Choose namespace using a labelSelector
- 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
- namespaces:
- description: Choose namespaces by name
- items:
- type: string
- type: array
- type: object
- type: array
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- additionalRoles:
- description: AdditionalRoles is a chained list of Role ARNs which the provider will sequentially assume before assuming the Role
- items:
- type: string
- type: array
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- prefix:
- description: Prefix adds a prefix to all retrieved values.
- type: string
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the provider will assume
- type: string
- secretsManager:
- description: SecretsManager defines how the provider behaves when interacting with AWS SecretsManager
- properties:
- forceDeleteWithoutRecovery:
- description: |-
- Specifies whether to delete the secret without any recovery window. You
- can't use both this parameter and RecoveryWindowInDays in the same call.
- If you don't use either, then by default Secrets Manager uses a 30 day
- recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-ForceDeleteWithoutRecovery
- type: boolean
- recoveryWindowInDays:
- description: |-
- The number of days from 7 to 30 that Secrets Manager waits before
- permanently deleting the secret. You can't use both this parameter and
- ForceDeleteWithoutRecovery in the same call. If you don't use either,
- then by default Secrets Manager uses a 30 day recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-RecoveryWindowInDays
- format: int64
- type: integer
- type: object
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- sessionTags:
- description: AWS STS assume role session tags
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- transitiveTagKeys:
- description: AWS STS assume role transitive session tags. Required when multiple rules are used with the provider
- items:
- type: string
- type: array
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- properties:
- clientCertificate:
- description: The Azure ClientCertificate of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientId:
- description: The Azure clientId of the service principle or managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- tenantId:
- description: The Azure tenantId of the managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- bitwardensecretsmanager:
- description: BitwardenSecretsManager configures this store to sync secrets using BitwardenSecretsManager provider
- properties:
- apiURL:
- type: string
- auth:
- description: |-
- Auth configures how secret-manager authenticates with a bitwarden machine account instance.
- Make sure that the token being used has permissions on the given secret.
- properties:
- secretRef:
- description: BitwardenSecretsManagerSecretRef contains the credential ref to the bitwarden instance.
- properties:
- credentials:
- description: AccessToken used for the bitwarden instance.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - credentials
- type: object
- required:
- - secretRef
- type: object
- bitwardenServerSDKURL:
- type: string
- caBundle:
- description: |-
- Base64 encoded certificate for the bitwarden server sdk. The sdk MUST run with HTTPS to make sure no MITM attack
- can be performed.
- type: string
- identityURL:
- type: string
- organizationID:
- description: OrganizationID determines which organization this secret store manages.
- type: string
- projectID:
- description: ProjectID determines which project this secret store manages.
- type: string
- required:
- - auth
- - caBundle
- - organizationID
- - projectID
- type: object
- chef:
- description: Chef configures this store to sync secrets with chef server
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against chef Server
- properties:
- secretRef:
- description: ChefAuthSecretRef holds secret references for chef server login credentials.
- properties:
- privateKeySecretRef:
- description: SecretKey is the Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - privateKeySecretRef
- type: object
- required:
- - secretRef
- type: object
- serverUrl:
- description: ServerURL is the chef server URL used to connect to. If using orgs you should include your org in the url and terminate the url with a "/"
- type: string
- username:
- description: UserName should be the user ID on the chef server
- type: string
- required:
- - auth
- - serverUrl
- - username
- type: object
- conjur:
- description: Conjur configures this store to sync secrets using conjur provider
- properties:
- auth:
- properties:
- apikey:
- properties:
- account:
- type: string
- apiKeyRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - account
- - apiKeyRef
- - userRef
- type: object
- jwt:
- properties:
- account:
- type: string
- hostId:
- description: |-
- Optional HostID for JWT authentication. This may be used depending
- on how the Conjur JWT authenticator policy is configured.
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Conjur using the JWT authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional ServiceAccountRef specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- serviceID:
- description: The conjur authn jwt webservice id
- type: string
- required:
- - account
- - serviceID
- type: object
- type: object
- caBundle:
- type: string
- caProvider:
- description: |-
- Used to provide custom certificate authority (CA) certificates
- for a secret store. The CAProvider points to a Secret or ConfigMap resource
- that contains a PEM-encoded certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- type: string
- required:
- - auth
- - url
- type: object
- delinea:
- description: |-
- Delinea DevOps Secrets Vault
- https://docs.delinea.com/online-help/products/devops-secrets-vault/current
- properties:
- clientId:
- description: ClientID is the non-secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- clientSecret:
- description: ClientSecret is the secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- tenant:
- description: Tenant is the chosen hostname / site name.
- type: string
- tld:
- description: |-
- TLD is based on the server location that was chosen during provisioning.
- If unset, defaults to "com".
- type: string
- urlTemplate:
- description: |-
- URLTemplate
- If unset, defaults to "https://%s.secretsvaultcloud.%s/v1/%s%s".
- type: string
- required:
- - clientId
- - clientSecret
- - tenant
- type: object
- device42:
- description: Device42 configures this store to sync secrets using the Device42 provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Device42 instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- host:
- description: URL configures the Device42 instance URL.
- type: string
- required:
- - auth
- - host
- type: object
- doppler:
- description: Doppler configures this store to sync secrets using the Doppler provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Doppler API
- properties:
- secretRef:
- properties:
- dopplerToken:
- description: |-
- The DopplerToken is used for authentication.
- See https://docs.doppler.com/reference/api#authentication for auth token types.
- The Key attribute defaults to dopplerToken if not specified.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - dopplerToken
- type: object
- required:
- - secretRef
- type: object
- config:
- description: Doppler config (required if not using a Service Token)
- type: string
- format:
- description: Format enables the downloading of secrets as a file (string)
- enum:
- - json
- - dotnet-json
- - env
- - yaml
- - docker
- type: string
- nameTransformer:
- description: Environment variable compatible name transforms that change secret names to a different format
- enum:
- - upper-camel
- - camel
- - lower-snake
- - tf-var
- - dotnet-env
- - lower-kebab
- type: string
- project:
- description: Doppler project (required if not using a Service Token)
- type: string
- required:
- - auth
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- description: 'Deprecated: ValueMap is deprecated and is intended to be removed in the future, use the `value` field instead.'
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- fortanix:
- description: Fortanix configures this store to sync secrets using the Fortanix provider
- properties:
- apiKey:
- description: APIKey is the API token to access SDKMS Applications.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the SDKMS API Key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- description: APIURL is the URL of SDKMS API. Defaults to `sdkms.fortanix.com`.
- type: string
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- location:
- description: Location optionally defines a location for a secret
- type: string
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- environment:
- description: Environment environment_scope of gitlab CI/CD variables (Please see https://docs.gitlab.com/ee/ci/environments/#create-a-static-environment on how to create environments)
- type: string
- groupIDs:
- description: GroupIDs specify, which gitlab groups to pull secrets from. Group secrets are read from left to right followed by the project variables.
- items:
- type: string
- type: array
- inheritFromGroups:
- description: InheritFromGroups specifies whether parent groups should be discovered and checked for secrets.
- type: boolean
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- maxProperties: 1
- minProperties: 1
- properties:
- containerAuth:
- description: IBM Container-based auth with IAM Trusted Profile.
- properties:
- iamEndpoint:
- type: string
- profile:
- description: the IBM Trusted Profile
- type: string
- tokenLocation:
- description: Location the token is mounted on the pod
- type: string
- required:
- - profile
- type: object
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- infisical:
- description: Infisical configures this store to sync secrets using the Infisical provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Infisical API
- properties:
- universalAuthCredentials:
- properties:
- clientId:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecret
- type: object
- type: object
- hostAPI:
- default: https://app.infisical.com/api
- type: string
- secretsScope:
- properties:
- environmentSlug:
- type: string
- projectSlug:
- type: string
- secretsPath:
- default: /
- type: string
- required:
- - environmentSlug
- - projectSlug
- type: object
- required:
- - auth
- - secretsScope
- type: object
- keepersecurity:
- description: KeeperSecurity configures this store to sync secrets using the KeeperSecurity provider
- properties:
- authRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- folderID:
- type: string
- required:
- - authRef
- - folderID
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- authRef:
- description: A reference to a secret that contains the auth information.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- type: object
- onboardbase:
- description: Onboardbase configures this store to sync secrets using the Onboardbase provider
- properties:
- apiHost:
- default: https://public.onboardbase.com/api/v1/
- description: APIHost use this to configure the host url for the API for selfhosted installation, default is https://public.onboardbase.com/api/v1/
- type: string
- auth:
- description: Auth configures how the Operator authenticates with the Onboardbase API
- properties:
- apiKeyRef:
- description: |-
- OnboardbaseAPIKey is the APIKey generated by an admin account.
- It is used to recognize and authorize access to a project and environment within onboardbase
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- passcodeRef:
- description: OnboardbasePasscode is the passcode attached to the API Key
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - apiKeyRef
- - passcodeRef
- type: object
- environment:
- default: development
- description: Environment is the name of an environmnent within a project to pull the secrets from
- type: string
- project:
- default: development
- description: Project is an onboardbase project that the secrets should be pulled from
- type: string
- required:
- - apiHost
- - auth
- - environment
- - project
- type: object
- onepassword:
- description: OnePassword configures this store to sync secrets using the 1Password Cloud provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against OnePassword Connect Server
- properties:
- secretRef:
- description: OnePasswordAuthSecretRef holds secret references for 1Password credentials.
- properties:
- connectTokenSecretRef:
- description: The ConnectToken is used for authentication to a 1Password Connect Server.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - connectTokenSecretRef
- type: object
- required:
- - secretRef
- type: object
- connectHost:
- description: ConnectHost defines the OnePassword Connect Server to connect to
- type: string
- vaults:
- additionalProperties:
- type: integer
- description: Vaults defines which OnePassword vaults to search in which order
- type: object
- required:
- - auth
- - connectHost
- - vaults
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, use the instance principal, otherwise the user credentials specified in Auth.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passbolt:
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against Passbolt Server
- properties:
- passwordSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privateKeySecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - passwordSecretRef
- - privateKeySecretRef
- type: object
- host:
- description: Host defines the Passbolt Server to connect to
- type: string
- required:
- - auth
- - host
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- pulumi:
- description: Pulumi configures this store to sync secrets using the Pulumi provider
- properties:
- accessToken:
- description: AccessToken is the access tokens to sign in to the Pulumi Cloud Console.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the Pulumi API token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- default: https://api.pulumi.com/api/preview
- description: APIURL is the URL of the Pulumi API.
- type: string
- environment:
- description: |-
- Environment are YAML documents composed of static key-value pairs, programmatic expressions,
- dynamically retrieved values from supported providers including all major clouds,
- and other Pulumi ESC environments.
- To create a new environment, visit https://www.pulumi.com/docs/esc/environments/ for more information.
- type: string
- organization:
- description: |-
- Organization are a space to collaborate on shared projects and stacks.
- To create a new organization, visit https://app.pulumi.com/ and click "New Organization".
- type: string
- required:
- - accessToken
- - environment
- - organization
- type: object
- scaleway:
- description: Scaleway
- properties:
- accessKey:
- description: AccessKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- apiUrl:
- description: APIURL is the url of the api to use. Defaults to https://api.scaleway.com
- type: string
- projectId:
- description: 'ProjectID is the id of your project, which you can find in the console: https://console.scaleway.com/project/settings'
- type: string
- region:
- description: 'Region where your secrets are located: https://developers.scaleway.com/en/quickstart/#region-and-zone'
- type: string
- secretKey:
- description: SecretKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - accessKey
- - projectId
- - region
- - secretKey
- type: object
- secretserver:
- description: |-
- SecretServer configures this store to sync secrets using SecretServer provider
- https://docs.delinea.com/online-help/secret-server/start.htm
- properties:
- password:
- description: Password is the secret server account password.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- serverURL:
- description: |-
- ServerURL
- URL to your secret server installation
- type: string
- username:
- description: Username is the secret server account username.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - password
- - serverURL
- - username
- type: object
- senhasegura:
- description: Senhasegura configures this store to sync secrets using senhasegura provider
- properties:
- auth:
- description: Auth defines parameters to authenticate in senhasegura
- properties:
- clientId:
- type: string
- clientSecretSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecretSecretRef
- type: object
- ignoreSslCertificate:
- default: false
- description: IgnoreSslCertificate defines if SSL certificate must be ignored
- type: boolean
- module:
- description: Module defines which senhasegura module should be used to get secrets
- type: string
- url:
- description: URL of senhasegura
- type: string
- required:
- - auth
- - module
- - url
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexcertificatemanager:
- description: YandexCertificateManager configures this store to sync secrets using Yandex Certificate Manager provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Certificate Manager
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- refreshInterval:
- description: Used to configure store refresh interval in seconds. Empty or 0 will default to the controller config.
- type: integer
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- capabilities:
- description: SecretStoreCapabilities defines the possible operations a SecretStore can do.
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/ecrauthorizationtoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: ecrauthorizationtokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - ecrauthorizationtoken
- kind: ECRAuthorizationToken
- listKind: ECRAuthorizationTokenList
- plural: ecrauthorizationtokens
- shortNames:
- - ecrauthorizationtoken
- singular: ecrauthorizationtoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- ECRAuthorizationTokenSpec uses the GetAuthorizationToken API to retrieve an
- authorization token.
- The authorization token is valid for 12 hours.
- The authorizationToken returned is a base64 encoded string that can be decoded
- and used in a docker login command to authenticate to a registry.
- For more information, see Registry authentication (https://docs.aws.amazon.com/AmazonECR/latest/userguide/Registries.html#registry_auth) in the Amazon Elastic Container Registry User Guide.
- 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:
- properties:
- auth:
- description: Auth defines how to authenticate with AWS
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: Region specifies the region to operate in.
- type: string
- role:
- description: |-
- You can assume a role before making calls to the
- desired AWS service.
- type: string
- required:
- - region
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/externalsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: externalsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: ExternalSecret
- listKind: ExternalSecretList
- plural: externalsecrets
- shortNames:
- - es
- singular: externalsecret
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .spec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshInterval
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: ExternalSecret is the Schema for the external-secrets 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: ExternalSecretSpec defines the desired state of ExternalSecret.
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: ExternalSecretDataRemoteRef defines Provider data location.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- type: string
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- description: ExternalSecretDataRemoteRef defines Provider data location.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Merge
- - None
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v1
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- maxProperties: 1
- minProperties: 1
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- required:
- - secretStoreRef
- - target
- type: object
- status:
- properties:
- binding:
- description: Binding represents a servicebinding.io Provisioned Service reference to the secret
- properties:
- name:
- default: ""
- description: |-
- Name of the referent.
- This field is effectively required, but due to backwards compatibility is
- allowed to be empty. Instances of this type with an empty value here are
- almost certainly wrong.
- TODO: Add other useful fields. apiVersion, kind, uid?
- More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
- TODO: Drop `kubebuilder:default` when controller-gen doesn't need it https://github.com/kubernetes-sigs/kubebuilder/issues/3896.
- type: string
- type: object
- x-kubernetes-map-type: atomic
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version
- type: string
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .spec.secretStoreRef.name
- name: Store
- type: string
- - jsonPath: .spec.refreshInterval
- name: Refresh Interval
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: ExternalSecret is the Schema for the external-secrets 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: ExternalSecretSpec defines the desired state of ExternalSecret.
- properties:
- data:
- description: Data defines the connection between the Kubernetes Secret keys and the Provider data
- items:
- description: ExternalSecretData defines the connection between the Kubernetes Secret key (spec.data.) and the Provider data.
- properties:
- remoteRef:
- description: |-
- RemoteRef points to the remote secret and defines
- which secret (version/property/..) to fetch.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- secretKey:
- description: |-
- SecretKey defines the key in which the controller stores
- the value. This is the key in the Kind=Secret
- type: string
- sourceRef:
- description: |-
- SourceRef allows you to override the source
- from which the value will pulled from.
- maxProperties: 1
- properties:
- generatorRef:
- description: |-
- GeneratorRef points to a generator custom resource.
-
-
- Deprecated: The generatorRef is not implemented in .data[].
- this will be removed with v1.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- required:
- - remoteRef
- - secretKey
- type: object
- type: array
- dataFrom:
- description: |-
- DataFrom is used to fetch all properties from a specific Provider data
- If multiple entries are specified, the Secret keys are merged in the specified order
- items:
- properties:
- extract:
- description: |-
- Used to extract multiple key/value pairs from one secret
- Note: Extract does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- key:
- description: Key is the key used in the Provider, mandatory
- type: string
- metadataPolicy:
- default: None
- description: Policy for fetching tags/labels from provider secrets, possible options are Fetch, None. Defaults to None
- enum:
- - None
- - Fetch
- type: string
- property:
- description: Used to select a specific property of the Provider value (if a map), if supported
- type: string
- version:
- description: Used to select a specific version of the Provider value, if supported
- type: string
- required:
- - key
- type: object
- find:
- description: |-
- Used to find secrets based on tags or regular expressions
- Note: Find does not support sourceRef.Generator or sourceRef.GeneratorRef.
- properties:
- conversionStrategy:
- default: Default
- description: Used to define a conversion Strategy
- enum:
- - Default
- - Unicode
- type: string
- decodingStrategy:
- default: None
- description: Used to define a decoding Strategy
- enum:
- - Auto
- - Base64
- - Base64URL
- - None
- type: string
- name:
- description: Finds secrets based on the name.
- properties:
- regexp:
- description: Finds secrets base
- type: string
- type: object
- path:
- description: A root path to start the find operations.
- type: string
- tags:
- additionalProperties:
- type: string
- description: Find secrets based on tags.
- type: object
- type: object
- rewrite:
- description: |-
- Used to rewrite secret Keys after getting them from the secret Provider
- Multiple Rewrite operations can be provided. They are applied in a layered order (first to last)
- items:
- properties:
- regexp:
- description: |-
- Used to rewrite with regular expressions.
- The resulting key will be the output of a regexp.ReplaceAll operation.
- properties:
- source:
- description: Used to define the regular expression of a re.Compiler.
- type: string
- target:
- description: Used to define the target pattern of a ReplaceAll operation.
- type: string
- required:
- - source
- - target
- type: object
- transform:
- description: |-
- Used to apply string transformation on the secrets.
- The resulting key will be the output of the template applied by the operation.
- properties:
- template:
- description: |-
- Used to define the template to apply on the secret name.
- `.value ` will specify the secret name in the template.
- type: string
- required:
- - template
- type: object
- type: object
- type: array
- sourceRef:
- description: |-
- SourceRef points to a store or generator
- which contains secret values ready to use.
- Use this in combination with Extract or Find pull values out of
- a specific SecretStore.
- When sourceRef points to a generator Extract or Find is not supported.
- The generator returns a static map of values
- maxProperties: 1
- properties:
- generatorRef:
- description: GeneratorRef points to a generator custom resource.
- properties:
- apiVersion:
- default: generators.external-secrets.io/v1alpha1
- description: Specify the apiVersion of the generator resource
- type: string
- kind:
- description: Specify the Kind of the resource, e.g. Password, ACRAccessToken etc.
- type: string
- name:
- description: Specify the name of the generator resource
- type: string
- required:
- - kind
- - name
- type: object
- storeRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- type: object
- type: object
- type: array
- refreshInterval:
- default: 1h
- description: |-
- RefreshInterval is the amount of time before the values are read again from the SecretStore provider
- Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h"
- May be set to zero to fetch and create it once. Defaults to 1h.
- type: string
- secretStoreRef:
- description: SecretStoreRef defines which SecretStore to fetch the ExternalSecret data.
- properties:
- kind:
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- name:
- description: Name of the SecretStore resource
- type: string
- required:
- - name
- type: object
- target:
- default:
- creationPolicy: Owner
- deletionPolicy: Retain
- description: |-
- ExternalSecretTarget defines the Kubernetes Secret to be created
- There can be only one target per ExternalSecret.
- properties:
- creationPolicy:
- default: Owner
- description: |-
- CreationPolicy defines rules on how to create the resulting Secret
- Defaults to 'Owner'
- enum:
- - Owner
- - Orphan
- - Merge
- - None
- type: string
- deletionPolicy:
- default: Retain
- description: |-
- DeletionPolicy defines rules on how to delete the resulting Secret
- Defaults to 'Retain'
- enum:
- - Delete
- - Merge
- - Retain
- type: string
- immutable:
- description: Immutable defines if the final secret will be immutable
- type: boolean
- name:
- description: |-
- Name defines the name of the Secret resource to be managed
- This field is immutable
- Defaults to the .metadata.name of the ExternalSecret resource
- type: string
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- type: object
- type: object
- status:
- properties:
- binding:
- description: Binding represents a servicebinding.io Provisioned Service reference to the secret
- properties:
- name:
- default: ""
- description: |-
- Name of the referent.
- This field is effectively required, but due to backwards compatibility is
- allowed to be empty. Instances of this type with an empty value here are
- almost certainly wrong.
- TODO: Add other useful fields. apiVersion, kind, uid?
- More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
- TODO: Drop `kubebuilder:default` when controller-gen doesn't need it https://github.com/kubernetes-sigs/kubebuilder/issues/3896.
- type: string
- type: object
- x-kubernetes-map-type: atomic
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version
- type: string
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/fake.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: fakes.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - fake
- kind: Fake
- listKind: FakeList
- plural: fakes
- shortNames:
- - fake
- singular: fake
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Fake generator is used for testing. It lets you define
- a static set of credentials that is always returned.
- 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: FakeSpec contains the static data.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters VDS based on this property
- type: string
- data:
- additionalProperties:
- type: string
- description: |-
- Data defines the static data returned
- by this generator.
- type: object
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/gcraccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: gcraccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - gcraccesstoken
- kind: GCRAccessToken
- listKind: GCRAccessTokenList
- plural: gcraccesstokens
- shortNames:
- - gcraccesstoken
- singular: gcraccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- GCRAccessToken generates an GCP access token
- that can be used to authenticate with GCR.
- 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:
- properties:
- auth:
- description: Auth defines the means for authenticating with GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID defines which project to use to authenticate with
- type: string
- required:
- - auth
- - projectID
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/githubaccesstoken.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: githubaccesstokens.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - githubaccesstoken
- kind: GithubAccessToken
- listKind: GithubAccessTokenList
- plural: githubaccesstokens
- shortNames:
- - githubaccesstoken
- singular: githubaccesstoken
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: GithubAccessToken generates ghs_ accessToken
- 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:
- properties:
- appID:
- type: string
- auth:
- description: Auth configures how ESO authenticates with a Github instance.
- properties:
- privateKey:
- properties:
- secretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - secretRef
- type: object
- required:
- - privateKey
- type: object
- installID:
- type: string
- url:
- description: URL configures the Github instance URL. Defaults to https://github.com/.
- type: string
- required:
- - appID
- - auth
- - installID
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/password.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: passwords.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - password
- kind: Password
- listKind: PasswordList
- plural: passwords
- shortNames:
- - password
- singular: password
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Password generates a random password based on the
- configuration parameters in spec.
- You can specify the length, characterset and other attributes.
- 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: PasswordSpec controls the behavior of the password generator.
- properties:
- allowRepeat:
- default: false
- description: set AllowRepeat to true to allow repeating characters.
- type: boolean
- digits:
- description: |-
- Digits specifies the number of digits in the generated
- password. If omitted it defaults to 25% of the length of the password
- type: integer
- length:
- default: 24
- description: |-
- Length of the password to be generated.
- Defaults to 24
- type: integer
- noUpper:
- default: false
- description: Set NoUpper to disable uppercase characters
- type: boolean
- symbolCharacters:
- description: |-
- SymbolCharacters specifies the special characters that should be used
- in the generated password.
- type: string
- symbols:
- description: |-
- Symbols specifies the number of symbol characters in the generated
- password. If omitted it defaults to 25% of the length of the password
- type: integer
- required:
- - allowRepeat
- - length
- - noUpper
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/pushsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- name: pushsecrets.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - pushsecrets
- kind: PushSecret
- listKind: PushSecretList
- plural: pushsecrets
- singular: pushsecret
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- name: v1alpha1
- schema:
- openAPIV3Schema:
- 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: PushSecretSpec configures the behavior of the PushSecret.
- properties:
- data:
- description: Secret Data that should be pushed to providers
- items:
- properties:
- conversionStrategy:
- default: None
- description: Used to define a conversion Strategy for the secret keys
- enum:
- - None
- - ReverseUnicode
- type: string
- match:
- description: Match a given Secret Key to be pushed to the provider.
- properties:
- remoteRef:
- description: Remote Refs to push to providers.
- properties:
- property:
- description: Name of the property in the resulting secret
- type: string
- remoteKey:
- description: Name of the resulting provider secret.
- type: string
- required:
- - remoteKey
- type: object
- secretKey:
- description: Secret Key to be pushed
- type: string
- required:
- - remoteRef
- type: object
- metadata:
- description: |-
- Metadata is metadata attached to the secret.
- The structure of metadata is provider specific, please look it up in the provider documentation.
- x-kubernetes-preserve-unknown-fields: true
- required:
- - match
- type: object
- type: array
- deletionPolicy:
- default: None
- description: 'Deletion Policy to handle Secrets in the provider. Possible Values: "Delete/None". Defaults to "None".'
- enum:
- - Delete
- - None
- type: string
- refreshInterval:
- description: The Interval to which External Secrets will try to push a secret definition
- type: string
- secretStoreRefs:
- items:
- properties:
- kind:
- default: SecretStore
- description: |-
- Kind of the SecretStore resource (SecretStore or ClusterSecretStore)
- Defaults to `SecretStore`
- type: string
- labelSelector:
- description: Optionally, sync to secret stores with label selector
- 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
- name:
- description: Optionally, sync to the SecretStore of the given name
- type: string
- type: object
- type: array
- selector:
- description: The Secret Selector (k8s source) for the Push Secret
- properties:
- secret:
- description: Select a Secret to Push.
- properties:
- name:
- description: Name of the Secret. The Secret must exist in the same namespace as the PushSecret manifest.
- type: string
- required:
- - name
- type: object
- required:
- - secret
- type: object
- template:
- description: Template defines a blueprint for the created Secret resource.
- properties:
- data:
- additionalProperties:
- type: string
- type: object
- engineVersion:
- default: v2
- description: |-
- EngineVersion specifies the template engine version
- that should be used to compile/execute the
- template specified in .data and .templateFrom[].
- enum:
- - v1
- - v2
- type: string
- mergePolicy:
- default: Replace
- enum:
- - Replace
- - Merge
- type: string
- metadata:
- description: ExternalSecretTemplateMetadata defines metadata fields for the Secret blueprint.
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- templateFrom:
- items:
- properties:
- configMap:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- literal:
- type: string
- secret:
- properties:
- items:
- items:
- properties:
- key:
- type: string
- templateAs:
- default: Values
- enum:
- - Values
- - KeysAndValues
- type: string
- required:
- - key
- type: object
- type: array
- name:
- type: string
- required:
- - items
- - name
- type: object
- target:
- default: Data
- enum:
- - Data
- - Annotations
- - Labels
- type: string
- type: object
- type: array
- type:
- type: string
- type: object
- updatePolicy:
- default: Replace
- description: 'UpdatePolicy to handle Secrets in the provider. Possible Values: "Replace/IfNotExists". Defaults to "Replace".'
- enum:
- - Replace
- - IfNotExists
- type: string
- required:
- - secretStoreRefs
- - selector
- type: object
- status:
- description: PushSecretStatus indicates the history of the status of PushSecret.
- properties:
- conditions:
- items:
- description: PushSecretStatusCondition indicates the status of the PushSecret.
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- description: PushSecretConditionType indicates the condition of the PushSecret.
- type: string
- required:
- - status
- - type
- type: object
- type: array
- refreshTime:
- description: |-
- refreshTime is the time and date the external secret was fetched and
- the target secret updated
- format: date-time
- nullable: true
- type: string
- syncedPushSecrets:
- additionalProperties:
- additionalProperties:
- properties:
- conversionStrategy:
- default: None
- description: Used to define a conversion Strategy for the secret keys
- enum:
- - None
- - ReverseUnicode
- type: string
- match:
- description: Match a given Secret Key to be pushed to the provider.
- properties:
- remoteRef:
- description: Remote Refs to push to providers.
- properties:
- property:
- description: Name of the property in the resulting secret
- type: string
- remoteKey:
- description: Name of the resulting provider secret.
- type: string
- required:
- - remoteKey
- type: object
- secretKey:
- description: Secret Key to be pushed
- type: string
- required:
- - remoteRef
- type: object
- metadata:
- description: |-
- Metadata is metadata attached to the secret.
- The structure of metadata is provider specific, please look it up in the provider documentation.
- x-kubernetes-preserve-unknown-fields: true
- required:
- - match
- type: object
- type: object
- description: |-
- Synced PushSecrets, including secrets that already exist in provider.
- Matches secret stores to PushSecretData that was stored to that secret store.
- type: object
- syncedResourceVersion:
- description: SyncedResourceVersion keeps track of the last synced version.
- type: string
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/secretstore.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: secretstores.external-secrets.io
-spec:
- group: external-secrets.io
- names:
- categories:
- - externalsecrets
- kind: SecretStore
- listKind: SecretStoreList
- plural: secretstores
- shortNames:
- - ss
- singular: secretstore
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- deprecated: true
- name: v1alpha1
- schema:
- openAPIV3Schema:
- description: SecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the SecretManager provider will assume
- type: string
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type.
- properties:
- clientId:
- description: The Azure clientId of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- properties:
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- serviceAccount:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- required:
- - auth
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, instance principal is used. Optionally, the authenticating principal type
- and/or user data may be supplied for the use of workload identity and user principal.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - roleId
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: false
- subresources:
- status: {}
- - additionalPrinterColumns:
- - jsonPath: .metadata.creationTimestamp
- name: AGE
- type: date
- - jsonPath: .status.conditions[?(@.type=="Ready")].reason
- name: Status
- type: string
- - jsonPath: .status.capabilities
- name: Capabilities
- type: string
- - jsonPath: .status.conditions[?(@.type=="Ready")].status
- name: Ready
- type: string
- name: v1beta1
- schema:
- openAPIV3Schema:
- description: SecretStore represents a secure external location for storing secrets, which can be referenced as part of `storeRef` fields.
- 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: SecretStoreSpec defines the desired state of SecretStore.
- properties:
- conditions:
- description: Used to constraint a ClusterSecretStore to specific namespaces. Relevant only to ClusterSecretStore
- items:
- description: |-
- ClusterSecretStoreCondition describes a condition by which to choose namespaces to process ExternalSecrets in
- for a ClusterSecretStore instance.
- properties:
- namespaceRegexes:
- description: Choose namespaces by using regex matching
- items:
- type: string
- type: array
- namespaceSelector:
- description: Choose namespace using a labelSelector
- 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
- namespaces:
- description: Choose namespaces by name
- items:
- type: string
- type: array
- type: object
- type: array
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters ES based on this property
- type: string
- provider:
- description: Used to configure the provider. Only one provider may be set
- maxProperties: 1
- minProperties: 1
- properties:
- akeyless:
- description: Akeyless configures this store to sync secrets using Akeyless Vault provider
- properties:
- akeylessGWApiURL:
- description: Akeyless GW API Url from which the secrets to be fetched from.
- type: string
- authSecretRef:
- description: Auth configures how the operator authenticates with Akeyless.
- properties:
- kubernetesAuth:
- description: |-
- Kubernetes authenticates with Akeyless by passing the ServiceAccount
- token stored in the named Secret resource.
- properties:
- accessID:
- description: the Akeyless Kubernetes auth-method access-id
- type: string
- k8sConfName:
- description: Kubernetes-auth configuration name in Akeyless-Gateway
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Akeyless. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Akeyless. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - accessID
- - k8sConfName
- type: object
- secretRef:
- description: |-
- Reference to a Secret that contains the details
- to authenticate with Akeyless.
- properties:
- accessID:
- description: The SecretAccessID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessType:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessTypeParam:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- caBundle:
- description: |-
- PEM/base64 encoded CA bundle used to validate Akeyless Gateway certificate. Only used
- if the AkeylessGWApiURL URL is using HTTPS protocol. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Akeyless Gateway certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- required:
- - akeylessGWApiURL
- - authSecretRef
- type: object
- alibaba:
- description: Alibaba configures this store to sync secrets using Alibaba Cloud provider
- properties:
- auth:
- description: AlibabaAuth contains a secretRef for credentials.
- properties:
- rrsa:
- description: Authenticate against Alibaba using RRSA.
- properties:
- oidcProviderArn:
- type: string
- oidcTokenFilePath:
- type: string
- roleArn:
- type: string
- sessionName:
- type: string
- required:
- - oidcProviderArn
- - oidcTokenFilePath
- - roleArn
- - sessionName
- type: object
- secretRef:
- description: AlibabaAuthSecretRef holds secret references for Alibaba credentials.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- accessKeySecretSecretRef:
- description: The AccessKeySecret is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - accessKeyIDSecretRef
- - accessKeySecretSecretRef
- type: object
- type: object
- regionID:
- description: Alibaba Region to be used for the provider
- type: string
- required:
- - auth
- - regionID
- type: object
- aws:
- description: AWS configures this store to sync secrets using AWS Secret Manager provider
- properties:
- additionalRoles:
- description: AdditionalRoles is a chained list of Role ARNs which the provider will sequentially assume before assuming the Role
- items:
- type: string
- type: array
- auth:
- description: |-
- Auth defines the information necessary to authenticate against AWS
- if not set aws sdk will infer credentials from your environment
- see: https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
- properties:
- jwt:
- description: Authenticate against AWS using service account tokens.
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- secretRef:
- description: |-
- AWSAuthSecretRef holds secret references for AWS credentials
- both AccessKeyID and SecretAccessKey must be defined in order to properly authenticate.
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- prefix:
- description: Prefix adds a prefix to all retrieved values.
- type: string
- region:
- description: AWS Region to be used for the provider
- type: string
- role:
- description: Role is a Role ARN which the provider will assume
- type: string
- secretsManager:
- description: SecretsManager defines how the provider behaves when interacting with AWS SecretsManager
- properties:
- forceDeleteWithoutRecovery:
- description: |-
- Specifies whether to delete the secret without any recovery window. You
- can't use both this parameter and RecoveryWindowInDays in the same call.
- If you don't use either, then by default Secrets Manager uses a 30 day
- recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-ForceDeleteWithoutRecovery
- type: boolean
- recoveryWindowInDays:
- description: |-
- The number of days from 7 to 30 that Secrets Manager waits before
- permanently deleting the secret. You can't use both this parameter and
- ForceDeleteWithoutRecovery in the same call. If you don't use either,
- then by default Secrets Manager uses a 30 day recovery window.
- see: https://docs.aws.amazon.com/secretsmanager/latest/apireference/API_DeleteSecret.html#SecretsManager-DeleteSecret-request-RecoveryWindowInDays
- format: int64
- type: integer
- type: object
- service:
- description: Service defines which service should be used to fetch the secrets
- enum:
- - SecretsManager
- - ParameterStore
- type: string
- sessionTags:
- description: AWS STS assume role session tags
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- transitiveTagKeys:
- description: AWS STS assume role transitive session tags. Required when multiple rules are used with the provider
- items:
- type: string
- type: array
- required:
- - region
- - service
- type: object
- azurekv:
- description: AzureKV configures this store to sync secrets using Azure Key Vault provider
- properties:
- authSecretRef:
- description: Auth configures how the operator authenticates with Azure. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- properties:
- clientCertificate:
- description: The Azure ClientCertificate of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientId:
- description: The Azure clientId of the service principle or managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: The Azure ClientSecret of the service principle used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- tenantId:
- description: The Azure tenantId of the managed identity used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- authType:
- default: ServicePrincipal
- description: |-
- Auth type defines how to authenticate to the keyvault service.
- Valid values are:
- - "ServicePrincipal" (default): Using a service principal (tenantId, clientId, clientSecret)
- - "ManagedIdentity": Using Managed Identity assigned to the pod (see aad-pod-identity)
- enum:
- - ServicePrincipal
- - ManagedIdentity
- - WorkloadIdentity
- type: string
- environmentType:
- default: PublicCloud
- description: |-
- EnvironmentType specifies the Azure cloud environment endpoints to use for
- connecting and authenticating with Azure. By default it points to the public cloud AAD endpoint.
- The following endpoints are available, also see here: https://github.com/Azure/go-autorest/blob/main/autorest/azure/environments.go#L152
- PublicCloud, USGovernmentCloud, ChinaCloud, GermanCloud
- enum:
- - PublicCloud
- - USGovernmentCloud
- - ChinaCloud
- - GermanCloud
- type: string
- identityId:
- description: If multiple Managed Identity is assigned to the pod, you can select the one to be used
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- tenantId:
- description: TenantID configures the Azure Tenant to send requests to. Required for ServicePrincipal auth type. Optional for WorkloadIdentity.
- type: string
- vaultUrl:
- description: Vault Url from which the secrets to be fetched from.
- type: string
- required:
- - vaultUrl
- type: object
- bitwardensecretsmanager:
- description: BitwardenSecretsManager configures this store to sync secrets using BitwardenSecretsManager provider
- properties:
- apiURL:
- type: string
- auth:
- description: |-
- Auth configures how secret-manager authenticates with a bitwarden machine account instance.
- Make sure that the token being used has permissions on the given secret.
- properties:
- secretRef:
- description: BitwardenSecretsManagerSecretRef contains the credential ref to the bitwarden instance.
- properties:
- credentials:
- description: AccessToken used for the bitwarden instance.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - credentials
- type: object
- required:
- - secretRef
- type: object
- bitwardenServerSDKURL:
- type: string
- caBundle:
- description: |-
- Base64 encoded certificate for the bitwarden server sdk. The sdk MUST run with HTTPS to make sure no MITM attack
- can be performed.
- type: string
- identityURL:
- type: string
- organizationID:
- description: OrganizationID determines which organization this secret store manages.
- type: string
- projectID:
- description: ProjectID determines which project this secret store manages.
- type: string
- required:
- - auth
- - caBundle
- - organizationID
- - projectID
- type: object
- chef:
- description: Chef configures this store to sync secrets with chef server
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against chef Server
- properties:
- secretRef:
- description: ChefAuthSecretRef holds secret references for chef server login credentials.
- properties:
- privateKeySecretRef:
- description: SecretKey is the Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - privateKeySecretRef
- type: object
- required:
- - secretRef
- type: object
- serverUrl:
- description: ServerURL is the chef server URL used to connect to. If using orgs you should include your org in the url and terminate the url with a "/"
- type: string
- username:
- description: UserName should be the user ID on the chef server
- type: string
- required:
- - auth
- - serverUrl
- - username
- type: object
- conjur:
- description: Conjur configures this store to sync secrets using conjur provider
- properties:
- auth:
- properties:
- apikey:
- properties:
- account:
- type: string
- apiKeyRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - account
- - apiKeyRef
- - userRef
- type: object
- jwt:
- properties:
- account:
- type: string
- hostId:
- description: |-
- Optional HostID for JWT authentication. This may be used depending
- on how the Conjur JWT authenticator policy is configured.
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Conjur using the JWT authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional ServiceAccountRef specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- serviceID:
- description: The conjur authn jwt webservice id
- type: string
- required:
- - account
- - serviceID
- type: object
- type: object
- caBundle:
- type: string
- caProvider:
- description: |-
- Used to provide custom certificate authority (CA) certificates
- for a secret store. The CAProvider points to a Secret or ConfigMap resource
- that contains a PEM-encoded certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- type: string
- required:
- - auth
- - url
- type: object
- delinea:
- description: |-
- Delinea DevOps Secrets Vault
- https://docs.delinea.com/online-help/products/devops-secrets-vault/current
- properties:
- clientId:
- description: ClientID is the non-secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- clientSecret:
- description: ClientSecret is the secret part of the credential.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- tenant:
- description: Tenant is the chosen hostname / site name.
- type: string
- tld:
- description: |-
- TLD is based on the server location that was chosen during provisioning.
- If unset, defaults to "com".
- type: string
- urlTemplate:
- description: |-
- URLTemplate
- If unset, defaults to "https://%s.secretsvaultcloud.%s/v1/%s%s".
- type: string
- required:
- - clientId
- - clientSecret
- - tenant
- type: object
- device42:
- description: Device42 configures this store to sync secrets using the Device42 provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Device42 instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- host:
- description: URL configures the Device42 instance URL.
- type: string
- required:
- - auth
- - host
- type: object
- doppler:
- description: Doppler configures this store to sync secrets using the Doppler provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Doppler API
- properties:
- secretRef:
- properties:
- dopplerToken:
- description: |-
- The DopplerToken is used for authentication.
- See https://docs.doppler.com/reference/api#authentication for auth token types.
- The Key attribute defaults to dopplerToken if not specified.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - dopplerToken
- type: object
- required:
- - secretRef
- type: object
- config:
- description: Doppler config (required if not using a Service Token)
- type: string
- format:
- description: Format enables the downloading of secrets as a file (string)
- enum:
- - json
- - dotnet-json
- - env
- - yaml
- - docker
- type: string
- nameTransformer:
- description: Environment variable compatible name transforms that change secret names to a different format
- enum:
- - upper-camel
- - camel
- - lower-snake
- - tf-var
- - dotnet-env
- - lower-kebab
- type: string
- project:
- description: Doppler project (required if not using a Service Token)
- type: string
- required:
- - auth
- type: object
- fake:
- description: Fake configures a store with static key/value pairs
- properties:
- data:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- valueMap:
- additionalProperties:
- type: string
- description: 'Deprecated: ValueMap is deprecated and is intended to be removed in the future, use the `value` field instead.'
- type: object
- version:
- type: string
- required:
- - key
- type: object
- type: array
- required:
- - data
- type: object
- fortanix:
- description: Fortanix configures this store to sync secrets using the Fortanix provider
- properties:
- apiKey:
- description: APIKey is the API token to access SDKMS Applications.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the SDKMS API Key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- description: APIURL is the URL of SDKMS API. Defaults to `sdkms.fortanix.com`.
- type: string
- type: object
- gcpsm:
- description: GCPSM configures this store to sync secrets using Google Cloud Platform Secret Manager provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against GCP
- properties:
- secretRef:
- properties:
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- workloadIdentity:
- properties:
- clusterLocation:
- type: string
- clusterName:
- type: string
- clusterProjectID:
- type: string
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - clusterLocation
- - clusterName
- - serviceAccountRef
- type: object
- type: object
- location:
- description: Location optionally defines a location for a secret
- type: string
- projectID:
- description: ProjectID project where secret is located
- type: string
- type: object
- gitlab:
- description: GitLab configures this store to sync secrets using GitLab Variables provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a GitLab instance.
- properties:
- SecretRef:
- properties:
- accessToken:
- description: AccessToken is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - SecretRef
- type: object
- environment:
- description: Environment environment_scope of gitlab CI/CD variables (Please see https://docs.gitlab.com/ee/ci/environments/#create-a-static-environment on how to create environments)
- type: string
- groupIDs:
- description: GroupIDs specify, which gitlab groups to pull secrets from. Group secrets are read from left to right followed by the project variables.
- items:
- type: string
- type: array
- inheritFromGroups:
- description: InheritFromGroups specifies whether parent groups should be discovered and checked for secrets.
- type: boolean
- projectID:
- description: ProjectID specifies a project where secrets are located.
- type: string
- url:
- description: URL configures the GitLab instance URL. Defaults to https://gitlab.com/.
- type: string
- required:
- - auth
- type: object
- ibm:
- description: IBM configures this store to sync secrets using IBM Cloud provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the IBM secrets manager.
- maxProperties: 1
- minProperties: 1
- properties:
- containerAuth:
- description: IBM Container-based auth with IAM Trusted Profile.
- properties:
- iamEndpoint:
- type: string
- profile:
- description: the IBM Trusted Profile
- type: string
- tokenLocation:
- description: Location the token is mounted on the pod
- type: string
- required:
- - profile
- type: object
- secretRef:
- properties:
- secretApiKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- serviceUrl:
- description: ServiceURL is the Endpoint URL that is specific to the Secrets Manager service instance
- type: string
- required:
- - auth
- type: object
- infisical:
- description: Infisical configures this store to sync secrets using the Infisical provider
- properties:
- auth:
- description: Auth configures how the Operator authenticates with the Infisical API
- properties:
- universalAuthCredentials:
- properties:
- clientId:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientSecret:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecret
- type: object
- type: object
- hostAPI:
- default: https://app.infisical.com/api
- type: string
- secretsScope:
- properties:
- environmentSlug:
- type: string
- projectSlug:
- type: string
- secretsPath:
- default: /
- type: string
- required:
- - environmentSlug
- - projectSlug
- type: object
- required:
- - auth
- - secretsScope
- type: object
- keepersecurity:
- description: KeeperSecurity configures this store to sync secrets using the KeeperSecurity provider
- properties:
- authRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- folderID:
- type: string
- required:
- - authRef
- - folderID
- type: object
- kubernetes:
- description: Kubernetes configures this store to sync secrets using a Kubernetes cluster provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Kubernetes instance.
- maxProperties: 1
- minProperties: 1
- properties:
- cert:
- description: has both clientCert and clientKey as secretKeySelector
- properties:
- clientCert:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- clientKey:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- serviceAccount:
- description: points to a service account that should be used for authentication
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- token:
- description: use static token to authenticate with
- properties:
- bearerToken:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- type: object
- authRef:
- description: A reference to a secret that contains the auth information.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- remoteNamespace:
- default: default
- description: Remote namespace to fetch the secrets from
- type: string
- server:
- description: configures the Kubernetes server Address.
- properties:
- caBundle:
- description: CABundle is a base64-encoded CA certificate
- format: byte
- type: string
- caProvider:
- description: 'see: https://external-secrets.io/v0.4.1/spec/#external-secrets.io/v1alpha1.CAProvider'
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- url:
- default: kubernetes.default
- description: configures the Kubernetes server Address.
- type: string
- type: object
- type: object
- onboardbase:
- description: Onboardbase configures this store to sync secrets using the Onboardbase provider
- properties:
- apiHost:
- default: https://public.onboardbase.com/api/v1/
- description: APIHost use this to configure the host url for the API for selfhosted installation, default is https://public.onboardbase.com/api/v1/
- type: string
- auth:
- description: Auth configures how the Operator authenticates with the Onboardbase API
- properties:
- apiKeyRef:
- description: |-
- OnboardbaseAPIKey is the APIKey generated by an admin account.
- It is used to recognize and authorize access to a project and environment within onboardbase
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- passcodeRef:
- description: OnboardbasePasscode is the passcode attached to the API Key
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - apiKeyRef
- - passcodeRef
- type: object
- environment:
- default: development
- description: Environment is the name of an environmnent within a project to pull the secrets from
- type: string
- project:
- default: development
- description: Project is an onboardbase project that the secrets should be pulled from
- type: string
- required:
- - apiHost
- - auth
- - environment
- - project
- type: object
- onepassword:
- description: OnePassword configures this store to sync secrets using the 1Password Cloud provider
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against OnePassword Connect Server
- properties:
- secretRef:
- description: OnePasswordAuthSecretRef holds secret references for 1Password credentials.
- properties:
- connectTokenSecretRef:
- description: The ConnectToken is used for authentication to a 1Password Connect Server.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - connectTokenSecretRef
- type: object
- required:
- - secretRef
- type: object
- connectHost:
- description: ConnectHost defines the OnePassword Connect Server to connect to
- type: string
- vaults:
- additionalProperties:
- type: integer
- description: Vaults defines which OnePassword vaults to search in which order
- type: object
- required:
- - auth
- - connectHost
- - vaults
- type: object
- oracle:
- description: Oracle configures this store to sync secrets using Oracle Vault provider
- properties:
- auth:
- description: |-
- Auth configures how secret-manager authenticates with the Oracle Vault.
- If empty, use the instance principal, otherwise the user credentials specified in Auth.
- properties:
- secretRef:
- description: SecretRef to pass through sensitive information.
- properties:
- fingerprint:
- description: Fingerprint is the fingerprint of the API private key.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privatekey:
- description: PrivateKey is the user's API Signing Key in PEM format, used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - fingerprint
- - privatekey
- type: object
- tenancy:
- description: Tenancy is the tenancy OCID where user is located.
- type: string
- user:
- description: User is an access OCID specific to the account.
- type: string
- required:
- - secretRef
- - tenancy
- - user
- type: object
- compartment:
- description: |-
- Compartment is the vault compartment OCID.
- Required for PushSecret
- type: string
- encryptionKey:
- description: |-
- EncryptionKey is the OCID of the encryption key within the vault.
- Required for PushSecret
- type: string
- principalType:
- description: |-
- The type of principal to use for authentication. If left blank, the Auth struct will
- determine the principal type. This optional field must be specified if using
- workload identity.
- enum:
- - ""
- - UserPrincipal
- - InstancePrincipal
- - Workload
- type: string
- region:
- description: Region is the region where vault is located.
- type: string
- serviceAccountRef:
- description: |-
- ServiceAccountRef specified the service account
- that should be used when authenticating with WorkloadIdentity.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- vault:
- description: Vault is the vault's OCID of the specific vault where secret is located.
- type: string
- required:
- - region
- - vault
- type: object
- passbolt:
- properties:
- auth:
- description: Auth defines the information necessary to authenticate against Passbolt Server
- properties:
- passwordSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- privateKeySecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - passwordSecretRef
- - privateKeySecretRef
- type: object
- host:
- description: Host defines the Passbolt Server to connect to
- type: string
- required:
- - auth
- - host
- type: object
- passworddepot:
- description: Configures a store to sync secrets with a Password Depot instance.
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with a Password Depot instance.
- properties:
- secretRef:
- properties:
- credentials:
- description: Username / Password is used for authentication.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - secretRef
- type: object
- database:
- description: Database to use as source
- type: string
- host:
- description: URL configures the Password Depot instance URL.
- type: string
- required:
- - auth
- - database
- - host
- type: object
- pulumi:
- description: Pulumi configures this store to sync secrets using the Pulumi provider
- properties:
- accessToken:
- description: AccessToken is the access tokens to sign in to the Pulumi Cloud Console.
- properties:
- secretRef:
- description: SecretRef is a reference to a secret containing the Pulumi API token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- apiUrl:
- default: https://api.pulumi.com/api/preview
- description: APIURL is the URL of the Pulumi API.
- type: string
- environment:
- description: |-
- Environment are YAML documents composed of static key-value pairs, programmatic expressions,
- dynamically retrieved values from supported providers including all major clouds,
- and other Pulumi ESC environments.
- To create a new environment, visit https://www.pulumi.com/docs/esc/environments/ for more information.
- type: string
- organization:
- description: |-
- Organization are a space to collaborate on shared projects and stacks.
- To create a new organization, visit https://app.pulumi.com/ and click "New Organization".
- type: string
- required:
- - accessToken
- - environment
- - organization
- type: object
- scaleway:
- description: Scaleway
- properties:
- accessKey:
- description: AccessKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- apiUrl:
- description: APIURL is the url of the api to use. Defaults to https://api.scaleway.com
- type: string
- projectId:
- description: 'ProjectID is the id of your project, which you can find in the console: https://console.scaleway.com/project/settings'
- type: string
- region:
- description: 'Region where your secrets are located: https://developers.scaleway.com/en/quickstart/#region-and-zone'
- type: string
- secretKey:
- description: SecretKey is the non-secret part of the api key.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - accessKey
- - projectId
- - region
- - secretKey
- type: object
- secretserver:
- description: |-
- SecretServer configures this store to sync secrets using SecretServer provider
- https://docs.delinea.com/online-help/secret-server/start.htm
- properties:
- password:
- description: Password is the secret server account password.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- serverURL:
- description: |-
- ServerURL
- URL to your secret server installation
- type: string
- username:
- description: Username is the secret server account username.
- properties:
- secretRef:
- description: SecretRef references a key in a secret that will be used as value.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- value:
- description: Value can be specified directly to set a value without using a secret.
- type: string
- type: object
- required:
- - password
- - serverURL
- - username
- type: object
- senhasegura:
- description: Senhasegura configures this store to sync secrets using senhasegura provider
- properties:
- auth:
- description: Auth defines parameters to authenticate in senhasegura
- properties:
- clientId:
- type: string
- clientSecretSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - clientId
- - clientSecretSecretRef
- type: object
- ignoreSslCertificate:
- default: false
- description: IgnoreSslCertificate defines if SSL certificate must be ignored
- type: boolean
- module:
- description: Module defines which senhasegura module should be used to get secrets
- type: string
- url:
- description: URL of senhasegura
- type: string
- required:
- - auth
- - module
- - url
- type: object
- vault:
- description: Vault configures this store to sync secrets using Hashi provider
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- webhook:
- description: Webhook configures this store to sync secrets using a generic templated webhook
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- yandexcertificatemanager:
- description: YandexCertificateManager configures this store to sync secrets using Yandex Certificate Manager provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Certificate Manager
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- yandexlockbox:
- description: YandexLockbox configures this store to sync secrets using Yandex Lockbox provider
- properties:
- apiEndpoint:
- description: Yandex.Cloud API endpoint (e.g. 'api.cloud.yandex.net:443')
- type: string
- auth:
- description: Auth defines the information necessary to authenticate against Yandex Lockbox
- properties:
- authorizedKeySecretRef:
- description: The authorized key used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- caProvider:
- description: The provider for the CA bundle to use to validate Yandex.Cloud server certificate.
- properties:
- certSecretRef:
- description: |-
- A reference to a specific 'key' within a Secret resource,
- In some instances, `key` is a required field.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- required:
- - auth
- type: object
- type: object
- refreshInterval:
- description: Used to configure store refresh interval in seconds. Empty or 0 will default to the controller config.
- type: integer
- retrySettings:
- description: Used to configure http retries if failed
- properties:
- maxRetries:
- format: int32
- type: integer
- retryInterval:
- type: string
- type: object
- required:
- - provider
- type: object
- status:
- description: SecretStoreStatus defines the observed state of the SecretStore.
- properties:
- capabilities:
- description: SecretStoreCapabilities defines the possible operations a SecretStore can do.
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - status
- - type
- type: object
- type: array
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/vaultdynamicsecret.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: vaultdynamicsecrets.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - vaultdynamicsecret
- kind: VaultDynamicSecret
- listKind: VaultDynamicSecretList
- plural: vaultdynamicsecrets
- shortNames:
- - vaultdynamicsecret
- singular: vaultdynamicsecret
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- 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:
- properties:
- controller:
- description: |-
- Used to select the correct ESO controller (think: ingress.ingressClassName)
- The ESO controller is instantiated with a specific controller name and filters VDS based on this property
- type: string
- method:
- description: Vault API method to use (GET/POST/other)
- type: string
- parameters:
- description: Parameters to pass to Vault write (for non-GET methods)
- x-kubernetes-preserve-unknown-fields: true
- path:
- description: Vault path to obtain the dynamic secret from
- type: string
- provider:
- description: Vault provider common spec
- properties:
- auth:
- description: Auth configures how secret-manager authenticates with the Vault server.
- properties:
- appRole:
- description: |-
- AppRole authenticates with Vault using the App Role auth mechanism,
- with the role and secret stored in a Kubernetes Secret resource.
- properties:
- path:
- default: approle
- description: |-
- Path where the App Role authentication backend is mounted
- in Vault, e.g: "approle"
- type: string
- roleId:
- description: |-
- RoleID configured in the App Role authentication backend when setting
- up the authentication backend in Vault.
- type: string
- roleRef:
- description: |-
- Reference to a key in a Secret that contains the App Role ID used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role id.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- Reference to a key in a Secret that contains the App Role secret used
- to authenticate with Vault.
- The `key` field must be specified and denotes which entry within the Secret
- resource is used as the app role secret.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- - secretRef
- type: object
- cert:
- description: |-
- Cert authenticates with TLS Certificates by passing client certificate, private key and ca certificate
- Cert authentication method
- properties:
- clientCert:
- description: |-
- ClientCert is a certificate to authenticate using the Cert Vault
- authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing client private key to
- authenticate with Vault using the Cert authentication method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- iam:
- description: |-
- Iam authenticates with vault by passing a special AWS request signed with AWS IAM credentials
- AWS IAM authentication method
- properties:
- externalID:
- description: AWS External ID set on assumed IAM roles
- type: string
- jwt:
- description: Specify a service account with IRSA enabled
- properties:
- serviceAccountRef:
- description: A reference to a ServiceAccount resource.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- type: object
- path:
- description: 'Path where the AWS auth method is enabled in Vault, e.g: "aws"'
- type: string
- region:
- description: AWS region
- type: string
- role:
- description: This is the AWS role to be assumed before talking to vault
- type: string
- secretRef:
- description: Specify credentials in a Secret object
- properties:
- accessKeyIDSecretRef:
- description: The AccessKeyID is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- secretAccessKeySecretRef:
- description: The SecretAccessKey is used for authentication
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- sessionTokenSecretRef:
- description: |-
- The SessionToken used for authentication
- This must be defined if AccessKeyID and SecretAccessKey are temporary credentials
- see: https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_use-resources.html
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- vaultAwsIamServerID:
- description: 'X-Vault-AWS-IAM-Server-ID is an additional header used by Vault IAM auth method to mitigate against different types of replay attacks. More details here: https://developer.hashicorp.com/vault/docs/auth/aws'
- type: string
- vaultRole:
- description: Vault Role. In vault, a role describes an identity with a set of permissions, groups, or policies you want to attach a user of the secrets engine
- type: string
- required:
- - vaultRole
- type: object
- jwt:
- description: |-
- Jwt authenticates with Vault by passing role and JWT token using the
- JWT/OIDC authentication method
- properties:
- kubernetesServiceAccountToken:
- description: |-
- Optional ServiceAccountToken specifies the Kubernetes service account for which to request
- a token for with the `TokenRequest` API.
- properties:
- audiences:
- description: |-
- Optional audiences field that will be used to request a temporary Kubernetes service
- account token for the service account referenced by `serviceAccountRef`.
- Defaults to a single audience `vault` it not specified.
- Deprecated: use serviceAccountRef.Audiences instead
- items:
- type: string
- type: array
- expirationSeconds:
- description: |-
- Optional expiration time in seconds that will be used to request a temporary
- Kubernetes service account token for the service account referenced by
- `serviceAccountRef`.
- Deprecated: this will be removed in the future.
- Defaults to 10 minutes.
- format: int64
- type: integer
- serviceAccountRef:
- description: Service account field containing the name of a kubernetes ServiceAccount.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - serviceAccountRef
- type: object
- path:
- default: jwt
- description: |-
- Path where the JWT authentication backend is mounted
- in Vault, e.g: "jwt"
- type: string
- role:
- description: |-
- Role is a JWT role to authenticate using the JWT/OIDC Vault
- authentication method
- type: string
- secretRef:
- description: |-
- Optional SecretRef that refers to a key in a Secret resource containing JWT token to
- authenticate with Vault using the JWT/OIDC authentication method.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- required:
- - path
- type: object
- kubernetes:
- description: |-
- Kubernetes authenticates with Vault by passing the ServiceAccount
- token stored in the named Secret resource to the Vault server.
- properties:
- mountPath:
- default: kubernetes
- description: |-
- Path where the Kubernetes authentication backend is mounted in Vault, e.g:
- "kubernetes"
- type: string
- role:
- description: |-
- A required field containing the Vault Role to assume. A Role binds a
- Kubernetes ServiceAccount with a set of Vault policies.
- type: string
- secretRef:
- description: |-
- Optional secret field containing a Kubernetes ServiceAccount JWT used
- for authenticating with Vault. If a name is specified without a key,
- `token` is the default. If one is not specified, the one bound to
- the controller will be used.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- serviceAccountRef:
- description: |-
- Optional service account field containing the name of a kubernetes ServiceAccount.
- If the service account is specified, the service account secret token JWT will be used
- for authenticating with Vault. If the service account selector is not supplied,
- the secretRef will be used instead.
- properties:
- audiences:
- description: |-
- Audience specifies the `aud` claim for the service account token
- If the service account uses a well-known annotation for e.g. IRSA or GCP Workload Identity
- then this audiences will be appended to the list
- items:
- type: string
- type: array
- name:
- description: The name of the ServiceAccount resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- required:
- - name
- type: object
- required:
- - mountPath
- - role
- type: object
- ldap:
- description: |-
- Ldap authenticates with Vault by passing username/password pair using
- the LDAP authentication method
- properties:
- path:
- default: ldap
- description: |-
- Path where the LDAP authentication backend is mounted
- in Vault, e.g: "ldap"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the LDAP
- user used to authenticate with Vault using the LDAP authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a LDAP user name used to authenticate using the LDAP Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- namespace:
- description: |-
- Name of the vault namespace to authenticate to. This can be different than the namespace your secret is in.
- Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- This will default to Vault.Namespace field if set, or empty otherwise
- type: string
- tokenSecretRef:
- description: TokenSecretRef authenticates with Vault by presenting a token.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- userPass:
- description: UserPass authenticates with Vault by passing username/password pair
- properties:
- path:
- default: user
- description: |-
- Path where the UserPassword authentication backend is mounted
- in Vault, e.g: "user"
- type: string
- secretRef:
- description: |-
- SecretRef to a key in a Secret resource containing password for the
- user used to authenticate with Vault using the UserPass authentication
- method
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- username:
- description: |-
- Username is a user name used to authenticate using the UserPass Vault
- authentication method
- type: string
- required:
- - path
- - username
- type: object
- type: object
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate Vault server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate Vault server certificate.
- properties:
- key:
- description: The key where the CA certificate can be found in the Secret or ConfigMap.
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: |-
- The namespace the Provider type is in.
- Can only be defined when used in a ClusterSecretStore.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- forwardInconsistent:
- description: |-
- ForwardInconsistent tells Vault to forward read-after-write requests to the Vault
- leader instead of simply retrying within a loop. This can increase performance if
- the option is enabled serverside.
- https://www.vaultproject.io/docs/configuration/replication#allow_forwarding_via_header
- type: boolean
- headers:
- additionalProperties:
- type: string
- description: Headers to be added in Vault request
- type: object
- namespace:
- description: |-
- Name of the vault namespace. Namespaces is a set of features within Vault Enterprise that allows
- Vault environments to support Secure Multi-tenancy. e.g: "ns1".
- More about namespaces can be found here https://www.vaultproject.io/docs/enterprise/namespaces
- type: string
- path:
- description: |-
- Path is the mount path of the Vault KV backend endpoint, e.g:
- "secret". The v2 KV secret engine version specific "/data" path suffix
- for fetching secrets from Vault is optional and will be appended
- if not present in specified path.
- type: string
- readYourWrites:
- description: |-
- ReadYourWrites ensures isolated read-after-write semantics by
- providing discovered cluster replication states in each request.
- More information about eventual consistency in Vault can be found here
- https://www.vaultproject.io/docs/enterprise/consistency
- type: boolean
- server:
- description: 'Server is the connection address for the Vault server, e.g: "https://vault.example.com:8200".'
- type: string
- tls:
- description: |-
- The configuration used for client side related TLS communication, when the Vault server
- requires mutual authentication. Only used if the Server URL is using HTTPS protocol.
- This parameter is ignored for plain HTTP protocol connection.
- It's worth noting this configuration is different from the "TLS certificates auth method",
- which is available under the `auth.cert` section.
- properties:
- certSecretRef:
- description: |-
- CertSecretRef is a certificate added to the transport layer
- when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.crt'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- keySecretRef:
- description: |-
- KeySecretRef to a key in a Secret resource containing client private key
- added to the transport layer when communicating with the Vault server.
- If no key for the Secret is specified, external-secret will default to 'tls.key'.
- properties:
- key:
- description: |-
- The key of the entry in the Secret resource's `data` field to be used. Some instances of this field may be
- defaulted, in others it may be required.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- namespace:
- description: |-
- Namespace of the resource being referred to. Ignored if referent is not cluster-scoped. cluster-scoped defaults
- to the namespace of the referent.
- type: string
- type: object
- type: object
- version:
- default: v2
- description: |-
- Version is the Vault KV secret engine version. This can be either "v1" or
- "v2". Version defaults to "v2".
- enum:
- - v1
- - v2
- type: string
- required:
- - auth
- - server
- type: object
- resultType:
- default: Data
- description: |-
- Result type defines which data is returned from the generator.
- By default it is the "data" section of the Vault API response.
- When using e.g. /auth/token/create the "data" section is empty but
- the "auth" section contains the generated token.
- Please refer to the vault docs regarding the result data structure.
- enum:
- - Data
- - Auth
- type: string
- required:
- - path
- - provider
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/crds/webhook.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.15.0
- labels:
- external-secrets.io/component: controller
- name: webhooks.generators.external-secrets.io
-spec:
- group: generators.external-secrets.io
- names:
- categories:
- - webhook
- kind: Webhook
- listKind: WebhookList
- plural: webhooks
- shortNames:
- - webhookl
- singular: webhook
- scope: Namespaced
- versions:
- - name: v1alpha1
- schema:
- openAPIV3Schema:
- description: |-
- Webhook connects to a third party API server to handle the secrets generation
- configuration parameters in spec.
- You can specify the server, the token, and additional body parameters.
- See documentation for the full API specification for requests and responses.
- 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: WebhookSpec controls the behavior of the external generator. Any body parameters should be passed to the server through the parameters field.
- properties:
- body:
- description: Body
- type: string
- caBundle:
- description: |-
- PEM encoded CA bundle used to validate webhook server certificate. Only used
- if the Server URL is using HTTPS protocol. This parameter is ignored for
- plain HTTP protocol connection. If not set the system root certificates
- are used to validate the TLS connection.
- format: byte
- type: string
- caProvider:
- description: The provider for the CA bundle to use to validate webhook server certificate.
- properties:
- key:
- description: The key the value inside of the provider type to use, only used with "Secret" type
- type: string
- name:
- description: The name of the object located at the provider type.
- type: string
- namespace:
- description: The namespace the Provider type is in.
- type: string
- type:
- description: The type of provider to use such as "Secret", or "ConfigMap".
- enum:
- - Secret
- - ConfigMap
- type: string
- required:
- - name
- - type
- type: object
- headers:
- additionalProperties:
- type: string
- description: Headers
- type: object
- method:
- description: Webhook Method
- type: string
- result:
- description: Result formatting
- properties:
- jsonPath:
- description: Json path of return value
- type: string
- type: object
- secrets:
- description: |-
- Secrets to fill in templates
- These secrets will be passed to the templating function as key value pairs under the given name
- items:
- properties:
- name:
- description: Name of this secret in templates
- type: string
- secretRef:
- description: Secret ref to fill in credentials
- properties:
- key:
- description: The key where the token is found.
- type: string
- name:
- description: The name of the Secret resource being referred to.
- type: string
- type: object
- required:
- - name
- - secretRef
- type: object
- type: array
- timeout:
- description: Timeout
- type: string
- url:
- description: Webhook url to call
- type: string
- required:
- - result
- - url
- type: object
- type: object
- served: true
- storage: true
- subresources:
- status: {}
- conversion:
- strategy: Webhook
- webhook:
- conversionReviewVersions:
- - v1
- clientConfig:
- service:
- name: common-golang-external-secrets-webhook
- namespace: "default"
- path: /convert
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-cert-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "apiextensions.k8s.io"
- resources:
- - "customresourcedefinitions"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - "admissionregistration.k8s.io"
- resources:
- - "validatingwebhookconfigurations"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "endpoints"
- verbs:
- - "list"
- - "get"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "events"
- verbs:
- - "create"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "secrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "update"
- - "patch"
- - apiGroups:
- - "coordination.k8s.io"
- resources:
- - "leases"
- verbs:
- - "get"
- - "create"
- - "update"
- - "patch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "secretstores"
- - "clustersecretstores"
- - "externalsecrets"
- - "clusterexternalsecrets"
- - "pushsecrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "externalsecrets/status"
- - "externalsecrets/finalizers"
- - "secretstores"
- - "secretstores/status"
- - "secretstores/finalizers"
- - "clustersecretstores"
- - "clustersecretstores/status"
- - "clustersecretstores/finalizers"
- - "clusterexternalsecrets"
- - "clusterexternalsecrets/status"
- - "clusterexternalsecrets/finalizers"
- - "pushsecrets"
- - "pushsecrets/status"
- - "pushsecrets/finalizers"
- verbs:
- - "get"
- - "update"
- - "patch"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "serviceaccounts"
- - "namespaces"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- verbs:
- - "get"
- - "list"
- - "watch"
- - apiGroups:
- - ""
- resources:
- - "secrets"
- verbs:
- - "get"
- - "list"
- - "watch"
- - "create"
- - "update"
- - "delete"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "serviceaccounts/token"
- verbs:
- - "create"
- - apiGroups:
- - ""
- resources:
- - "events"
- verbs:
- - "create"
- - "patch"
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- verbs:
- - "create"
- - "update"
- - "delete"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-view
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- rbac.authorization.k8s.io/aggregate-to-view: "true"
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "secretstores"
- - "clustersecretstores"
- - "pushsecrets"
- verbs:
- - "get"
- - "watch"
- - "list"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "get"
- - "watch"
- - "list"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-edit
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- - "secretstores"
- - "clustersecretstores"
- - "pushsecrets"
- verbs:
- - "create"
- - "delete"
- - "deletecollection"
- - "patch"
- - "update"
- - apiGroups:
- - "generators.external-secrets.io"
- resources:
- - "acraccesstokens"
- - "ecrauthorizationtokens"
- - "fakes"
- - "gcraccesstokens"
- - "githubaccesstokens"
- - "passwords"
- - "vaultdynamicsecrets"
- - "webhooks"
- verbs:
- - "create"
- - "delete"
- - "deletecollection"
- - "patch"
- - "update"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- name: common-golang-external-secrets-servicebindings
- labels:
- servicebinding.io/controller: "true"
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - "external-secrets.io"
- resources:
- - "externalsecrets"
- verbs:
- - "get"
- - "list"
- - "watch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-golang-external-secrets-cert-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: common-golang-external-secrets-cert-controller
-subjects:
- - name: external-secrets-cert-controller
- namespace: default
- kind: ServiceAccount
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-golang-external-secrets-controller
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: common-golang-external-secrets-controller
-subjects:
- - name: common-golang-external-secrets
- namespace: default
- kind: ServiceAccount
----
-# Source: golang-external-secrets/templates/golang-external-secrets-hub-clusterrolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: role-tokenreview-binding
- namespace: default
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: golang-external-secrets
- namespace: golang-external-secrets
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: common-golang-external-secrets-leaderelection
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-rules:
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- resourceNames:
- - "external-secrets-controller"
- verbs:
- - "get"
- - "update"
- - "patch"
- - apiGroups:
- - ""
- resources:
- - "configmaps"
- verbs:
- - "create"
- - apiGroups:
- - "coordination.k8s.io"
- resources:
- - "leases"
- verbs:
- - "get"
- - "create"
- - "update"
- - "patch"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/rbac.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: common-golang-external-secrets-leaderelection
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: common-golang-external-secrets-leaderelection
-subjects:
- - kind: ServiceAccount
- name: common-golang-external-secrets
- namespace: default
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- external-secrets.io/component: webhook
-spec:
- type: ClusterIP
- ports:
- - port: 443
- targetPort: 10250
- protocol: TCP
- name: webhook
- selector:
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
----
-# Source: golang-external-secrets/charts/external-secrets/templates/cert-controller-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets-cert-controller
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-cert-controller
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- serviceAccountName: external-secrets-cert-controller
- automountServiceAccountToken: true
- hostNetwork: false
- containers:
- - name: cert-controller
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - certcontroller
- - --crd-requeue-interval=5m
- - --service-name=common-golang-external-secrets-webhook
- - --service-namespace=default
- - --secret-name=common-golang-external-secrets-webhook
- - --secret-namespace=default
- - --metrics-addr=:8080
- - --healthz-addr=:8081
- - --loglevel=info
- - --zap-time-encoding=epoch
- - --enable-partial-cache=true
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- readinessProbe:
- httpGet:
- port: 8081
- path: /readyz
- initialDelaySeconds: 20
- periodSeconds: 5
----
-# Source: golang-external-secrets/charts/external-secrets/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- serviceAccountName: common-golang-external-secrets
- automountServiceAccountToken: true
- hostNetwork: false
- containers:
- - name: external-secrets
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - --concurrent=1
- - --metrics-addr=:8080
- - --loglevel=info
- - --zap-time-encoding=epoch
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- dnsPolicy: ClusterFirst
----
-# Source: golang-external-secrets/charts/external-secrets/templates/webhook-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: common-golang-external-secrets-webhook
- namespace: default
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
-spec:
- replicas: 1
- revisionHistoryLimit: 10
- selector:
- matchLabels:
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- template:
- metadata:
- labels:
- helm.sh/chart: external-secrets-0.10.0
- app.kubernetes.io/name: external-secrets-webhook
- app.kubernetes.io/instance: common-golang-external-secrets
- app.kubernetes.io/version: "v0.10.0"
- app.kubernetes.io/managed-by: Helm
- spec:
- hostNetwork: false
- serviceAccountName: external-secrets-webhook
- automountServiceAccountToken: true
- containers:
- - name: webhook
- securityContext:
- allowPrivilegeEscalation: false
- capabilities:
- drop:
- - ALL
- readOnlyRootFilesystem: true
- runAsNonRoot: true
- image: ghcr.io/external-secrets/external-secrets:v0.10.0-ubi
- imagePullPolicy: IfNotPresent
- args:
- - webhook
- - --port=10250
- - --dns-name=common-golang-external-secrets-webhook.default.svc
- - --cert-dir=/tmp/certs
- - --check-interval=5m
- - --metrics-addr=:8080
- - --healthz-addr=:8081
- - --loglevel=info
- - --zap-time-encoding=epoch
- ports:
- - containerPort: 8080
- protocol: TCP
- name: metrics
- - containerPort: 10250
- protocol: TCP
- name: webhook
- readinessProbe:
- httpGet:
- port: 8081
- path: /readyz
- initialDelaySeconds: 20
- periodSeconds: 5
- volumeMounts:
- - name: certs
- mountPath: /tmp/certs
- readOnly: true
- volumes:
- - name: certs
- secret:
- secretName: common-golang-external-secrets-webhook
----
-# Source: golang-external-secrets/templates/vault/golang-external-secrets-hub-secretstore.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ClusterSecretStore
-metadata:
- name: vault-backend
- namespace: golang-external-secrets
-spec:
- provider:
- vault:
- server: https://vault-vault.apps.hub.example.com
- path: secret
- # Version of KV backend
- version: v2
-
- caProvider:
- type: ConfigMap
- name: kube-root-ca.crt
- key: ca.crt
- namespace: golang-external-secrets
-
- auth:
- kubernetes:
-
- mountPath: hub
- role: hub-role
-
- secretRef:
- name: golang-external-secrets
- namespace: golang-external-secrets
- key: "token"
----
-# Source: golang-external-secrets/charts/external-secrets/templates/validatingwebhook.yaml
-apiVersion: admissionregistration.k8s.io/v1
-kind: ValidatingWebhookConfiguration
-metadata:
- name: secretstore-validate
- labels:
- external-secrets.io/component: webhook
-webhooks:
-- name: "validate.secretstore.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["secretstores"]
- scope: "Namespaced"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-secretstore
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
-
-- name: "validate.clustersecretstore.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["clustersecretstores"]
- scope: "Cluster"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-clustersecretstore
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
----
-# Source: golang-external-secrets/charts/external-secrets/templates/validatingwebhook.yaml
-apiVersion: admissionregistration.k8s.io/v1
-kind: ValidatingWebhookConfiguration
-metadata:
- name: externalsecret-validate
- labels:
- external-secrets.io/component: webhook
-webhooks:
-- name: "validate.externalsecret.external-secrets.io"
- rules:
- - apiGroups: ["external-secrets.io"]
- apiVersions: ["v1beta1"]
- operations: ["CREATE", "UPDATE", "DELETE"]
- resources: ["externalsecrets"]
- scope: "Namespaced"
- clientConfig:
- service:
- namespace: default
- name: common-golang-external-secrets-webhook
- path: /validate-external-secrets-io-v1beta1-externalsecret
- admissionReviewVersions: ["v1", "v1beta1"]
- sideEffects: None
- timeoutSeconds: 5
- failurePolicy: Fail
diff --git a/tests/common-hashicorp-vault-industrial-edge-factory.expected.yaml b/tests/common-hashicorp-vault-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 14e5c956..00000000
--- a/tests/common-hashicorp-vault-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,410 +0,0 @@
----
-# Source: hashicorp-vault/charts/vault/templates/server-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
----
-# Source: hashicorp-vault/charts/vault/templates/server-config-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: common-hashicorp-vault-config
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-data:
- extraconfig-from-values.hcl: |-
-
- disable_mlock = true
- ui = true
- listener "tcp" {
- address = "[::]:8200"
- cluster_address = "[::]:8201"
- tls_cert_file = "/vault/userconfig/vault-secret/tls.crt"
- tls_key_file = "/vault/userconfig/vault-secret/tls.key"
- }
- storage "file" {
- path = "/vault/data"
- }
----
-# Source: hashicorp-vault/charts/vault/templates/server-clusterrolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-hashicorp-vault-server-binding
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: common-hashicorp-vault
- namespace: pattern-namespace
----
-# Source: hashicorp-vault/charts/vault/templates/server-headless-service.yaml
-# Service for Vault cluster
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault-internal
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
- vault-internal: "true"
- annotations:
-
-
- service.beta.openshift.io/serving-cert-secret-name: vault-secret-internal
-spec:
- clusterIP: None
- publishNotReadyAddresses: true
- ports:
- - name: "http"
- port: 8200
- targetPort: 8200
- - name: https-internal
- port: 8201
- targetPort: 8201
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
----
-# Source: hashicorp-vault/charts/vault/templates/server-service.yaml
-# Service for Vault cluster
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
- annotations:
-
-
- service.beta.openshift.io/serving-cert-secret-name: vault-secret
-spec:
- # We want the servers to become available even if they're not ready
- # since this DNS is also used for join operations.
- publishNotReadyAddresses: true
- ports:
- - name: http
- port: 8200
- targetPort: 8200
- - name: https-internal
- port: 8201
- targetPort: 8201
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
----
-# Source: hashicorp-vault/charts/vault/templates/ui-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault-ui
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault-ui
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- publishNotReadyAddresses: true
- ports:
- - name: http
- port: 8200
- targetPort: 8200
- type: ClusterIP
----
-# Source: hashicorp-vault/charts/vault/templates/server-statefulset.yaml
-# StatefulSet to run the actual vault server cluster.
-apiVersion: apps/v1
-kind: StatefulSet
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- serviceName: common-hashicorp-vault-internal
- podManagementPolicy: Parallel
- replicas: 1
- updateStrategy:
- type: OnDelete
- selector:
- matchLabels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- template:
- metadata:
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- annotations:
- spec:
-
- affinity:
- podAntiAffinity:
- requiredDuringSchedulingIgnoredDuringExecution:
- - labelSelector:
- matchLabels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: "common-hashicorp-vault"
- component: server
- topologyKey: kubernetes.io/hostname
-
-
-
-
- terminationGracePeriodSeconds: 10
- serviceAccountName: common-hashicorp-vault
-
- volumes:
-
- - name: config
- configMap:
- name: common-hashicorp-vault-config
-
- - name: userconfig-vault-secret
- secret:
- secretName: vault-secret
- defaultMode: 420
- - name: home
- emptyDir: {}
- containers:
- - name: vault
-
- image: registry.connect.redhat.com/hashicorp/vault:1.17.3-ubi
- imagePullPolicy: IfNotPresent
- command:
- - "/bin/sh"
- - "-ec"
- args:
- - |
- cp /vault/config/extraconfig-from-values.hcl /tmp/storageconfig.hcl;
- [ -n "${HOST_IP}" ] && sed -Ei "s|HOST_IP|${HOST_IP?}|g" /tmp/storageconfig.hcl;
- [ -n "${POD_IP}" ] && sed -Ei "s|POD_IP|${POD_IP?}|g" /tmp/storageconfig.hcl;
- [ -n "${HOSTNAME}" ] && sed -Ei "s|HOSTNAME|${HOSTNAME?}|g" /tmp/storageconfig.hcl;
- [ -n "${API_ADDR}" ] && sed -Ei "s|API_ADDR|${API_ADDR?}|g" /tmp/storageconfig.hcl;
- [ -n "${TRANSIT_ADDR}" ] && sed -Ei "s|TRANSIT_ADDR|${TRANSIT_ADDR?}|g" /tmp/storageconfig.hcl;
- [ -n "${RAFT_ADDR}" ] && sed -Ei "s|RAFT_ADDR|${RAFT_ADDR?}|g" /tmp/storageconfig.hcl;
- /usr/local/bin/docker-entrypoint.sh vault server -config=/tmp/storageconfig.hcl
-
- env:
- - name: HOST_IP
- valueFrom:
- fieldRef:
- fieldPath: status.hostIP
- - name: POD_IP
- valueFrom:
- fieldRef:
- fieldPath: status.podIP
- - name: VAULT_K8S_POD_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.name
- - name: VAULT_K8S_NAMESPACE
- valueFrom:
- fieldRef:
- fieldPath: metadata.namespace
- - name: VAULT_ADDR
- value: "http://127.0.0.1:8200"
- - name: VAULT_API_ADDR
- value: "http://$(POD_IP):8200"
- - name: SKIP_CHOWN
- value: "true"
- - name: SKIP_SETCAP
- value: "true"
- - name: HOSTNAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.name
- - name: VAULT_CLUSTER_ADDR
- value: "https://$(HOSTNAME).common-hashicorp-vault-internal:8201"
- - name: HOME
- value: "/home/vault"
-
-
- - name: "VAULT_ADDR"
- value: "https://vault.vault.svc.cluster.local:8200"
- - name: "VAULT_CACERT"
- value: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
-
- volumeMounts:
-
-
-
- - name: data
- mountPath: /vault/data
-
-
-
- - name: config
- mountPath: /vault/config
-
- - name: userconfig-vault-secret
- readOnly: true
- mountPath: /vault/userconfig/vault-secret
- - name: home
- mountPath: /home/vault
- ports:
- - containerPort: 8200
- name: http
- - containerPort: 8201
- name: https-internal
- - containerPort: 8202
- name: http-rep
- readinessProbe:
- # Check status; unsealed vault servers return 0
- # The exit code reflects the seal status:
- # 0 - unsealed
- # 1 - error
- # 2 - sealed
- exec:
- command: ["/bin/sh", "-ec", "vault status -tls-skip-verify"]
- failureThreshold: 2
- initialDelaySeconds: 5
- periodSeconds: 5
- successThreshold: 1
- timeoutSeconds: 3
- lifecycle:
- # Vault container doesn't receive SIGTERM from Kubernetes
- # and after the grace period ends, Kube sends SIGKILL. This
- # causes issues with graceful shutdowns such as deregistering itself
- # from Consul (zombie services).
- preStop:
- exec:
- command: [
- "/bin/sh", "-c",
- # Adding a sleep here to give the pod eviction a
- # chance to propagate, so requests will not be made
- # to this pod while it's terminating
- "sleep 5 && kill -SIGTERM $(pidof vault)",
- ]
-
-
- volumeClaimTemplates:
- - metadata:
- name: data
-
-
- spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 10Gi
----
-# Source: hashicorp-vault/templates/vault-app.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: vault-link
- namespace: vault
-spec:
- applicationMenu:
- section: HashiCorp Vault
- imageURL: 
- href: 'https://vault-vault.apps.region.example.com'
- location: ApplicationMenu
- text: 'Vault'
----
-# Source: hashicorp-vault/charts/vault/templates/server-route.yaml
-kind: Route
-apiVersion: route.openshift.io/v1
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- host:
- to:
- kind: Service
- name: common-hashicorp-vault
- weight: 100
- port:
- targetPort: 8200
- tls:
- termination: reencrypt
----
-# Source: hashicorp-vault/charts/vault/templates/tests/server-test.yaml
-apiVersion: v1
-kind: Pod
-metadata:
- name: common-hashicorp-vault-server-test
- namespace: pattern-namespace
- annotations:
- "helm.sh/hook": test
-spec:
-
- containers:
- - name: common-hashicorp-vault-server-test
- image: registry.connect.redhat.com/hashicorp/vault:1.17.3-ubi
- imagePullPolicy: IfNotPresent
- env:
- - name: VAULT_ADDR
- value: http://common-hashicorp-vault.pattern-namespace.svc:8200
-
- - name: "VAULT_ADDR"
- value: "https://vault.vault.svc.cluster.local:8200"
- - name: "VAULT_CACERT"
- value: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
- command:
- - /bin/sh
- - -c
- - |
- echo "Checking for sealed info in 'vault status' output"
- ATTEMPTS=10
- n=0
- until [ "$n" -ge $ATTEMPTS ]
- do
- echo "Attempt" $n...
- vault status -format yaml | grep -E '^sealed: (true|false)' && break
- n=$((n+1))
- sleep 5
- done
- if [ $n -ge $ATTEMPTS ]; then
- echo "timed out looking for sealed info in 'vault status' output"
- exit 1
- fi
-
- exit 0
- volumeMounts:
- volumes:
- restartPolicy: Never
diff --git a/tests/common-hashicorp-vault-industrial-edge-hub.expected.yaml b/tests/common-hashicorp-vault-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 14e5c956..00000000
--- a/tests/common-hashicorp-vault-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,410 +0,0 @@
----
-# Source: hashicorp-vault/charts/vault/templates/server-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
----
-# Source: hashicorp-vault/charts/vault/templates/server-config-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: common-hashicorp-vault-config
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-data:
- extraconfig-from-values.hcl: |-
-
- disable_mlock = true
- ui = true
- listener "tcp" {
- address = "[::]:8200"
- cluster_address = "[::]:8201"
- tls_cert_file = "/vault/userconfig/vault-secret/tls.crt"
- tls_key_file = "/vault/userconfig/vault-secret/tls.key"
- }
- storage "file" {
- path = "/vault/data"
- }
----
-# Source: hashicorp-vault/charts/vault/templates/server-clusterrolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-hashicorp-vault-server-binding
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: common-hashicorp-vault
- namespace: pattern-namespace
----
-# Source: hashicorp-vault/charts/vault/templates/server-headless-service.yaml
-# Service for Vault cluster
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault-internal
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
- vault-internal: "true"
- annotations:
-
-
- service.beta.openshift.io/serving-cert-secret-name: vault-secret-internal
-spec:
- clusterIP: None
- publishNotReadyAddresses: true
- ports:
- - name: "http"
- port: 8200
- targetPort: 8200
- - name: https-internal
- port: 8201
- targetPort: 8201
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
----
-# Source: hashicorp-vault/charts/vault/templates/server-service.yaml
-# Service for Vault cluster
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
- annotations:
-
-
- service.beta.openshift.io/serving-cert-secret-name: vault-secret
-spec:
- # We want the servers to become available even if they're not ready
- # since this DNS is also used for join operations.
- publishNotReadyAddresses: true
- ports:
- - name: http
- port: 8200
- targetPort: 8200
- - name: https-internal
- port: 8201
- targetPort: 8201
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
----
-# Source: hashicorp-vault/charts/vault/templates/ui-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault-ui
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault-ui
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- publishNotReadyAddresses: true
- ports:
- - name: http
- port: 8200
- targetPort: 8200
- type: ClusterIP
----
-# Source: hashicorp-vault/charts/vault/templates/server-statefulset.yaml
-# StatefulSet to run the actual vault server cluster.
-apiVersion: apps/v1
-kind: StatefulSet
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- serviceName: common-hashicorp-vault-internal
- podManagementPolicy: Parallel
- replicas: 1
- updateStrategy:
- type: OnDelete
- selector:
- matchLabels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- template:
- metadata:
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- annotations:
- spec:
-
- affinity:
- podAntiAffinity:
- requiredDuringSchedulingIgnoredDuringExecution:
- - labelSelector:
- matchLabels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: "common-hashicorp-vault"
- component: server
- topologyKey: kubernetes.io/hostname
-
-
-
-
- terminationGracePeriodSeconds: 10
- serviceAccountName: common-hashicorp-vault
-
- volumes:
-
- - name: config
- configMap:
- name: common-hashicorp-vault-config
-
- - name: userconfig-vault-secret
- secret:
- secretName: vault-secret
- defaultMode: 420
- - name: home
- emptyDir: {}
- containers:
- - name: vault
-
- image: registry.connect.redhat.com/hashicorp/vault:1.17.3-ubi
- imagePullPolicy: IfNotPresent
- command:
- - "/bin/sh"
- - "-ec"
- args:
- - |
- cp /vault/config/extraconfig-from-values.hcl /tmp/storageconfig.hcl;
- [ -n "${HOST_IP}" ] && sed -Ei "s|HOST_IP|${HOST_IP?}|g" /tmp/storageconfig.hcl;
- [ -n "${POD_IP}" ] && sed -Ei "s|POD_IP|${POD_IP?}|g" /tmp/storageconfig.hcl;
- [ -n "${HOSTNAME}" ] && sed -Ei "s|HOSTNAME|${HOSTNAME?}|g" /tmp/storageconfig.hcl;
- [ -n "${API_ADDR}" ] && sed -Ei "s|API_ADDR|${API_ADDR?}|g" /tmp/storageconfig.hcl;
- [ -n "${TRANSIT_ADDR}" ] && sed -Ei "s|TRANSIT_ADDR|${TRANSIT_ADDR?}|g" /tmp/storageconfig.hcl;
- [ -n "${RAFT_ADDR}" ] && sed -Ei "s|RAFT_ADDR|${RAFT_ADDR?}|g" /tmp/storageconfig.hcl;
- /usr/local/bin/docker-entrypoint.sh vault server -config=/tmp/storageconfig.hcl
-
- env:
- - name: HOST_IP
- valueFrom:
- fieldRef:
- fieldPath: status.hostIP
- - name: POD_IP
- valueFrom:
- fieldRef:
- fieldPath: status.podIP
- - name: VAULT_K8S_POD_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.name
- - name: VAULT_K8S_NAMESPACE
- valueFrom:
- fieldRef:
- fieldPath: metadata.namespace
- - name: VAULT_ADDR
- value: "http://127.0.0.1:8200"
- - name: VAULT_API_ADDR
- value: "http://$(POD_IP):8200"
- - name: SKIP_CHOWN
- value: "true"
- - name: SKIP_SETCAP
- value: "true"
- - name: HOSTNAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.name
- - name: VAULT_CLUSTER_ADDR
- value: "https://$(HOSTNAME).common-hashicorp-vault-internal:8201"
- - name: HOME
- value: "/home/vault"
-
-
- - name: "VAULT_ADDR"
- value: "https://vault.vault.svc.cluster.local:8200"
- - name: "VAULT_CACERT"
- value: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
-
- volumeMounts:
-
-
-
- - name: data
- mountPath: /vault/data
-
-
-
- - name: config
- mountPath: /vault/config
-
- - name: userconfig-vault-secret
- readOnly: true
- mountPath: /vault/userconfig/vault-secret
- - name: home
- mountPath: /home/vault
- ports:
- - containerPort: 8200
- name: http
- - containerPort: 8201
- name: https-internal
- - containerPort: 8202
- name: http-rep
- readinessProbe:
- # Check status; unsealed vault servers return 0
- # The exit code reflects the seal status:
- # 0 - unsealed
- # 1 - error
- # 2 - sealed
- exec:
- command: ["/bin/sh", "-ec", "vault status -tls-skip-verify"]
- failureThreshold: 2
- initialDelaySeconds: 5
- periodSeconds: 5
- successThreshold: 1
- timeoutSeconds: 3
- lifecycle:
- # Vault container doesn't receive SIGTERM from Kubernetes
- # and after the grace period ends, Kube sends SIGKILL. This
- # causes issues with graceful shutdowns such as deregistering itself
- # from Consul (zombie services).
- preStop:
- exec:
- command: [
- "/bin/sh", "-c",
- # Adding a sleep here to give the pod eviction a
- # chance to propagate, so requests will not be made
- # to this pod while it's terminating
- "sleep 5 && kill -SIGTERM $(pidof vault)",
- ]
-
-
- volumeClaimTemplates:
- - metadata:
- name: data
-
-
- spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 10Gi
----
-# Source: hashicorp-vault/templates/vault-app.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: vault-link
- namespace: vault
-spec:
- applicationMenu:
- section: HashiCorp Vault
- imageURL: 
- href: 'https://vault-vault.apps.region.example.com'
- location: ApplicationMenu
- text: 'Vault'
----
-# Source: hashicorp-vault/charts/vault/templates/server-route.yaml
-kind: Route
-apiVersion: route.openshift.io/v1
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- host:
- to:
- kind: Service
- name: common-hashicorp-vault
- weight: 100
- port:
- targetPort: 8200
- tls:
- termination: reencrypt
----
-# Source: hashicorp-vault/charts/vault/templates/tests/server-test.yaml
-apiVersion: v1
-kind: Pod
-metadata:
- name: common-hashicorp-vault-server-test
- namespace: pattern-namespace
- annotations:
- "helm.sh/hook": test
-spec:
-
- containers:
- - name: common-hashicorp-vault-server-test
- image: registry.connect.redhat.com/hashicorp/vault:1.17.3-ubi
- imagePullPolicy: IfNotPresent
- env:
- - name: VAULT_ADDR
- value: http://common-hashicorp-vault.pattern-namespace.svc:8200
-
- - name: "VAULT_ADDR"
- value: "https://vault.vault.svc.cluster.local:8200"
- - name: "VAULT_CACERT"
- value: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
- command:
- - /bin/sh
- - -c
- - |
- echo "Checking for sealed info in 'vault status' output"
- ATTEMPTS=10
- n=0
- until [ "$n" -ge $ATTEMPTS ]
- do
- echo "Attempt" $n...
- vault status -format yaml | grep -E '^sealed: (true|false)' && break
- n=$((n+1))
- sleep 5
- done
- if [ $n -ge $ATTEMPTS ]; then
- echo "timed out looking for sealed info in 'vault status' output"
- exit 1
- fi
-
- exit 0
- volumeMounts:
- volumes:
- restartPolicy: Never
diff --git a/tests/common-hashicorp-vault-medical-diagnosis-hub.expected.yaml b/tests/common-hashicorp-vault-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 14e5c956..00000000
--- a/tests/common-hashicorp-vault-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,410 +0,0 @@
----
-# Source: hashicorp-vault/charts/vault/templates/server-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
----
-# Source: hashicorp-vault/charts/vault/templates/server-config-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: common-hashicorp-vault-config
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-data:
- extraconfig-from-values.hcl: |-
-
- disable_mlock = true
- ui = true
- listener "tcp" {
- address = "[::]:8200"
- cluster_address = "[::]:8201"
- tls_cert_file = "/vault/userconfig/vault-secret/tls.crt"
- tls_key_file = "/vault/userconfig/vault-secret/tls.key"
- }
- storage "file" {
- path = "/vault/data"
- }
----
-# Source: hashicorp-vault/charts/vault/templates/server-clusterrolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-hashicorp-vault-server-binding
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: common-hashicorp-vault
- namespace: pattern-namespace
----
-# Source: hashicorp-vault/charts/vault/templates/server-headless-service.yaml
-# Service for Vault cluster
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault-internal
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
- vault-internal: "true"
- annotations:
-
-
- service.beta.openshift.io/serving-cert-secret-name: vault-secret-internal
-spec:
- clusterIP: None
- publishNotReadyAddresses: true
- ports:
- - name: "http"
- port: 8200
- targetPort: 8200
- - name: https-internal
- port: 8201
- targetPort: 8201
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
----
-# Source: hashicorp-vault/charts/vault/templates/server-service.yaml
-# Service for Vault cluster
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
- annotations:
-
-
- service.beta.openshift.io/serving-cert-secret-name: vault-secret
-spec:
- # We want the servers to become available even if they're not ready
- # since this DNS is also used for join operations.
- publishNotReadyAddresses: true
- ports:
- - name: http
- port: 8200
- targetPort: 8200
- - name: https-internal
- port: 8201
- targetPort: 8201
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
----
-# Source: hashicorp-vault/charts/vault/templates/ui-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault-ui
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault-ui
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- publishNotReadyAddresses: true
- ports:
- - name: http
- port: 8200
- targetPort: 8200
- type: ClusterIP
----
-# Source: hashicorp-vault/charts/vault/templates/server-statefulset.yaml
-# StatefulSet to run the actual vault server cluster.
-apiVersion: apps/v1
-kind: StatefulSet
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- serviceName: common-hashicorp-vault-internal
- podManagementPolicy: Parallel
- replicas: 1
- updateStrategy:
- type: OnDelete
- selector:
- matchLabels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- template:
- metadata:
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- annotations:
- spec:
-
- affinity:
- podAntiAffinity:
- requiredDuringSchedulingIgnoredDuringExecution:
- - labelSelector:
- matchLabels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: "common-hashicorp-vault"
- component: server
- topologyKey: kubernetes.io/hostname
-
-
-
-
- terminationGracePeriodSeconds: 10
- serviceAccountName: common-hashicorp-vault
-
- volumes:
-
- - name: config
- configMap:
- name: common-hashicorp-vault-config
-
- - name: userconfig-vault-secret
- secret:
- secretName: vault-secret
- defaultMode: 420
- - name: home
- emptyDir: {}
- containers:
- - name: vault
-
- image: registry.connect.redhat.com/hashicorp/vault:1.17.3-ubi
- imagePullPolicy: IfNotPresent
- command:
- - "/bin/sh"
- - "-ec"
- args:
- - |
- cp /vault/config/extraconfig-from-values.hcl /tmp/storageconfig.hcl;
- [ -n "${HOST_IP}" ] && sed -Ei "s|HOST_IP|${HOST_IP?}|g" /tmp/storageconfig.hcl;
- [ -n "${POD_IP}" ] && sed -Ei "s|POD_IP|${POD_IP?}|g" /tmp/storageconfig.hcl;
- [ -n "${HOSTNAME}" ] && sed -Ei "s|HOSTNAME|${HOSTNAME?}|g" /tmp/storageconfig.hcl;
- [ -n "${API_ADDR}" ] && sed -Ei "s|API_ADDR|${API_ADDR?}|g" /tmp/storageconfig.hcl;
- [ -n "${TRANSIT_ADDR}" ] && sed -Ei "s|TRANSIT_ADDR|${TRANSIT_ADDR?}|g" /tmp/storageconfig.hcl;
- [ -n "${RAFT_ADDR}" ] && sed -Ei "s|RAFT_ADDR|${RAFT_ADDR?}|g" /tmp/storageconfig.hcl;
- /usr/local/bin/docker-entrypoint.sh vault server -config=/tmp/storageconfig.hcl
-
- env:
- - name: HOST_IP
- valueFrom:
- fieldRef:
- fieldPath: status.hostIP
- - name: POD_IP
- valueFrom:
- fieldRef:
- fieldPath: status.podIP
- - name: VAULT_K8S_POD_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.name
- - name: VAULT_K8S_NAMESPACE
- valueFrom:
- fieldRef:
- fieldPath: metadata.namespace
- - name: VAULT_ADDR
- value: "http://127.0.0.1:8200"
- - name: VAULT_API_ADDR
- value: "http://$(POD_IP):8200"
- - name: SKIP_CHOWN
- value: "true"
- - name: SKIP_SETCAP
- value: "true"
- - name: HOSTNAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.name
- - name: VAULT_CLUSTER_ADDR
- value: "https://$(HOSTNAME).common-hashicorp-vault-internal:8201"
- - name: HOME
- value: "/home/vault"
-
-
- - name: "VAULT_ADDR"
- value: "https://vault.vault.svc.cluster.local:8200"
- - name: "VAULT_CACERT"
- value: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
-
- volumeMounts:
-
-
-
- - name: data
- mountPath: /vault/data
-
-
-
- - name: config
- mountPath: /vault/config
-
- - name: userconfig-vault-secret
- readOnly: true
- mountPath: /vault/userconfig/vault-secret
- - name: home
- mountPath: /home/vault
- ports:
- - containerPort: 8200
- name: http
- - containerPort: 8201
- name: https-internal
- - containerPort: 8202
- name: http-rep
- readinessProbe:
- # Check status; unsealed vault servers return 0
- # The exit code reflects the seal status:
- # 0 - unsealed
- # 1 - error
- # 2 - sealed
- exec:
- command: ["/bin/sh", "-ec", "vault status -tls-skip-verify"]
- failureThreshold: 2
- initialDelaySeconds: 5
- periodSeconds: 5
- successThreshold: 1
- timeoutSeconds: 3
- lifecycle:
- # Vault container doesn't receive SIGTERM from Kubernetes
- # and after the grace period ends, Kube sends SIGKILL. This
- # causes issues with graceful shutdowns such as deregistering itself
- # from Consul (zombie services).
- preStop:
- exec:
- command: [
- "/bin/sh", "-c",
- # Adding a sleep here to give the pod eviction a
- # chance to propagate, so requests will not be made
- # to this pod while it's terminating
- "sleep 5 && kill -SIGTERM $(pidof vault)",
- ]
-
-
- volumeClaimTemplates:
- - metadata:
- name: data
-
-
- spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 10Gi
----
-# Source: hashicorp-vault/templates/vault-app.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: vault-link
- namespace: vault
-spec:
- applicationMenu:
- section: HashiCorp Vault
- imageURL: 
- href: 'https://vault-vault.apps.region.example.com'
- location: ApplicationMenu
- text: 'Vault'
----
-# Source: hashicorp-vault/charts/vault/templates/server-route.yaml
-kind: Route
-apiVersion: route.openshift.io/v1
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- host:
- to:
- kind: Service
- name: common-hashicorp-vault
- weight: 100
- port:
- targetPort: 8200
- tls:
- termination: reencrypt
----
-# Source: hashicorp-vault/charts/vault/templates/tests/server-test.yaml
-apiVersion: v1
-kind: Pod
-metadata:
- name: common-hashicorp-vault-server-test
- namespace: pattern-namespace
- annotations:
- "helm.sh/hook": test
-spec:
-
- containers:
- - name: common-hashicorp-vault-server-test
- image: registry.connect.redhat.com/hashicorp/vault:1.17.3-ubi
- imagePullPolicy: IfNotPresent
- env:
- - name: VAULT_ADDR
- value: http://common-hashicorp-vault.pattern-namespace.svc:8200
-
- - name: "VAULT_ADDR"
- value: "https://vault.vault.svc.cluster.local:8200"
- - name: "VAULT_CACERT"
- value: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
- command:
- - /bin/sh
- - -c
- - |
- echo "Checking for sealed info in 'vault status' output"
- ATTEMPTS=10
- n=0
- until [ "$n" -ge $ATTEMPTS ]
- do
- echo "Attempt" $n...
- vault status -format yaml | grep -E '^sealed: (true|false)' && break
- n=$((n+1))
- sleep 5
- done
- if [ $n -ge $ATTEMPTS ]; then
- echo "timed out looking for sealed info in 'vault status' output"
- exit 1
- fi
-
- exit 0
- volumeMounts:
- volumes:
- restartPolicy: Never
diff --git a/tests/common-hashicorp-vault-naked.expected.yaml b/tests/common-hashicorp-vault-naked.expected.yaml
deleted file mode 100644
index 8003384e..00000000
--- a/tests/common-hashicorp-vault-naked.expected.yaml
+++ /dev/null
@@ -1,410 +0,0 @@
----
-# Source: hashicorp-vault/charts/vault/templates/server-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: common-hashicorp-vault
- namespace: default
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
----
-# Source: hashicorp-vault/charts/vault/templates/server-config-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: common-hashicorp-vault-config
- namespace: default
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-data:
- extraconfig-from-values.hcl: |-
-
- disable_mlock = true
- ui = true
- listener "tcp" {
- address = "[::]:8200"
- cluster_address = "[::]:8201"
- tls_cert_file = "/vault/userconfig/vault-secret/tls.crt"
- tls_key_file = "/vault/userconfig/vault-secret/tls.key"
- }
- storage "file" {
- path = "/vault/data"
- }
----
-# Source: hashicorp-vault/charts/vault/templates/server-clusterrolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-hashicorp-vault-server-binding
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: common-hashicorp-vault
- namespace: default
----
-# Source: hashicorp-vault/charts/vault/templates/server-headless-service.yaml
-# Service for Vault cluster
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault-internal
- namespace: default
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
- vault-internal: "true"
- annotations:
-
-
- service.beta.openshift.io/serving-cert-secret-name: vault-secret-internal
-spec:
- clusterIP: None
- publishNotReadyAddresses: true
- ports:
- - name: "http"
- port: 8200
- targetPort: 8200
- - name: https-internal
- port: 8201
- targetPort: 8201
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
----
-# Source: hashicorp-vault/charts/vault/templates/server-service.yaml
-# Service for Vault cluster
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault
- namespace: default
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
- annotations:
-
-
- service.beta.openshift.io/serving-cert-secret-name: vault-secret
-spec:
- # We want the servers to become available even if they're not ready
- # since this DNS is also used for join operations.
- publishNotReadyAddresses: true
- ports:
- - name: http
- port: 8200
- targetPort: 8200
- - name: https-internal
- port: 8201
- targetPort: 8201
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
----
-# Source: hashicorp-vault/charts/vault/templates/ui-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault-ui
- namespace: default
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault-ui
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- publishNotReadyAddresses: true
- ports:
- - name: http
- port: 8200
- targetPort: 8200
- type: ClusterIP
----
-# Source: hashicorp-vault/charts/vault/templates/server-statefulset.yaml
-# StatefulSet to run the actual vault server cluster.
-apiVersion: apps/v1
-kind: StatefulSet
-metadata:
- name: common-hashicorp-vault
- namespace: default
- labels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- serviceName: common-hashicorp-vault-internal
- podManagementPolicy: Parallel
- replicas: 1
- updateStrategy:
- type: OnDelete
- selector:
- matchLabels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- template:
- metadata:
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- annotations:
- spec:
-
- affinity:
- podAntiAffinity:
- requiredDuringSchedulingIgnoredDuringExecution:
- - labelSelector:
- matchLabels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: "common-hashicorp-vault"
- component: server
- topologyKey: kubernetes.io/hostname
-
-
-
-
- terminationGracePeriodSeconds: 10
- serviceAccountName: common-hashicorp-vault
-
- volumes:
-
- - name: config
- configMap:
- name: common-hashicorp-vault-config
-
- - name: userconfig-vault-secret
- secret:
- secretName: vault-secret
- defaultMode: 420
- - name: home
- emptyDir: {}
- containers:
- - name: vault
-
- image: registry.connect.redhat.com/hashicorp/vault:1.17.3-ubi
- imagePullPolicy: IfNotPresent
- command:
- - "/bin/sh"
- - "-ec"
- args:
- - |
- cp /vault/config/extraconfig-from-values.hcl /tmp/storageconfig.hcl;
- [ -n "${HOST_IP}" ] && sed -Ei "s|HOST_IP|${HOST_IP?}|g" /tmp/storageconfig.hcl;
- [ -n "${POD_IP}" ] && sed -Ei "s|POD_IP|${POD_IP?}|g" /tmp/storageconfig.hcl;
- [ -n "${HOSTNAME}" ] && sed -Ei "s|HOSTNAME|${HOSTNAME?}|g" /tmp/storageconfig.hcl;
- [ -n "${API_ADDR}" ] && sed -Ei "s|API_ADDR|${API_ADDR?}|g" /tmp/storageconfig.hcl;
- [ -n "${TRANSIT_ADDR}" ] && sed -Ei "s|TRANSIT_ADDR|${TRANSIT_ADDR?}|g" /tmp/storageconfig.hcl;
- [ -n "${RAFT_ADDR}" ] && sed -Ei "s|RAFT_ADDR|${RAFT_ADDR?}|g" /tmp/storageconfig.hcl;
- /usr/local/bin/docker-entrypoint.sh vault server -config=/tmp/storageconfig.hcl
-
- env:
- - name: HOST_IP
- valueFrom:
- fieldRef:
- fieldPath: status.hostIP
- - name: POD_IP
- valueFrom:
- fieldRef:
- fieldPath: status.podIP
- - name: VAULT_K8S_POD_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.name
- - name: VAULT_K8S_NAMESPACE
- valueFrom:
- fieldRef:
- fieldPath: metadata.namespace
- - name: VAULT_ADDR
- value: "http://127.0.0.1:8200"
- - name: VAULT_API_ADDR
- value: "http://$(POD_IP):8200"
- - name: SKIP_CHOWN
- value: "true"
- - name: SKIP_SETCAP
- value: "true"
- - name: HOSTNAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.name
- - name: VAULT_CLUSTER_ADDR
- value: "https://$(HOSTNAME).common-hashicorp-vault-internal:8201"
- - name: HOME
- value: "/home/vault"
-
-
- - name: "VAULT_ADDR"
- value: "https://vault.vault.svc.cluster.local:8200"
- - name: "VAULT_CACERT"
- value: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
-
- volumeMounts:
-
-
-
- - name: data
- mountPath: /vault/data
-
-
-
- - name: config
- mountPath: /vault/config
-
- - name: userconfig-vault-secret
- readOnly: true
- mountPath: /vault/userconfig/vault-secret
- - name: home
- mountPath: /home/vault
- ports:
- - containerPort: 8200
- name: http
- - containerPort: 8201
- name: https-internal
- - containerPort: 8202
- name: http-rep
- readinessProbe:
- # Check status; unsealed vault servers return 0
- # The exit code reflects the seal status:
- # 0 - unsealed
- # 1 - error
- # 2 - sealed
- exec:
- command: ["/bin/sh", "-ec", "vault status -tls-skip-verify"]
- failureThreshold: 2
- initialDelaySeconds: 5
- periodSeconds: 5
- successThreshold: 1
- timeoutSeconds: 3
- lifecycle:
- # Vault container doesn't receive SIGTERM from Kubernetes
- # and after the grace period ends, Kube sends SIGKILL. This
- # causes issues with graceful shutdowns such as deregistering itself
- # from Consul (zombie services).
- preStop:
- exec:
- command: [
- "/bin/sh", "-c",
- # Adding a sleep here to give the pod eviction a
- # chance to propagate, so requests will not be made
- # to this pod while it's terminating
- "sleep 5 && kill -SIGTERM $(pidof vault)",
- ]
-
-
- volumeClaimTemplates:
- - metadata:
- name: data
-
-
- spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 10Gi
----
-# Source: hashicorp-vault/templates/vault-app.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: vault-link
- namespace: vault
-spec:
- applicationMenu:
- section: HashiCorp Vault
- imageURL: 
- href: 'https://vault-vault.apps.foo.cluster.com'
- location: ApplicationMenu
- text: 'Vault'
----
-# Source: hashicorp-vault/charts/vault/templates/server-route.yaml
-kind: Route
-apiVersion: route.openshift.io/v1
-metadata:
- name: common-hashicorp-vault
- namespace: default
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- host:
- to:
- kind: Service
- name: common-hashicorp-vault
- weight: 100
- port:
- targetPort: 8200
- tls:
- termination: reencrypt
----
-# Source: hashicorp-vault/charts/vault/templates/tests/server-test.yaml
-apiVersion: v1
-kind: Pod
-metadata:
- name: common-hashicorp-vault-server-test
- namespace: default
- annotations:
- "helm.sh/hook": test
-spec:
-
- containers:
- - name: common-hashicorp-vault-server-test
- image: registry.connect.redhat.com/hashicorp/vault:1.17.3-ubi
- imagePullPolicy: IfNotPresent
- env:
- - name: VAULT_ADDR
- value: http://common-hashicorp-vault.default.svc:8200
-
- - name: "VAULT_ADDR"
- value: "https://vault.vault.svc.cluster.local:8200"
- - name: "VAULT_CACERT"
- value: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
- command:
- - /bin/sh
- - -c
- - |
- echo "Checking for sealed info in 'vault status' output"
- ATTEMPTS=10
- n=0
- until [ "$n" -ge $ATTEMPTS ]
- do
- echo "Attempt" $n...
- vault status -format yaml | grep -E '^sealed: (true|false)' && break
- n=$((n+1))
- sleep 5
- done
- if [ $n -ge $ATTEMPTS ]; then
- echo "timed out looking for sealed info in 'vault status' output"
- exit 1
- fi
-
- exit 0
- volumeMounts:
- volumes:
- restartPolicy: Never
diff --git a/tests/common-hashicorp-vault-normal.expected.yaml b/tests/common-hashicorp-vault-normal.expected.yaml
deleted file mode 100644
index 14e5c956..00000000
--- a/tests/common-hashicorp-vault-normal.expected.yaml
+++ /dev/null
@@ -1,410 +0,0 @@
----
-# Source: hashicorp-vault/charts/vault/templates/server-serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
----
-# Source: hashicorp-vault/charts/vault/templates/server-config-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: common-hashicorp-vault-config
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-data:
- extraconfig-from-values.hcl: |-
-
- disable_mlock = true
- ui = true
- listener "tcp" {
- address = "[::]:8200"
- cluster_address = "[::]:8201"
- tls_cert_file = "/vault/userconfig/vault-secret/tls.crt"
- tls_key_file = "/vault/userconfig/vault-secret/tls.key"
- }
- storage "file" {
- path = "/vault/data"
- }
----
-# Source: hashicorp-vault/charts/vault/templates/server-clusterrolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: common-hashicorp-vault-server-binding
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: common-hashicorp-vault
- namespace: pattern-namespace
----
-# Source: hashicorp-vault/charts/vault/templates/server-headless-service.yaml
-# Service for Vault cluster
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault-internal
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
- vault-internal: "true"
- annotations:
-
-
- service.beta.openshift.io/serving-cert-secret-name: vault-secret-internal
-spec:
- clusterIP: None
- publishNotReadyAddresses: true
- ports:
- - name: "http"
- port: 8200
- targetPort: 8200
- - name: https-internal
- port: 8201
- targetPort: 8201
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
----
-# Source: hashicorp-vault/charts/vault/templates/server-service.yaml
-# Service for Vault cluster
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
- annotations:
-
-
- service.beta.openshift.io/serving-cert-secret-name: vault-secret
-spec:
- # We want the servers to become available even if they're not ready
- # since this DNS is also used for join operations.
- publishNotReadyAddresses: true
- ports:
- - name: http
- port: 8200
- targetPort: 8200
- - name: https-internal
- port: 8201
- targetPort: 8201
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
----
-# Source: hashicorp-vault/charts/vault/templates/ui-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- name: common-hashicorp-vault-ui
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault-ui
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- selector:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- publishNotReadyAddresses: true
- ports:
- - name: http
- port: 8200
- targetPort: 8200
- type: ClusterIP
----
-# Source: hashicorp-vault/charts/vault/templates/server-statefulset.yaml
-# StatefulSet to run the actual vault server cluster.
-apiVersion: apps/v1
-kind: StatefulSet
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- serviceName: common-hashicorp-vault-internal
- podManagementPolicy: Parallel
- replicas: 1
- updateStrategy:
- type: OnDelete
- selector:
- matchLabels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- template:
- metadata:
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- component: server
- annotations:
- spec:
-
- affinity:
- podAntiAffinity:
- requiredDuringSchedulingIgnoredDuringExecution:
- - labelSelector:
- matchLabels:
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: "common-hashicorp-vault"
- component: server
- topologyKey: kubernetes.io/hostname
-
-
-
-
- terminationGracePeriodSeconds: 10
- serviceAccountName: common-hashicorp-vault
-
- volumes:
-
- - name: config
- configMap:
- name: common-hashicorp-vault-config
-
- - name: userconfig-vault-secret
- secret:
- secretName: vault-secret
- defaultMode: 420
- - name: home
- emptyDir: {}
- containers:
- - name: vault
-
- image: registry.connect.redhat.com/hashicorp/vault:1.17.3-ubi
- imagePullPolicy: IfNotPresent
- command:
- - "/bin/sh"
- - "-ec"
- args:
- - |
- cp /vault/config/extraconfig-from-values.hcl /tmp/storageconfig.hcl;
- [ -n "${HOST_IP}" ] && sed -Ei "s|HOST_IP|${HOST_IP?}|g" /tmp/storageconfig.hcl;
- [ -n "${POD_IP}" ] && sed -Ei "s|POD_IP|${POD_IP?}|g" /tmp/storageconfig.hcl;
- [ -n "${HOSTNAME}" ] && sed -Ei "s|HOSTNAME|${HOSTNAME?}|g" /tmp/storageconfig.hcl;
- [ -n "${API_ADDR}" ] && sed -Ei "s|API_ADDR|${API_ADDR?}|g" /tmp/storageconfig.hcl;
- [ -n "${TRANSIT_ADDR}" ] && sed -Ei "s|TRANSIT_ADDR|${TRANSIT_ADDR?}|g" /tmp/storageconfig.hcl;
- [ -n "${RAFT_ADDR}" ] && sed -Ei "s|RAFT_ADDR|${RAFT_ADDR?}|g" /tmp/storageconfig.hcl;
- /usr/local/bin/docker-entrypoint.sh vault server -config=/tmp/storageconfig.hcl
-
- env:
- - name: HOST_IP
- valueFrom:
- fieldRef:
- fieldPath: status.hostIP
- - name: POD_IP
- valueFrom:
- fieldRef:
- fieldPath: status.podIP
- - name: VAULT_K8S_POD_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.name
- - name: VAULT_K8S_NAMESPACE
- valueFrom:
- fieldRef:
- fieldPath: metadata.namespace
- - name: VAULT_ADDR
- value: "http://127.0.0.1:8200"
- - name: VAULT_API_ADDR
- value: "http://$(POD_IP):8200"
- - name: SKIP_CHOWN
- value: "true"
- - name: SKIP_SETCAP
- value: "true"
- - name: HOSTNAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.name
- - name: VAULT_CLUSTER_ADDR
- value: "https://$(HOSTNAME).common-hashicorp-vault-internal:8201"
- - name: HOME
- value: "/home/vault"
-
-
- - name: "VAULT_ADDR"
- value: "https://vault.vault.svc.cluster.local:8200"
- - name: "VAULT_CACERT"
- value: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
-
- volumeMounts:
-
-
-
- - name: data
- mountPath: /vault/data
-
-
-
- - name: config
- mountPath: /vault/config
-
- - name: userconfig-vault-secret
- readOnly: true
- mountPath: /vault/userconfig/vault-secret
- - name: home
- mountPath: /home/vault
- ports:
- - containerPort: 8200
- name: http
- - containerPort: 8201
- name: https-internal
- - containerPort: 8202
- name: http-rep
- readinessProbe:
- # Check status; unsealed vault servers return 0
- # The exit code reflects the seal status:
- # 0 - unsealed
- # 1 - error
- # 2 - sealed
- exec:
- command: ["/bin/sh", "-ec", "vault status -tls-skip-verify"]
- failureThreshold: 2
- initialDelaySeconds: 5
- periodSeconds: 5
- successThreshold: 1
- timeoutSeconds: 3
- lifecycle:
- # Vault container doesn't receive SIGTERM from Kubernetes
- # and after the grace period ends, Kube sends SIGKILL. This
- # causes issues with graceful shutdowns such as deregistering itself
- # from Consul (zombie services).
- preStop:
- exec:
- command: [
- "/bin/sh", "-c",
- # Adding a sleep here to give the pod eviction a
- # chance to propagate, so requests will not be made
- # to this pod while it's terminating
- "sleep 5 && kill -SIGTERM $(pidof vault)",
- ]
-
-
- volumeClaimTemplates:
- - metadata:
- name: data
-
-
- spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 10Gi
----
-# Source: hashicorp-vault/templates/vault-app.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: vault-link
- namespace: vault
-spec:
- applicationMenu:
- section: HashiCorp Vault
- imageURL: 
- href: 'https://vault-vault.apps.region.example.com'
- location: ApplicationMenu
- text: 'Vault'
----
-# Source: hashicorp-vault/charts/vault/templates/server-route.yaml
-kind: Route
-apiVersion: route.openshift.io/v1
-metadata:
- name: common-hashicorp-vault
- namespace: pattern-namespace
- labels:
- helm.sh/chart: vault-0.28.1
- app.kubernetes.io/name: vault
- app.kubernetes.io/instance: common-hashicorp-vault
- app.kubernetes.io/managed-by: Helm
-spec:
- host:
- to:
- kind: Service
- name: common-hashicorp-vault
- weight: 100
- port:
- targetPort: 8200
- tls:
- termination: reencrypt
----
-# Source: hashicorp-vault/charts/vault/templates/tests/server-test.yaml
-apiVersion: v1
-kind: Pod
-metadata:
- name: common-hashicorp-vault-server-test
- namespace: pattern-namespace
- annotations:
- "helm.sh/hook": test
-spec:
-
- containers:
- - name: common-hashicorp-vault-server-test
- image: registry.connect.redhat.com/hashicorp/vault:1.17.3-ubi
- imagePullPolicy: IfNotPresent
- env:
- - name: VAULT_ADDR
- value: http://common-hashicorp-vault.pattern-namespace.svc:8200
-
- - name: "VAULT_ADDR"
- value: "https://vault.vault.svc.cluster.local:8200"
- - name: "VAULT_CACERT"
- value: "/var/run/secrets/kubernetes.io/serviceaccount/service-ca.crt"
- command:
- - /bin/sh
- - -c
- - |
- echo "Checking for sealed info in 'vault status' output"
- ATTEMPTS=10
- n=0
- until [ "$n" -ge $ATTEMPTS ]
- do
- echo "Attempt" $n...
- vault status -format yaml | grep -E '^sealed: (true|false)' && break
- n=$((n+1))
- sleep 5
- done
- if [ $n -ge $ATTEMPTS ]; then
- echo "timed out looking for sealed info in 'vault status' output"
- exit 1
- fi
-
- exit 0
- volumeMounts:
- volumes:
- restartPolicy: Never
diff --git a/tests/common-install-naked.expected.yaml b/tests/common-install-naked.expected.yaml
deleted file mode 100644
index 7d1fc880..00000000
--- a/tests/common-install-naked.expected.yaml
+++ /dev/null
@@ -1,63 +0,0 @@
----
-# Source: pattern-install/templates/argocd/namespace.yaml
-# Pre-create so we can create our argo app for keeping subscriptions in sync
-# Do it here so that we don't try to sync it in the future
-apiVersion: v1
-kind: Namespace
-metadata:
- name: openshift-gitops
----
-# Source: pattern-install/templates/argocd/application.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: common-install-default
- namespace: openshift-gitops
-spec:
- destination:
- name: in-cluster
- namespace: common-install-default
- project: default
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- valueFiles:
- - "https://github.com/pattern-clone/mypattern/raw/main/values-global.yaml"
- - "https://github.com/pattern-clone/mypattern/raw/main/values-default.yaml"
- # Track the progress of https://github.com/argoproj/argo-cd/pull/6280
- parameters:
- - name: global.repoURL
- value: $ARGOCD_APP_SOURCE_REPO_URL
- - name: global.targetRevision
- value: $ARGOCD_APP_SOURCE_TARGET_REVISION
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.valuesDirectoryURL
- value: https://github.com/pattern-clone/mypattern/raw/main
- - name: global.pattern
- value: common-install
- - name: global.hubClusterDomain
- value:
- syncPolicy:
- automated: {}
----
-# Source: pattern-install/templates/argocd/subscription.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: openshift-gitops-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/openshift-gitops-operator.openshift-operators: ""
-spec:
- channel: stable
- installPlanApproval: Automatic
- name: openshift-gitops-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- config:
- env:
- - name: ARGOCD_CLUSTER_CONFIG_NAMESPACES
- value: common-install-default,openshift-gitops
diff --git a/tests/common-install-normal.expected.yaml b/tests/common-install-normal.expected.yaml
deleted file mode 100644
index e92456f9..00000000
--- a/tests/common-install-normal.expected.yaml
+++ /dev/null
@@ -1,63 +0,0 @@
----
-# Source: pattern-install/templates/argocd/namespace.yaml
-# Pre-create so we can create our argo app for keeping subscriptions in sync
-# Do it here so that we don't try to sync it in the future
-apiVersion: v1
-kind: Namespace
-metadata:
- name: openshift-gitops
----
-# Source: pattern-install/templates/argocd/application.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: Application
-metadata:
- name: common-install-hub
- namespace: openshift-gitops
-spec:
- destination:
- name: in-cluster
- namespace: common-install-hub
- project: default
- source:
- repoURL: https://github.com/pattern-clone/mypattern
- targetRevision: main
- path: common/clustergroup
- helm:
- valueFiles:
- - "https://github.com/pattern-clone/mypattern/raw/main/values-global.yaml"
- - "https://github.com/pattern-clone/mypattern/raw/main/values-hub.yaml"
- # Track the progress of https://github.com/argoproj/argo-cd/pull/6280
- parameters:
- - name: global.repoURL
- value: $ARGOCD_APP_SOURCE_REPO_URL
- - name: global.targetRevision
- value: $ARGOCD_APP_SOURCE_TARGET_REVISION
- - name: global.namespace
- value: $ARGOCD_APP_NAMESPACE
- - name: global.valuesDirectoryURL
- value: https://github.com/pattern-clone/mypattern/raw/main
- - name: global.pattern
- value: common-install
- - name: global.hubClusterDomain
- value: hub.example.com
- syncPolicy:
- automated: {}
----
-# Source: pattern-install/templates/argocd/subscription.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: openshift-gitops-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/openshift-gitops-operator.openshift-operators: ""
-spec:
- channel: stable
- installPlanApproval: Automatic
- name: openshift-gitops-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
- config:
- env:
- - name: ARGOCD_CLUSTER_CONFIG_NAMESPACES
- value: common-install-hub,openshift-gitops
diff --git a/tests/common-letsencrypt-industrial-edge-factory.expected.yaml b/tests/common-letsencrypt-industrial-edge-factory.expected.yaml
deleted file mode 100644
index b5aded2f..00000000
--- a/tests/common-letsencrypt-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,202 +0,0 @@
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: cert-manager-operator
-spec:
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: cert-manager
-spec:
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: letsencrypt
-spec:
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: config.openshift.io/v1
-kind: APIServer
-metadata:
- name: cluster
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- servingCerts:
- namedCertificates:
- - names:
- - api.region.example.com
- servingCertificate:
- name: api-validated-patterns-letsencrypt-cert
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: ArgoCD
-metadata:
- name: openshift-gitops
- namespace: openshift-gitops
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- server:
- route:
- enabled: true
- tls:
- termination: reencrypt
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operator.openshift.io/v1alpha1
-kind: CertManager
-metadata:
- name: cluster
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- managementState: "Managed"
- unsupportedConfigOverrides:
- # Here's an example to supply custom DNS settings.
- controller:
- args:
- - "--dns01-recursive-nameservers=8.8.8.8:53,1.1.1.1:53"
- - "--dns01-recursive-nameservers-only"
----
-# Source: letsencrypt/templates/api-cert.yaml
-apiVersion: cert-manager.io/v1
-kind: Certificate
-metadata:
- name: api-validated-patterns-cert
- namespace: openshift-config
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- secretName: api-validated-patterns-letsencrypt-cert
- duration: 168h0m0s
- renewBefore: 28h0m0s
- commonName: 'api.region.example.com'
- usages:
- - server auth
- dnsNames:
- - api.region.example.com
- issuerRef:
- name: validated-patterns-issuer
- kind: ClusterIssuer
- subject:
- organizations:
- - hybrid-cloud-patterns.io
----
-# Source: letsencrypt/templates/wildcard-cert.yaml
-apiVersion: cert-manager.io/v1
-kind: Certificate
-metadata:
- name: lets-encrypt-certs
- namespace: openshift-ingress
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- secretName: lets-encrypt-wildcart-cert-tls
- duration: 168h0m0s
- renewBefore: 28h0m0s
- commonName: '*.apps.region.example.com'
- usages:
- - server auth
- dnsNames:
- - '*.apps.region.example.com'
- issuerRef:
- name: validated-patterns-issuer
- kind: ClusterIssuer
- subject:
- organizations:
- - hybrid-cloud-patterns.io
----
-# Source: letsencrypt/templates/issuer.yaml
-apiVersion: cert-manager.io/v1
-kind: ClusterIssuer
-metadata:
- name: validated-patterns-issuer
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- acme:
- server: https://acme-staging-v02.api.letsencrypt.org/directory
- email: test@example.com
- privateKeySecretRef:
- name: validated-patterns-issuer-account-key
- solvers:
- - selector: {}
- dns01:
- route53:
- region: eu-central-1
- accessKeyIDSecretRef:
- name: cert-manager-dns-credentials
- key: aws_access_key_id
- secretAccessKeySecretRef:
- name: cert-manager-dns-credentials
- key: aws_secret_access_key
----
-# Source: letsencrypt/templates/credentials-request.yaml
-apiVersion: cloudcredential.openshift.io/v1
-kind: CredentialsRequest
-metadata:
- name: letsencrypt-cert-manager-dns
- namespace: openshift-cloud-credential-operator
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- providerSpec:
- apiVersion: cloudcredential.openshift.io/v1
- kind: AWSProviderSpec
- statementEntries:
- - action:
- - 'route53:ChangeResourceRecordSets'
- - 'route53:GetChange'
- - 'route53:ListHostedZonesByName'
- - 'route53:ListHostedZones'
- effect: Allow
- resource: '*'
- secretRef:
- name: cert-manager-dns-credentials
- namespace: cert-manager
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: operator.openshift.io/v1
-kind: IngressController
-metadata:
- name: default
- namespace: openshift-ingress-operator
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- routeAdmission:
- wildcardPolicy: WildcardsAllowed
- defaultCertificate:
- name: lets-encrypt-wildcart-cert-tls
-# Patch the cluster-wide argocd instance so it uses the ingress tls cert
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: cert-manager-operator
- namespace: cert-manager-operator
-spec:
- targetNamespaces:
- - cert-manager-operator
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: openshift-cert-manager-operator
- namespace: cert-manager-operator
-spec:
- channel: "stable-v1"
- installPlanApproval: Automatic
- name: openshift-cert-manager-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
diff --git a/tests/common-letsencrypt-industrial-edge-hub.expected.yaml b/tests/common-letsencrypt-industrial-edge-hub.expected.yaml
deleted file mode 100644
index b5aded2f..00000000
--- a/tests/common-letsencrypt-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,202 +0,0 @@
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: cert-manager-operator
-spec:
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: cert-manager
-spec:
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: letsencrypt
-spec:
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: config.openshift.io/v1
-kind: APIServer
-metadata:
- name: cluster
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- servingCerts:
- namedCertificates:
- - names:
- - api.region.example.com
- servingCertificate:
- name: api-validated-patterns-letsencrypt-cert
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: ArgoCD
-metadata:
- name: openshift-gitops
- namespace: openshift-gitops
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- server:
- route:
- enabled: true
- tls:
- termination: reencrypt
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operator.openshift.io/v1alpha1
-kind: CertManager
-metadata:
- name: cluster
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- managementState: "Managed"
- unsupportedConfigOverrides:
- # Here's an example to supply custom DNS settings.
- controller:
- args:
- - "--dns01-recursive-nameservers=8.8.8.8:53,1.1.1.1:53"
- - "--dns01-recursive-nameservers-only"
----
-# Source: letsencrypt/templates/api-cert.yaml
-apiVersion: cert-manager.io/v1
-kind: Certificate
-metadata:
- name: api-validated-patterns-cert
- namespace: openshift-config
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- secretName: api-validated-patterns-letsencrypt-cert
- duration: 168h0m0s
- renewBefore: 28h0m0s
- commonName: 'api.region.example.com'
- usages:
- - server auth
- dnsNames:
- - api.region.example.com
- issuerRef:
- name: validated-patterns-issuer
- kind: ClusterIssuer
- subject:
- organizations:
- - hybrid-cloud-patterns.io
----
-# Source: letsencrypt/templates/wildcard-cert.yaml
-apiVersion: cert-manager.io/v1
-kind: Certificate
-metadata:
- name: lets-encrypt-certs
- namespace: openshift-ingress
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- secretName: lets-encrypt-wildcart-cert-tls
- duration: 168h0m0s
- renewBefore: 28h0m0s
- commonName: '*.apps.region.example.com'
- usages:
- - server auth
- dnsNames:
- - '*.apps.region.example.com'
- issuerRef:
- name: validated-patterns-issuer
- kind: ClusterIssuer
- subject:
- organizations:
- - hybrid-cloud-patterns.io
----
-# Source: letsencrypt/templates/issuer.yaml
-apiVersion: cert-manager.io/v1
-kind: ClusterIssuer
-metadata:
- name: validated-patterns-issuer
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- acme:
- server: https://acme-staging-v02.api.letsencrypt.org/directory
- email: test@example.com
- privateKeySecretRef:
- name: validated-patterns-issuer-account-key
- solvers:
- - selector: {}
- dns01:
- route53:
- region: eu-central-1
- accessKeyIDSecretRef:
- name: cert-manager-dns-credentials
- key: aws_access_key_id
- secretAccessKeySecretRef:
- name: cert-manager-dns-credentials
- key: aws_secret_access_key
----
-# Source: letsencrypt/templates/credentials-request.yaml
-apiVersion: cloudcredential.openshift.io/v1
-kind: CredentialsRequest
-metadata:
- name: letsencrypt-cert-manager-dns
- namespace: openshift-cloud-credential-operator
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- providerSpec:
- apiVersion: cloudcredential.openshift.io/v1
- kind: AWSProviderSpec
- statementEntries:
- - action:
- - 'route53:ChangeResourceRecordSets'
- - 'route53:GetChange'
- - 'route53:ListHostedZonesByName'
- - 'route53:ListHostedZones'
- effect: Allow
- resource: '*'
- secretRef:
- name: cert-manager-dns-credentials
- namespace: cert-manager
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: operator.openshift.io/v1
-kind: IngressController
-metadata:
- name: default
- namespace: openshift-ingress-operator
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- routeAdmission:
- wildcardPolicy: WildcardsAllowed
- defaultCertificate:
- name: lets-encrypt-wildcart-cert-tls
-# Patch the cluster-wide argocd instance so it uses the ingress tls cert
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: cert-manager-operator
- namespace: cert-manager-operator
-spec:
- targetNamespaces:
- - cert-manager-operator
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: openshift-cert-manager-operator
- namespace: cert-manager-operator
-spec:
- channel: "stable-v1"
- installPlanApproval: Automatic
- name: openshift-cert-manager-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
diff --git a/tests/common-letsencrypt-medical-diagnosis-hub.expected.yaml b/tests/common-letsencrypt-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index b5aded2f..00000000
--- a/tests/common-letsencrypt-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,202 +0,0 @@
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: cert-manager-operator
-spec:
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: cert-manager
-spec:
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: letsencrypt
-spec:
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: config.openshift.io/v1
-kind: APIServer
-metadata:
- name: cluster
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- servingCerts:
- namedCertificates:
- - names:
- - api.region.example.com
- servingCertificate:
- name: api-validated-patterns-letsencrypt-cert
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: ArgoCD
-metadata:
- name: openshift-gitops
- namespace: openshift-gitops
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- server:
- route:
- enabled: true
- tls:
- termination: reencrypt
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operator.openshift.io/v1alpha1
-kind: CertManager
-metadata:
- name: cluster
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- managementState: "Managed"
- unsupportedConfigOverrides:
- # Here's an example to supply custom DNS settings.
- controller:
- args:
- - "--dns01-recursive-nameservers=8.8.8.8:53,1.1.1.1:53"
- - "--dns01-recursive-nameservers-only"
----
-# Source: letsencrypt/templates/api-cert.yaml
-apiVersion: cert-manager.io/v1
-kind: Certificate
-metadata:
- name: api-validated-patterns-cert
- namespace: openshift-config
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- secretName: api-validated-patterns-letsencrypt-cert
- duration: 168h0m0s
- renewBefore: 28h0m0s
- commonName: 'api.region.example.com'
- usages:
- - server auth
- dnsNames:
- - api.region.example.com
- issuerRef:
- name: validated-patterns-issuer
- kind: ClusterIssuer
- subject:
- organizations:
- - hybrid-cloud-patterns.io
----
-# Source: letsencrypt/templates/wildcard-cert.yaml
-apiVersion: cert-manager.io/v1
-kind: Certificate
-metadata:
- name: lets-encrypt-certs
- namespace: openshift-ingress
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- secretName: lets-encrypt-wildcart-cert-tls
- duration: 168h0m0s
- renewBefore: 28h0m0s
- commonName: '*.apps.region.example.com'
- usages:
- - server auth
- dnsNames:
- - '*.apps.region.example.com'
- issuerRef:
- name: validated-patterns-issuer
- kind: ClusterIssuer
- subject:
- organizations:
- - hybrid-cloud-patterns.io
----
-# Source: letsencrypt/templates/issuer.yaml
-apiVersion: cert-manager.io/v1
-kind: ClusterIssuer
-metadata:
- name: validated-patterns-issuer
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- acme:
- server: https://acme-staging-v02.api.letsencrypt.org/directory
- email: test@example.com
- privateKeySecretRef:
- name: validated-patterns-issuer-account-key
- solvers:
- - selector: {}
- dns01:
- route53:
- region: eu-central-1
- accessKeyIDSecretRef:
- name: cert-manager-dns-credentials
- key: aws_access_key_id
- secretAccessKeySecretRef:
- name: cert-manager-dns-credentials
- key: aws_secret_access_key
----
-# Source: letsencrypt/templates/credentials-request.yaml
-apiVersion: cloudcredential.openshift.io/v1
-kind: CredentialsRequest
-metadata:
- name: letsencrypt-cert-manager-dns
- namespace: openshift-cloud-credential-operator
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- providerSpec:
- apiVersion: cloudcredential.openshift.io/v1
- kind: AWSProviderSpec
- statementEntries:
- - action:
- - 'route53:ChangeResourceRecordSets'
- - 'route53:GetChange'
- - 'route53:ListHostedZonesByName'
- - 'route53:ListHostedZones'
- effect: Allow
- resource: '*'
- secretRef:
- name: cert-manager-dns-credentials
- namespace: cert-manager
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: operator.openshift.io/v1
-kind: IngressController
-metadata:
- name: default
- namespace: openshift-ingress-operator
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- routeAdmission:
- wildcardPolicy: WildcardsAllowed
- defaultCertificate:
- name: lets-encrypt-wildcart-cert-tls
-# Patch the cluster-wide argocd instance so it uses the ingress tls cert
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: cert-manager-operator
- namespace: cert-manager-operator
-spec:
- targetNamespaces:
- - cert-manager-operator
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: openshift-cert-manager-operator
- namespace: cert-manager-operator
-spec:
- channel: "stable-v1"
- installPlanApproval: Automatic
- name: openshift-cert-manager-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
diff --git a/tests/common-letsencrypt-naked.expected.yaml b/tests/common-letsencrypt-naked.expected.yaml
deleted file mode 100644
index 73aa94a4..00000000
--- a/tests/common-letsencrypt-naked.expected.yaml
+++ /dev/null
@@ -1,202 +0,0 @@
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: cert-manager-operator
-spec:
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: cert-manager
-spec:
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: letsencrypt
-spec:
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: config.openshift.io/v1
-kind: APIServer
-metadata:
- name: cluster
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- servingCerts:
- namedCertificates:
- - names:
- - api.example.com
- servingCertificate:
- name: api-validated-patterns-letsencrypt-cert
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: ArgoCD
-metadata:
- name: openshift-gitops
- namespace: openshift-gitops
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- server:
- route:
- enabled: true
- tls:
- termination: reencrypt
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operator.openshift.io/v1alpha1
-kind: CertManager
-metadata:
- name: cluster
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- managementState: "Managed"
- unsupportedConfigOverrides:
- # Here's an example to supply custom DNS settings.
- controller:
- args:
- - "--dns01-recursive-nameservers=8.8.8.8:53,1.1.1.1:53"
- - "--dns01-recursive-nameservers-only"
----
-# Source: letsencrypt/templates/api-cert.yaml
-apiVersion: cert-manager.io/v1
-kind: Certificate
-metadata:
- name: api-validated-patterns-cert
- namespace: openshift-config
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- secretName: api-validated-patterns-letsencrypt-cert
- duration: 168h0m0s
- renewBefore: 28h0m0s
- commonName: 'api.example.com'
- usages:
- - server auth
- dnsNames:
- - api.example.com
- issuerRef:
- name: validated-patterns-issuer
- kind: ClusterIssuer
- subject:
- organizations:
- - hybrid-cloud-patterns.io
----
-# Source: letsencrypt/templates/wildcard-cert.yaml
-apiVersion: cert-manager.io/v1
-kind: Certificate
-metadata:
- name: lets-encrypt-certs
- namespace: openshift-ingress
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- secretName: lets-encrypt-wildcart-cert-tls
- duration: 168h0m0s
- renewBefore: 28h0m0s
- commonName: '*.apps.example.com'
- usages:
- - server auth
- dnsNames:
- - '*.apps.example.com'
- issuerRef:
- name: validated-patterns-issuer
- kind: ClusterIssuer
- subject:
- organizations:
- - hybrid-cloud-patterns.io
----
-# Source: letsencrypt/templates/issuer.yaml
-apiVersion: cert-manager.io/v1
-kind: ClusterIssuer
-metadata:
- name: validated-patterns-issuer
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- acme:
- server: https://acme-staging-v02.api.letsencrypt.org/directory
- email: test@example.com
- privateKeySecretRef:
- name: validated-patterns-issuer-account-key
- solvers:
- - selector: {}
- dns01:
- route53:
- region: eu-central-1
- accessKeyIDSecretRef:
- name: cert-manager-dns-credentials
- key: aws_access_key_id
- secretAccessKeySecretRef:
- name: cert-manager-dns-credentials
- key: aws_secret_access_key
----
-# Source: letsencrypt/templates/credentials-request.yaml
-apiVersion: cloudcredential.openshift.io/v1
-kind: CredentialsRequest
-metadata:
- name: letsencrypt-cert-manager-dns
- namespace: openshift-cloud-credential-operator
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- providerSpec:
- apiVersion: cloudcredential.openshift.io/v1
- kind: AWSProviderSpec
- statementEntries:
- - action:
- - 'route53:ChangeResourceRecordSets'
- - 'route53:GetChange'
- - 'route53:ListHostedZonesByName'
- - 'route53:ListHostedZones'
- effect: Allow
- resource: '*'
- secretRef:
- name: cert-manager-dns-credentials
- namespace: cert-manager
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: operator.openshift.io/v1
-kind: IngressController
-metadata:
- name: default
- namespace: openshift-ingress-operator
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- routeAdmission:
- wildcardPolicy: WildcardsAllowed
- defaultCertificate:
- name: lets-encrypt-wildcart-cert-tls
-# Patch the cluster-wide argocd instance so it uses the ingress tls cert
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: cert-manager-operator
- namespace: cert-manager-operator
-spec:
- targetNamespaces:
- - cert-manager-operator
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: openshift-cert-manager-operator
- namespace: cert-manager-operator
-spec:
- channel: "stable-v1"
- installPlanApproval: Automatic
- name: openshift-cert-manager-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
diff --git a/tests/common-letsencrypt-normal.expected.yaml b/tests/common-letsencrypt-normal.expected.yaml
deleted file mode 100644
index b5aded2f..00000000
--- a/tests/common-letsencrypt-normal.expected.yaml
+++ /dev/null
@@ -1,202 +0,0 @@
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: cert-manager-operator
-spec:
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: cert-manager
-spec:
----
-# Source: letsencrypt/templates/namespaces.yaml
-apiVersion: v1
-kind: Namespace
-metadata:
- name: letsencrypt
-spec:
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: config.openshift.io/v1
-kind: APIServer
-metadata:
- name: cluster
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- servingCerts:
- namedCertificates:
- - names:
- - api.region.example.com
- servingCertificate:
- name: api-validated-patterns-letsencrypt-cert
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: argoproj.io/v1alpha1
-kind: ArgoCD
-metadata:
- name: openshift-gitops
- namespace: openshift-gitops
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- server:
- route:
- enabled: true
- tls:
- termination: reencrypt
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operator.openshift.io/v1alpha1
-kind: CertManager
-metadata:
- name: cluster
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- managementState: "Managed"
- unsupportedConfigOverrides:
- # Here's an example to supply custom DNS settings.
- controller:
- args:
- - "--dns01-recursive-nameservers=8.8.8.8:53,1.1.1.1:53"
- - "--dns01-recursive-nameservers-only"
----
-# Source: letsencrypt/templates/api-cert.yaml
-apiVersion: cert-manager.io/v1
-kind: Certificate
-metadata:
- name: api-validated-patterns-cert
- namespace: openshift-config
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- secretName: api-validated-patterns-letsencrypt-cert
- duration: 168h0m0s
- renewBefore: 28h0m0s
- commonName: 'api.region.example.com'
- usages:
- - server auth
- dnsNames:
- - api.region.example.com
- issuerRef:
- name: validated-patterns-issuer
- kind: ClusterIssuer
- subject:
- organizations:
- - hybrid-cloud-patterns.io
----
-# Source: letsencrypt/templates/wildcard-cert.yaml
-apiVersion: cert-manager.io/v1
-kind: Certificate
-metadata:
- name: lets-encrypt-certs
- namespace: openshift-ingress
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- secretName: lets-encrypt-wildcart-cert-tls
- duration: 168h0m0s
- renewBefore: 28h0m0s
- commonName: '*.apps.region.example.com'
- usages:
- - server auth
- dnsNames:
- - '*.apps.region.example.com'
- issuerRef:
- name: validated-patterns-issuer
- kind: ClusterIssuer
- subject:
- organizations:
- - hybrid-cloud-patterns.io
----
-# Source: letsencrypt/templates/issuer.yaml
-apiVersion: cert-manager.io/v1
-kind: ClusterIssuer
-metadata:
- name: validated-patterns-issuer
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- acme:
- server: https://acme-staging-v02.api.letsencrypt.org/directory
- email: test@example.com
- privateKeySecretRef:
- name: validated-patterns-issuer-account-key
- solvers:
- - selector: {}
- dns01:
- route53:
- region: eu-central-1
- accessKeyIDSecretRef:
- name: cert-manager-dns-credentials
- key: aws_access_key_id
- secretAccessKeySecretRef:
- name: cert-manager-dns-credentials
- key: aws_secret_access_key
----
-# Source: letsencrypt/templates/credentials-request.yaml
-apiVersion: cloudcredential.openshift.io/v1
-kind: CredentialsRequest
-metadata:
- name: letsencrypt-cert-manager-dns
- namespace: openshift-cloud-credential-operator
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
-spec:
- providerSpec:
- apiVersion: cloudcredential.openshift.io/v1
- kind: AWSProviderSpec
- statementEntries:
- - action:
- - 'route53:ChangeResourceRecordSets'
- - 'route53:GetChange'
- - 'route53:ListHostedZonesByName'
- - 'route53:ListHostedZones'
- effect: Allow
- resource: '*'
- secretRef:
- name: cert-manager-dns-credentials
- namespace: cert-manager
----
-# Source: letsencrypt/templates/default-routes.yaml
-apiVersion: operator.openshift.io/v1
-kind: IngressController
-metadata:
- name: default
- namespace: openshift-ingress-operator
- annotations:
- argocd.argoproj.io/sync-options: ServerSideApply=true, Validate=false, SkipDryRunOnMissingResource=true
-spec:
- routeAdmission:
- wildcardPolicy: WildcardsAllowed
- defaultCertificate:
- name: lets-encrypt-wildcart-cert-tls
-# Patch the cluster-wide argocd instance so it uses the ingress tls cert
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operators.coreos.com/v1
-kind: OperatorGroup
-metadata:
- name: cert-manager-operator
- namespace: cert-manager-operator
-spec:
- targetNamespaces:
- - cert-manager-operator
----
-# Source: letsencrypt/templates/cert-manager-installation.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: openshift-cert-manager-operator
- namespace: cert-manager-operator
-spec:
- channel: "stable-v1"
- installPlanApproval: Automatic
- name: openshift-cert-manager-operator
- source: redhat-operators
- sourceNamespace: openshift-marketplace
diff --git a/tests/common-operator-install-industrial-edge-factory.expected.yaml b/tests/common-operator-install-industrial-edge-factory.expected.yaml
deleted file mode 100644
index bcedc405..00000000
--- a/tests/common-operator-install-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,44 +0,0 @@
----
-# Source: pattern-install/templates/pattern-operator-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: patterns-operator-config
- namespace: openshift-operators
-data:
- gitops.catalogSource: redhat-operators
- gitops.channel: gitops-1.13
-
- # gitops.sourceNamespace: GitOpsDefaultCatalogSourceNamespace
- # gitops.installApprovalPlan: GitOpsDefaultApprovalPlan
- # gitops.ManualSync: GitOpsDefaultManualSync
- # gitops.name: GitOpsDefaultPackageName
----
-# Source: pattern-install/templates/pattern.yaml
-apiVersion: gitops.hybrid-cloud-patterns.io/v1alpha1
-kind: Pattern
-metadata:
- name: common-operator-install
- namespace: openshift-operators
-spec:
- clusterGroupName: hub
- gitSpec:
- targetRepo: https://github.com/pattern-clone/mypattern
- targetRevision: main
- multiSourceConfig:
- enabled: false
----
-# Source: pattern-install/templates/subscription.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: patterns-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/patterns-operator.openshift-operators: ""
-spec:
- channel: fast
- installPlanApproval: Automatic
- name: patterns-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
diff --git a/tests/common-operator-install-industrial-edge-hub.expected.yaml b/tests/common-operator-install-industrial-edge-hub.expected.yaml
deleted file mode 100644
index bcedc405..00000000
--- a/tests/common-operator-install-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,44 +0,0 @@
----
-# Source: pattern-install/templates/pattern-operator-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: patterns-operator-config
- namespace: openshift-operators
-data:
- gitops.catalogSource: redhat-operators
- gitops.channel: gitops-1.13
-
- # gitops.sourceNamespace: GitOpsDefaultCatalogSourceNamespace
- # gitops.installApprovalPlan: GitOpsDefaultApprovalPlan
- # gitops.ManualSync: GitOpsDefaultManualSync
- # gitops.name: GitOpsDefaultPackageName
----
-# Source: pattern-install/templates/pattern.yaml
-apiVersion: gitops.hybrid-cloud-patterns.io/v1alpha1
-kind: Pattern
-metadata:
- name: common-operator-install
- namespace: openshift-operators
-spec:
- clusterGroupName: hub
- gitSpec:
- targetRepo: https://github.com/pattern-clone/mypattern
- targetRevision: main
- multiSourceConfig:
- enabled: false
----
-# Source: pattern-install/templates/subscription.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: patterns-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/patterns-operator.openshift-operators: ""
-spec:
- channel: fast
- installPlanApproval: Automatic
- name: patterns-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
diff --git a/tests/common-operator-install-medical-diagnosis-hub.expected.yaml b/tests/common-operator-install-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index bcedc405..00000000
--- a/tests/common-operator-install-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,44 +0,0 @@
----
-# Source: pattern-install/templates/pattern-operator-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: patterns-operator-config
- namespace: openshift-operators
-data:
- gitops.catalogSource: redhat-operators
- gitops.channel: gitops-1.13
-
- # gitops.sourceNamespace: GitOpsDefaultCatalogSourceNamespace
- # gitops.installApprovalPlan: GitOpsDefaultApprovalPlan
- # gitops.ManualSync: GitOpsDefaultManualSync
- # gitops.name: GitOpsDefaultPackageName
----
-# Source: pattern-install/templates/pattern.yaml
-apiVersion: gitops.hybrid-cloud-patterns.io/v1alpha1
-kind: Pattern
-metadata:
- name: common-operator-install
- namespace: openshift-operators
-spec:
- clusterGroupName: hub
- gitSpec:
- targetRepo: https://github.com/pattern-clone/mypattern
- targetRevision: main
- multiSourceConfig:
- enabled: false
----
-# Source: pattern-install/templates/subscription.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: patterns-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/patterns-operator.openshift-operators: ""
-spec:
- channel: fast
- installPlanApproval: Automatic
- name: patterns-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
diff --git a/tests/common-operator-install-naked.expected.yaml b/tests/common-operator-install-naked.expected.yaml
deleted file mode 100644
index 7466acc4..00000000
--- a/tests/common-operator-install-naked.expected.yaml
+++ /dev/null
@@ -1,44 +0,0 @@
----
-# Source: pattern-install/templates/pattern-operator-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: patterns-operator-config
- namespace: openshift-operators
-data:
- gitops.catalogSource: redhat-operators
- gitops.channel: gitops-1.13
-
- # gitops.sourceNamespace: GitOpsDefaultCatalogSourceNamespace
- # gitops.installApprovalPlan: GitOpsDefaultApprovalPlan
- # gitops.ManualSync: GitOpsDefaultManualSync
- # gitops.name: GitOpsDefaultPackageName
----
-# Source: pattern-install/templates/pattern.yaml
-apiVersion: gitops.hybrid-cloud-patterns.io/v1alpha1
-kind: Pattern
-metadata:
- name: common-operator-install
- namespace: openshift-operators
-spec:
- clusterGroupName: default
- gitSpec:
- targetRepo: https://github.com/pattern-clone/mypattern
- targetRevision: main
- multiSourceConfig:
- enabled: false
----
-# Source: pattern-install/templates/subscription.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: patterns-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/patterns-operator.openshift-operators: ""
-spec:
- channel: fast
- installPlanApproval: Automatic
- name: patterns-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
diff --git a/tests/common-operator-install-normal.expected.yaml b/tests/common-operator-install-normal.expected.yaml
deleted file mode 100644
index bcedc405..00000000
--- a/tests/common-operator-install-normal.expected.yaml
+++ /dev/null
@@ -1,44 +0,0 @@
----
-# Source: pattern-install/templates/pattern-operator-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: patterns-operator-config
- namespace: openshift-operators
-data:
- gitops.catalogSource: redhat-operators
- gitops.channel: gitops-1.13
-
- # gitops.sourceNamespace: GitOpsDefaultCatalogSourceNamespace
- # gitops.installApprovalPlan: GitOpsDefaultApprovalPlan
- # gitops.ManualSync: GitOpsDefaultManualSync
- # gitops.name: GitOpsDefaultPackageName
----
-# Source: pattern-install/templates/pattern.yaml
-apiVersion: gitops.hybrid-cloud-patterns.io/v1alpha1
-kind: Pattern
-metadata:
- name: common-operator-install
- namespace: openshift-operators
-spec:
- clusterGroupName: hub
- gitSpec:
- targetRepo: https://github.com/pattern-clone/mypattern
- targetRevision: main
- multiSourceConfig:
- enabled: false
----
-# Source: pattern-install/templates/subscription.yaml
-apiVersion: operators.coreos.com/v1alpha1
-kind: Subscription
-metadata:
- name: patterns-operator
- namespace: openshift-operators
- labels:
- operators.coreos.com/patterns-operator.openshift-operators: ""
-spec:
- channel: fast
- installPlanApproval: Automatic
- name: patterns-operator
- source: community-operators
- sourceNamespace: openshift-marketplace
diff --git a/tests/hub-acs-central-industrial-edge-factory.expected.yaml b/tests/hub-acs-central-industrial-edge-factory.expected.yaml
deleted file mode 100644
index f3d99fd7..00000000
--- a/tests/hub-acs-central-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,541 +0,0 @@
----
-# Source: acs/templates/rbac/cluster-init-bundle-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: create-cluster-init
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "1"
----
-# Source: acs/templates/rbac/cluster-init-bundle-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "1"
- name: create-cluster-init
- namespace: stackrox
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - list
- - create
- - patch
- - update
- - apiGroups:
- - platform.stackrox.io
- resources:
- - securedclusters
- verbs:
- - get
- - list
- - patch
- - update
----
-# Source: acs/templates/rbac/cluster-init-bundle-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: create-cluster-init
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "1"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: create-cluster-init
-subjects:
- - kind: ServiceAccount
- name: create-cluster-init
- namespace: stackrox
----
-# Source: acs/templates/create-cluster-init-bundle-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/sync-wave: "5"
- name: create-cluster-init-bundle
- namespace: stackrox
-spec:
- template:
- metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: PASSWORD
- valueFrom:
- secretKeyRef:
- name: central-htpasswd
- key: password
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- if kubectl get secret/sensor-tls &> /dev/null; then
- echo "cluster-init bundle has already been configured, doing nothing"
- exit 0
- else
-
- # Wait for central to be ready
- attempt_counter=0
- max_attempts=20
- echo "Waiting for central to be available..."
- until $(curl -k --output /dev/null --silent --head --fail https://central); do
- if [ ${attempt_counter} -eq ${max_attempts} ];then
- echo "Max attempts reached"
- exit 1
- fi
-
- printf '.'
- attempt_counter=$(($attempt_counter+1))
- echo "Made attempt $attempt_counter, waiting..."
- done
-
- echo "Configuring cluster-init bundle"
- export DATA={\"name\":\"local-cluster\"}
- curl -k -o /tmp/bundle.json -X POST -u "admin:$PASSWORD" -H "Content-Type: application/json" --data $DATA https://central/v1/cluster-init/init-bundles
-
- echo "Bundle received"
- cat /tmp/bundle.json
-
- echo "Applying bundle"
- # No jq in container, python to the rescue
- cat /tmp/bundle.json | python3 -c "import sys, json; print(json.load(sys.stdin)['kubectlBundle'])" | base64 -d | oc apply -f -
- # Touch SecuredCluster to force operator to reconcile
- oc label SecuredCluster local-cluster cluster-init-job-status=created
-
- echo "ACS Cluster init bundle generated and applied"
- fi
- imagePullPolicy: Always
- name: create-cluster-init-bundle
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: create-cluster-init
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 30
----
-# Source: acs/templates/integration/job-stackrox-api-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "8"
- name: get-stackrox-api-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli-tools:latest
- command:
- - /bin/bash
- - -c
- - |
- ACSTOKEN=$(curl -sk -u "admin:$(oc extract secret/central-htpasswd --keys=password --to=-)" "https://central-stackrox.apps.hub.example.com/v1/apitokens/generate" -d '{"name":"token name", "role": "Admin"}' | jq -r '.token')
- oc create secret -n stackrox generic acs-api-token --from-literal=token=$ACSTOKEN
- name: stackrox-api-token
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 300
- restartPolicy: Never
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 60
----
-# Source: acs/templates/job-create-auth-provider.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/sync-wave: "7"
- name: create-auth-provider
- namespace: stackrox
-spec:
- template:
- metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: PASSWORD
- valueFrom:
- secretKeyRef:
- name: central-htpasswd
- key: password
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- echo "Creating auth provider in RHACS"
- export DATA={\"name\":\"local-cluster\"}
- curl -X POST -u "admin:$PASSWORD" -k https://central/v1/authProviders --data '{"name": "OpenShift OAuth", "type": "openshift", "enabled": true}' > /tmp/output.json
- AUTH_PROVIDER_ID=$(sed 's/,/\n/g' /tmp/output.json | grep -w id | awk -F\" '{ print $4 }') ### Since the image does not have the 'jq' command
- JSON_PAYLOAD="{\"roleName\":\"Admin\",\"props\":{\"authProviderId\":\"$AUTH_PROVIDER_ID\",\"key\":\"name\",\"value\":\"kube:admin\"}}"
- curl -X POST -u "admin:$PASSWORD" -k https://central/v1/groups -s --data "$JSON_PAYLOAD" ### Adding the Admin entry for the KubeAdmin user
- imagePullPolicy: Always
- name: create-auth-provider
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: create-cluster-init
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 30
----
-# Source: acs/templates/central-stackrox-central-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: Central
-metadata:
- namespace: stackrox
- name: stackrox-central-services
-spec:
- central:
- exposure:
- loadBalancer:
- enabled: false
- port: 443
- nodePort:
- enabled: false
- route:
- enabled: true
- persistence:
- persistentVolumeClaim:
- claimName: stackrox-db
- egress:
- connectivityPolicy: Online
- scanner:
- analyzer:
- scaling:
- autoScaling: Enabled
- maxReplicas: 5
- minReplicas: 2
- replicas: 3
- scannerComponent: Enabled
----
-# Source: acs/templates/acs-console-link.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: factory-acs-link
- namespace: stackrox
-spec:
- applicationMenu:
- section: Red Hat applications
- imageURL: 'https://upload.wikimedia.org/wikipedia/commons/3/3a/OpenShift-LogoType.svg'
- href: 'https://central-stackrox.apps.region.example.com'
- location: ApplicationMenu
- text: 'Red Hat Advanced Cluster Security for Kubernetes'
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acs-integrations-token-placement-binding
-placementRef:
- name: acs-integrations-token-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-acs-integrations-token
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acs/templates/policy/secured-cluster-secret-placement-binding.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: secured-cluster-secret-placement-binding
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-placementRef:
- name: secured-cluster-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: secured-cluster-secret-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acs-integrations-token-placement
-spec:
- # This will go to all devel clusters
- clusterSelector:
- # Using matchLabels because I need it in only one clusterGroup
- matchLabels:
- clusterGroup: devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: acs/templates/policy/secured-cluster-secret-placement-rule.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: secured-cluster-secret-placement
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-spec:
- # This will go to all managed clusters
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-acs-integrations-token
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acs-api-token-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: acs-api-token
- namespace: stackrox
- apiVersion: v1
- data:
- token: '{{hub fromSecret "stackrox" "acs-api-token" "token" hub}}'
----
-# Source: acs/templates/policy/policy-acs-central-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-5 Security Alerts Advisories and
- Directives
- policy.open-cluster-management.io/standards: NIST SP 800-53
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-acs-central-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-acs-central-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: central
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: scanner-db
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: scanner
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: acs/templates/policy/policy-acs-secured-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-5 Security Alerts Advisories and
- Directives
- policy.open-cluster-management.io/standards: NIST SP 800-53
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-acs-secured-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-acs-secured-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: sensor
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: DaemonSet
- metadata:
- name: collector
- namespace: stackrox
- status:
- numberMisscheduled: 0
- remediationAction: inform
- severity: medium
----
-# Source: acs/templates/policy/secured-cluster-secret-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: secured-cluster-secret-policy
- namespace: stackrox
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "2"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: secured-cluster-secret
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
-# policy.open-cluster-management.io/trigger-update: "2"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- - rhacs-operator
- - stackrox
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- admission-control-cert.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "admission-control-cert.pem" hub}}'
- admission-control-key.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "admission-control-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: admission-control-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- sensor-cert.pem: '{{hub fromSecret "stackrox" "sensor-tls" "sensor-cert.pem" hub}}'
- sensor-key.pem: '{{hub fromSecret "stackrox" "sensor-tls" "sensor-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "sensor-tls" "ca.pem" hub}}'
- acs-host: '{{hub fromSecret "stackrox" "sensor-tls" "acs-host" hub}}'
- kind: Secret
- metadata:
- name: sensor-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- collector-cert.pem: '{{hub fromSecret "stackrox" "collector-tls" "collector-cert.pem" hub}}'
- collector-key.pem: '{{hub fromSecret "stackrox" "collector-tls" "collector-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "collector-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: collector-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- cert.pem: '{{hub fromSecret "stackrox" "scanner-tls" "cert.pem" hub}}'
- key.pem: '{{hub fromSecret "stackrox" "scanner-tls" "key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "scanner-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: scanner-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- cert.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "cert.pem" hub}}'
- key.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: scanner-db-tls
- namespace: stackrox
- type: Opaque
diff --git a/tests/hub-acs-central-industrial-edge-hub.expected.yaml b/tests/hub-acs-central-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 56a57c16..00000000
--- a/tests/hub-acs-central-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,541 +0,0 @@
----
-# Source: acs/templates/rbac/cluster-init-bundle-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: create-cluster-init
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "1"
----
-# Source: acs/templates/rbac/cluster-init-bundle-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "1"
- name: create-cluster-init
- namespace: stackrox
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - list
- - create
- - patch
- - update
- - apiGroups:
- - platform.stackrox.io
- resources:
- - securedclusters
- verbs:
- - get
- - list
- - patch
- - update
----
-# Source: acs/templates/rbac/cluster-init-bundle-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: create-cluster-init
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "1"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: create-cluster-init
-subjects:
- - kind: ServiceAccount
- name: create-cluster-init
- namespace: stackrox
----
-# Source: acs/templates/create-cluster-init-bundle-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/sync-wave: "5"
- name: create-cluster-init-bundle
- namespace: stackrox
-spec:
- template:
- metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: PASSWORD
- valueFrom:
- secretKeyRef:
- name: central-htpasswd
- key: password
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- if kubectl get secret/sensor-tls &> /dev/null; then
- echo "cluster-init bundle has already been configured, doing nothing"
- exit 0
- else
-
- # Wait for central to be ready
- attempt_counter=0
- max_attempts=20
- echo "Waiting for central to be available..."
- until $(curl -k --output /dev/null --silent --head --fail https://central); do
- if [ ${attempt_counter} -eq ${max_attempts} ];then
- echo "Max attempts reached"
- exit 1
- fi
-
- printf '.'
- attempt_counter=$(($attempt_counter+1))
- echo "Made attempt $attempt_counter, waiting..."
- done
-
- echo "Configuring cluster-init bundle"
- export DATA={\"name\":\"local-cluster\"}
- curl -k -o /tmp/bundle.json -X POST -u "admin:$PASSWORD" -H "Content-Type: application/json" --data $DATA https://central/v1/cluster-init/init-bundles
-
- echo "Bundle received"
- cat /tmp/bundle.json
-
- echo "Applying bundle"
- # No jq in container, python to the rescue
- cat /tmp/bundle.json | python3 -c "import sys, json; print(json.load(sys.stdin)['kubectlBundle'])" | base64 -d | oc apply -f -
- # Touch SecuredCluster to force operator to reconcile
- oc label SecuredCluster local-cluster cluster-init-job-status=created
-
- echo "ACS Cluster init bundle generated and applied"
- fi
- imagePullPolicy: Always
- name: create-cluster-init-bundle
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: create-cluster-init
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 30
----
-# Source: acs/templates/integration/job-stackrox-api-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "8"
- name: get-stackrox-api-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli-tools:latest
- command:
- - /bin/bash
- - -c
- - |
- ACSTOKEN=$(curl -sk -u "admin:$(oc extract secret/central-htpasswd --keys=password --to=-)" "https://central-stackrox.apps.hub.example.com/v1/apitokens/generate" -d '{"name":"token name", "role": "Admin"}' | jq -r '.token')
- oc create secret -n stackrox generic acs-api-token --from-literal=token=$ACSTOKEN
- name: stackrox-api-token
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 300
- restartPolicy: Never
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 60
----
-# Source: acs/templates/job-create-auth-provider.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/sync-wave: "7"
- name: create-auth-provider
- namespace: stackrox
-spec:
- template:
- metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: PASSWORD
- valueFrom:
- secretKeyRef:
- name: central-htpasswd
- key: password
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- echo "Creating auth provider in RHACS"
- export DATA={\"name\":\"local-cluster\"}
- curl -X POST -u "admin:$PASSWORD" -k https://central/v1/authProviders --data '{"name": "OpenShift OAuth", "type": "openshift", "enabled": true}' > /tmp/output.json
- AUTH_PROVIDER_ID=$(sed 's/,/\n/g' /tmp/output.json | grep -w id | awk -F\" '{ print $4 }') ### Since the image does not have the 'jq' command
- JSON_PAYLOAD="{\"roleName\":\"Admin\",\"props\":{\"authProviderId\":\"$AUTH_PROVIDER_ID\",\"key\":\"name\",\"value\":\"kube:admin\"}}"
- curl -X POST -u "admin:$PASSWORD" -k https://central/v1/groups -s --data "$JSON_PAYLOAD" ### Adding the Admin entry for the KubeAdmin user
- imagePullPolicy: Always
- name: create-auth-provider
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: create-cluster-init
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 30
----
-# Source: acs/templates/central-stackrox-central-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: Central
-metadata:
- namespace: stackrox
- name: stackrox-central-services
-spec:
- central:
- exposure:
- loadBalancer:
- enabled: false
- port: 443
- nodePort:
- enabled: false
- route:
- enabled: true
- persistence:
- persistentVolumeClaim:
- claimName: stackrox-db
- egress:
- connectivityPolicy: Online
- scanner:
- analyzer:
- scaling:
- autoScaling: Enabled
- maxReplicas: 5
- minReplicas: 2
- replicas: 3
- scannerComponent: Enabled
----
-# Source: acs/templates/acs-console-link.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: datacenter-acs-link
- namespace: stackrox
-spec:
- applicationMenu:
- section: Red Hat applications
- imageURL: 'https://upload.wikimedia.org/wikipedia/commons/3/3a/OpenShift-LogoType.svg'
- href: 'https://central-stackrox.apps.region.example.com'
- location: ApplicationMenu
- text: 'Red Hat Advanced Cluster Security for Kubernetes'
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acs-integrations-token-placement-binding
-placementRef:
- name: acs-integrations-token-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-acs-integrations-token
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acs/templates/policy/secured-cluster-secret-placement-binding.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: secured-cluster-secret-placement-binding
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-placementRef:
- name: secured-cluster-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: secured-cluster-secret-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acs-integrations-token-placement
-spec:
- # This will go to all devel clusters
- clusterSelector:
- # Using matchLabels because I need it in only one clusterGroup
- matchLabels:
- clusterGroup: devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: acs/templates/policy/secured-cluster-secret-placement-rule.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: secured-cluster-secret-placement
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-spec:
- # This will go to all managed clusters
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-acs-integrations-token
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acs-api-token-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: acs-api-token
- namespace: stackrox
- apiVersion: v1
- data:
- token: '{{hub fromSecret "stackrox" "acs-api-token" "token" hub}}'
----
-# Source: acs/templates/policy/policy-acs-central-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-5 Security Alerts Advisories and
- Directives
- policy.open-cluster-management.io/standards: NIST SP 800-53
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-acs-central-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-acs-central-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: central
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: scanner-db
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: scanner
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: acs/templates/policy/policy-acs-secured-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-5 Security Alerts Advisories and
- Directives
- policy.open-cluster-management.io/standards: NIST SP 800-53
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-acs-secured-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-acs-secured-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: sensor
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: DaemonSet
- metadata:
- name: collector
- namespace: stackrox
- status:
- numberMisscheduled: 0
- remediationAction: inform
- severity: medium
----
-# Source: acs/templates/policy/secured-cluster-secret-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: secured-cluster-secret-policy
- namespace: stackrox
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "2"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: secured-cluster-secret
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
-# policy.open-cluster-management.io/trigger-update: "2"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- - rhacs-operator
- - stackrox
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- admission-control-cert.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "admission-control-cert.pem" hub}}'
- admission-control-key.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "admission-control-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: admission-control-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- sensor-cert.pem: '{{hub fromSecret "stackrox" "sensor-tls" "sensor-cert.pem" hub}}'
- sensor-key.pem: '{{hub fromSecret "stackrox" "sensor-tls" "sensor-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "sensor-tls" "ca.pem" hub}}'
- acs-host: '{{hub fromSecret "stackrox" "sensor-tls" "acs-host" hub}}'
- kind: Secret
- metadata:
- name: sensor-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- collector-cert.pem: '{{hub fromSecret "stackrox" "collector-tls" "collector-cert.pem" hub}}'
- collector-key.pem: '{{hub fromSecret "stackrox" "collector-tls" "collector-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "collector-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: collector-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- cert.pem: '{{hub fromSecret "stackrox" "scanner-tls" "cert.pem" hub}}'
- key.pem: '{{hub fromSecret "stackrox" "scanner-tls" "key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "scanner-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: scanner-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- cert.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "cert.pem" hub}}'
- key.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: scanner-db-tls
- namespace: stackrox
- type: Opaque
diff --git a/tests/hub-acs-central-medical-diagnosis-hub.expected.yaml b/tests/hub-acs-central-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 70e26f63..00000000
--- a/tests/hub-acs-central-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,541 +0,0 @@
----
-# Source: acs/templates/rbac/cluster-init-bundle-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: create-cluster-init
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "1"
----
-# Source: acs/templates/rbac/cluster-init-bundle-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "1"
- name: create-cluster-init
- namespace: stackrox
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - list
- - create
- - patch
- - update
- - apiGroups:
- - platform.stackrox.io
- resources:
- - securedclusters
- verbs:
- - get
- - list
- - patch
- - update
----
-# Source: acs/templates/rbac/cluster-init-bundle-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: create-cluster-init
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "1"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: create-cluster-init
-subjects:
- - kind: ServiceAccount
- name: create-cluster-init
- namespace: stackrox
----
-# Source: acs/templates/create-cluster-init-bundle-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/sync-wave: "5"
- name: create-cluster-init-bundle
- namespace: stackrox
-spec:
- template:
- metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: PASSWORD
- valueFrom:
- secretKeyRef:
- name: central-htpasswd
- key: password
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- if kubectl get secret/sensor-tls &> /dev/null; then
- echo "cluster-init bundle has already been configured, doing nothing"
- exit 0
- else
-
- # Wait for central to be ready
- attempt_counter=0
- max_attempts=20
- echo "Waiting for central to be available..."
- until $(curl -k --output /dev/null --silent --head --fail https://central); do
- if [ ${attempt_counter} -eq ${max_attempts} ];then
- echo "Max attempts reached"
- exit 1
- fi
-
- printf '.'
- attempt_counter=$(($attempt_counter+1))
- echo "Made attempt $attempt_counter, waiting..."
- done
-
- echo "Configuring cluster-init bundle"
- export DATA={\"name\":\"local-cluster\"}
- curl -k -o /tmp/bundle.json -X POST -u "admin:$PASSWORD" -H "Content-Type: application/json" --data $DATA https://central/v1/cluster-init/init-bundles
-
- echo "Bundle received"
- cat /tmp/bundle.json
-
- echo "Applying bundle"
- # No jq in container, python to the rescue
- cat /tmp/bundle.json | python3 -c "import sys, json; print(json.load(sys.stdin)['kubectlBundle'])" | base64 -d | oc apply -f -
- # Touch SecuredCluster to force operator to reconcile
- oc label SecuredCluster local-cluster cluster-init-job-status=created
-
- echo "ACS Cluster init bundle generated and applied"
- fi
- imagePullPolicy: Always
- name: create-cluster-init-bundle
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: create-cluster-init
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 30
----
-# Source: acs/templates/integration/job-stackrox-api-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "8"
- name: get-stackrox-api-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli-tools:latest
- command:
- - /bin/bash
- - -c
- - |
- ACSTOKEN=$(curl -sk -u "admin:$(oc extract secret/central-htpasswd --keys=password --to=-)" "https://central-stackrox.apps.hub.example.com/v1/apitokens/generate" -d '{"name":"token name", "role": "Admin"}' | jq -r '.token')
- oc create secret -n stackrox generic acs-api-token --from-literal=token=$ACSTOKEN
- name: stackrox-api-token
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 300
- restartPolicy: Never
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 60
----
-# Source: acs/templates/job-create-auth-provider.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/sync-wave: "7"
- name: create-auth-provider
- namespace: stackrox
-spec:
- template:
- metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: PASSWORD
- valueFrom:
- secretKeyRef:
- name: central-htpasswd
- key: password
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- echo "Creating auth provider in RHACS"
- export DATA={\"name\":\"local-cluster\"}
- curl -X POST -u "admin:$PASSWORD" -k https://central/v1/authProviders --data '{"name": "OpenShift OAuth", "type": "openshift", "enabled": true}' > /tmp/output.json
- AUTH_PROVIDER_ID=$(sed 's/,/\n/g' /tmp/output.json | grep -w id | awk -F\" '{ print $4 }') ### Since the image does not have the 'jq' command
- JSON_PAYLOAD="{\"roleName\":\"Admin\",\"props\":{\"authProviderId\":\"$AUTH_PROVIDER_ID\",\"key\":\"name\",\"value\":\"kube:admin\"}}"
- curl -X POST -u "admin:$PASSWORD" -k https://central/v1/groups -s --data "$JSON_PAYLOAD" ### Adding the Admin entry for the KubeAdmin user
- imagePullPolicy: Always
- name: create-auth-provider
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: create-cluster-init
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 30
----
-# Source: acs/templates/central-stackrox-central-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: Central
-metadata:
- namespace: stackrox
- name: stackrox-central-services
-spec:
- central:
- exposure:
- loadBalancer:
- enabled: false
- port: 443
- nodePort:
- enabled: false
- route:
- enabled: true
- persistence:
- persistentVolumeClaim:
- claimName: stackrox-db
- egress:
- connectivityPolicy: Online
- scanner:
- analyzer:
- scaling:
- autoScaling: Enabled
- maxReplicas: 5
- minReplicas: 2
- replicas: 3
- scannerComponent: Enabled
----
-# Source: acs/templates/acs-console-link.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: hub-acs-link
- namespace: stackrox
-spec:
- applicationMenu:
- section: Red Hat applications
- imageURL: 'https://upload.wikimedia.org/wikipedia/commons/3/3a/OpenShift-LogoType.svg'
- href: 'https://central-stackrox.apps.region.example.com'
- location: ApplicationMenu
- text: 'Red Hat Advanced Cluster Security for Kubernetes'
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acs-integrations-token-placement-binding
-placementRef:
- name: acs-integrations-token-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-acs-integrations-token
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acs/templates/policy/secured-cluster-secret-placement-binding.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: secured-cluster-secret-placement-binding
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-placementRef:
- name: secured-cluster-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: secured-cluster-secret-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acs-integrations-token-placement
-spec:
- # This will go to all devel clusters
- clusterSelector:
- # Using matchLabels because I need it in only one clusterGroup
- matchLabels:
- clusterGroup: devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: acs/templates/policy/secured-cluster-secret-placement-rule.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: secured-cluster-secret-placement
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-spec:
- # This will go to all managed clusters
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-acs-integrations-token
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acs-api-token-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: acs-api-token
- namespace: stackrox
- apiVersion: v1
- data:
- token: '{{hub fromSecret "stackrox" "acs-api-token" "token" hub}}'
----
-# Source: acs/templates/policy/policy-acs-central-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-5 Security Alerts Advisories and
- Directives
- policy.open-cluster-management.io/standards: NIST SP 800-53
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-acs-central-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-acs-central-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: central
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: scanner-db
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: scanner
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: acs/templates/policy/policy-acs-secured-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-5 Security Alerts Advisories and
- Directives
- policy.open-cluster-management.io/standards: NIST SP 800-53
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-acs-secured-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-acs-secured-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: sensor
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: DaemonSet
- metadata:
- name: collector
- namespace: stackrox
- status:
- numberMisscheduled: 0
- remediationAction: inform
- severity: medium
----
-# Source: acs/templates/policy/secured-cluster-secret-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: secured-cluster-secret-policy
- namespace: stackrox
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "2"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: secured-cluster-secret
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
-# policy.open-cluster-management.io/trigger-update: "2"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- - rhacs-operator
- - stackrox
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- admission-control-cert.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "admission-control-cert.pem" hub}}'
- admission-control-key.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "admission-control-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: admission-control-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- sensor-cert.pem: '{{hub fromSecret "stackrox" "sensor-tls" "sensor-cert.pem" hub}}'
- sensor-key.pem: '{{hub fromSecret "stackrox" "sensor-tls" "sensor-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "sensor-tls" "ca.pem" hub}}'
- acs-host: '{{hub fromSecret "stackrox" "sensor-tls" "acs-host" hub}}'
- kind: Secret
- metadata:
- name: sensor-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- collector-cert.pem: '{{hub fromSecret "stackrox" "collector-tls" "collector-cert.pem" hub}}'
- collector-key.pem: '{{hub fromSecret "stackrox" "collector-tls" "collector-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "collector-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: collector-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- cert.pem: '{{hub fromSecret "stackrox" "scanner-tls" "cert.pem" hub}}'
- key.pem: '{{hub fromSecret "stackrox" "scanner-tls" "key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "scanner-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: scanner-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- cert.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "cert.pem" hub}}'
- key.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: scanner-db-tls
- namespace: stackrox
- type: Opaque
diff --git a/tests/hub-acs-central-naked.expected.yaml b/tests/hub-acs-central-naked.expected.yaml
deleted file mode 100644
index ecccd822..00000000
--- a/tests/hub-acs-central-naked.expected.yaml
+++ /dev/null
@@ -1,541 +0,0 @@
----
-# Source: acs/templates/rbac/cluster-init-bundle-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: create-cluster-init
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "1"
----
-# Source: acs/templates/rbac/cluster-init-bundle-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "1"
- name: create-cluster-init
- namespace: stackrox
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - list
- - create
- - patch
- - update
- - apiGroups:
- - platform.stackrox.io
- resources:
- - securedclusters
- verbs:
- - get
- - list
- - patch
- - update
----
-# Source: acs/templates/rbac/cluster-init-bundle-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: create-cluster-init
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "1"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: create-cluster-init
-subjects:
- - kind: ServiceAccount
- name: create-cluster-init
- namespace: stackrox
----
-# Source: acs/templates/create-cluster-init-bundle-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/sync-wave: "5"
- name: create-cluster-init-bundle
- namespace: stackrox
-spec:
- template:
- metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: PASSWORD
- valueFrom:
- secretKeyRef:
- name: central-htpasswd
- key: password
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- if kubectl get secret/sensor-tls &> /dev/null; then
- echo "cluster-init bundle has already been configured, doing nothing"
- exit 0
- else
-
- # Wait for central to be ready
- attempt_counter=0
- max_attempts=20
- echo "Waiting for central to be available..."
- until $(curl -k --output /dev/null --silent --head --fail https://central); do
- if [ ${attempt_counter} -eq ${max_attempts} ];then
- echo "Max attempts reached"
- exit 1
- fi
-
- printf '.'
- attempt_counter=$(($attempt_counter+1))
- echo "Made attempt $attempt_counter, waiting..."
- done
-
- echo "Configuring cluster-init bundle"
- export DATA={\"name\":\"local-cluster\"}
- curl -k -o /tmp/bundle.json -X POST -u "admin:$PASSWORD" -H "Content-Type: application/json" --data $DATA https://central/v1/cluster-init/init-bundles
-
- echo "Bundle received"
- cat /tmp/bundle.json
-
- echo "Applying bundle"
- # No jq in container, python to the rescue
- cat /tmp/bundle.json | python3 -c "import sys, json; print(json.load(sys.stdin)['kubectlBundle'])" | base64 -d | oc apply -f -
- # Touch SecuredCluster to force operator to reconcile
- oc label SecuredCluster local-cluster cluster-init-job-status=created
-
- echo "ACS Cluster init bundle generated and applied"
- fi
- imagePullPolicy: Always
- name: create-cluster-init-bundle
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: create-cluster-init
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 30
----
-# Source: acs/templates/integration/job-stackrox-api-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "8"
- name: get-stackrox-api-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli-tools:latest
- command:
- - /bin/bash
- - -c
- - |
- ACSTOKEN=$(curl -sk -u "admin:$(oc extract secret/central-htpasswd --keys=password --to=-)" "https://central-stackrox.AUTOMATIC/v1/apitokens/generate" -d '{"name":"token name", "role": "Admin"}' | jq -r '.token')
- oc create secret -n stackrox generic acs-api-token --from-literal=token=$ACSTOKEN
- name: stackrox-api-token
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 300
- restartPolicy: Never
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 60
----
-# Source: acs/templates/job-create-auth-provider.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/sync-wave: "7"
- name: create-auth-provider
- namespace: stackrox
-spec:
- template:
- metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: PASSWORD
- valueFrom:
- secretKeyRef:
- name: central-htpasswd
- key: password
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- echo "Creating auth provider in RHACS"
- export DATA={\"name\":\"local-cluster\"}
- curl -X POST -u "admin:$PASSWORD" -k https://central/v1/authProviders --data '{"name": "OpenShift OAuth", "type": "openshift", "enabled": true}' > /tmp/output.json
- AUTH_PROVIDER_ID=$(sed 's/,/\n/g' /tmp/output.json | grep -w id | awk -F\" '{ print $4 }') ### Since the image does not have the 'jq' command
- JSON_PAYLOAD="{\"roleName\":\"Admin\",\"props\":{\"authProviderId\":\"$AUTH_PROVIDER_ID\",\"key\":\"name\",\"value\":\"kube:admin\"}}"
- curl -X POST -u "admin:$PASSWORD" -k https://central/v1/groups -s --data "$JSON_PAYLOAD" ### Adding the Admin entry for the KubeAdmin user
- imagePullPolicy: Always
- name: create-auth-provider
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: create-cluster-init
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 30
----
-# Source: acs/templates/central-stackrox-central-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: Central
-metadata:
- namespace: stackrox
- name: stackrox-central-services
-spec:
- central:
- exposure:
- loadBalancer:
- enabled: false
- port: 443
- nodePort:
- enabled: false
- route:
- enabled: true
- persistence:
- persistentVolumeClaim:
- claimName: stackrox-db
- egress:
- connectivityPolicy: Online
- scanner:
- analyzer:
- scaling:
- autoScaling: Enabled
- maxReplicas: 5
- minReplicas: 2
- replicas: 3
- scannerComponent: Enabled
----
-# Source: acs/templates/acs-console-link.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: AUTOMATIC-acs-link
- namespace: stackrox
-spec:
- applicationMenu:
- section: Red Hat applications
- imageURL: 'https://upload.wikimedia.org/wikipedia/commons/3/3a/OpenShift-LogoType.svg'
- href: 'https://central-stackrox.AUTOMATIC'
- location: ApplicationMenu
- text: 'Red Hat Advanced Cluster Security for Kubernetes'
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acs-integrations-token-placement-binding
-placementRef:
- name: acs-integrations-token-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-acs-integrations-token
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acs/templates/policy/secured-cluster-secret-placement-binding.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: secured-cluster-secret-placement-binding
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-placementRef:
- name: secured-cluster-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: secured-cluster-secret-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acs-integrations-token-placement
-spec:
- # This will go to all devel clusters
- clusterSelector:
- # Using matchLabels because I need it in only one clusterGroup
- matchLabels:
- clusterGroup: devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: acs/templates/policy/secured-cluster-secret-placement-rule.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: secured-cluster-secret-placement
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-spec:
- # This will go to all managed clusters
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-acs-integrations-token
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acs-api-token-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: acs-api-token
- namespace: stackrox
- apiVersion: v1
- data:
- token: '{{hub fromSecret "stackrox" "acs-api-token" "token" hub}}'
----
-# Source: acs/templates/policy/policy-acs-central-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-5 Security Alerts Advisories and
- Directives
- policy.open-cluster-management.io/standards: NIST SP 800-53
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-acs-central-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-acs-central-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: central
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: scanner-db
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: scanner
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: acs/templates/policy/policy-acs-secured-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-5 Security Alerts Advisories and
- Directives
- policy.open-cluster-management.io/standards: NIST SP 800-53
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-acs-secured-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-acs-secured-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: sensor
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: DaemonSet
- metadata:
- name: collector
- namespace: stackrox
- status:
- numberMisscheduled: 0
- remediationAction: inform
- severity: medium
----
-# Source: acs/templates/policy/secured-cluster-secret-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: secured-cluster-secret-policy
- namespace: stackrox
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "2"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: secured-cluster-secret
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
-# policy.open-cluster-management.io/trigger-update: "2"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- - rhacs-operator
- - stackrox
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- admission-control-cert.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "admission-control-cert.pem" hub}}'
- admission-control-key.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "admission-control-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: admission-control-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- sensor-cert.pem: '{{hub fromSecret "stackrox" "sensor-tls" "sensor-cert.pem" hub}}'
- sensor-key.pem: '{{hub fromSecret "stackrox" "sensor-tls" "sensor-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "sensor-tls" "ca.pem" hub}}'
- acs-host: '{{hub fromSecret "stackrox" "sensor-tls" "acs-host" hub}}'
- kind: Secret
- metadata:
- name: sensor-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- collector-cert.pem: '{{hub fromSecret "stackrox" "collector-tls" "collector-cert.pem" hub}}'
- collector-key.pem: '{{hub fromSecret "stackrox" "collector-tls" "collector-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "collector-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: collector-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- cert.pem: '{{hub fromSecret "stackrox" "scanner-tls" "cert.pem" hub}}'
- key.pem: '{{hub fromSecret "stackrox" "scanner-tls" "key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "scanner-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: scanner-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- cert.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "cert.pem" hub}}'
- key.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: scanner-db-tls
- namespace: stackrox
- type: Opaque
diff --git a/tests/hub-acs-central-normal.expected.yaml b/tests/hub-acs-central-normal.expected.yaml
deleted file mode 100644
index 115081af..00000000
--- a/tests/hub-acs-central-normal.expected.yaml
+++ /dev/null
@@ -1,541 +0,0 @@
----
-# Source: acs/templates/rbac/cluster-init-bundle-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: create-cluster-init
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "1"
----
-# Source: acs/templates/rbac/cluster-init-bundle-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "1"
- name: create-cluster-init
- namespace: stackrox
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - list
- - create
- - patch
- - update
- - apiGroups:
- - platform.stackrox.io
- resources:
- - securedclusters
- verbs:
- - get
- - list
- - patch
- - update
----
-# Source: acs/templates/rbac/cluster-init-bundle-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: create-cluster-init
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "1"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: Role
- name: create-cluster-init
-subjects:
- - kind: ServiceAccount
- name: create-cluster-init
- namespace: stackrox
----
-# Source: acs/templates/create-cluster-init-bundle-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/sync-wave: "5"
- name: create-cluster-init-bundle
- namespace: stackrox
-spec:
- template:
- metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: PASSWORD
- valueFrom:
- secretKeyRef:
- name: central-htpasswd
- key: password
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- if kubectl get secret/sensor-tls &> /dev/null; then
- echo "cluster-init bundle has already been configured, doing nothing"
- exit 0
- else
-
- # Wait for central to be ready
- attempt_counter=0
- max_attempts=20
- echo "Waiting for central to be available..."
- until $(curl -k --output /dev/null --silent --head --fail https://central); do
- if [ ${attempt_counter} -eq ${max_attempts} ];then
- echo "Max attempts reached"
- exit 1
- fi
-
- printf '.'
- attempt_counter=$(($attempt_counter+1))
- echo "Made attempt $attempt_counter, waiting..."
- done
-
- echo "Configuring cluster-init bundle"
- export DATA={\"name\":\"local-cluster\"}
- curl -k -o /tmp/bundle.json -X POST -u "admin:$PASSWORD" -H "Content-Type: application/json" --data $DATA https://central/v1/cluster-init/init-bundles
-
- echo "Bundle received"
- cat /tmp/bundle.json
-
- echo "Applying bundle"
- # No jq in container, python to the rescue
- cat /tmp/bundle.json | python3 -c "import sys, json; print(json.load(sys.stdin)['kubectlBundle'])" | base64 -d | oc apply -f -
- # Touch SecuredCluster to force operator to reconcile
- oc label SecuredCluster local-cluster cluster-init-job-status=created
-
- echo "ACS Cluster init bundle generated and applied"
- fi
- imagePullPolicy: Always
- name: create-cluster-init-bundle
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: create-cluster-init
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 30
----
-# Source: acs/templates/integration/job-stackrox-api-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "8"
- name: get-stackrox-api-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli-tools:latest
- command:
- - /bin/bash
- - -c
- - |
- ACSTOKEN=$(curl -sk -u "admin:$(oc extract secret/central-htpasswd --keys=password --to=-)" "https://central-stackrox.apps.hub.example.com/v1/apitokens/generate" -d '{"name":"token name", "role": "Admin"}' | jq -r '.token')
- oc create secret -n stackrox generic acs-api-token --from-literal=token=$ACSTOKEN
- name: stackrox-api-token
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 300
- restartPolicy: Never
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 60
----
-# Source: acs/templates/job-create-auth-provider.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- argocd.argoproj.io/sync-wave: "7"
- name: create-auth-provider
- namespace: stackrox
-spec:
- template:
- metadata:
- annotations:
- argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: PASSWORD
- valueFrom:
- secretKeyRef:
- name: central-htpasswd
- key: password
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- echo "Creating auth provider in RHACS"
- export DATA={\"name\":\"local-cluster\"}
- curl -X POST -u "admin:$PASSWORD" -k https://central/v1/authProviders --data '{"name": "OpenShift OAuth", "type": "openshift", "enabled": true}' > /tmp/output.json
- AUTH_PROVIDER_ID=$(sed 's/,/\n/g' /tmp/output.json | grep -w id | awk -F\" '{ print $4 }') ### Since the image does not have the 'jq' command
- JSON_PAYLOAD="{\"roleName\":\"Admin\",\"props\":{\"authProviderId\":\"$AUTH_PROVIDER_ID\",\"key\":\"name\",\"value\":\"kube:admin\"}}"
- curl -X POST -u "admin:$PASSWORD" -k https://central/v1/groups -s --data "$JSON_PAYLOAD" ### Adding the Admin entry for the KubeAdmin user
- imagePullPolicy: Always
- name: create-auth-provider
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: create-cluster-init
- serviceAccountName: create-cluster-init
- terminationGracePeriodSeconds: 30
----
-# Source: acs/templates/central-stackrox-central-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: Central
-metadata:
- namespace: stackrox
- name: stackrox-central-services
-spec:
- central:
- exposure:
- loadBalancer:
- enabled: false
- port: 443
- nodePort:
- enabled: false
- route:
- enabled: true
- persistence:
- persistentVolumeClaim:
- claimName: stackrox-db
- egress:
- connectivityPolicy: Online
- scanner:
- analyzer:
- scaling:
- autoScaling: Enabled
- maxReplicas: 5
- minReplicas: 2
- replicas: 3
- scannerComponent: Enabled
----
-# Source: acs/templates/acs-console-link.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: example-acs-link
- namespace: stackrox
-spec:
- applicationMenu:
- section: Red Hat applications
- imageURL: 'https://upload.wikimedia.org/wikipedia/commons/3/3a/OpenShift-LogoType.svg'
- href: 'https://central-stackrox.apps.region.example.com'
- location: ApplicationMenu
- text: 'Red Hat Advanced Cluster Security for Kubernetes'
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: acs-integrations-token-placement-binding
-placementRef:
- name: acs-integrations-token-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-acs-integrations-token
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acs/templates/policy/secured-cluster-secret-placement-binding.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: secured-cluster-secret-placement-binding
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-placementRef:
- name: secured-cluster-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: secured-cluster-secret-policy
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: acs-integrations-token-placement
-spec:
- # This will go to all devel clusters
- clusterSelector:
- # Using matchLabels because I need it in only one clusterGroup
- matchLabels:
- clusterGroup: devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: acs/templates/policy/secured-cluster-secret-placement-rule.yaml
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: secured-cluster-secret-placement
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-spec:
- # This will go to all managed clusters
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: acs/templates/integration/policy-acs-integrations-token.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-acs-integrations-token
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: acs-api-token-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: acs-api-token
- namespace: stackrox
- apiVersion: v1
- data:
- token: '{{hub fromSecret "stackrox" "acs-api-token" "token" hub}}'
----
-# Source: acs/templates/policy/policy-acs-central-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-5 Security Alerts Advisories and
- Directives
- policy.open-cluster-management.io/standards: NIST SP 800-53
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-acs-central-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-acs-central-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: central
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: scanner-db
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: scanner
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: acs/templates/policy/policy-acs-secured-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-5 Security Alerts Advisories and
- Directives
- policy.open-cluster-management.io/standards: NIST SP 800-53
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-acs-secured-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-acs-secured-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: sensor
- namespace: stackrox
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: DaemonSet
- metadata:
- name: collector
- namespace: stackrox
- status:
- numberMisscheduled: 0
- remediationAction: inform
- severity: medium
----
-# Source: acs/templates/policy/secured-cluster-secret-policy.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: secured-cluster-secret-policy
- namespace: stackrox
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "2"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: secured-cluster-secret
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
-# policy.open-cluster-management.io/trigger-update: "2"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- exclude:
- - kube-*
- include:
- - default
- - rhacs-operator
- - stackrox
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- admission-control-cert.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "admission-control-cert.pem" hub}}'
- admission-control-key.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "admission-control-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "admission-control-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: admission-control-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- sensor-cert.pem: '{{hub fromSecret "stackrox" "sensor-tls" "sensor-cert.pem" hub}}'
- sensor-key.pem: '{{hub fromSecret "stackrox" "sensor-tls" "sensor-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "sensor-tls" "ca.pem" hub}}'
- acs-host: '{{hub fromSecret "stackrox" "sensor-tls" "acs-host" hub}}'
- kind: Secret
- metadata:
- name: sensor-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- collector-cert.pem: '{{hub fromSecret "stackrox" "collector-tls" "collector-cert.pem" hub}}'
- collector-key.pem: '{{hub fromSecret "stackrox" "collector-tls" "collector-key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "collector-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: collector-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- cert.pem: '{{hub fromSecret "stackrox" "scanner-tls" "cert.pem" hub}}'
- key.pem: '{{hub fromSecret "stackrox" "scanner-tls" "key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "scanner-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: scanner-tls
- namespace: stackrox
- type: Opaque
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- data:
- cert.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "cert.pem" hub}}'
- key.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "key.pem" hub}}'
- ca.pem: '{{hub fromSecret "stackrox" "scanner-db-tls" "ca.pem" hub}}'
- kind: Secret
- metadata:
- name: scanner-db-tls
- namespace: stackrox
- type: Opaque
diff --git a/tests/hub-acs-secured-industrial-edge-factory.expected.yaml b/tests/hub-acs-secured-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 168d722e..00000000
--- a/tests/hub-acs-secured-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,26 +0,0 @@
----
-# Source: acs/templates/securedcluster-stackrox-secured-cluster-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: SecuredCluster
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: stackrox-secured-cluster-services
- namespace: stackrox
-spec:
- clusterName: region
- auditLogs:
- collection: Auto
- admissionControl:
- listenOnUpdates: true
- bypass: BreakGlassAnnotation
- contactImageScanners: DoNotScanInline
- listenOnCreates: true
- timeoutSeconds: 3
- listenOnEvents: true
- centralEndpoint: central-stackrox.apps.hub.example.com:443
- perNode:
- collector:
- collection: EBPF
- imageFlavor: Regular
- taintToleration: TolerateTaints
diff --git a/tests/hub-acs-secured-industrial-edge-hub.expected.yaml b/tests/hub-acs-secured-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 168d722e..00000000
--- a/tests/hub-acs-secured-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,26 +0,0 @@
----
-# Source: acs/templates/securedcluster-stackrox-secured-cluster-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: SecuredCluster
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: stackrox-secured-cluster-services
- namespace: stackrox
-spec:
- clusterName: region
- auditLogs:
- collection: Auto
- admissionControl:
- listenOnUpdates: true
- bypass: BreakGlassAnnotation
- contactImageScanners: DoNotScanInline
- listenOnCreates: true
- timeoutSeconds: 3
- listenOnEvents: true
- centralEndpoint: central-stackrox.apps.hub.example.com:443
- perNode:
- collector:
- collection: EBPF
- imageFlavor: Regular
- taintToleration: TolerateTaints
diff --git a/tests/hub-acs-secured-medical-diagnosis-hub.expected.yaml b/tests/hub-acs-secured-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 168d722e..00000000
--- a/tests/hub-acs-secured-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,26 +0,0 @@
----
-# Source: acs/templates/securedcluster-stackrox-secured-cluster-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: SecuredCluster
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: stackrox-secured-cluster-services
- namespace: stackrox
-spec:
- clusterName: region
- auditLogs:
- collection: Auto
- admissionControl:
- listenOnUpdates: true
- bypass: BreakGlassAnnotation
- contactImageScanners: DoNotScanInline
- listenOnCreates: true
- timeoutSeconds: 3
- listenOnEvents: true
- centralEndpoint: central-stackrox.apps.hub.example.com:443
- perNode:
- collector:
- collection: EBPF
- imageFlavor: Regular
- taintToleration: TolerateTaints
diff --git a/tests/hub-acs-secured-naked.expected.yaml b/tests/hub-acs-secured-naked.expected.yaml
deleted file mode 100644
index 5c42bb78..00000000
--- a/tests/hub-acs-secured-naked.expected.yaml
+++ /dev/null
@@ -1,26 +0,0 @@
----
-# Source: acs/templates/securedcluster-stackrox-secured-cluster-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: SecuredCluster
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: stackrox-secured-cluster-services
- namespace: stackrox
-spec:
- clusterName:
- auditLogs:
- collection: Auto
- admissionControl:
- listenOnUpdates: true
- bypass: BreakGlassAnnotation
- contactImageScanners: DoNotScanInline
- listenOnCreates: true
- timeoutSeconds: 3
- listenOnEvents: true
- centralEndpoint: central-stackrox.:443
- perNode:
- collector:
- collection: EBPF
- imageFlavor: Regular
- taintToleration: TolerateTaints
diff --git a/tests/hub-acs-secured-normal.expected.yaml b/tests/hub-acs-secured-normal.expected.yaml
deleted file mode 100644
index 168d722e..00000000
--- a/tests/hub-acs-secured-normal.expected.yaml
+++ /dev/null
@@ -1,26 +0,0 @@
----
-# Source: acs/templates/securedcluster-stackrox-secured-cluster-services.yaml
-apiVersion: platform.stackrox.io/v1alpha1
-kind: SecuredCluster
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: stackrox-secured-cluster-services
- namespace: stackrox
-spec:
- clusterName: region
- auditLogs:
- collection: Auto
- admissionControl:
- listenOnUpdates: true
- bypass: BreakGlassAnnotation
- contactImageScanners: DoNotScanInline
- listenOnCreates: true
- timeoutSeconds: 3
- listenOnEvents: true
- centralEndpoint: central-stackrox.apps.hub.example.com:443
- perNode:
- collector:
- collection: EBPF
- imageFlavor: Regular
- taintToleration: TolerateTaints
diff --git a/tests/hub-cli-tools-industrial-edge-factory.expected.yaml b/tests/hub-cli-tools-industrial-edge-factory.expected.yaml
deleted file mode 100644
index ccd696e3..00000000
--- a/tests/hub-cli-tools-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: cli-tools/templates/buildConfig/bc.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: cli-tools
- namespace: openshift
- labels:
- app: cli-tools
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-patterns/s2i-cli-tools
- contextDir: containerfiles
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Dockerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: cli-tools:latest
- triggers:
- - type: ImageChange
----
-# Source: cli-tools/templates/imageStreams/is.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: cli-tools
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: image-registry.openshift-image-registry.svc:5000/openshift/cli
- from:
- kind: DockerImage
- name: image-registry.openshift-image-registry.svc:5000/openshift/cli
- referencePolicy:
- type: Source
diff --git a/tests/hub-cli-tools-industrial-edge-hub.expected.yaml b/tests/hub-cli-tools-industrial-edge-hub.expected.yaml
deleted file mode 100644
index ccd696e3..00000000
--- a/tests/hub-cli-tools-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: cli-tools/templates/buildConfig/bc.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: cli-tools
- namespace: openshift
- labels:
- app: cli-tools
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-patterns/s2i-cli-tools
- contextDir: containerfiles
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Dockerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: cli-tools:latest
- triggers:
- - type: ImageChange
----
-# Source: cli-tools/templates/imageStreams/is.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: cli-tools
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: image-registry.openshift-image-registry.svc:5000/openshift/cli
- from:
- kind: DockerImage
- name: image-registry.openshift-image-registry.svc:5000/openshift/cli
- referencePolicy:
- type: Source
diff --git a/tests/hub-cli-tools-medical-diagnosis-hub.expected.yaml b/tests/hub-cli-tools-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index ccd696e3..00000000
--- a/tests/hub-cli-tools-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: cli-tools/templates/buildConfig/bc.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: cli-tools
- namespace: openshift
- labels:
- app: cli-tools
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-patterns/s2i-cli-tools
- contextDir: containerfiles
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Dockerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: cli-tools:latest
- triggers:
- - type: ImageChange
----
-# Source: cli-tools/templates/imageStreams/is.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: cli-tools
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: image-registry.openshift-image-registry.svc:5000/openshift/cli
- from:
- kind: DockerImage
- name: image-registry.openshift-image-registry.svc:5000/openshift/cli
- referencePolicy:
- type: Source
diff --git a/tests/hub-cli-tools-naked.expected.yaml b/tests/hub-cli-tools-naked.expected.yaml
deleted file mode 100644
index ccd696e3..00000000
--- a/tests/hub-cli-tools-naked.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: cli-tools/templates/buildConfig/bc.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: cli-tools
- namespace: openshift
- labels:
- app: cli-tools
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-patterns/s2i-cli-tools
- contextDir: containerfiles
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Dockerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: cli-tools:latest
- triggers:
- - type: ImageChange
----
-# Source: cli-tools/templates/imageStreams/is.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: cli-tools
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: image-registry.openshift-image-registry.svc:5000/openshift/cli
- from:
- kind: DockerImage
- name: image-registry.openshift-image-registry.svc:5000/openshift/cli
- referencePolicy:
- type: Source
diff --git a/tests/hub-cli-tools-normal.expected.yaml b/tests/hub-cli-tools-normal.expected.yaml
deleted file mode 100644
index ccd696e3..00000000
--- a/tests/hub-cli-tools-normal.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: cli-tools/templates/buildConfig/bc.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: cli-tools
- namespace: openshift
- labels:
- app: cli-tools
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-patterns/s2i-cli-tools
- contextDir: containerfiles
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Dockerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: cli-tools:latest
- triggers:
- - type: ImageChange
----
-# Source: cli-tools/templates/imageStreams/is.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: cli-tools
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: image-registry.openshift-image-registry.svc:5000/openshift/cli
- from:
- kind: DockerImage
- name: image-registry.openshift-image-registry.svc:5000/openshift/cli
- referencePolicy:
- type: Source
diff --git a/tests/hub-external-secrets-industrial-edge-factory.expected.yaml b/tests/hub-external-secrets-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 369a7c97..00000000
--- a/tests/hub-external-secrets-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,98 +0,0 @@
----
-# Source: external-secrets/templates/rolebinding-external-secrets.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: rolebinding-devops-externalsecret
- namespace: default
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: external-secrets
- namespace: devsecops-ci
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/eso-reports-htpasswd.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: reports-nginx-externalsecret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: reports-nginx-htpasswd
- template:
- metadata:
- type: Opaque
- dataFrom:
- - extract:
- key: secret/data/hub/devsecops
----
-# Source: external-secrets/templates/git-secret.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- name: git-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: git-secret
- template:
- metadata:
- annotations:
- # Tekton magic, see https://tekton.dev/vault/pipelines-v0.15.2/auth/
- tekton.dev/git-0: https://github.com/PLAINTEXT
- type: kubernetes.io/basic-auth
- dataFrom:
- - extract:
- key: secret/data/hub/git
----
-# Source: external-secrets/templates/image-registry-credentials.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- # This is the external image registry (e.g. quay.io/docker)
- name: image-registry-credentials
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: image-registry-credentials
- template:
- dataFrom:
- - extract:
- key: secret/data/hub/imageregistry
diff --git a/tests/hub-external-secrets-industrial-edge-hub.expected.yaml b/tests/hub-external-secrets-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 21e9d887..00000000
--- a/tests/hub-external-secrets-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,342 +0,0 @@
----
-# Source: external-secrets/templates/rolebinding-external-secrets.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: rolebinding-devops-externalsecret
- namespace: default
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: external-secrets
- namespace: devsecops-ci
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/eso-reports-htpasswd.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: reports-nginx-externalsecret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: reports-nginx-htpasswd
- template:
- metadata:
- type: Opaque
- dataFrom:
- - extract:
- key: secret/data/hub/devsecops
----
-# Source: external-secrets/templates/git-secret.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- name: git-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: git-secret
- template:
- metadata:
- annotations:
- # Tekton magic, see https://tekton.dev/vault/pipelines-v0.15.2/auth/
- tekton.dev/git-0: https://github.com/PLAINTEXT
- type: kubernetes.io/basic-auth
- dataFrom:
- - extract:
- key: secret/data/hub/git
----
-# Source: external-secrets/templates/image-registry-credentials.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- # This is the external image registry (e.g. quay.io/docker)
- name: image-registry-credentials
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: image-registry-credentials
- template:
- dataFrom:
- - extract:
- key: secret/data/hub/imageregistry
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: git-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: git-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-git-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: quayio-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: quayio-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-quayio-registry-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: reports-nginx-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: reports-nginx-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-reports-nginx-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: git-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup/cluster-group
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- - prod
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: quayio-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: reports-nginx-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup/cluster-group
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-git-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "15"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: git-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - devsecops-ci
- object-templates:
- - complianceType: musthave
- objectDefinition:
- kind: Secret
- type: kubernetes.io/basic-auth
- metadata:
- name: git-secret
- namespace: devsecops-ci
- annotations:
- tekton.dev/git-0: https://github.com
- apiVersion: v1
- data:
- username: '{{hub fromSecret "devsecops-ci" "git-secret" "username" hub}}'
- password: '{{hub fromSecret "devsecops-ci" "git-secret" "password" hub}}'
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-quayio-registry-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: quayio-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: image-registry-credentials
- namespace: devsecops-ci
- annotations:
- # Tekton magic, see https://tekton.dev/vault/pipelines-v0.15.2/auth/
- tekton.dev/docker-0: https://quay.io
- apiVersion: v1
- data:
- username: '{{hub fromSecret "devsecops-ci" "image-registry-credentials" "username" hub}}'
- password: '{{hub fromSecret "devsecops-ci" "image-registry-credentials" "password" hub}}'
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-reports-nginx-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "15"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: reports-nginx-secret-policy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - devsecops-ci
- object-templates:
- - complianceType: musthave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: reports-nginx-htpasswd
- namespace: devsecops-ci
- apiVersion: v1
- data:
- htpasswd: '{{hub fromSecret "devsecops-ci" "reports-nginx-htpasswd" "htpasswd" hub}}'
diff --git a/tests/hub-external-secrets-medical-diagnosis-hub.expected.yaml b/tests/hub-external-secrets-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 21e9d887..00000000
--- a/tests/hub-external-secrets-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,342 +0,0 @@
----
-# Source: external-secrets/templates/rolebinding-external-secrets.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: rolebinding-devops-externalsecret
- namespace: default
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: external-secrets
- namespace: devsecops-ci
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/eso-reports-htpasswd.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: reports-nginx-externalsecret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: reports-nginx-htpasswd
- template:
- metadata:
- type: Opaque
- dataFrom:
- - extract:
- key: secret/data/hub/devsecops
----
-# Source: external-secrets/templates/git-secret.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- name: git-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: git-secret
- template:
- metadata:
- annotations:
- # Tekton magic, see https://tekton.dev/vault/pipelines-v0.15.2/auth/
- tekton.dev/git-0: https://github.com/PLAINTEXT
- type: kubernetes.io/basic-auth
- dataFrom:
- - extract:
- key: secret/data/hub/git
----
-# Source: external-secrets/templates/image-registry-credentials.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- # This is the external image registry (e.g. quay.io/docker)
- name: image-registry-credentials
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: image-registry-credentials
- template:
- dataFrom:
- - extract:
- key: secret/data/hub/imageregistry
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: git-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: git-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-git-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: quayio-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: quayio-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-quayio-registry-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: reports-nginx-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: reports-nginx-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-reports-nginx-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: git-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup/cluster-group
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- - prod
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: quayio-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: reports-nginx-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup/cluster-group
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-git-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "15"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: git-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - devsecops-ci
- object-templates:
- - complianceType: musthave
- objectDefinition:
- kind: Secret
- type: kubernetes.io/basic-auth
- metadata:
- name: git-secret
- namespace: devsecops-ci
- annotations:
- tekton.dev/git-0: https://github.com
- apiVersion: v1
- data:
- username: '{{hub fromSecret "devsecops-ci" "git-secret" "username" hub}}'
- password: '{{hub fromSecret "devsecops-ci" "git-secret" "password" hub}}'
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-quayio-registry-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: quayio-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: image-registry-credentials
- namespace: devsecops-ci
- annotations:
- # Tekton magic, see https://tekton.dev/vault/pipelines-v0.15.2/auth/
- tekton.dev/docker-0: https://quay.io
- apiVersion: v1
- data:
- username: '{{hub fromSecret "devsecops-ci" "image-registry-credentials" "username" hub}}'
- password: '{{hub fromSecret "devsecops-ci" "image-registry-credentials" "password" hub}}'
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-reports-nginx-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "15"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: reports-nginx-secret-policy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - devsecops-ci
- object-templates:
- - complianceType: musthave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: reports-nginx-htpasswd
- namespace: devsecops-ci
- apiVersion: v1
- data:
- htpasswd: '{{hub fromSecret "devsecops-ci" "reports-nginx-htpasswd" "htpasswd" hub}}'
diff --git a/tests/hub-external-secrets-naked.expected.yaml b/tests/hub-external-secrets-naked.expected.yaml
deleted file mode 100644
index 21e9d887..00000000
--- a/tests/hub-external-secrets-naked.expected.yaml
+++ /dev/null
@@ -1,342 +0,0 @@
----
-# Source: external-secrets/templates/rolebinding-external-secrets.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: rolebinding-devops-externalsecret
- namespace: default
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: external-secrets
- namespace: devsecops-ci
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/eso-reports-htpasswd.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: reports-nginx-externalsecret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: reports-nginx-htpasswd
- template:
- metadata:
- type: Opaque
- dataFrom:
- - extract:
- key: secret/data/hub/devsecops
----
-# Source: external-secrets/templates/git-secret.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- name: git-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: git-secret
- template:
- metadata:
- annotations:
- # Tekton magic, see https://tekton.dev/vault/pipelines-v0.15.2/auth/
- tekton.dev/git-0: https://github.com/PLAINTEXT
- type: kubernetes.io/basic-auth
- dataFrom:
- - extract:
- key: secret/data/hub/git
----
-# Source: external-secrets/templates/image-registry-credentials.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- # This is the external image registry (e.g. quay.io/docker)
- name: image-registry-credentials
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: image-registry-credentials
- template:
- dataFrom:
- - extract:
- key: secret/data/hub/imageregistry
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: git-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: git-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-git-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: quayio-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: quayio-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-quayio-registry-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: reports-nginx-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: reports-nginx-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-reports-nginx-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: git-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup/cluster-group
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- - prod
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: quayio-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: reports-nginx-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup/cluster-group
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-git-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "15"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: git-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - devsecops-ci
- object-templates:
- - complianceType: musthave
- objectDefinition:
- kind: Secret
- type: kubernetes.io/basic-auth
- metadata:
- name: git-secret
- namespace: devsecops-ci
- annotations:
- tekton.dev/git-0: https://github.com
- apiVersion: v1
- data:
- username: '{{hub fromSecret "devsecops-ci" "git-secret" "username" hub}}'
- password: '{{hub fromSecret "devsecops-ci" "git-secret" "password" hub}}'
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-quayio-registry-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: quayio-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: image-registry-credentials
- namespace: devsecops-ci
- annotations:
- # Tekton magic, see https://tekton.dev/vault/pipelines-v0.15.2/auth/
- tekton.dev/docker-0: https://quay.io
- apiVersion: v1
- data:
- username: '{{hub fromSecret "devsecops-ci" "image-registry-credentials" "username" hub}}'
- password: '{{hub fromSecret "devsecops-ci" "image-registry-credentials" "password" hub}}'
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-reports-nginx-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "15"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: reports-nginx-secret-policy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - devsecops-ci
- object-templates:
- - complianceType: musthave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: reports-nginx-htpasswd
- namespace: devsecops-ci
- apiVersion: v1
- data:
- htpasswd: '{{hub fromSecret "devsecops-ci" "reports-nginx-htpasswd" "htpasswd" hub}}'
diff --git a/tests/hub-external-secrets-normal.expected.yaml b/tests/hub-external-secrets-normal.expected.yaml
deleted file mode 100644
index 21e9d887..00000000
--- a/tests/hub-external-secrets-normal.expected.yaml
+++ /dev/null
@@ -1,342 +0,0 @@
----
-# Source: external-secrets/templates/rolebinding-external-secrets.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: rolebinding-devops-externalsecret
- namespace: default
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: system:auth-delegator
-subjects:
-- kind: ServiceAccount
- name: external-secrets
- namespace: devsecops-ci
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-# The policy needs to be added to the ACM HUB and then it will be pushed on all clusters
-# except the HUB (see placementrule on the bottom)
----
-# Source: external-secrets/templates/eso-reports-htpasswd.yaml
-apiVersion: external-secrets.io/v1beta1
-kind: ExternalSecret
-metadata:
- name: reports-nginx-externalsecret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: reports-nginx-htpasswd
- template:
- metadata:
- type: Opaque
- dataFrom:
- - extract:
- key: secret/data/hub/devsecops
----
-# Source: external-secrets/templates/git-secret.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- name: git-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: git-secret
- template:
- metadata:
- annotations:
- # Tekton magic, see https://tekton.dev/vault/pipelines-v0.15.2/auth/
- tekton.dev/git-0: https://github.com/PLAINTEXT
- type: kubernetes.io/basic-auth
- dataFrom:
- - extract:
- key: secret/data/hub/git
----
-# Source: external-secrets/templates/image-registry-credentials.yaml
-apiVersion: "external-secrets.io/v1beta1"
-kind: ExternalSecret
-metadata:
- # This is the external image registry (e.g. quay.io/docker)
- name: image-registry-credentials
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
- argocd.argoproj.io/sync-options: Replace=true, PruneLast=true
-spec:
- refreshInterval: 15s
- secretStoreRef:
- name: vault-backend
- kind: ClusterSecretStore
- target:
- name: image-registry-credentials
- template:
- dataFrom:
- - extract:
- key: secret/data/hub/imageregistry
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: git-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: git-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-git-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: quayio-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: quayio-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-quayio-registry-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: reports-nginx-secret-placement-binding
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-placementRef:
- name: reports-nginx-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-reports-nginx-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: git-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup/cluster-group
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- - prod
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: quayio-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: reports-nginx-secret-placement
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup/cluster-group
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: external-secrets/templates/policy-git-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-git-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "15"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: git-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - devsecops-ci
- object-templates:
- - complianceType: musthave
- objectDefinition:
- kind: Secret
- type: kubernetes.io/basic-auth
- metadata:
- name: git-secret
- namespace: devsecops-ci
- annotations:
- tekton.dev/git-0: https://github.com
- apiVersion: v1
- data:
- username: '{{hub fromSecret "devsecops-ci" "git-secret" "username" hub}}'
- password: '{{hub fromSecret "devsecops-ci" "git-secret" "password" hub}}'
----
-# Source: external-secrets/templates/policy-quayio-registry-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-quayio-registry-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: quayio-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: image-registry-credentials
- namespace: devsecops-ci
- annotations:
- # Tekton magic, see https://tekton.dev/vault/pipelines-v0.15.2/auth/
- tekton.dev/docker-0: https://quay.io
- apiVersion: v1
- data:
- username: '{{hub fromSecret "devsecops-ci" "image-registry-credentials" "username" hub}}'
- password: '{{hub fromSecret "devsecops-ci" "image-registry-credentials" "password" hub}}'
----
-# Source: external-secrets/templates/policy-reports-nginx-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-reports-nginx-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-wave: "15"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: reports-nginx-secret-policy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - devsecops-ci
- object-templates:
- - complianceType: musthave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: reports-nginx-htpasswd
- namespace: devsecops-ci
- apiVersion: v1
- data:
- htpasswd: '{{hub fromSecret "devsecops-ci" "reports-nginx-htpasswd" "htpasswd" hub}}'
diff --git a/tests/hub-odf-industrial-edge-factory.expected.yaml b/tests/hub-odf-industrial-edge-factory.expected.yaml
deleted file mode 100644
index b4ed9f1e..00000000
--- a/tests/hub-odf-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,183 +0,0 @@
----
-# Source: odf/templates/rbac/label-storage-bundle-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: label-storage-nodes
- namespace: openshift-storage
- annotations:
- argocd.argoproj.io/sync-wave: "1"
----
-# Source: odf/templates/rbac/label-storage-bundle-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "1"
- name: label-storage-nodes
-rules:
- - apiGroups:
- - ""
- resources:
- - nodes
- verbs:
- - get
- - list
- - patch
- - update
----
-# Source: odf/templates/rbac/label-storage-bundle-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: label-storage-nodes
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: label-storage-nodes
-subjects:
- - kind: ServiceAccount
- name: label-storage-nodes
- namespace: openshift-storage
----
-# Source: odf/templates/rbac/quay-noobaa-deploy-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-noobaa-deploy-role
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-admin-role
-subjects:
- - kind: ServiceAccount
- name: quay-admin-sa
- namespace: openshift-storage
----
-# Source: odf/templates/label-storage-nodes-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: label-storage-nodes-bundle
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- set -e
- if ! oc get nodes -l cluster.ocs.openshift.io/openshift-storage= ; then
- echo "Worker nodes already labeled for storage"
- exit 0
- else
- # Wait for central to be ready
- attempt_counter=0
- max_attempts=20
- echo "Labeling all worker nodes for storage"
- oc label node -l node-role.kubernetes.io/worker= cluster.ocs.openshift.io/openshift-storage=
- echo "Worker nodes labeled for storage"
- fi
- imagePullPolicy: Always
- name: label-storage-nodes-bundle
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: label-storage-nodes
- serviceAccountName: label-storage-nodes
- terminationGracePeriodSeconds: 30
----
-# Source: odf/templates/policy-odf-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-7 Software Firmware and Information
- Integrity
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-odf-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-odf-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: noobaa-operator
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: ocs-operator
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: odf-operator-controller-manager
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: odf/templates/storagecluster.yaml
-apiVersion: ocs.openshift.io/v1
-kind: StorageCluster
-metadata:
- annotations:
- uninstall.ocs.openshift.io/cleanup-policy: delete
- uninstall.ocs.openshift.io/mode: graceful
- finalizers:
- - storagecluster.ocs.openshift.io
- name: ocs-storagecluster
- namespace: openshift-storage
-spec:
- arbiter: {}
- encryption:
- kms: {}
- externalStorage: {}
- managedResources:
- cephBlockPools: {}
- cephCluster: {}
- cephConfig: {}
- cephDashboard: {}
- cephFilesystems: {}
- cephObjectStoreUsers: {}
- cephObjectStores: {}
- mirroring: {}
- multiCloudGateway:
- dbStorageClassName: default-rwo
- reconcileStrategy: standalone
diff --git a/tests/hub-odf-industrial-edge-hub.expected.yaml b/tests/hub-odf-industrial-edge-hub.expected.yaml
deleted file mode 100644
index b4ed9f1e..00000000
--- a/tests/hub-odf-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,183 +0,0 @@
----
-# Source: odf/templates/rbac/label-storage-bundle-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: label-storage-nodes
- namespace: openshift-storage
- annotations:
- argocd.argoproj.io/sync-wave: "1"
----
-# Source: odf/templates/rbac/label-storage-bundle-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "1"
- name: label-storage-nodes
-rules:
- - apiGroups:
- - ""
- resources:
- - nodes
- verbs:
- - get
- - list
- - patch
- - update
----
-# Source: odf/templates/rbac/label-storage-bundle-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: label-storage-nodes
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: label-storage-nodes
-subjects:
- - kind: ServiceAccount
- name: label-storage-nodes
- namespace: openshift-storage
----
-# Source: odf/templates/rbac/quay-noobaa-deploy-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-noobaa-deploy-role
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-admin-role
-subjects:
- - kind: ServiceAccount
- name: quay-admin-sa
- namespace: openshift-storage
----
-# Source: odf/templates/label-storage-nodes-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: label-storage-nodes-bundle
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- set -e
- if ! oc get nodes -l cluster.ocs.openshift.io/openshift-storage= ; then
- echo "Worker nodes already labeled for storage"
- exit 0
- else
- # Wait for central to be ready
- attempt_counter=0
- max_attempts=20
- echo "Labeling all worker nodes for storage"
- oc label node -l node-role.kubernetes.io/worker= cluster.ocs.openshift.io/openshift-storage=
- echo "Worker nodes labeled for storage"
- fi
- imagePullPolicy: Always
- name: label-storage-nodes-bundle
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: label-storage-nodes
- serviceAccountName: label-storage-nodes
- terminationGracePeriodSeconds: 30
----
-# Source: odf/templates/policy-odf-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-7 Software Firmware and Information
- Integrity
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-odf-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-odf-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: noobaa-operator
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: ocs-operator
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: odf-operator-controller-manager
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: odf/templates/storagecluster.yaml
-apiVersion: ocs.openshift.io/v1
-kind: StorageCluster
-metadata:
- annotations:
- uninstall.ocs.openshift.io/cleanup-policy: delete
- uninstall.ocs.openshift.io/mode: graceful
- finalizers:
- - storagecluster.ocs.openshift.io
- name: ocs-storagecluster
- namespace: openshift-storage
-spec:
- arbiter: {}
- encryption:
- kms: {}
- externalStorage: {}
- managedResources:
- cephBlockPools: {}
- cephCluster: {}
- cephConfig: {}
- cephDashboard: {}
- cephFilesystems: {}
- cephObjectStoreUsers: {}
- cephObjectStores: {}
- mirroring: {}
- multiCloudGateway:
- dbStorageClassName: default-rwo
- reconcileStrategy: standalone
diff --git a/tests/hub-odf-medical-diagnosis-hub.expected.yaml b/tests/hub-odf-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index b4ed9f1e..00000000
--- a/tests/hub-odf-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,183 +0,0 @@
----
-# Source: odf/templates/rbac/label-storage-bundle-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: label-storage-nodes
- namespace: openshift-storage
- annotations:
- argocd.argoproj.io/sync-wave: "1"
----
-# Source: odf/templates/rbac/label-storage-bundle-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "1"
- name: label-storage-nodes
-rules:
- - apiGroups:
- - ""
- resources:
- - nodes
- verbs:
- - get
- - list
- - patch
- - update
----
-# Source: odf/templates/rbac/label-storage-bundle-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: label-storage-nodes
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: label-storage-nodes
-subjects:
- - kind: ServiceAccount
- name: label-storage-nodes
- namespace: openshift-storage
----
-# Source: odf/templates/rbac/quay-noobaa-deploy-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-noobaa-deploy-role
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-admin-role
-subjects:
- - kind: ServiceAccount
- name: quay-admin-sa
- namespace: openshift-storage
----
-# Source: odf/templates/label-storage-nodes-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: label-storage-nodes-bundle
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- set -e
- if ! oc get nodes -l cluster.ocs.openshift.io/openshift-storage= ; then
- echo "Worker nodes already labeled for storage"
- exit 0
- else
- # Wait for central to be ready
- attempt_counter=0
- max_attempts=20
- echo "Labeling all worker nodes for storage"
- oc label node -l node-role.kubernetes.io/worker= cluster.ocs.openshift.io/openshift-storage=
- echo "Worker nodes labeled for storage"
- fi
- imagePullPolicy: Always
- name: label-storage-nodes-bundle
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: label-storage-nodes
- serviceAccountName: label-storage-nodes
- terminationGracePeriodSeconds: 30
----
-# Source: odf/templates/policy-odf-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-7 Software Firmware and Information
- Integrity
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-odf-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-odf-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: noobaa-operator
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: ocs-operator
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: odf-operator-controller-manager
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: odf/templates/storagecluster.yaml
-apiVersion: ocs.openshift.io/v1
-kind: StorageCluster
-metadata:
- annotations:
- uninstall.ocs.openshift.io/cleanup-policy: delete
- uninstall.ocs.openshift.io/mode: graceful
- finalizers:
- - storagecluster.ocs.openshift.io
- name: ocs-storagecluster
- namespace: openshift-storage
-spec:
- arbiter: {}
- encryption:
- kms: {}
- externalStorage: {}
- managedResources:
- cephBlockPools: {}
- cephCluster: {}
- cephConfig: {}
- cephDashboard: {}
- cephFilesystems: {}
- cephObjectStoreUsers: {}
- cephObjectStores: {}
- mirroring: {}
- multiCloudGateway:
- dbStorageClassName: default-rwo
- reconcileStrategy: standalone
diff --git a/tests/hub-odf-naked.expected.yaml b/tests/hub-odf-naked.expected.yaml
deleted file mode 100644
index b4ed9f1e..00000000
--- a/tests/hub-odf-naked.expected.yaml
+++ /dev/null
@@ -1,183 +0,0 @@
----
-# Source: odf/templates/rbac/label-storage-bundle-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: label-storage-nodes
- namespace: openshift-storage
- annotations:
- argocd.argoproj.io/sync-wave: "1"
----
-# Source: odf/templates/rbac/label-storage-bundle-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "1"
- name: label-storage-nodes
-rules:
- - apiGroups:
- - ""
- resources:
- - nodes
- verbs:
- - get
- - list
- - patch
- - update
----
-# Source: odf/templates/rbac/label-storage-bundle-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: label-storage-nodes
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: label-storage-nodes
-subjects:
- - kind: ServiceAccount
- name: label-storage-nodes
- namespace: openshift-storage
----
-# Source: odf/templates/rbac/quay-noobaa-deploy-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-noobaa-deploy-role
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-admin-role
-subjects:
- - kind: ServiceAccount
- name: quay-admin-sa
- namespace: openshift-storage
----
-# Source: odf/templates/label-storage-nodes-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: label-storage-nodes-bundle
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- set -e
- if ! oc get nodes -l cluster.ocs.openshift.io/openshift-storage= ; then
- echo "Worker nodes already labeled for storage"
- exit 0
- else
- # Wait for central to be ready
- attempt_counter=0
- max_attempts=20
- echo "Labeling all worker nodes for storage"
- oc label node -l node-role.kubernetes.io/worker= cluster.ocs.openshift.io/openshift-storage=
- echo "Worker nodes labeled for storage"
- fi
- imagePullPolicy: Always
- name: label-storage-nodes-bundle
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: label-storage-nodes
- serviceAccountName: label-storage-nodes
- terminationGracePeriodSeconds: 30
----
-# Source: odf/templates/policy-odf-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-7 Software Firmware and Information
- Integrity
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-odf-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-odf-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: noobaa-operator
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: ocs-operator
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: odf-operator-controller-manager
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: odf/templates/storagecluster.yaml
-apiVersion: ocs.openshift.io/v1
-kind: StorageCluster
-metadata:
- annotations:
- uninstall.ocs.openshift.io/cleanup-policy: delete
- uninstall.ocs.openshift.io/mode: graceful
- finalizers:
- - storagecluster.ocs.openshift.io
- name: ocs-storagecluster
- namespace: openshift-storage
-spec:
- arbiter: {}
- encryption:
- kms: {}
- externalStorage: {}
- managedResources:
- cephBlockPools: {}
- cephCluster: {}
- cephConfig: {}
- cephDashboard: {}
- cephFilesystems: {}
- cephObjectStoreUsers: {}
- cephObjectStores: {}
- mirroring: {}
- multiCloudGateway:
- dbStorageClassName: default-rwo
- reconcileStrategy: standalone
diff --git a/tests/hub-odf-normal.expected.yaml b/tests/hub-odf-normal.expected.yaml
deleted file mode 100644
index b4ed9f1e..00000000
--- a/tests/hub-odf-normal.expected.yaml
+++ /dev/null
@@ -1,183 +0,0 @@
----
-# Source: odf/templates/rbac/label-storage-bundle-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: label-storage-nodes
- namespace: openshift-storage
- annotations:
- argocd.argoproj.io/sync-wave: "1"
----
-# Source: odf/templates/rbac/label-storage-bundle-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "1"
- name: label-storage-nodes
-rules:
- - apiGroups:
- - ""
- resources:
- - nodes
- verbs:
- - get
- - list
- - patch
- - update
----
-# Source: odf/templates/rbac/label-storage-bundle-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: label-storage-nodes
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: label-storage-nodes
-subjects:
- - kind: ServiceAccount
- name: label-storage-nodes
- namespace: openshift-storage
----
-# Source: odf/templates/rbac/quay-noobaa-deploy-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-noobaa-deploy-role
- annotations:
- argocd.argoproj.io/sync-wave: "2"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-admin-role
-subjects:
- - kind: ServiceAccount
- name: quay-admin-sa
- namespace: openshift-storage
----
-# Source: odf/templates/label-storage-nodes-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "3"
- name: label-storage-nodes-bundle
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- #!/usr/bin/env bash
- set -e
- if ! oc get nodes -l cluster.ocs.openshift.io/openshift-storage= ; then
- echo "Worker nodes already labeled for storage"
- exit 0
- else
- # Wait for central to be ready
- attempt_counter=0
- max_attempts=20
- echo "Labeling all worker nodes for storage"
- oc label node -l node-role.kubernetes.io/worker= cluster.ocs.openshift.io/openshift-storage=
- echo "Worker nodes labeled for storage"
- fi
- imagePullPolicy: Always
- name: label-storage-nodes-bundle
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: label-storage-nodes
- serviceAccountName: label-storage-nodes
- terminationGracePeriodSeconds: 30
----
-# Source: odf/templates/policy-odf-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-7 Software Firmware and Information
- Integrity
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-odf-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-odf-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: noobaa-operator
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: ocs-operator
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: odf-operator-controller-manager
- namespace: openshift-storage
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: odf/templates/storagecluster.yaml
-apiVersion: ocs.openshift.io/v1
-kind: StorageCluster
-metadata:
- annotations:
- uninstall.ocs.openshift.io/cleanup-policy: delete
- uninstall.ocs.openshift.io/mode: graceful
- finalizers:
- - storagecluster.ocs.openshift.io
- name: ocs-storagecluster
- namespace: openshift-storage
-spec:
- arbiter: {}
- encryption:
- kms: {}
- externalStorage: {}
- managedResources:
- cephBlockPools: {}
- cephCluster: {}
- cephConfig: {}
- cephDashboard: {}
- cephFilesystems: {}
- cephObjectStoreUsers: {}
- cephObjectStores: {}
- mirroring: {}
- multiCloudGateway:
- dbStorageClassName: default-rwo
- reconcileStrategy: standalone
diff --git a/tests/hub-opp-industrial-edge-factory.expected.yaml b/tests/hub-opp-industrial-edge-factory.expected.yaml
deleted file mode 100644
index d432d0a6..00000000
--- a/tests/hub-opp-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,200 +0,0 @@
----
-# Source: opp/templates/ocm-observability-bucket-claim.yaml
-#apiVersion: operator.openshift.io/v1
-#kind: Console
-#metadata:
-# name: cluster
-#spec:
-# plugins:
-# - odf-console
----
-# Source: opp/templates/clusterset-binding.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta2
-kind: ManagedClusterSetBinding
-metadata:
- name: default
- namespace: policies
-spec:
- clusterSet: default
----
-# Source: opp/templates/ocm-observability-bucket-claim.yaml
-apiVersion: objectbucket.io/v1alpha1
-kind: ObjectBucketClaim
-metadata:
- name: obc-observability
- namespace: openshift-storage
-spec:
- generateBucketName: obc-observability-bucket
- storageClassName: openshift-storage.noobaa.io
----
-# Source: opp/templates/placement-hub.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta1
-kind: Placement
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: placement-openshift-plus-hub
- namespace: policies
-spec:
- predicates:
- - requiredClusterSelector:
- labelSelector:
- matchExpressions:
- - key: name
- operator: In
- values:
- - local-cluster
----
-# Source: opp/templates/placement-managed.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta1
-kind: Placement
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: placement-openshift-plus-managed
- namespace: policies
-spec:
- predicates:
- - requiredClusterSelector:
- labelSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: name
- operator: NotIn
- values:
- - local-cluster
----
-# Source: opp/templates/placement-binding-hub.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: binding-policy-openshift-plus-hub
- namespace: policies
-placementRef:
- apiGroup: cluster.open-cluster-management.io
- kind: Placement
- name: placement-openshift-plus-hub
-subjects:
-- apiGroup: policy.open-cluster-management.io
- kind: PolicySet
- name: openshift-plus-hub
----
-# Source: opp/templates/placement-binding-managed.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: binding-policy-openshift-plus-managed
- namespace: policies
-placementRef:
- apiGroup: cluster.open-cluster-management.io
- kind: Placement
- name: placement-openshift-plus-managed
-subjects:
-- apiGroup: policy.open-cluster-management.io
- kind: PolicySet
- name: openshift-plus-managed
----
-# Source: opp/templates/policy-ocm-observability.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: CA Assessment Authorization and
- Monitoring
- policy.open-cluster-management.io/controls: CA-7 Continuous Monitoring
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-ocm-observability
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-ocm-observability
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- kind: Secret
- metadata:
- name: thanos-object-storage
- namespace: open-cluster-management-observability
- type: Opaque
- stringData:
- thanos.yaml: |
- type: s3
- config:
- bucket: '{{ (lookup "objectbucket.io/v1alpha1" "ObjectBucket" "" "obc-openshift-storage-obc-observability").spec.endpoint.bucketName }}'
- endpoint: '{{ (lookup "objectbucket.io/v1alpha1" "ObjectBucket" "" "obc-openshift-storage-obc-observability").spec.endpoint.bucketHost }}'
- insecure: false
- access_key: '{{ (lookup "v1" "Secret" "openshift-storage" "noobaa-admin").data.AWS_ACCESS_KEY_ID | base64dec }}'
- secret_key: '{{ (lookup "v1" "Secret" "openshift-storage" "noobaa-admin").data.AWS_SECRET_ACCESS_KEY | base64dec }}'
- http_config:
- insecure_skip_verify: true
- tls_config:
- insecure_skip_verify: true
- - complianceType: musthave
- objectDefinition:
- apiVersion: observability.open-cluster-management.io/v1beta2
- kind: MultiClusterObservability
- metadata:
- name: observability
- spec:
- observabilityAddonSpec: {}
- storageConfig:
- metricObjectStorage:
- key: thanos.yaml
- name: thanos-object-storage
- remediationAction: enforce
- severity: medium
----
-# Source: opp/templates/policyset-hub.yaml
-apiVersion: policy.open-cluster-management.io/v1beta1
-kind: PolicySet
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: openshift-plus-hub
- namespace: policies
-spec:
- description: The OpenShift Platform Plus policy set applies several policies that
- installs the OpenShift Platform Plus products using best practices that allow
- them to work well together. This policy set is focued on the components that install
- to the Advanced Cluster Management hub.
- policies:
- - policy-acs-central-status
- - policy-acs-secured-status
- - policy-ocm-observability
- - policy-odf-status
- - policy-quay-status
----
-# Source: opp/templates/policyset-managed.yaml
-apiVersion: policy.open-cluster-management.io/v1beta1
-kind: PolicySet
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: openshift-plus-managed
- namespace: policies
-spec:
- description: The OpenShift Platform Plus policy set applies several policies that
- installs the OpenShift Platform Plus products using best practices that allow
- them to work well together. This policy set if focued on the components that install
- to every managed cluster.
- policies:
- - policy-acs-secured-status
diff --git a/tests/hub-opp-industrial-edge-hub.expected.yaml b/tests/hub-opp-industrial-edge-hub.expected.yaml
deleted file mode 100644
index d432d0a6..00000000
--- a/tests/hub-opp-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,200 +0,0 @@
----
-# Source: opp/templates/ocm-observability-bucket-claim.yaml
-#apiVersion: operator.openshift.io/v1
-#kind: Console
-#metadata:
-# name: cluster
-#spec:
-# plugins:
-# - odf-console
----
-# Source: opp/templates/clusterset-binding.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta2
-kind: ManagedClusterSetBinding
-metadata:
- name: default
- namespace: policies
-spec:
- clusterSet: default
----
-# Source: opp/templates/ocm-observability-bucket-claim.yaml
-apiVersion: objectbucket.io/v1alpha1
-kind: ObjectBucketClaim
-metadata:
- name: obc-observability
- namespace: openshift-storage
-spec:
- generateBucketName: obc-observability-bucket
- storageClassName: openshift-storage.noobaa.io
----
-# Source: opp/templates/placement-hub.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta1
-kind: Placement
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: placement-openshift-plus-hub
- namespace: policies
-spec:
- predicates:
- - requiredClusterSelector:
- labelSelector:
- matchExpressions:
- - key: name
- operator: In
- values:
- - local-cluster
----
-# Source: opp/templates/placement-managed.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta1
-kind: Placement
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: placement-openshift-plus-managed
- namespace: policies
-spec:
- predicates:
- - requiredClusterSelector:
- labelSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: name
- operator: NotIn
- values:
- - local-cluster
----
-# Source: opp/templates/placement-binding-hub.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: binding-policy-openshift-plus-hub
- namespace: policies
-placementRef:
- apiGroup: cluster.open-cluster-management.io
- kind: Placement
- name: placement-openshift-plus-hub
-subjects:
-- apiGroup: policy.open-cluster-management.io
- kind: PolicySet
- name: openshift-plus-hub
----
-# Source: opp/templates/placement-binding-managed.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: binding-policy-openshift-plus-managed
- namespace: policies
-placementRef:
- apiGroup: cluster.open-cluster-management.io
- kind: Placement
- name: placement-openshift-plus-managed
-subjects:
-- apiGroup: policy.open-cluster-management.io
- kind: PolicySet
- name: openshift-plus-managed
----
-# Source: opp/templates/policy-ocm-observability.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: CA Assessment Authorization and
- Monitoring
- policy.open-cluster-management.io/controls: CA-7 Continuous Monitoring
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-ocm-observability
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-ocm-observability
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- kind: Secret
- metadata:
- name: thanos-object-storage
- namespace: open-cluster-management-observability
- type: Opaque
- stringData:
- thanos.yaml: |
- type: s3
- config:
- bucket: '{{ (lookup "objectbucket.io/v1alpha1" "ObjectBucket" "" "obc-openshift-storage-obc-observability").spec.endpoint.bucketName }}'
- endpoint: '{{ (lookup "objectbucket.io/v1alpha1" "ObjectBucket" "" "obc-openshift-storage-obc-observability").spec.endpoint.bucketHost }}'
- insecure: false
- access_key: '{{ (lookup "v1" "Secret" "openshift-storage" "noobaa-admin").data.AWS_ACCESS_KEY_ID | base64dec }}'
- secret_key: '{{ (lookup "v1" "Secret" "openshift-storage" "noobaa-admin").data.AWS_SECRET_ACCESS_KEY | base64dec }}'
- http_config:
- insecure_skip_verify: true
- tls_config:
- insecure_skip_verify: true
- - complianceType: musthave
- objectDefinition:
- apiVersion: observability.open-cluster-management.io/v1beta2
- kind: MultiClusterObservability
- metadata:
- name: observability
- spec:
- observabilityAddonSpec: {}
- storageConfig:
- metricObjectStorage:
- key: thanos.yaml
- name: thanos-object-storage
- remediationAction: enforce
- severity: medium
----
-# Source: opp/templates/policyset-hub.yaml
-apiVersion: policy.open-cluster-management.io/v1beta1
-kind: PolicySet
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: openshift-plus-hub
- namespace: policies
-spec:
- description: The OpenShift Platform Plus policy set applies several policies that
- installs the OpenShift Platform Plus products using best practices that allow
- them to work well together. This policy set is focued on the components that install
- to the Advanced Cluster Management hub.
- policies:
- - policy-acs-central-status
- - policy-acs-secured-status
- - policy-ocm-observability
- - policy-odf-status
- - policy-quay-status
----
-# Source: opp/templates/policyset-managed.yaml
-apiVersion: policy.open-cluster-management.io/v1beta1
-kind: PolicySet
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: openshift-plus-managed
- namespace: policies
-spec:
- description: The OpenShift Platform Plus policy set applies several policies that
- installs the OpenShift Platform Plus products using best practices that allow
- them to work well together. This policy set if focued on the components that install
- to every managed cluster.
- policies:
- - policy-acs-secured-status
diff --git a/tests/hub-opp-medical-diagnosis-hub.expected.yaml b/tests/hub-opp-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index d432d0a6..00000000
--- a/tests/hub-opp-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,200 +0,0 @@
----
-# Source: opp/templates/ocm-observability-bucket-claim.yaml
-#apiVersion: operator.openshift.io/v1
-#kind: Console
-#metadata:
-# name: cluster
-#spec:
-# plugins:
-# - odf-console
----
-# Source: opp/templates/clusterset-binding.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta2
-kind: ManagedClusterSetBinding
-metadata:
- name: default
- namespace: policies
-spec:
- clusterSet: default
----
-# Source: opp/templates/ocm-observability-bucket-claim.yaml
-apiVersion: objectbucket.io/v1alpha1
-kind: ObjectBucketClaim
-metadata:
- name: obc-observability
- namespace: openshift-storage
-spec:
- generateBucketName: obc-observability-bucket
- storageClassName: openshift-storage.noobaa.io
----
-# Source: opp/templates/placement-hub.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta1
-kind: Placement
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: placement-openshift-plus-hub
- namespace: policies
-spec:
- predicates:
- - requiredClusterSelector:
- labelSelector:
- matchExpressions:
- - key: name
- operator: In
- values:
- - local-cluster
----
-# Source: opp/templates/placement-managed.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta1
-kind: Placement
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: placement-openshift-plus-managed
- namespace: policies
-spec:
- predicates:
- - requiredClusterSelector:
- labelSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: name
- operator: NotIn
- values:
- - local-cluster
----
-# Source: opp/templates/placement-binding-hub.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: binding-policy-openshift-plus-hub
- namespace: policies
-placementRef:
- apiGroup: cluster.open-cluster-management.io
- kind: Placement
- name: placement-openshift-plus-hub
-subjects:
-- apiGroup: policy.open-cluster-management.io
- kind: PolicySet
- name: openshift-plus-hub
----
-# Source: opp/templates/placement-binding-managed.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: binding-policy-openshift-plus-managed
- namespace: policies
-placementRef:
- apiGroup: cluster.open-cluster-management.io
- kind: Placement
- name: placement-openshift-plus-managed
-subjects:
-- apiGroup: policy.open-cluster-management.io
- kind: PolicySet
- name: openshift-plus-managed
----
-# Source: opp/templates/policy-ocm-observability.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: CA Assessment Authorization and
- Monitoring
- policy.open-cluster-management.io/controls: CA-7 Continuous Monitoring
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-ocm-observability
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-ocm-observability
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- kind: Secret
- metadata:
- name: thanos-object-storage
- namespace: open-cluster-management-observability
- type: Opaque
- stringData:
- thanos.yaml: |
- type: s3
- config:
- bucket: '{{ (lookup "objectbucket.io/v1alpha1" "ObjectBucket" "" "obc-openshift-storage-obc-observability").spec.endpoint.bucketName }}'
- endpoint: '{{ (lookup "objectbucket.io/v1alpha1" "ObjectBucket" "" "obc-openshift-storage-obc-observability").spec.endpoint.bucketHost }}'
- insecure: false
- access_key: '{{ (lookup "v1" "Secret" "openshift-storage" "noobaa-admin").data.AWS_ACCESS_KEY_ID | base64dec }}'
- secret_key: '{{ (lookup "v1" "Secret" "openshift-storage" "noobaa-admin").data.AWS_SECRET_ACCESS_KEY | base64dec }}'
- http_config:
- insecure_skip_verify: true
- tls_config:
- insecure_skip_verify: true
- - complianceType: musthave
- objectDefinition:
- apiVersion: observability.open-cluster-management.io/v1beta2
- kind: MultiClusterObservability
- metadata:
- name: observability
- spec:
- observabilityAddonSpec: {}
- storageConfig:
- metricObjectStorage:
- key: thanos.yaml
- name: thanos-object-storage
- remediationAction: enforce
- severity: medium
----
-# Source: opp/templates/policyset-hub.yaml
-apiVersion: policy.open-cluster-management.io/v1beta1
-kind: PolicySet
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: openshift-plus-hub
- namespace: policies
-spec:
- description: The OpenShift Platform Plus policy set applies several policies that
- installs the OpenShift Platform Plus products using best practices that allow
- them to work well together. This policy set is focued on the components that install
- to the Advanced Cluster Management hub.
- policies:
- - policy-acs-central-status
- - policy-acs-secured-status
- - policy-ocm-observability
- - policy-odf-status
- - policy-quay-status
----
-# Source: opp/templates/policyset-managed.yaml
-apiVersion: policy.open-cluster-management.io/v1beta1
-kind: PolicySet
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: openshift-plus-managed
- namespace: policies
-spec:
- description: The OpenShift Platform Plus policy set applies several policies that
- installs the OpenShift Platform Plus products using best practices that allow
- them to work well together. This policy set if focued on the components that install
- to every managed cluster.
- policies:
- - policy-acs-secured-status
diff --git a/tests/hub-opp-naked.expected.yaml b/tests/hub-opp-naked.expected.yaml
deleted file mode 100644
index d432d0a6..00000000
--- a/tests/hub-opp-naked.expected.yaml
+++ /dev/null
@@ -1,200 +0,0 @@
----
-# Source: opp/templates/ocm-observability-bucket-claim.yaml
-#apiVersion: operator.openshift.io/v1
-#kind: Console
-#metadata:
-# name: cluster
-#spec:
-# plugins:
-# - odf-console
----
-# Source: opp/templates/clusterset-binding.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta2
-kind: ManagedClusterSetBinding
-metadata:
- name: default
- namespace: policies
-spec:
- clusterSet: default
----
-# Source: opp/templates/ocm-observability-bucket-claim.yaml
-apiVersion: objectbucket.io/v1alpha1
-kind: ObjectBucketClaim
-metadata:
- name: obc-observability
- namespace: openshift-storage
-spec:
- generateBucketName: obc-observability-bucket
- storageClassName: openshift-storage.noobaa.io
----
-# Source: opp/templates/placement-hub.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta1
-kind: Placement
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: placement-openshift-plus-hub
- namespace: policies
-spec:
- predicates:
- - requiredClusterSelector:
- labelSelector:
- matchExpressions:
- - key: name
- operator: In
- values:
- - local-cluster
----
-# Source: opp/templates/placement-managed.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta1
-kind: Placement
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: placement-openshift-plus-managed
- namespace: policies
-spec:
- predicates:
- - requiredClusterSelector:
- labelSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: name
- operator: NotIn
- values:
- - local-cluster
----
-# Source: opp/templates/placement-binding-hub.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: binding-policy-openshift-plus-hub
- namespace: policies
-placementRef:
- apiGroup: cluster.open-cluster-management.io
- kind: Placement
- name: placement-openshift-plus-hub
-subjects:
-- apiGroup: policy.open-cluster-management.io
- kind: PolicySet
- name: openshift-plus-hub
----
-# Source: opp/templates/placement-binding-managed.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: binding-policy-openshift-plus-managed
- namespace: policies
-placementRef:
- apiGroup: cluster.open-cluster-management.io
- kind: Placement
- name: placement-openshift-plus-managed
-subjects:
-- apiGroup: policy.open-cluster-management.io
- kind: PolicySet
- name: openshift-plus-managed
----
-# Source: opp/templates/policy-ocm-observability.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: CA Assessment Authorization and
- Monitoring
- policy.open-cluster-management.io/controls: CA-7 Continuous Monitoring
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-ocm-observability
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-ocm-observability
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- kind: Secret
- metadata:
- name: thanos-object-storage
- namespace: open-cluster-management-observability
- type: Opaque
- stringData:
- thanos.yaml: |
- type: s3
- config:
- bucket: '{{ (lookup "objectbucket.io/v1alpha1" "ObjectBucket" "" "obc-openshift-storage-obc-observability").spec.endpoint.bucketName }}'
- endpoint: '{{ (lookup "objectbucket.io/v1alpha1" "ObjectBucket" "" "obc-openshift-storage-obc-observability").spec.endpoint.bucketHost }}'
- insecure: false
- access_key: '{{ (lookup "v1" "Secret" "openshift-storage" "noobaa-admin").data.AWS_ACCESS_KEY_ID | base64dec }}'
- secret_key: '{{ (lookup "v1" "Secret" "openshift-storage" "noobaa-admin").data.AWS_SECRET_ACCESS_KEY | base64dec }}'
- http_config:
- insecure_skip_verify: true
- tls_config:
- insecure_skip_verify: true
- - complianceType: musthave
- objectDefinition:
- apiVersion: observability.open-cluster-management.io/v1beta2
- kind: MultiClusterObservability
- metadata:
- name: observability
- spec:
- observabilityAddonSpec: {}
- storageConfig:
- metricObjectStorage:
- key: thanos.yaml
- name: thanos-object-storage
- remediationAction: enforce
- severity: medium
----
-# Source: opp/templates/policyset-hub.yaml
-apiVersion: policy.open-cluster-management.io/v1beta1
-kind: PolicySet
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: openshift-plus-hub
- namespace: policies
-spec:
- description: The OpenShift Platform Plus policy set applies several policies that
- installs the OpenShift Platform Plus products using best practices that allow
- them to work well together. This policy set is focued on the components that install
- to the Advanced Cluster Management hub.
- policies:
- - policy-acs-central-status
- - policy-acs-secured-status
- - policy-ocm-observability
- - policy-odf-status
- - policy-quay-status
----
-# Source: opp/templates/policyset-managed.yaml
-apiVersion: policy.open-cluster-management.io/v1beta1
-kind: PolicySet
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: openshift-plus-managed
- namespace: policies
-spec:
- description: The OpenShift Platform Plus policy set applies several policies that
- installs the OpenShift Platform Plus products using best practices that allow
- them to work well together. This policy set if focued on the components that install
- to every managed cluster.
- policies:
- - policy-acs-secured-status
diff --git a/tests/hub-opp-normal.expected.yaml b/tests/hub-opp-normal.expected.yaml
deleted file mode 100644
index d432d0a6..00000000
--- a/tests/hub-opp-normal.expected.yaml
+++ /dev/null
@@ -1,200 +0,0 @@
----
-# Source: opp/templates/ocm-observability-bucket-claim.yaml
-#apiVersion: operator.openshift.io/v1
-#kind: Console
-#metadata:
-# name: cluster
-#spec:
-# plugins:
-# - odf-console
----
-# Source: opp/templates/clusterset-binding.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta2
-kind: ManagedClusterSetBinding
-metadata:
- name: default
- namespace: policies
-spec:
- clusterSet: default
----
-# Source: opp/templates/ocm-observability-bucket-claim.yaml
-apiVersion: objectbucket.io/v1alpha1
-kind: ObjectBucketClaim
-metadata:
- name: obc-observability
- namespace: openshift-storage
-spec:
- generateBucketName: obc-observability-bucket
- storageClassName: openshift-storage.noobaa.io
----
-# Source: opp/templates/placement-hub.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta1
-kind: Placement
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: placement-openshift-plus-hub
- namespace: policies
-spec:
- predicates:
- - requiredClusterSelector:
- labelSelector:
- matchExpressions:
- - key: name
- operator: In
- values:
- - local-cluster
----
-# Source: opp/templates/placement-managed.yaml
-apiVersion: cluster.open-cluster-management.io/v1beta1
-kind: Placement
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: placement-openshift-plus-managed
- namespace: policies
-spec:
- predicates:
- - requiredClusterSelector:
- labelSelector:
- matchExpressions:
- - key: vendor
- operator: In
- values:
- - OpenShift
- - key: name
- operator: NotIn
- values:
- - local-cluster
----
-# Source: opp/templates/placement-binding-hub.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: binding-policy-openshift-plus-hub
- namespace: policies
-placementRef:
- apiGroup: cluster.open-cluster-management.io
- kind: Placement
- name: placement-openshift-plus-hub
-subjects:
-- apiGroup: policy.open-cluster-management.io
- kind: PolicySet
- name: openshift-plus-hub
----
-# Source: opp/templates/placement-binding-managed.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: binding-policy-openshift-plus-managed
- namespace: policies
-placementRef:
- apiGroup: cluster.open-cluster-management.io
- kind: Placement
- name: placement-openshift-plus-managed
-subjects:
-- apiGroup: policy.open-cluster-management.io
- kind: PolicySet
- name: openshift-plus-managed
----
-# Source: opp/templates/policy-ocm-observability.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: CA Assessment Authorization and
- Monitoring
- policy.open-cluster-management.io/controls: CA-7 Continuous Monitoring
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-ocm-observability
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-ocm-observability
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: v1
- kind: Secret
- metadata:
- name: thanos-object-storage
- namespace: open-cluster-management-observability
- type: Opaque
- stringData:
- thanos.yaml: |
- type: s3
- config:
- bucket: '{{ (lookup "objectbucket.io/v1alpha1" "ObjectBucket" "" "obc-openshift-storage-obc-observability").spec.endpoint.bucketName }}'
- endpoint: '{{ (lookup "objectbucket.io/v1alpha1" "ObjectBucket" "" "obc-openshift-storage-obc-observability").spec.endpoint.bucketHost }}'
- insecure: false
- access_key: '{{ (lookup "v1" "Secret" "openshift-storage" "noobaa-admin").data.AWS_ACCESS_KEY_ID | base64dec }}'
- secret_key: '{{ (lookup "v1" "Secret" "openshift-storage" "noobaa-admin").data.AWS_SECRET_ACCESS_KEY | base64dec }}'
- http_config:
- insecure_skip_verify: true
- tls_config:
- insecure_skip_verify: true
- - complianceType: musthave
- objectDefinition:
- apiVersion: observability.open-cluster-management.io/v1beta2
- kind: MultiClusterObservability
- metadata:
- name: observability
- spec:
- observabilityAddonSpec: {}
- storageConfig:
- metricObjectStorage:
- key: thanos.yaml
- name: thanos-object-storage
- remediationAction: enforce
- severity: medium
----
-# Source: opp/templates/policyset-hub.yaml
-apiVersion: policy.open-cluster-management.io/v1beta1
-kind: PolicySet
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: openshift-plus-hub
- namespace: policies
-spec:
- description: The OpenShift Platform Plus policy set applies several policies that
- installs the OpenShift Platform Plus products using best practices that allow
- them to work well together. This policy set is focued on the components that install
- to the Advanced Cluster Management hub.
- policies:
- - policy-acs-central-status
- - policy-acs-secured-status
- - policy-ocm-observability
- - policy-odf-status
- - policy-quay-status
----
-# Source: opp/templates/policyset-managed.yaml
-apiVersion: policy.open-cluster-management.io/v1beta1
-kind: PolicySet
-metadata:
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: openshift-plus-managed
- namespace: policies
-spec:
- description: The OpenShift Platform Plus policy set applies several policies that
- installs the OpenShift Platform Plus products using best practices that allow
- them to work well together. This policy set if focued on the components that install
- to every managed cluster.
- policies:
- - policy-acs-secured-status
diff --git a/tests/hub-quay-industrial-edge-factory.expected.yaml b/tests/hub-quay-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 1cfda3ee..00000000
--- a/tests/hub-quay-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,513 +0,0 @@
----
-# Source: quay/templates/rbac/quay-admin-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: quay-admin-sa
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/secret/secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: quay-init-config-bundle-secret
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "4"
-type: Opaque
-stringData:
- config.yaml: |
- FEATURE_USER_INITIALIZE: true
- FEATURE_GENERAL_OCI_SUPPORT: true
- BROWSER_API_CALLS_XHR_ONLY: false
- SUPER_USERS:
- - quayadmin
- FEATURE_USER_CREATION: true
- ALLOW_PULLS_WITHOUT_STRICT_LOGGING: false
- AUTHENTICATION_TYPE: Database
- DEFAULT_TAG_EXPIRATION: 2w
- ENTERPRISE_LOGO_URL: /static/img/RH_Logo_Quay_Black_UX-
- FEATURE_BUILD_SUPPORT: false
- FEATURE_DIRECT_LOGIN: true
- FEATURE_MAILING: false
- REGISTRY_TITLE: Red Hat Quay
- REGISTRY_TITLE_SHORT: Quay
- TEAM_RESYNC_STALE_TIME: 60m
- TESTING: false
- CREATE_NAMESPACE_ON_PUSH: true
----
-# Source: quay/templates/quayRegistry/cm-create-quaye-pull-secret.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: create-quaye-pull-secret
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- create-quaye-pull-secret.sh: |
- #!/bin/bash -e
-
- function quay_cmd() {
- DATA='{}'
- if [ ! -z "$4" ]; then
- DATA=$4
- fi
- echo "[$1] $2 $3 --data $DATA" 1>&2
- AUTH="Fake: dummy"
- if [ $1 = "Basic" ]; then
- COUNT=$(oc -n $QUAY_NAMESPACE get --ignore-not-found=true secret $QUAY_USER_SECRET | wc -l)
- if [ $COUNT -gt 1 ]; then
- BASIC=$(oc -n $QUAY_NAMESPACE extract secret/$QUAY_USER_SECRET --keys=basic --to=-)
- fi
- AUTH="Authorization: Basic $BASIC"
-
- elif [ $1 = "Bearer" ]; then
- AUTH="Authorization: Bearer $TOKEN"
- fi
- curl -X $2 $CURL_OPTS -H 'Content-Type: application/json' -H "$AUTH" https://$QUAY_HOST$3 --data "$DATA"
- echo "[INFO] Success" 1>&2
- }
-
- CURL_OPTS="-fsk"
- QUAY_USER_SECRET=quay-user
-
- env | grep QUAY | grep -v QUAY_REGISTRY
- if [ -z "$QUAY_NAMESPACE" ]; then
- QUAY_NAMESPACE=quay-enterprise
- fi
- if [ -z "$QUAY_HOST" ]; then
- QUAY_HOST="quay-registry-quay-quay-enterprise.apps.hub.example.com"
- fi
- if [ -z "$QUAY_USER" ]; then
- QUAY_USER=developer1
- fi
- if [ -z "$QUAY_USER_EMAIL" ]; then
- QUAY_USER_EMAIL=developer1@myorg.com
- fi
- if [ -z "$QUAY_ORG" ]; then
- QUAY_ORG=devel
- fi
- if [ -z "$QUAY_ORG_EMAIL" ]; then
- QUAY_ORG_EMAIL=devel@myorg.com
- fi
- if [ -z "$QUAY_REPO" ]; then
- QUAY_REPO=example
- fi
-
- echo "[INFO] Looking for initial token ..."
- SECRET_NAME=quay-init-token
- COUNT=$(oc -n $QUAY_NAMESPACE get --ignore-not-found=true secret $SECRET_NAME | wc -l)
- if [ $COUNT = 0 ]; then
- INITPASS=$(tr -dc A-Za-z0-9 Applications -> {app} -> Generate Token
- # If there was a programatic way to do it here, we could avoid the problem with the bearer token expiring after 150min
- APPLICATION=automation
- COUNT=$(quay_cmd Bearer GET /api/v1/organization/$QUAY_ORG/applications | grep $APPLICATION | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Creating $APPLICATION application..."
- quay_cmd Bearer POST /api/v1/organization/$QUAY_ORG/applications "{\"name\": \"$QUAY_ORG-automation\", \"description\": \"automation app\" }"
- fi
-
- echo "[INFO] Looking for initial repo ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/repository/$QUAY_ORG/$QUAY_REPO | grep -v not_found | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Creating $QUAY_REPO repo..."
- quay_cmd Bearer POST /api/v1/repository "{\"namespace\":\"$QUAY_ORG\", \"repository\":\"$QUAY_REPO\", \"visibility\":\"public\", \"description\":\"Development Repo\", \"repo_kind\":\"image\"}"
- fi
-
- echo "[INFO] Looking for $QUAY_ORG members ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/organization/$QUAY_ORG/team/owners/members | grep "name\": \"$QUAY_USER\"" | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Associating $QUAY_USER with $QUAY_ORG ..."
- quay_cmd Bearer PUT /api/v1/organization/$QUAY_ORG/team/owners/members/$QUAY_USER '{}'
- fi
-
- echo "[INFO] Looking for $QUAY_REPO admins ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/repository/$QUAY_ORG/$QUAY_REPO/permissions/user/$QUAY_USER | grep '"role": "admin"' | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Give $QUAY_USER admin rights to the repo ..."
- quay_cmd Bearer PUT /api/v1/repository/$QUAY_ORG/$QUAY_REPO/permissions/user/$QUAY_USER '{ "role": "admin"}'
- fi
-
- echo "[INFO] Job finished"
----
-# Source: quay/templates/quayRegistry/cm-wait-for-quay-app-deploy.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: wait-for-quay-app
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
-data:
- wait-on-quay-to-deploy.sh: |
- echo -n "Waiting for the Quay Registry CR to be available ."
- RC=$(oc wait QuayRegistry quay-registry --for=condition=Available=true > /dev/null 2>&1;echo $?)
-
- while [ $RC -ne 0 ]; do
- sleep 2
- echo -n "."
- RC=$(oc wait QuayRegistry quay-registry --for=condition=Available=true > /dev/null 2>&1;echo $?)
- done
- echo "done"
----
-# Source: quay/templates/rbac/quay-admin-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: quay-admin-role
-rules:
- - apiGroups:
- - quay.redhat.com
- resources:
- - quayregistries
- verbs:
- - get
- - list
- - watch
- - delete
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
- - delete
----
-# Source: quay/templates/rbac/quay-admin-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-admin-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-admin-role
-subjects:
- - kind: ServiceAccount
- name: quay-admin-sa
- namespace: quay-enterprise
----
-# Source: quay/templates/quayRegistry/job-create-quaye-pull-secret.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "10"
- # quaye is abbrev. for Quay Enterprise - diff from quayio
- name: create-quaye-pull-secret
- namespace: quay-enterprise
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: QUAY_REPO
- value: "example"
- command:
- - /bin/bash
- - -c
- - |
- oc wait QuayRegistry quay-registry --for=condition=Available=true
- '/tmp/create-quaye-pull-secret.sh'
- name: create-quaye-pull-secret
- volumeMounts:
- - mountPath: /tmp/create-quaye-pull-secret.sh
- name: create-quaye-pull-secret
- subPath: create-quaye-pull-secret.sh
- volumes:
- - name: create-quaye-pull-secret
- configMap:
- name: create-quaye-pull-secret
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: quay-admin-sa
- serviceAccountName: quay-admin-sa
- terminationGracePeriodSeconds: 400
----
-# Source: quay/templates/quayRegistry/job-wait-on-quay-app-deploy.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: wait-for-quay-app-deploy
- namespace: quay-enterprise
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- # wait for the operator QuayRegistry CR to be available
- /tmp/wait-on-quay-to-deploy.sh
- name: wait-for-quay-app
- volumeMounts:
- - mountPath: /tmp/wait-on-quay-to-deploy.sh
- name: wait-for-quay-app
- subPath: wait-on-quay-to-deploy.sh
- volumes:
- - name: wait-for-quay-app
- configMap:
- name: wait-for-quay-app
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: quay-admin-sa
- terminationGracePeriodSeconds: 60
----
-# Source: quay/templates/quayRegistry/quay-console-link.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: factory-quay-link
- namespace: quay-enterprise
-spec:
- applicationMenu:
- section: Red Hat applications
- imageURL: 'https://upload.wikimedia.org/wikipedia/commons/3/3a/OpenShift-LogoType.svg'
- href: 'https://quay-registry-quay-quay-enterprise.apps.region.example.com'
- location: ApplicationMenu
- text: 'Red Hat Quay Enterprise Registry'
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: quay-pull-secret-placement-binding
- namespace: devsecops-ci
-placementRef:
- name: quay-pull-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-quay-pull-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: quay-pull-secret-placement
- namespace: devsecops-ci
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- - prod
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: quay/templates/policy-quay-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-7 Software Firmware and Information
- Integrity
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-quay-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-quay-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: quay-registry-quay-app
- namespace: quay-enterprise
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: quay-registry-quay-database
- namespace: quay-enterprise
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-quay-pull-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: quay-pull-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - openshift-operators
- - devsecops-ci
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: quay-pull-secret
- namespace: devsecops-ci # consider changing this to devsecops-ci
- apiVersion: v1
- data:
- .dockerconfigjson: '{{hub fromSecret "devsecops-ci" "quay-pull-secret" ".dockerconfigjson" hub}}'
----
-# Source: quay/templates/quayRegistry/registry.yaml
-apiVersion: quay.redhat.com/v1
-kind: QuayRegistry
-metadata:
- name: quay-registry
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "4"
-spec:
- components:
- - kind: clair
- managed: true
- - kind: horizontalpodautoscaler
- managed: true
- - kind: mirror
- managed: true
- - kind: monitoring
- managed: true
- - kind: postgres
- managed: true
- - kind: redis
- managed: true
- - kind: objectstorage
- managed: true
- - kind: route
- managed: true
- - kind: tls
- managed: true
- - kind: quay
- managed: true
- - kind: clairpostgres
- managed: true
- configBundleSecret: quay-init-config-bundle-secret
diff --git a/tests/hub-quay-industrial-edge-hub.expected.yaml b/tests/hub-quay-industrial-edge-hub.expected.yaml
deleted file mode 100644
index c2666d12..00000000
--- a/tests/hub-quay-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,513 +0,0 @@
----
-# Source: quay/templates/rbac/quay-admin-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: quay-admin-sa
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/secret/secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: quay-init-config-bundle-secret
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "4"
-type: Opaque
-stringData:
- config.yaml: |
- FEATURE_USER_INITIALIZE: true
- FEATURE_GENERAL_OCI_SUPPORT: true
- BROWSER_API_CALLS_XHR_ONLY: false
- SUPER_USERS:
- - quayadmin
- FEATURE_USER_CREATION: true
- ALLOW_PULLS_WITHOUT_STRICT_LOGGING: false
- AUTHENTICATION_TYPE: Database
- DEFAULT_TAG_EXPIRATION: 2w
- ENTERPRISE_LOGO_URL: /static/img/RH_Logo_Quay_Black_UX-
- FEATURE_BUILD_SUPPORT: false
- FEATURE_DIRECT_LOGIN: true
- FEATURE_MAILING: false
- REGISTRY_TITLE: Red Hat Quay
- REGISTRY_TITLE_SHORT: Quay
- TEAM_RESYNC_STALE_TIME: 60m
- TESTING: false
- CREATE_NAMESPACE_ON_PUSH: true
----
-# Source: quay/templates/quayRegistry/cm-create-quaye-pull-secret.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: create-quaye-pull-secret
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- create-quaye-pull-secret.sh: |
- #!/bin/bash -e
-
- function quay_cmd() {
- DATA='{}'
- if [ ! -z "$4" ]; then
- DATA=$4
- fi
- echo "[$1] $2 $3 --data $DATA" 1>&2
- AUTH="Fake: dummy"
- if [ $1 = "Basic" ]; then
- COUNT=$(oc -n $QUAY_NAMESPACE get --ignore-not-found=true secret $QUAY_USER_SECRET | wc -l)
- if [ $COUNT -gt 1 ]; then
- BASIC=$(oc -n $QUAY_NAMESPACE extract secret/$QUAY_USER_SECRET --keys=basic --to=-)
- fi
- AUTH="Authorization: Basic $BASIC"
-
- elif [ $1 = "Bearer" ]; then
- AUTH="Authorization: Bearer $TOKEN"
- fi
- curl -X $2 $CURL_OPTS -H 'Content-Type: application/json' -H "$AUTH" https://$QUAY_HOST$3 --data "$DATA"
- echo "[INFO] Success" 1>&2
- }
-
- CURL_OPTS="-fsk"
- QUAY_USER_SECRET=quay-user
-
- env | grep QUAY | grep -v QUAY_REGISTRY
- if [ -z "$QUAY_NAMESPACE" ]; then
- QUAY_NAMESPACE=quay-enterprise
- fi
- if [ -z "$QUAY_HOST" ]; then
- QUAY_HOST="quay-registry-quay-quay-enterprise.apps.hub.example.com"
- fi
- if [ -z "$QUAY_USER" ]; then
- QUAY_USER=developer1
- fi
- if [ -z "$QUAY_USER_EMAIL" ]; then
- QUAY_USER_EMAIL=developer1@myorg.com
- fi
- if [ -z "$QUAY_ORG" ]; then
- QUAY_ORG=devel
- fi
- if [ -z "$QUAY_ORG_EMAIL" ]; then
- QUAY_ORG_EMAIL=devel@myorg.com
- fi
- if [ -z "$QUAY_REPO" ]; then
- QUAY_REPO=example
- fi
-
- echo "[INFO] Looking for initial token ..."
- SECRET_NAME=quay-init-token
- COUNT=$(oc -n $QUAY_NAMESPACE get --ignore-not-found=true secret $SECRET_NAME | wc -l)
- if [ $COUNT = 0 ]; then
- INITPASS=$(tr -dc A-Za-z0-9 Applications -> {app} -> Generate Token
- # If there was a programatic way to do it here, we could avoid the problem with the bearer token expiring after 150min
- APPLICATION=automation
- COUNT=$(quay_cmd Bearer GET /api/v1/organization/$QUAY_ORG/applications | grep $APPLICATION | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Creating $APPLICATION application..."
- quay_cmd Bearer POST /api/v1/organization/$QUAY_ORG/applications "{\"name\": \"$QUAY_ORG-automation\", \"description\": \"automation app\" }"
- fi
-
- echo "[INFO] Looking for initial repo ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/repository/$QUAY_ORG/$QUAY_REPO | grep -v not_found | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Creating $QUAY_REPO repo..."
- quay_cmd Bearer POST /api/v1/repository "{\"namespace\":\"$QUAY_ORG\", \"repository\":\"$QUAY_REPO\", \"visibility\":\"public\", \"description\":\"Development Repo\", \"repo_kind\":\"image\"}"
- fi
-
- echo "[INFO] Looking for $QUAY_ORG members ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/organization/$QUAY_ORG/team/owners/members | grep "name\": \"$QUAY_USER\"" | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Associating $QUAY_USER with $QUAY_ORG ..."
- quay_cmd Bearer PUT /api/v1/organization/$QUAY_ORG/team/owners/members/$QUAY_USER '{}'
- fi
-
- echo "[INFO] Looking for $QUAY_REPO admins ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/repository/$QUAY_ORG/$QUAY_REPO/permissions/user/$QUAY_USER | grep '"role": "admin"' | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Give $QUAY_USER admin rights to the repo ..."
- quay_cmd Bearer PUT /api/v1/repository/$QUAY_ORG/$QUAY_REPO/permissions/user/$QUAY_USER '{ "role": "admin"}'
- fi
-
- echo "[INFO] Job finished"
----
-# Source: quay/templates/quayRegistry/cm-wait-for-quay-app-deploy.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: wait-for-quay-app
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
-data:
- wait-on-quay-to-deploy.sh: |
- echo -n "Waiting for the Quay Registry CR to be available ."
- RC=$(oc wait QuayRegistry quay-registry --for=condition=Available=true > /dev/null 2>&1;echo $?)
-
- while [ $RC -ne 0 ]; do
- sleep 2
- echo -n "."
- RC=$(oc wait QuayRegistry quay-registry --for=condition=Available=true > /dev/null 2>&1;echo $?)
- done
- echo "done"
----
-# Source: quay/templates/rbac/quay-admin-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: quay-admin-role
-rules:
- - apiGroups:
- - quay.redhat.com
- resources:
- - quayregistries
- verbs:
- - get
- - list
- - watch
- - delete
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
- - delete
----
-# Source: quay/templates/rbac/quay-admin-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-admin-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-admin-role
-subjects:
- - kind: ServiceAccount
- name: quay-admin-sa
- namespace: quay-enterprise
----
-# Source: quay/templates/quayRegistry/job-create-quaye-pull-secret.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "10"
- # quaye is abbrev. for Quay Enterprise - diff from quayio
- name: create-quaye-pull-secret
- namespace: quay-enterprise
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: QUAY_REPO
- value: "example"
- command:
- - /bin/bash
- - -c
- - |
- oc wait QuayRegistry quay-registry --for=condition=Available=true
- '/tmp/create-quaye-pull-secret.sh'
- name: create-quaye-pull-secret
- volumeMounts:
- - mountPath: /tmp/create-quaye-pull-secret.sh
- name: create-quaye-pull-secret
- subPath: create-quaye-pull-secret.sh
- volumes:
- - name: create-quaye-pull-secret
- configMap:
- name: create-quaye-pull-secret
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: quay-admin-sa
- serviceAccountName: quay-admin-sa
- terminationGracePeriodSeconds: 400
----
-# Source: quay/templates/quayRegistry/job-wait-on-quay-app-deploy.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: wait-for-quay-app-deploy
- namespace: quay-enterprise
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- # wait for the operator QuayRegistry CR to be available
- /tmp/wait-on-quay-to-deploy.sh
- name: wait-for-quay-app
- volumeMounts:
- - mountPath: /tmp/wait-on-quay-to-deploy.sh
- name: wait-for-quay-app
- subPath: wait-on-quay-to-deploy.sh
- volumes:
- - name: wait-for-quay-app
- configMap:
- name: wait-for-quay-app
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: quay-admin-sa
- terminationGracePeriodSeconds: 60
----
-# Source: quay/templates/quayRegistry/quay-console-link.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: datacenter-quay-link
- namespace: quay-enterprise
-spec:
- applicationMenu:
- section: Red Hat applications
- imageURL: 'https://upload.wikimedia.org/wikipedia/commons/3/3a/OpenShift-LogoType.svg'
- href: 'https://quay-registry-quay-quay-enterprise.apps.region.example.com'
- location: ApplicationMenu
- text: 'Red Hat Quay Enterprise Registry'
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: quay-pull-secret-placement-binding
- namespace: devsecops-ci
-placementRef:
- name: quay-pull-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-quay-pull-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: quay-pull-secret-placement
- namespace: devsecops-ci
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- - prod
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: quay/templates/policy-quay-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-7 Software Firmware and Information
- Integrity
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-quay-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-quay-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: quay-registry-quay-app
- namespace: quay-enterprise
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: quay-registry-quay-database
- namespace: quay-enterprise
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-quay-pull-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: quay-pull-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - openshift-operators
- - devsecops-ci
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: quay-pull-secret
- namespace: devsecops-ci # consider changing this to devsecops-ci
- apiVersion: v1
- data:
- .dockerconfigjson: '{{hub fromSecret "devsecops-ci" "quay-pull-secret" ".dockerconfigjson" hub}}'
----
-# Source: quay/templates/quayRegistry/registry.yaml
-apiVersion: quay.redhat.com/v1
-kind: QuayRegistry
-metadata:
- name: quay-registry
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "4"
-spec:
- components:
- - kind: clair
- managed: true
- - kind: horizontalpodautoscaler
- managed: true
- - kind: mirror
- managed: true
- - kind: monitoring
- managed: true
- - kind: postgres
- managed: true
- - kind: redis
- managed: true
- - kind: objectstorage
- managed: true
- - kind: route
- managed: true
- - kind: tls
- managed: true
- - kind: quay
- managed: true
- - kind: clairpostgres
- managed: true
- configBundleSecret: quay-init-config-bundle-secret
diff --git a/tests/hub-quay-medical-diagnosis-hub.expected.yaml b/tests/hub-quay-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 1f75942e..00000000
--- a/tests/hub-quay-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,513 +0,0 @@
----
-# Source: quay/templates/rbac/quay-admin-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: quay-admin-sa
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/secret/secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: quay-init-config-bundle-secret
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "4"
-type: Opaque
-stringData:
- config.yaml: |
- FEATURE_USER_INITIALIZE: true
- FEATURE_GENERAL_OCI_SUPPORT: true
- BROWSER_API_CALLS_XHR_ONLY: false
- SUPER_USERS:
- - quayadmin
- FEATURE_USER_CREATION: true
- ALLOW_PULLS_WITHOUT_STRICT_LOGGING: false
- AUTHENTICATION_TYPE: Database
- DEFAULT_TAG_EXPIRATION: 2w
- ENTERPRISE_LOGO_URL: /static/img/RH_Logo_Quay_Black_UX-
- FEATURE_BUILD_SUPPORT: false
- FEATURE_DIRECT_LOGIN: true
- FEATURE_MAILING: false
- REGISTRY_TITLE: Red Hat Quay
- REGISTRY_TITLE_SHORT: Quay
- TEAM_RESYNC_STALE_TIME: 60m
- TESTING: false
- CREATE_NAMESPACE_ON_PUSH: true
----
-# Source: quay/templates/quayRegistry/cm-create-quaye-pull-secret.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: create-quaye-pull-secret
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- create-quaye-pull-secret.sh: |
- #!/bin/bash -e
-
- function quay_cmd() {
- DATA='{}'
- if [ ! -z "$4" ]; then
- DATA=$4
- fi
- echo "[$1] $2 $3 --data $DATA" 1>&2
- AUTH="Fake: dummy"
- if [ $1 = "Basic" ]; then
- COUNT=$(oc -n $QUAY_NAMESPACE get --ignore-not-found=true secret $QUAY_USER_SECRET | wc -l)
- if [ $COUNT -gt 1 ]; then
- BASIC=$(oc -n $QUAY_NAMESPACE extract secret/$QUAY_USER_SECRET --keys=basic --to=-)
- fi
- AUTH="Authorization: Basic $BASIC"
-
- elif [ $1 = "Bearer" ]; then
- AUTH="Authorization: Bearer $TOKEN"
- fi
- curl -X $2 $CURL_OPTS -H 'Content-Type: application/json' -H "$AUTH" https://$QUAY_HOST$3 --data "$DATA"
- echo "[INFO] Success" 1>&2
- }
-
- CURL_OPTS="-fsk"
- QUAY_USER_SECRET=quay-user
-
- env | grep QUAY | grep -v QUAY_REGISTRY
- if [ -z "$QUAY_NAMESPACE" ]; then
- QUAY_NAMESPACE=quay-enterprise
- fi
- if [ -z "$QUAY_HOST" ]; then
- QUAY_HOST="quay-registry-quay-quay-enterprise.apps.hub.example.com"
- fi
- if [ -z "$QUAY_USER" ]; then
- QUAY_USER=developer1
- fi
- if [ -z "$QUAY_USER_EMAIL" ]; then
- QUAY_USER_EMAIL=developer1@myorg.com
- fi
- if [ -z "$QUAY_ORG" ]; then
- QUAY_ORG=devel
- fi
- if [ -z "$QUAY_ORG_EMAIL" ]; then
- QUAY_ORG_EMAIL=devel@myorg.com
- fi
- if [ -z "$QUAY_REPO" ]; then
- QUAY_REPO=example
- fi
-
- echo "[INFO] Looking for initial token ..."
- SECRET_NAME=quay-init-token
- COUNT=$(oc -n $QUAY_NAMESPACE get --ignore-not-found=true secret $SECRET_NAME | wc -l)
- if [ $COUNT = 0 ]; then
- INITPASS=$(tr -dc A-Za-z0-9 Applications -> {app} -> Generate Token
- # If there was a programatic way to do it here, we could avoid the problem with the bearer token expiring after 150min
- APPLICATION=automation
- COUNT=$(quay_cmd Bearer GET /api/v1/organization/$QUAY_ORG/applications | grep $APPLICATION | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Creating $APPLICATION application..."
- quay_cmd Bearer POST /api/v1/organization/$QUAY_ORG/applications "{\"name\": \"$QUAY_ORG-automation\", \"description\": \"automation app\" }"
- fi
-
- echo "[INFO] Looking for initial repo ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/repository/$QUAY_ORG/$QUAY_REPO | grep -v not_found | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Creating $QUAY_REPO repo..."
- quay_cmd Bearer POST /api/v1/repository "{\"namespace\":\"$QUAY_ORG\", \"repository\":\"$QUAY_REPO\", \"visibility\":\"public\", \"description\":\"Development Repo\", \"repo_kind\":\"image\"}"
- fi
-
- echo "[INFO] Looking for $QUAY_ORG members ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/organization/$QUAY_ORG/team/owners/members | grep "name\": \"$QUAY_USER\"" | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Associating $QUAY_USER with $QUAY_ORG ..."
- quay_cmd Bearer PUT /api/v1/organization/$QUAY_ORG/team/owners/members/$QUAY_USER '{}'
- fi
-
- echo "[INFO] Looking for $QUAY_REPO admins ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/repository/$QUAY_ORG/$QUAY_REPO/permissions/user/$QUAY_USER | grep '"role": "admin"' | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Give $QUAY_USER admin rights to the repo ..."
- quay_cmd Bearer PUT /api/v1/repository/$QUAY_ORG/$QUAY_REPO/permissions/user/$QUAY_USER '{ "role": "admin"}'
- fi
-
- echo "[INFO] Job finished"
----
-# Source: quay/templates/quayRegistry/cm-wait-for-quay-app-deploy.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: wait-for-quay-app
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
-data:
- wait-on-quay-to-deploy.sh: |
- echo -n "Waiting for the Quay Registry CR to be available ."
- RC=$(oc wait QuayRegistry quay-registry --for=condition=Available=true > /dev/null 2>&1;echo $?)
-
- while [ $RC -ne 0 ]; do
- sleep 2
- echo -n "."
- RC=$(oc wait QuayRegistry quay-registry --for=condition=Available=true > /dev/null 2>&1;echo $?)
- done
- echo "done"
----
-# Source: quay/templates/rbac/quay-admin-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: quay-admin-role
-rules:
- - apiGroups:
- - quay.redhat.com
- resources:
- - quayregistries
- verbs:
- - get
- - list
- - watch
- - delete
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
- - delete
----
-# Source: quay/templates/rbac/quay-admin-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-admin-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-admin-role
-subjects:
- - kind: ServiceAccount
- name: quay-admin-sa
- namespace: quay-enterprise
----
-# Source: quay/templates/quayRegistry/job-create-quaye-pull-secret.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "10"
- # quaye is abbrev. for Quay Enterprise - diff from quayio
- name: create-quaye-pull-secret
- namespace: quay-enterprise
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: QUAY_REPO
- value: "example"
- command:
- - /bin/bash
- - -c
- - |
- oc wait QuayRegistry quay-registry --for=condition=Available=true
- '/tmp/create-quaye-pull-secret.sh'
- name: create-quaye-pull-secret
- volumeMounts:
- - mountPath: /tmp/create-quaye-pull-secret.sh
- name: create-quaye-pull-secret
- subPath: create-quaye-pull-secret.sh
- volumes:
- - name: create-quaye-pull-secret
- configMap:
- name: create-quaye-pull-secret
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: quay-admin-sa
- serviceAccountName: quay-admin-sa
- terminationGracePeriodSeconds: 400
----
-# Source: quay/templates/quayRegistry/job-wait-on-quay-app-deploy.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: wait-for-quay-app-deploy
- namespace: quay-enterprise
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- # wait for the operator QuayRegistry CR to be available
- /tmp/wait-on-quay-to-deploy.sh
- name: wait-for-quay-app
- volumeMounts:
- - mountPath: /tmp/wait-on-quay-to-deploy.sh
- name: wait-for-quay-app
- subPath: wait-on-quay-to-deploy.sh
- volumes:
- - name: wait-for-quay-app
- configMap:
- name: wait-for-quay-app
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: quay-admin-sa
- terminationGracePeriodSeconds: 60
----
-# Source: quay/templates/quayRegistry/quay-console-link.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: hub-quay-link
- namespace: quay-enterprise
-spec:
- applicationMenu:
- section: Red Hat applications
- imageURL: 'https://upload.wikimedia.org/wikipedia/commons/3/3a/OpenShift-LogoType.svg'
- href: 'https://quay-registry-quay-quay-enterprise.apps.region.example.com'
- location: ApplicationMenu
- text: 'Red Hat Quay Enterprise Registry'
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: quay-pull-secret-placement-binding
- namespace: devsecops-ci
-placementRef:
- name: quay-pull-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-quay-pull-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: quay-pull-secret-placement
- namespace: devsecops-ci
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- - prod
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: quay/templates/policy-quay-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-7 Software Firmware and Information
- Integrity
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-quay-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-quay-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: quay-registry-quay-app
- namespace: quay-enterprise
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: quay-registry-quay-database
- namespace: quay-enterprise
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-quay-pull-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: quay-pull-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - openshift-operators
- - devsecops-ci
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: quay-pull-secret
- namespace: devsecops-ci # consider changing this to devsecops-ci
- apiVersion: v1
- data:
- .dockerconfigjson: '{{hub fromSecret "devsecops-ci" "quay-pull-secret" ".dockerconfigjson" hub}}'
----
-# Source: quay/templates/quayRegistry/registry.yaml
-apiVersion: quay.redhat.com/v1
-kind: QuayRegistry
-metadata:
- name: quay-registry
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "4"
-spec:
- components:
- - kind: clair
- managed: true
- - kind: horizontalpodautoscaler
- managed: true
- - kind: mirror
- managed: true
- - kind: monitoring
- managed: true
- - kind: postgres
- managed: true
- - kind: redis
- managed: true
- - kind: objectstorage
- managed: true
- - kind: route
- managed: true
- - kind: tls
- managed: true
- - kind: quay
- managed: true
- - kind: clairpostgres
- managed: true
- configBundleSecret: quay-init-config-bundle-secret
diff --git a/tests/hub-quay-naked.expected.yaml b/tests/hub-quay-naked.expected.yaml
deleted file mode 100644
index ae86a24c..00000000
--- a/tests/hub-quay-naked.expected.yaml
+++ /dev/null
@@ -1,513 +0,0 @@
----
-# Source: quay/templates/rbac/quay-admin-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: quay-admin-sa
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/secret/secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: quay-init-config-bundle-secret
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "4"
-type: Opaque
-stringData:
- config.yaml: |
- FEATURE_USER_INITIALIZE: true
- FEATURE_GENERAL_OCI_SUPPORT: true
- BROWSER_API_CALLS_XHR_ONLY: false
- SUPER_USERS:
- - quayadmin
- FEATURE_USER_CREATION: true
- ALLOW_PULLS_WITHOUT_STRICT_LOGGING: false
- AUTHENTICATION_TYPE: Database
- DEFAULT_TAG_EXPIRATION: 2w
- ENTERPRISE_LOGO_URL: /static/img/RH_Logo_Quay_Black_UX-
- FEATURE_BUILD_SUPPORT: false
- FEATURE_DIRECT_LOGIN: true
- FEATURE_MAILING: false
- REGISTRY_TITLE: Red Hat Quay
- REGISTRY_TITLE_SHORT: Quay
- TEAM_RESYNC_STALE_TIME: 60m
- TESTING: false
- CREATE_NAMESPACE_ON_PUSH: true
----
-# Source: quay/templates/quayRegistry/cm-create-quaye-pull-secret.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: create-quaye-pull-secret
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- create-quaye-pull-secret.sh: |
- #!/bin/bash -e
-
- function quay_cmd() {
- DATA='{}'
- if [ ! -z "$4" ]; then
- DATA=$4
- fi
- echo "[$1] $2 $3 --data $DATA" 1>&2
- AUTH="Fake: dummy"
- if [ $1 = "Basic" ]; then
- COUNT=$(oc -n $QUAY_NAMESPACE get --ignore-not-found=true secret $QUAY_USER_SECRET | wc -l)
- if [ $COUNT -gt 1 ]; then
- BASIC=$(oc -n $QUAY_NAMESPACE extract secret/$QUAY_USER_SECRET --keys=basic --to=-)
- fi
- AUTH="Authorization: Basic $BASIC"
-
- elif [ $1 = "Bearer" ]; then
- AUTH="Authorization: Bearer $TOKEN"
- fi
- curl -X $2 $CURL_OPTS -H 'Content-Type: application/json' -H "$AUTH" https://$QUAY_HOST$3 --data "$DATA"
- echo "[INFO] Success" 1>&2
- }
-
- CURL_OPTS="-fsk"
- QUAY_USER_SECRET=quay-user
-
- env | grep QUAY | grep -v QUAY_REGISTRY
- if [ -z "$QUAY_NAMESPACE" ]; then
- QUAY_NAMESPACE=quay-enterprise
- fi
- if [ -z "$QUAY_HOST" ]; then
- QUAY_HOST="quay-registry-quay-quay-enterprise."
- fi
- if [ -z "$QUAY_USER" ]; then
- QUAY_USER=developer1
- fi
- if [ -z "$QUAY_USER_EMAIL" ]; then
- QUAY_USER_EMAIL=developer1@myorg.com
- fi
- if [ -z "$QUAY_ORG" ]; then
- QUAY_ORG=devel
- fi
- if [ -z "$QUAY_ORG_EMAIL" ]; then
- QUAY_ORG_EMAIL=devel@myorg.com
- fi
- if [ -z "$QUAY_REPO" ]; then
- QUAY_REPO=example
- fi
-
- echo "[INFO] Looking for initial token ..."
- SECRET_NAME=quay-init-token
- COUNT=$(oc -n $QUAY_NAMESPACE get --ignore-not-found=true secret $SECRET_NAME | wc -l)
- if [ $COUNT = 0 ]; then
- INITPASS=$(tr -dc A-Za-z0-9 Applications -> {app} -> Generate Token
- # If there was a programatic way to do it here, we could avoid the problem with the bearer token expiring after 150min
- APPLICATION=automation
- COUNT=$(quay_cmd Bearer GET /api/v1/organization/$QUAY_ORG/applications | grep $APPLICATION | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Creating $APPLICATION application..."
- quay_cmd Bearer POST /api/v1/organization/$QUAY_ORG/applications "{\"name\": \"$QUAY_ORG-automation\", \"description\": \"automation app\" }"
- fi
-
- echo "[INFO] Looking for initial repo ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/repository/$QUAY_ORG/$QUAY_REPO | grep -v not_found | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Creating $QUAY_REPO repo..."
- quay_cmd Bearer POST /api/v1/repository "{\"namespace\":\"$QUAY_ORG\", \"repository\":\"$QUAY_REPO\", \"visibility\":\"public\", \"description\":\"Development Repo\", \"repo_kind\":\"image\"}"
- fi
-
- echo "[INFO] Looking for $QUAY_ORG members ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/organization/$QUAY_ORG/team/owners/members | grep "name\": \"$QUAY_USER\"" | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Associating $QUAY_USER with $QUAY_ORG ..."
- quay_cmd Bearer PUT /api/v1/organization/$QUAY_ORG/team/owners/members/$QUAY_USER '{}'
- fi
-
- echo "[INFO] Looking for $QUAY_REPO admins ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/repository/$QUAY_ORG/$QUAY_REPO/permissions/user/$QUAY_USER | grep '"role": "admin"' | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Give $QUAY_USER admin rights to the repo ..."
- quay_cmd Bearer PUT /api/v1/repository/$QUAY_ORG/$QUAY_REPO/permissions/user/$QUAY_USER '{ "role": "admin"}'
- fi
-
- echo "[INFO] Job finished"
----
-# Source: quay/templates/quayRegistry/cm-wait-for-quay-app-deploy.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: wait-for-quay-app
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
-data:
- wait-on-quay-to-deploy.sh: |
- echo -n "Waiting for the Quay Registry CR to be available ."
- RC=$(oc wait QuayRegistry quay-registry --for=condition=Available=true > /dev/null 2>&1;echo $?)
-
- while [ $RC -ne 0 ]; do
- sleep 2
- echo -n "."
- RC=$(oc wait QuayRegistry quay-registry --for=condition=Available=true > /dev/null 2>&1;echo $?)
- done
- echo "done"
----
-# Source: quay/templates/rbac/quay-admin-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: quay-admin-role
-rules:
- - apiGroups:
- - quay.redhat.com
- resources:
- - quayregistries
- verbs:
- - get
- - list
- - watch
- - delete
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
- - delete
----
-# Source: quay/templates/rbac/quay-admin-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-admin-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-admin-role
-subjects:
- - kind: ServiceAccount
- name: quay-admin-sa
- namespace: quay-enterprise
----
-# Source: quay/templates/quayRegistry/job-create-quaye-pull-secret.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "10"
- # quaye is abbrev. for Quay Enterprise - diff from quayio
- name: create-quaye-pull-secret
- namespace: quay-enterprise
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: QUAY_REPO
- value: "example"
- command:
- - /bin/bash
- - -c
- - |
- oc wait QuayRegistry quay-registry --for=condition=Available=true
- '/tmp/create-quaye-pull-secret.sh'
- name: create-quaye-pull-secret
- volumeMounts:
- - mountPath: /tmp/create-quaye-pull-secret.sh
- name: create-quaye-pull-secret
- subPath: create-quaye-pull-secret.sh
- volumes:
- - name: create-quaye-pull-secret
- configMap:
- name: create-quaye-pull-secret
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: quay-admin-sa
- serviceAccountName: quay-admin-sa
- terminationGracePeriodSeconds: 400
----
-# Source: quay/templates/quayRegistry/job-wait-on-quay-app-deploy.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: wait-for-quay-app-deploy
- namespace: quay-enterprise
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- # wait for the operator QuayRegistry CR to be available
- /tmp/wait-on-quay-to-deploy.sh
- name: wait-for-quay-app
- volumeMounts:
- - mountPath: /tmp/wait-on-quay-to-deploy.sh
- name: wait-for-quay-app
- subPath: wait-on-quay-to-deploy.sh
- volumes:
- - name: wait-for-quay-app
- configMap:
- name: wait-for-quay-app
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: quay-admin-sa
- terminationGracePeriodSeconds: 60
----
-# Source: quay/templates/quayRegistry/quay-console-link.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: AUTOMATIC-quay-link
- namespace: quay-enterprise
-spec:
- applicationMenu:
- section: Red Hat applications
- imageURL: 'https://upload.wikimedia.org/wikipedia/commons/3/3a/OpenShift-LogoType.svg'
- href: 'https://quay-registry-quay-quay-enterprise.'
- location: ApplicationMenu
- text: 'Red Hat Quay Enterprise Registry'
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: quay-pull-secret-placement-binding
- namespace: devsecops-ci
-placementRef:
- name: quay-pull-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-quay-pull-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: quay-pull-secret-placement
- namespace: devsecops-ci
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- - prod
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: quay/templates/policy-quay-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-7 Software Firmware and Information
- Integrity
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-quay-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-quay-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: quay-registry-quay-app
- namespace: quay-enterprise
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: quay-registry-quay-database
- namespace: quay-enterprise
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-quay-pull-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: quay-pull-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - openshift-operators
- - devsecops-ci
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: quay-pull-secret
- namespace: devsecops-ci # consider changing this to devsecops-ci
- apiVersion: v1
- data:
- .dockerconfigjson: '{{hub fromSecret "devsecops-ci" "quay-pull-secret" ".dockerconfigjson" hub}}'
----
-# Source: quay/templates/quayRegistry/registry.yaml
-apiVersion: quay.redhat.com/v1
-kind: QuayRegistry
-metadata:
- name: quay-registry
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "4"
-spec:
- components:
- - kind: clair
- managed: true
- - kind: horizontalpodautoscaler
- managed: true
- - kind: mirror
- managed: true
- - kind: monitoring
- managed: true
- - kind: postgres
- managed: true
- - kind: redis
- managed: true
- - kind: objectstorage
- managed: true
- - kind: route
- managed: true
- - kind: tls
- managed: true
- - kind: quay
- managed: true
- - kind: clairpostgres
- managed: true
- configBundleSecret: quay-init-config-bundle-secret
diff --git a/tests/hub-quay-normal.expected.yaml b/tests/hub-quay-normal.expected.yaml
deleted file mode 100644
index abd798f5..00000000
--- a/tests/hub-quay-normal.expected.yaml
+++ /dev/null
@@ -1,513 +0,0 @@
----
-# Source: quay/templates/rbac/quay-admin-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: quay-admin-sa
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/secret/secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: quay-init-config-bundle-secret
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "4"
-type: Opaque
-stringData:
- config.yaml: |
- FEATURE_USER_INITIALIZE: true
- FEATURE_GENERAL_OCI_SUPPORT: true
- BROWSER_API_CALLS_XHR_ONLY: false
- SUPER_USERS:
- - quayadmin
- FEATURE_USER_CREATION: true
- ALLOW_PULLS_WITHOUT_STRICT_LOGGING: false
- AUTHENTICATION_TYPE: Database
- DEFAULT_TAG_EXPIRATION: 2w
- ENTERPRISE_LOGO_URL: /static/img/RH_Logo_Quay_Black_UX-
- FEATURE_BUILD_SUPPORT: false
- FEATURE_DIRECT_LOGIN: true
- FEATURE_MAILING: false
- REGISTRY_TITLE: Red Hat Quay
- REGISTRY_TITLE_SHORT: Quay
- TEAM_RESYNC_STALE_TIME: 60m
- TESTING: false
- CREATE_NAMESPACE_ON_PUSH: true
----
-# Source: quay/templates/quayRegistry/cm-create-quaye-pull-secret.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: create-quaye-pull-secret
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "-1"
-data:
- create-quaye-pull-secret.sh: |
- #!/bin/bash -e
-
- function quay_cmd() {
- DATA='{}'
- if [ ! -z "$4" ]; then
- DATA=$4
- fi
- echo "[$1] $2 $3 --data $DATA" 1>&2
- AUTH="Fake: dummy"
- if [ $1 = "Basic" ]; then
- COUNT=$(oc -n $QUAY_NAMESPACE get --ignore-not-found=true secret $QUAY_USER_SECRET | wc -l)
- if [ $COUNT -gt 1 ]; then
- BASIC=$(oc -n $QUAY_NAMESPACE extract secret/$QUAY_USER_SECRET --keys=basic --to=-)
- fi
- AUTH="Authorization: Basic $BASIC"
-
- elif [ $1 = "Bearer" ]; then
- AUTH="Authorization: Bearer $TOKEN"
- fi
- curl -X $2 $CURL_OPTS -H 'Content-Type: application/json' -H "$AUTH" https://$QUAY_HOST$3 --data "$DATA"
- echo "[INFO] Success" 1>&2
- }
-
- CURL_OPTS="-fsk"
- QUAY_USER_SECRET=quay-user
-
- env | grep QUAY | grep -v QUAY_REGISTRY
- if [ -z "$QUAY_NAMESPACE" ]; then
- QUAY_NAMESPACE=quay-enterprise
- fi
- if [ -z "$QUAY_HOST" ]; then
- QUAY_HOST="quay-registry-quay-quay-enterprise.apps.hub.example.com"
- fi
- if [ -z "$QUAY_USER" ]; then
- QUAY_USER=developer1
- fi
- if [ -z "$QUAY_USER_EMAIL" ]; then
- QUAY_USER_EMAIL=developer1@myorg.com
- fi
- if [ -z "$QUAY_ORG" ]; then
- QUAY_ORG=devel
- fi
- if [ -z "$QUAY_ORG_EMAIL" ]; then
- QUAY_ORG_EMAIL=devel@myorg.com
- fi
- if [ -z "$QUAY_REPO" ]; then
- QUAY_REPO=example
- fi
-
- echo "[INFO] Looking for initial token ..."
- SECRET_NAME=quay-init-token
- COUNT=$(oc -n $QUAY_NAMESPACE get --ignore-not-found=true secret $SECRET_NAME | wc -l)
- if [ $COUNT = 0 ]; then
- INITPASS=$(tr -dc A-Za-z0-9 Applications -> {app} -> Generate Token
- # If there was a programatic way to do it here, we could avoid the problem with the bearer token expiring after 150min
- APPLICATION=automation
- COUNT=$(quay_cmd Bearer GET /api/v1/organization/$QUAY_ORG/applications | grep $APPLICATION | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Creating $APPLICATION application..."
- quay_cmd Bearer POST /api/v1/organization/$QUAY_ORG/applications "{\"name\": \"$QUAY_ORG-automation\", \"description\": \"automation app\" }"
- fi
-
- echo "[INFO] Looking for initial repo ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/repository/$QUAY_ORG/$QUAY_REPO | grep -v not_found | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Creating $QUAY_REPO repo..."
- quay_cmd Bearer POST /api/v1/repository "{\"namespace\":\"$QUAY_ORG\", \"repository\":\"$QUAY_REPO\", \"visibility\":\"public\", \"description\":\"Development Repo\", \"repo_kind\":\"image\"}"
- fi
-
- echo "[INFO] Looking for $QUAY_ORG members ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/organization/$QUAY_ORG/team/owners/members | grep "name\": \"$QUAY_USER\"" | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Associating $QUAY_USER with $QUAY_ORG ..."
- quay_cmd Bearer PUT /api/v1/organization/$QUAY_ORG/team/owners/members/$QUAY_USER '{}'
- fi
-
- echo "[INFO] Looking for $QUAY_REPO admins ..."
- COUNT=$(quay_cmd Bearer GET /api/v1/repository/$QUAY_ORG/$QUAY_REPO/permissions/user/$QUAY_USER | grep '"role": "admin"' | wc -l)
- if [ $COUNT = 0 ]; then
- echo "[INFO] Give $QUAY_USER admin rights to the repo ..."
- quay_cmd Bearer PUT /api/v1/repository/$QUAY_ORG/$QUAY_REPO/permissions/user/$QUAY_USER '{ "role": "admin"}'
- fi
-
- echo "[INFO] Job finished"
----
-# Source: quay/templates/quayRegistry/cm-wait-for-quay-app-deploy.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- # quaye abbrev. for Quay Enterprise
- name: wait-for-quay-app
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
-data:
- wait-on-quay-to-deploy.sh: |
- echo -n "Waiting for the Quay Registry CR to be available ."
- RC=$(oc wait QuayRegistry quay-registry --for=condition=Available=true > /dev/null 2>&1;echo $?)
-
- while [ $RC -ne 0 ]; do
- sleep 2
- echo -n "."
- RC=$(oc wait QuayRegistry quay-registry --for=condition=Available=true > /dev/null 2>&1;echo $?)
- done
- echo "done"
----
-# Source: quay/templates/rbac/quay-admin-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: quay-admin-role
-rules:
- - apiGroups:
- - quay.redhat.com
- resources:
- - quayregistries
- verbs:
- - get
- - list
- - watch
- - delete
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
- - delete
----
-# Source: quay/templates/rbac/quay-admin-rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-admin-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-admin-role
-subjects:
- - kind: ServiceAccount
- name: quay-admin-sa
- namespace: quay-enterprise
----
-# Source: quay/templates/quayRegistry/job-create-quaye-pull-secret.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "10"
- # quaye is abbrev. for Quay Enterprise - diff from quayio
- name: create-quaye-pull-secret
- namespace: quay-enterprise
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- env:
- - name: QUAY_REPO
- value: "example"
- command:
- - /bin/bash
- - -c
- - |
- oc wait QuayRegistry quay-registry --for=condition=Available=true
- '/tmp/create-quaye-pull-secret.sh'
- name: create-quaye-pull-secret
- volumeMounts:
- - mountPath: /tmp/create-quaye-pull-secret.sh
- name: create-quaye-pull-secret
- subPath: create-quaye-pull-secret.sh
- volumes:
- - name: create-quaye-pull-secret
- configMap:
- name: create-quaye-pull-secret
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: quay-admin-sa
- serviceAccountName: quay-admin-sa
- terminationGracePeriodSeconds: 400
----
-# Source: quay/templates/quayRegistry/job-wait-on-quay-app-deploy.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: wait-for-quay-app-deploy
- namespace: quay-enterprise
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- # wait for the operator QuayRegistry CR to be available
- /tmp/wait-on-quay-to-deploy.sh
- name: wait-for-quay-app
- volumeMounts:
- - mountPath: /tmp/wait-on-quay-to-deploy.sh
- name: wait-for-quay-app
- subPath: wait-on-quay-to-deploy.sh
- volumes:
- - name: wait-for-quay-app
- configMap:
- name: wait-for-quay-app
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: quay-admin-sa
- terminationGracePeriodSeconds: 60
----
-# Source: quay/templates/quayRegistry/quay-console-link.yaml
-apiVersion: console.openshift.io/v1
-kind: ConsoleLink
-metadata:
- name: example-quay-link
- namespace: quay-enterprise
-spec:
- applicationMenu:
- section: Red Hat applications
- imageURL: 'https://upload.wikimedia.org/wikipedia/commons/3/3a/OpenShift-LogoType.svg'
- href: 'https://quay-registry-quay-quay-enterprise.apps.region.example.com'
- location: ApplicationMenu
- text: 'Red Hat Quay Enterprise Registry'
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: PlacementBinding
-metadata:
- name: quay-pull-secret-placement-binding
- namespace: devsecops-ci
-placementRef:
- name: quay-pull-secret-placement
- kind: PlacementRule
- apiGroup: apps.open-cluster-management.io
-subjects:
- - name: policy-quay-pull-secret
- kind: Policy
- apiGroup: policy.open-cluster-management.io
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-# We need to run this on any managed cluster but not on the HUB
-apiVersion: apps.open-cluster-management.io/v1
-kind: PlacementRule
-metadata:
- name: quay-pull-secret-placement
- namespace: devsecops-ci
-spec:
- # This will go to both devel and secured clusters
- clusterSelector:
- # Using matchExpression because I need it in more than one clusterGroup
- matchExpressions:
- - key: clusterGroup
- operator: In
- values:
- - devel
- - prod
- clusterConditions:
- - status: 'True'
- type: ManagedClusterConditionAvailable
----
-# Source: quay/templates/policy-quay-status.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- annotations:
- policy.open-cluster-management.io/categories: SI System and Information Integrity
- policy.open-cluster-management.io/controls: SI-7 Software Firmware and Information
- Integrity
- policy.open-cluster-management.io/standards: NIST SP 800-53
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- labels:
- open-cluster-management.io/policy-set: openshift-plus
- name: policy-quay-status
- namespace: policies
-spec:
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: policy-quay-status
- spec:
- object-templates:
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: quay-registry-quay-app
- namespace: quay-enterprise
- status:
- conditions:
- - status: "True"
- type: Available
- - complianceType: musthave
- objectDefinition:
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: quay-registry-quay-database
- namespace: quay-enterprise
- status:
- conditions:
- - status: "True"
- type: Available
- remediationAction: inform
- severity: medium
----
-# Source: quay/templates/quayRegistry/policy-quay-pull-secret.yaml
-apiVersion: policy.open-cluster-management.io/v1
-kind: Policy
-metadata:
- name: policy-quay-pull-secret
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/sync-options: SkipPrune
- argocd.argoproj.io/sync-wave: "7"
-spec:
- remediationAction: enforce
- disabled: false
- policy-templates:
- - objectDefinition:
- apiVersion: policy.open-cluster-management.io/v1
- kind: ConfigurationPolicy
- metadata:
- name: quay-pull-secret-configpolicy
- annotations:
- apps.open-cluster-management.io/deployables: "secret"
- spec:
- remediationAction: enforce
- severity: medium
- namespaceSelector:
- include:
- - default
- - openshift-operators
- - devsecops-ci
- object-templates:
- - complianceType: mustonlyhave
- objectDefinition:
- kind: Secret
- type: Opaque
- metadata:
- name: quay-pull-secret
- namespace: devsecops-ci # consider changing this to devsecops-ci
- apiVersion: v1
- data:
- .dockerconfigjson: '{{hub fromSecret "devsecops-ci" "quay-pull-secret" ".dockerconfigjson" hub}}'
----
-# Source: quay/templates/quayRegistry/registry.yaml
-apiVersion: quay.redhat.com/v1
-kind: QuayRegistry
-metadata:
- name: quay-registry
- namespace: quay-enterprise
- annotations:
- argocd.argoproj.io/sync-wave: "4"
-spec:
- components:
- - kind: clair
- managed: true
- - kind: horizontalpodautoscaler
- managed: true
- - kind: mirror
- managed: true
- - kind: monitoring
- managed: true
- - kind: postgres
- managed: true
- - kind: redis
- managed: true
- - kind: objectstorage
- managed: true
- - kind: route
- managed: true
- - kind: tls
- managed: true
- - kind: quay
- managed: true
- - kind: clairpostgres
- managed: true
- configBundleSecret: quay-init-config-bundle-secret
diff --git a/tests/region-acs-industrial-edge-factory.expected.yaml b/tests/region-acs-industrial-edge-factory.expected.yaml
deleted file mode 100644
index bf5bae7c..00000000
--- a/tests/region-acs-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,78 +0,0 @@
----
-# Source: quay/templates/rbac/sa-quay-bridge.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: acs-integration-sa
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/stackrox-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: roxsecrets
- namespace: devsecops-ci
-stringData:
- rox_central_endpoint: central-stackrox.apps.hub.example.com:443
----
-# Source: quay/templates/rbac/role-acs-integration.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: acs-integration-role
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
----
-# Source: quay/templates/rbac/rolebinding-acs-integration.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: acs-integration-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: acs-integration-role
-subjects:
- - kind: ServiceAccount
- name: acs-integration-sa
- namespace: stackrox
----
-# Source: quay/templates/job-copy-acs-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: copy-acs-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- # copy acs-api-token secret into pipeline namespace
- oc get secret acs-api-token --namespace=stackrox -oyaml | grep -v '\s*namespace:\s' |oc apply --namespace=devsecops-ci -f -
- name: copy-acs-token
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: acs-integration-sa
- terminationGracePeriodSeconds: 60
diff --git a/tests/region-acs-industrial-edge-hub.expected.yaml b/tests/region-acs-industrial-edge-hub.expected.yaml
deleted file mode 100644
index bf5bae7c..00000000
--- a/tests/region-acs-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,78 +0,0 @@
----
-# Source: quay/templates/rbac/sa-quay-bridge.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: acs-integration-sa
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/stackrox-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: roxsecrets
- namespace: devsecops-ci
-stringData:
- rox_central_endpoint: central-stackrox.apps.hub.example.com:443
----
-# Source: quay/templates/rbac/role-acs-integration.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: acs-integration-role
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
----
-# Source: quay/templates/rbac/rolebinding-acs-integration.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: acs-integration-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: acs-integration-role
-subjects:
- - kind: ServiceAccount
- name: acs-integration-sa
- namespace: stackrox
----
-# Source: quay/templates/job-copy-acs-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: copy-acs-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- # copy acs-api-token secret into pipeline namespace
- oc get secret acs-api-token --namespace=stackrox -oyaml | grep -v '\s*namespace:\s' |oc apply --namespace=devsecops-ci -f -
- name: copy-acs-token
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: acs-integration-sa
- terminationGracePeriodSeconds: 60
diff --git a/tests/region-acs-medical-diagnosis-hub.expected.yaml b/tests/region-acs-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index bf5bae7c..00000000
--- a/tests/region-acs-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,78 +0,0 @@
----
-# Source: quay/templates/rbac/sa-quay-bridge.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: acs-integration-sa
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/stackrox-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: roxsecrets
- namespace: devsecops-ci
-stringData:
- rox_central_endpoint: central-stackrox.apps.hub.example.com:443
----
-# Source: quay/templates/rbac/role-acs-integration.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: acs-integration-role
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
----
-# Source: quay/templates/rbac/rolebinding-acs-integration.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: acs-integration-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: acs-integration-role
-subjects:
- - kind: ServiceAccount
- name: acs-integration-sa
- namespace: stackrox
----
-# Source: quay/templates/job-copy-acs-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: copy-acs-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- # copy acs-api-token secret into pipeline namespace
- oc get secret acs-api-token --namespace=stackrox -oyaml | grep -v '\s*namespace:\s' |oc apply --namespace=devsecops-ci -f -
- name: copy-acs-token
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: acs-integration-sa
- terminationGracePeriodSeconds: 60
diff --git a/tests/region-acs-naked.expected.yaml b/tests/region-acs-naked.expected.yaml
deleted file mode 100644
index bb181a1a..00000000
--- a/tests/region-acs-naked.expected.yaml
+++ /dev/null
@@ -1,78 +0,0 @@
----
-# Source: quay/templates/rbac/sa-quay-bridge.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: acs-integration-sa
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/stackrox-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: roxsecrets
- namespace: devsecops-ci
-stringData:
- rox_central_endpoint: central-stackrox.AUTOMATIC:443
----
-# Source: quay/templates/rbac/role-acs-integration.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: acs-integration-role
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
----
-# Source: quay/templates/rbac/rolebinding-acs-integration.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: acs-integration-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: acs-integration-role
-subjects:
- - kind: ServiceAccount
- name: acs-integration-sa
- namespace: stackrox
----
-# Source: quay/templates/job-copy-acs-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: copy-acs-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- # copy acs-api-token secret into pipeline namespace
- oc get secret acs-api-token --namespace=stackrox -oyaml | grep -v '\s*namespace:\s' |oc apply --namespace=devsecops-ci -f -
- name: copy-acs-token
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: acs-integration-sa
- terminationGracePeriodSeconds: 60
diff --git a/tests/region-acs-normal.expected.yaml b/tests/region-acs-normal.expected.yaml
deleted file mode 100644
index bf5bae7c..00000000
--- a/tests/region-acs-normal.expected.yaml
+++ /dev/null
@@ -1,78 +0,0 @@
----
-# Source: quay/templates/rbac/sa-quay-bridge.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: acs-integration-sa
- namespace: stackrox
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/stackrox-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: roxsecrets
- namespace: devsecops-ci
-stringData:
- rox_central_endpoint: central-stackrox.apps.hub.example.com:443
----
-# Source: quay/templates/rbac/role-acs-integration.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: acs-integration-role
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
----
-# Source: quay/templates/rbac/rolebinding-acs-integration.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: acs-integration-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: acs-integration-role
-subjects:
- - kind: ServiceAccount
- name: acs-integration-sa
- namespace: stackrox
----
-# Source: quay/templates/job-copy-acs-token.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: Sync
- argocd.argoproj.io/sync-wave: "6"
- name: copy-acs-token
- namespace: stackrox
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cli:latest
- command:
- - /bin/bash
- - -c
- - |
- # copy acs-api-token secret into pipeline namespace
- oc get secret acs-api-token --namespace=stackrox -oyaml | grep -v '\s*namespace:\s' |oc apply --namespace=devsecops-ci -f -
- name: copy-acs-token
- dnsPolicy: ClusterFirst
- activeDeadlineSeconds: 900
- restartPolicy: Never
- serviceAccountName: acs-integration-sa
- terminationGracePeriodSeconds: 60
diff --git a/tests/region-cosign-industrial-edge-factory.expected.yaml b/tests/region-cosign-industrial-edge-factory.expected.yaml
deleted file mode 100644
index b58f8712..00000000
--- a/tests/region-cosign-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,149 +0,0 @@
----
-# Source: cosign/templates/rbac/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: cosign-sa
- namespace: openshift-pipelines
- annotations: {}
----
-# Source: cosign/templates/cosign-cm-script.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: create-cosign-pubkey
- namespace: openshift-pipelines
-data:
- cosign.sh: |
- #!/bin/bash
- # check for signing-secrets in openshift-pipelines
- SECRET=$(oc get secret signing-secrets -n openshift-pipelines)
- if [[ $? -ne 0 ]]
- then
- export COSIGN_PASSWORD=$(openssl rand -base64 32)
- cosign generate-key-pair k8s://openshift-pipelines/signing-secrets --output-file /tmp/cosign.pub
- oc create secret generic cosign-pubkey --from-file=/tmp/cosign.pub
- else
- echo "the signing-secrets secret exists in openshift-pipelines"
- fi
----
-# Source: cosign/templates/rbac/role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: cosign-mgmt
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/hook: PreSync
- argocd.argoproj.io/sync-wave: "-15"
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - list
- - patch
- - create
- - update
- - delete
----
-# Source: cosign/templates/rbac/rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: cosign-mgmt
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/hook: PreSync
- argocd.argoproj.io/sync-wave: "-15"
-subjects:
-- kind: ServiceAccount
- name: cosign-sa
- namespace: openshift-pipelines
- apiGroup: ""
-roleRef:
- kind: Role
- name: cosign-mgmt
- apiGroup: rbac.authorization.k8s.io
----
-# Source: cosign/templates/cosign_pubkey-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: PostSync
- name: create-cosign-pubkey
- namespace: openshift-pipelines
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cosign:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/cosign.sh'
- name: create-cosign-pubkey
- volumeMounts:
- - mountPath: /tmp/cosign.sh
- name: cosign
- subPath: cosign.sh
- volumes:
- - name: cosign
- configMap:
- name: create-cosign-pubkey
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: cosign-sa
- serviceAccountName: cosign-sa
- terminationGracePeriodSeconds: 60
----
-# Source: cosign/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: cosign
- namespace: openshift
- labels:
- app: cosign
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/cosign
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: cosign:latest
- triggers:
- - type: ImageChange
----
-# Source: cosign/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: cosign
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-cosign-industrial-edge-hub.expected.yaml b/tests/region-cosign-industrial-edge-hub.expected.yaml
deleted file mode 100644
index b58f8712..00000000
--- a/tests/region-cosign-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,149 +0,0 @@
----
-# Source: cosign/templates/rbac/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: cosign-sa
- namespace: openshift-pipelines
- annotations: {}
----
-# Source: cosign/templates/cosign-cm-script.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: create-cosign-pubkey
- namespace: openshift-pipelines
-data:
- cosign.sh: |
- #!/bin/bash
- # check for signing-secrets in openshift-pipelines
- SECRET=$(oc get secret signing-secrets -n openshift-pipelines)
- if [[ $? -ne 0 ]]
- then
- export COSIGN_PASSWORD=$(openssl rand -base64 32)
- cosign generate-key-pair k8s://openshift-pipelines/signing-secrets --output-file /tmp/cosign.pub
- oc create secret generic cosign-pubkey --from-file=/tmp/cosign.pub
- else
- echo "the signing-secrets secret exists in openshift-pipelines"
- fi
----
-# Source: cosign/templates/rbac/role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: cosign-mgmt
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/hook: PreSync
- argocd.argoproj.io/sync-wave: "-15"
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - list
- - patch
- - create
- - update
- - delete
----
-# Source: cosign/templates/rbac/rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: cosign-mgmt
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/hook: PreSync
- argocd.argoproj.io/sync-wave: "-15"
-subjects:
-- kind: ServiceAccount
- name: cosign-sa
- namespace: openshift-pipelines
- apiGroup: ""
-roleRef:
- kind: Role
- name: cosign-mgmt
- apiGroup: rbac.authorization.k8s.io
----
-# Source: cosign/templates/cosign_pubkey-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: PostSync
- name: create-cosign-pubkey
- namespace: openshift-pipelines
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cosign:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/cosign.sh'
- name: create-cosign-pubkey
- volumeMounts:
- - mountPath: /tmp/cosign.sh
- name: cosign
- subPath: cosign.sh
- volumes:
- - name: cosign
- configMap:
- name: create-cosign-pubkey
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: cosign-sa
- serviceAccountName: cosign-sa
- terminationGracePeriodSeconds: 60
----
-# Source: cosign/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: cosign
- namespace: openshift
- labels:
- app: cosign
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/cosign
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: cosign:latest
- triggers:
- - type: ImageChange
----
-# Source: cosign/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: cosign
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-cosign-medical-diagnosis-hub.expected.yaml b/tests/region-cosign-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index b58f8712..00000000
--- a/tests/region-cosign-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,149 +0,0 @@
----
-# Source: cosign/templates/rbac/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: cosign-sa
- namespace: openshift-pipelines
- annotations: {}
----
-# Source: cosign/templates/cosign-cm-script.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: create-cosign-pubkey
- namespace: openshift-pipelines
-data:
- cosign.sh: |
- #!/bin/bash
- # check for signing-secrets in openshift-pipelines
- SECRET=$(oc get secret signing-secrets -n openshift-pipelines)
- if [[ $? -ne 0 ]]
- then
- export COSIGN_PASSWORD=$(openssl rand -base64 32)
- cosign generate-key-pair k8s://openshift-pipelines/signing-secrets --output-file /tmp/cosign.pub
- oc create secret generic cosign-pubkey --from-file=/tmp/cosign.pub
- else
- echo "the signing-secrets secret exists in openshift-pipelines"
- fi
----
-# Source: cosign/templates/rbac/role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: cosign-mgmt
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/hook: PreSync
- argocd.argoproj.io/sync-wave: "-15"
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - list
- - patch
- - create
- - update
- - delete
----
-# Source: cosign/templates/rbac/rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: cosign-mgmt
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/hook: PreSync
- argocd.argoproj.io/sync-wave: "-15"
-subjects:
-- kind: ServiceAccount
- name: cosign-sa
- namespace: openshift-pipelines
- apiGroup: ""
-roleRef:
- kind: Role
- name: cosign-mgmt
- apiGroup: rbac.authorization.k8s.io
----
-# Source: cosign/templates/cosign_pubkey-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: PostSync
- name: create-cosign-pubkey
- namespace: openshift-pipelines
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cosign:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/cosign.sh'
- name: create-cosign-pubkey
- volumeMounts:
- - mountPath: /tmp/cosign.sh
- name: cosign
- subPath: cosign.sh
- volumes:
- - name: cosign
- configMap:
- name: create-cosign-pubkey
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: cosign-sa
- serviceAccountName: cosign-sa
- terminationGracePeriodSeconds: 60
----
-# Source: cosign/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: cosign
- namespace: openshift
- labels:
- app: cosign
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/cosign
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: cosign:latest
- triggers:
- - type: ImageChange
----
-# Source: cosign/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: cosign
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-cosign-naked.expected.yaml b/tests/region-cosign-naked.expected.yaml
deleted file mode 100644
index b58f8712..00000000
--- a/tests/region-cosign-naked.expected.yaml
+++ /dev/null
@@ -1,149 +0,0 @@
----
-# Source: cosign/templates/rbac/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: cosign-sa
- namespace: openshift-pipelines
- annotations: {}
----
-# Source: cosign/templates/cosign-cm-script.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: create-cosign-pubkey
- namespace: openshift-pipelines
-data:
- cosign.sh: |
- #!/bin/bash
- # check for signing-secrets in openshift-pipelines
- SECRET=$(oc get secret signing-secrets -n openshift-pipelines)
- if [[ $? -ne 0 ]]
- then
- export COSIGN_PASSWORD=$(openssl rand -base64 32)
- cosign generate-key-pair k8s://openshift-pipelines/signing-secrets --output-file /tmp/cosign.pub
- oc create secret generic cosign-pubkey --from-file=/tmp/cosign.pub
- else
- echo "the signing-secrets secret exists in openshift-pipelines"
- fi
----
-# Source: cosign/templates/rbac/role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: cosign-mgmt
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/hook: PreSync
- argocd.argoproj.io/sync-wave: "-15"
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - list
- - patch
- - create
- - update
- - delete
----
-# Source: cosign/templates/rbac/rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: cosign-mgmt
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/hook: PreSync
- argocd.argoproj.io/sync-wave: "-15"
-subjects:
-- kind: ServiceAccount
- name: cosign-sa
- namespace: openshift-pipelines
- apiGroup: ""
-roleRef:
- kind: Role
- name: cosign-mgmt
- apiGroup: rbac.authorization.k8s.io
----
-# Source: cosign/templates/cosign_pubkey-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: PostSync
- name: create-cosign-pubkey
- namespace: openshift-pipelines
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cosign:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/cosign.sh'
- name: create-cosign-pubkey
- volumeMounts:
- - mountPath: /tmp/cosign.sh
- name: cosign
- subPath: cosign.sh
- volumes:
- - name: cosign
- configMap:
- name: create-cosign-pubkey
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: cosign-sa
- serviceAccountName: cosign-sa
- terminationGracePeriodSeconds: 60
----
-# Source: cosign/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: cosign
- namespace: openshift
- labels:
- app: cosign
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/cosign
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: cosign:latest
- triggers:
- - type: ImageChange
----
-# Source: cosign/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: cosign
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-cosign-normal.expected.yaml b/tests/region-cosign-normal.expected.yaml
deleted file mode 100644
index b58f8712..00000000
--- a/tests/region-cosign-normal.expected.yaml
+++ /dev/null
@@ -1,149 +0,0 @@
----
-# Source: cosign/templates/rbac/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: cosign-sa
- namespace: openshift-pipelines
- annotations: {}
----
-# Source: cosign/templates/cosign-cm-script.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: create-cosign-pubkey
- namespace: openshift-pipelines
-data:
- cosign.sh: |
- #!/bin/bash
- # check for signing-secrets in openshift-pipelines
- SECRET=$(oc get secret signing-secrets -n openshift-pipelines)
- if [[ $? -ne 0 ]]
- then
- export COSIGN_PASSWORD=$(openssl rand -base64 32)
- cosign generate-key-pair k8s://openshift-pipelines/signing-secrets --output-file /tmp/cosign.pub
- oc create secret generic cosign-pubkey --from-file=/tmp/cosign.pub
- else
- echo "the signing-secrets secret exists in openshift-pipelines"
- fi
----
-# Source: cosign/templates/rbac/role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: cosign-mgmt
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/hook: PreSync
- argocd.argoproj.io/sync-wave: "-15"
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - list
- - patch
- - create
- - update
- - delete
----
-# Source: cosign/templates/rbac/rolebinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: RoleBinding
-metadata:
- name: cosign-mgmt
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/hook: PreSync
- argocd.argoproj.io/sync-wave: "-15"
-subjects:
-- kind: ServiceAccount
- name: cosign-sa
- namespace: openshift-pipelines
- apiGroup: ""
-roleRef:
- kind: Role
- name: cosign-mgmt
- apiGroup: rbac.authorization.k8s.io
----
-# Source: cosign/templates/cosign_pubkey-job.yaml
-apiVersion: batch/v1
-kind: Job
-metadata:
- annotations:
- argocd.argoproj.io/hook: PostSync
- name: create-cosign-pubkey
- namespace: openshift-pipelines
-spec:
- template:
- spec:
- containers:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/cosign:latest
- command:
- - /bin/bash
- - -c
- - |
- '/tmp/cosign.sh'
- name: create-cosign-pubkey
- volumeMounts:
- - mountPath: /tmp/cosign.sh
- name: cosign
- subPath: cosign.sh
- volumes:
- - name: cosign
- configMap:
- name: create-cosign-pubkey
- defaultMode: 0755
- dnsPolicy: ClusterFirst
- restartPolicy: Never
- serviceAccount: cosign-sa
- serviceAccountName: cosign-sa
- terminationGracePeriodSeconds: 60
----
-# Source: cosign/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: cosign
- namespace: openshift
- labels:
- app: cosign
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/cosign
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: cosign:latest
- triggers:
- - type: ImageChange
----
-# Source: cosign/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: cosign
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-nexus-industrial-edge-factory.expected.yaml b/tests/region-nexus-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 87876078..00000000
--- a/tests/region-nexus-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,126 +0,0 @@
----
-# Source: nexus/templates/deployment.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus-pv
- namespace: devsecops-ci
-spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 25Gi
----
-# Source: nexus/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus
- namespace: devsecops-ci
-spec:
- ports:
- - name: 8081-tcp
- port: 8081
- protocol: TCP
- targetPort: 8081
- selector:
- app: nexus
- sessionAffinity: None
- type: ClusterIP
----
-# Source: nexus/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: nexus
- namespace: devsecops-ci
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: nexus
- template:
- metadata:
- labels:
- app: nexus
- spec:
- containers:
- - name: nexus
- image: quay.io/hybridcloudpatterns/nexus3:3.16.2
- env:
- - name: CONTEXT_PATH
- value: /
- imagePullPolicy: IfNotPresent
- ports:
- - containerPort: 8081
- protocol: TCP
- livenessProbe:
- exec:
- command:
- - echo
- - ok
- failureThreshold: 3
- initialDelaySeconds: 30
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8081
- scheme: HTTP
- initialDelaySeconds: 30
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- resources:
- limits:
- memory: 4Gi
- cpu: 2
- requests:
- memory: 512Mi
- cpu: 200m
- terminationMessagePath: /dev/termination-log
- volumeMounts:
- - mountPath: /nexus-data
- name: nexus-data
- volumes:
- - name: nexus-data
- persistentVolumeClaim:
- claimName: nexus-pv
----
-# Source: nexus/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 8081-tcp
- to:
- kind: Service
- name: nexus
- weight: 100
diff --git a/tests/region-nexus-industrial-edge-hub.expected.yaml b/tests/region-nexus-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 87876078..00000000
--- a/tests/region-nexus-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,126 +0,0 @@
----
-# Source: nexus/templates/deployment.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus-pv
- namespace: devsecops-ci
-spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 25Gi
----
-# Source: nexus/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus
- namespace: devsecops-ci
-spec:
- ports:
- - name: 8081-tcp
- port: 8081
- protocol: TCP
- targetPort: 8081
- selector:
- app: nexus
- sessionAffinity: None
- type: ClusterIP
----
-# Source: nexus/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: nexus
- namespace: devsecops-ci
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: nexus
- template:
- metadata:
- labels:
- app: nexus
- spec:
- containers:
- - name: nexus
- image: quay.io/hybridcloudpatterns/nexus3:3.16.2
- env:
- - name: CONTEXT_PATH
- value: /
- imagePullPolicy: IfNotPresent
- ports:
- - containerPort: 8081
- protocol: TCP
- livenessProbe:
- exec:
- command:
- - echo
- - ok
- failureThreshold: 3
- initialDelaySeconds: 30
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8081
- scheme: HTTP
- initialDelaySeconds: 30
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- resources:
- limits:
- memory: 4Gi
- cpu: 2
- requests:
- memory: 512Mi
- cpu: 200m
- terminationMessagePath: /dev/termination-log
- volumeMounts:
- - mountPath: /nexus-data
- name: nexus-data
- volumes:
- - name: nexus-data
- persistentVolumeClaim:
- claimName: nexus-pv
----
-# Source: nexus/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 8081-tcp
- to:
- kind: Service
- name: nexus
- weight: 100
diff --git a/tests/region-nexus-medical-diagnosis-hub.expected.yaml b/tests/region-nexus-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 87876078..00000000
--- a/tests/region-nexus-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,126 +0,0 @@
----
-# Source: nexus/templates/deployment.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus-pv
- namespace: devsecops-ci
-spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 25Gi
----
-# Source: nexus/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus
- namespace: devsecops-ci
-spec:
- ports:
- - name: 8081-tcp
- port: 8081
- protocol: TCP
- targetPort: 8081
- selector:
- app: nexus
- sessionAffinity: None
- type: ClusterIP
----
-# Source: nexus/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: nexus
- namespace: devsecops-ci
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: nexus
- template:
- metadata:
- labels:
- app: nexus
- spec:
- containers:
- - name: nexus
- image: quay.io/hybridcloudpatterns/nexus3:3.16.2
- env:
- - name: CONTEXT_PATH
- value: /
- imagePullPolicy: IfNotPresent
- ports:
- - containerPort: 8081
- protocol: TCP
- livenessProbe:
- exec:
- command:
- - echo
- - ok
- failureThreshold: 3
- initialDelaySeconds: 30
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8081
- scheme: HTTP
- initialDelaySeconds: 30
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- resources:
- limits:
- memory: 4Gi
- cpu: 2
- requests:
- memory: 512Mi
- cpu: 200m
- terminationMessagePath: /dev/termination-log
- volumeMounts:
- - mountPath: /nexus-data
- name: nexus-data
- volumes:
- - name: nexus-data
- persistentVolumeClaim:
- claimName: nexus-pv
----
-# Source: nexus/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 8081-tcp
- to:
- kind: Service
- name: nexus
- weight: 100
diff --git a/tests/region-nexus-naked.expected.yaml b/tests/region-nexus-naked.expected.yaml
deleted file mode 100644
index 87876078..00000000
--- a/tests/region-nexus-naked.expected.yaml
+++ /dev/null
@@ -1,126 +0,0 @@
----
-# Source: nexus/templates/deployment.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus-pv
- namespace: devsecops-ci
-spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 25Gi
----
-# Source: nexus/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus
- namespace: devsecops-ci
-spec:
- ports:
- - name: 8081-tcp
- port: 8081
- protocol: TCP
- targetPort: 8081
- selector:
- app: nexus
- sessionAffinity: None
- type: ClusterIP
----
-# Source: nexus/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: nexus
- namespace: devsecops-ci
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: nexus
- template:
- metadata:
- labels:
- app: nexus
- spec:
- containers:
- - name: nexus
- image: quay.io/hybridcloudpatterns/nexus3:3.16.2
- env:
- - name: CONTEXT_PATH
- value: /
- imagePullPolicy: IfNotPresent
- ports:
- - containerPort: 8081
- protocol: TCP
- livenessProbe:
- exec:
- command:
- - echo
- - ok
- failureThreshold: 3
- initialDelaySeconds: 30
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8081
- scheme: HTTP
- initialDelaySeconds: 30
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- resources:
- limits:
- memory: 4Gi
- cpu: 2
- requests:
- memory: 512Mi
- cpu: 200m
- terminationMessagePath: /dev/termination-log
- volumeMounts:
- - mountPath: /nexus-data
- name: nexus-data
- volumes:
- - name: nexus-data
- persistentVolumeClaim:
- claimName: nexus-pv
----
-# Source: nexus/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 8081-tcp
- to:
- kind: Service
- name: nexus
- weight: 100
diff --git a/tests/region-nexus-normal.expected.yaml b/tests/region-nexus-normal.expected.yaml
deleted file mode 100644
index 87876078..00000000
--- a/tests/region-nexus-normal.expected.yaml
+++ /dev/null
@@ -1,126 +0,0 @@
----
-# Source: nexus/templates/deployment.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus-pv
- namespace: devsecops-ci
-spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 25Gi
----
-# Source: nexus/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus
- namespace: devsecops-ci
-spec:
- ports:
- - name: 8081-tcp
- port: 8081
- protocol: TCP
- targetPort: 8081
- selector:
- app: nexus
- sessionAffinity: None
- type: ClusterIP
----
-# Source: nexus/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: nexus
- namespace: devsecops-ci
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: nexus
- template:
- metadata:
- labels:
- app: nexus
- spec:
- containers:
- - name: nexus
- image: quay.io/hybridcloudpatterns/nexus3:3.16.2
- env:
- - name: CONTEXT_PATH
- value: /
- imagePullPolicy: IfNotPresent
- ports:
- - containerPort: 8081
- protocol: TCP
- livenessProbe:
- exec:
- command:
- - echo
- - ok
- failureThreshold: 3
- initialDelaySeconds: 30
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8081
- scheme: HTTP
- initialDelaySeconds: 30
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- resources:
- limits:
- memory: 4Gi
- cpu: 2
- requests:
- memory: 512Mi
- cpu: 200m
- terminationMessagePath: /dev/termination-log
- volumeMounts:
- - mountPath: /nexus-data
- name: nexus-data
- volumes:
- - name: nexus-data
- persistentVolumeClaim:
- claimName: nexus-pv
----
-# Source: nexus/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: nexus
- app.kubernetes.io/instance: nexus
- app.kubernetes.io/name: nexus
- app.kubernetes.io/part-of: nexus
- name: nexus
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 8081-tcp
- to:
- kind: Service
- name: nexus
- weight: 100
diff --git a/tests/region-pipelines-industrial-edge-factory.expected.yaml b/tests/region-pipelines-industrial-edge-factory.expected.yaml
deleted file mode 100644
index c5fab07f..00000000
--- a/tests/region-pipelines-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,2472 +0,0 @@
----
-# Source: pipelines/templates/app-pipeline/rbac/pipeline-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-imagePullSecrets:
-- name: image-registry-credentials
-metadata:
- name: pipeline
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/syncOptions: ServerSideApply=true
-secrets:
- - name: acs-api-token
- - name: git-secret
- - name: quay-pull-secret
----
-# Source: pipelines/templates/app-pipeline/rbac/registry-credential-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-imagePullSecrets:
-- name: image-registry-credentials
-metadata:
- name: pipeline-svc
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-secrets:
- - name: quay-api-token
- - name: acs-api-token
- - name: quay-pull-secret
----
-# Source: pipelines/templates/app-pipeline/configmaps/argocd-en-cm.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: argocd-env-configmap
- namespace: devsecops-ci
-data:
- ARGOCD_SERVER: development-gitops-server.mypattern-development.svc:443
----
-# Source: pipelines/templates/app-pipeline/configmaps/maven-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: maven-settings
-data:
- settings.xml: |
-
-
-
-
- nexus
- admin
- admin123
-
-
-
-
- nexus
- nexus
- http://nexus:8081/repository/maven-public/
- *
-
-
-
----
-# Source: pipelines/templates/chains/tekton-chains-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: chains-config
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-options: ServerSideApply=true
-data:
- artifacts.oci.storage: 'oci'
- artifacts.taskrun.format: tekton
- artifacts.taskrun.storage: tekton
- artifacts.oci.format: simplesigning
- artifacts.oci.signer: cosign
----
-# Source: pipelines/templates/environment.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: environment
-data:
- DESCRIPTION: "Config keys for openshift-pipelines"
----
-# Source: pipelines/templates/app-pipeline/storageclass/vp-storageClass.yaml
-apiVersion: storage.k8s.io/v1
-kind: StorageClass
-allowVolumeExpansion: true
-metadata:
- name: default-rwo-vp
-parameters:
- encrypted: "true"
- type: default-rwo
-provisioner:
-reclaimPolicy: Delete
-volumeBindingMode: Immediate
----
-# Source: pipelines/templates/app-pipeline/pvcs/pipeline-pvc.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- name: pipeline-pvc
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- resources:
- requests:
- storage: 5Gi
- storageClassName: gp3-csi
- volumeMode: Filesystem
- accessModes:
- - ReadWriteOnce
----
-# Source: pipelines/templates/app-pipeline/rbac/imagestream-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: imagestream-view
-rules:
-- apiGroups:
- - image.openshift.io
- resources:
- - imagestreams
- verbs:
- - get
-- apiGroups:
- - image.openshift.io
- resources:
- - imagestreamimports
- verbs:
- - create
----
-# Source: pipelines/templates/app-pipeline/tasks/task-crda-scan.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: crda-scan
-spec:
- params:
- - default: pom.xml
- description: the path and manifest that should be scanned
- name: manifest
- type: string
- - default: spring-petclinic
- description: application folder name
- name: application_folder
- type: string
- steps:
- - image: quay.io/jchraibi/crda-image:0.1
- name: crda-code-scan
- resources: {}
- script: >
- #!/usr/bin/env bash
-
- set +x
-
- export NO_COLOR="True"
-
- echo "---" echo "Installing tar"
-
- chmod +x /crda > /dev/null
-
- echo "## Scanning application manifest $(params.manifest)"
-
- /crda config set consent_telemetry false
-
- /crda auth -t b6eb51e7-af6c-4bdb-b006-3005711316ca
-
- /crda analyse
- $(workspaces.source.path)/$(params.application_folder)/$(params.manifest)
-
- echo "## Scan finished ##"
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-image-scan-task.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-image-scan
-spec:
- params:
- - name: rox_central_endpoint
- type: string
- description: the address:port tuple for StackRox Central (example - rox.stackrox.io:443)
- default: 'central-stackrox.apps.hub.example.com:443'
- - name: rox_api_token
- type: string
- description: Secret containing the StackRox API token with CI permissions
- default: acs-api-token
- - name: image
- type: string
- description: Full name of image to scan (example -- gcr.io/rox/sample:5.0-rc1)
- - name: output_format
- type: string
- description: Output format (json | csv | table)
- default: json
- - name: image_digest
- description: Digest in sha256 hash format of the image to scan
- type: string
- steps:
- - name: rox-image-scan
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- name: $(params.rox_api_token)
- key: token
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- script: |
- #!/usr/bin/env bash
- set +x
- export NO_COLOR="True"
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN" https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output ./roxctl > /dev/null; echo "Getting roxctl"
- chmod +x ./roxctl > /dev/null
- echo "## Scanning image $(params.image)@$(params.image_digest)"
- ./roxctl image scan --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT --image $(params.image)@$(params.image_digest) --output $(params.output_format)
- echo "## Go to https://$ROX_CENTRAL_ENDPOINT/main/vulnerability-management/image/$(params.image_digest) to check more info"
----
-# Source: pipelines/templates/app-pipeline/tasks/task-rox-deployment-check.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-deployment-check
-spec:
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: rox_central_endpoint
- type: string
- description: Secret containing the address:port tuple for StackRox Central (example - rox.stackrox.io:443)
- default: 'central-stackrox.apps.hub.example.com:443'
- - name: rox_api_token
- type: string
- default: acs-api-token
- description: Secret containing the StackRox API token with CI permissions
- - name: file
- type: string
- description: YAML file in the deployfiles workspace
- - name: deployment_files_path
- type: string
- description: Path/Folder for the k8s deployment files to check
- results:
- - name: check_output
- description: Output of `roxctl deployment check`
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
- steps:
-
- - name: git-clone
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- rm -rf git-update-digest-workdir
- git clone $(params.GIT_REPOSITORY) git-update-digest-workdir
- cd git-update-digest-workdir/$(params.deployment_files_path)
-
- - name: rox-deployment-check
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- workingDir: $(workspaces.workspace.path)
- env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- name: $(params.rox_api_token)
- key: token
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- script: |
- #!/usr/bin/env bash
- set +x
- cd git-update-digest-workdir/$(params.deployment_files_path)
- cat $(params.file)
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN" https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output ./roxctl > /dev/null; echo "Getting roxctl"
- chmod +x ./roxctl > /dev/null
- ./roxctl deployment check --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT -f $(params.file)
----
-# Source: pipelines/templates/app-pipeline/tasks/task-rox-image-check.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-image-check
-spec:
- params:
- - description: >-
- Secret containing the address:port tuple for StackRox Central (example -
- rox.stackrox.io:443)
- name: rox_central_endpoint
- default: 'central-stackrox.apps.hub.example.com:443'
- type: string
- - description: Secret containing the StackRox API token with CI permissions
- name: rox_api_token
- type: string
- - description: 'Full name of image to scan (example -- gcr.io/rox/sample:5.0-rc1)'
- name: image
- type: string
- - name: image_digest
- description: Digest in sha256 hash format of the image to check
- type: string
- results:
- - description: Output of `roxctl image check`
- name: check_output
- steps:
- - env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- key: token
- name: $(params.rox_api_token)
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- name: rox-image-check
- resources: {}
- script: >-
- #!/usr/bin/env bash
-
- set +x
-
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN"
- https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output
- ./roxctl > /dev/null; echo "Getting roxctl"
-
- chmod +x ./roxctl > /dev/null
-
- ./roxctl image check --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT
- --image $(params.image)@$(params.image_digest)
----
-# Source: pipelines/templates/app-pipeline/imageStreams/imagestream-devsecops.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: spring-petclinic
- namespace: devsecops-ci
----
-# Source: pipelines/templates/app-pipeline/devsecops-rh-fixed.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: devsecops-rh-v2-fixed
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/staging
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: unit-tests
- params:
- - name: GOALS
- value:
- - package
- - -f
- - spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: code-analysis
- params:
- - name: GOALS
- value:
- - install
- - sonar:sonar
- - -f
- - spring-petclinic
- - -Dsonar.host.url=http://sonarqube:9000
- - -Dsonar.userHome=/tmp/sonar
- - -DskipTests=true
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: dependency-report
- params:
- - name: SOURCE_DIR
- value: spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: dependency-report
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - code-analysis
- - unit-tests
- - dependency-report
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11-fixed
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: gogs
- - name: GIT_PASSWORD
- value: gogs
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- #jrickard-value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: crda-scan
- params:
- - name: manifest
- value: pom.xml
- runAfter:
- - source-clone
- taskRef:
- kind: ClusterTask
- name: crda-scan
- workspaces:
- - name: source
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/devsecops-rh.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: devsecops-rh-v2
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/staging
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: unit-tests
- params:
- - name: GOALS
- value:
- - package
- - -f
- - spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: code-analysis
- params:
- - name: GOALS
- value:
- - install
- - sonar:sonar
- - -f
- - spring-petclinic
- - -Dsonar.host.url=http://sonarqube:9000
- - -Dsonar.userHome=/tmp/sonar
- - -DskipTests=true
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: dependency-report
- params:
- - name: SOURCE_DIR
- value: spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: dependency-report
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - code-analysis
- - unit-tests
- - dependency-report
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: gogs
- - name: GIT_PASSWORD
- value: gogs
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- #jrickard-value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: crda-scan
- params:
- - name: manifest
- value: pom.xml
- runAfter:
- - source-clone
- taskRef:
- kind: ClusterTask
- name: crda-scan
- workspaces:
- - name: source
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/simple-pipeline.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: simple-pipeline
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/stage
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - source-clone
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/tasks/task-create-promote-pull-request.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: create-promote-pull-request
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: GIT_USERNAME
- type: string
- - name: GIT_PASSWORD
- type: string
- - name: COPY_FROM_PATH
- type: string
- - name: COPY_TO_PATH
- type: string
- results:
- - description: The branch name used for pull-request
- name: branch_name
- steps:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- name: promote
- resources: {}
- script: >
- set -x
-
- rm -rf pull-request-workdir
-
- git clone $(params.GIT_REPOSITORY) pull-request-workdir
-
- cd pull-request-workdir
-
- git config user.email "pipelines-ci@redhat.com"
-
- git config user.name "pipelines-ci"
-
-
- branch_name=ci-$(context.taskRun.name)
-
- git checkout -b $branch_name
-
- echo -n "$branch_name" > $(results.branch_name.path)
-
-
- /bin/cp -rf $(params.COPY_FROM_PATH)/* $(params.COPY_TO_PATH)
-
-
- git status
-
- git add $(params.COPY_TO_PATH)
-
- git commit -m "[$(context.taskRun.name)] Promotion from
- $(params.COPY_FROM_PATH) to $(params.COPY_TO_PATH)"
-
-
- git remote add auth-origin $(echo $(params.GIT_REPOSITORY) | sed -E
- "s#http://(.*)#http://$(params.GIT_USERNAME):$(params.GIT_PASSWORD)@\1#g")
-
- git push -u auth-origin HEAD
- workingDir: $(workspaces.workspace.path)
- - image: quay.io/siamaksade/python-oc
- name: create-pull-request
- resources: {}
- script: >
- #!/usr/bin/env python3
-
-
- import os
-
- import requests
-
-
- gitea_user = "$(params.GIT_USERNAME)"
-
- gitea_pwd = "$(params.GIT_PASSWORD)"
-
- giteaURL = "http://gitea-AUTOMATED.apps.region.example.com"
-
-
- branch_result = open("$(results.branch_name.path)")
-
- git_branch = branch_result.read()
-
- branch_result.close()
-
-
- print("Git server: " + giteaURL)
-
- print("Branch name: " + git_branch)
-
-
- pr_title = "[$(context.taskRun.name)] Promote to STAGE environment"
-
- pr_body = "TaskRun $(context.taskRun.name)\\nPromoting application from
- DEV to STAGE environment"
-
- data_pr = '{"base": "master","body": "' + pr_body + '","head": "' +
- git_branch + '","title": "' + pr_title + '"}'
-
- headers = {'Content-Type': 'application/json'}
-
- resp = requests.post(url = giteaURL + "/api/v1/repos/" + gitea_user +
- "/spring-petclinic-config/pulls",
- headers = headers,
- auth = (gitea_user, gitea_pwd),
- data = data_pr)
-
-
- if resp.status_code != 200:
- print("Error creating pull-request (status code: {})".format(resp.status_code))
- print(resp.content)
- else:
- print("Created pull-request.")
- workingDir: $(workspaces.workspace.path)
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
----
-# Source: pipelines/templates/app-pipeline/tasks/task-dependency-report.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: dependency-report
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
-spec:
- params:
- - name: SOURCE_DIR
- description: The directory within the workspace where application source is located
- default: "."
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- - default: ''
- description: The Maven repository mirror url
- name: MAVEN_MIRROR_URL
- type: string
- - default: ''
- description: The username for the proxy server
- name: PROXY_USER
- type: string
- - default: ''
- description: The password for the proxy server
- name: PROXY_PASSWORD
- type: string
- - default: ''
- description: Port number for the proxy server
- name: PROXY_PORT
- type: string
- - default: ''
- description: Proxy server Host
- name: PROXY_HOST
- type: string
- - default: ''
- description: Non proxy server host
- name: PROXY_NON_PROXY_HOSTS
- type: string
- - default: http
- description: Protocol for the proxy ie http or https
- name: PROXY_PROTOCOL
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
- - description: The workspace consisting of the custom maven settings provided by the user.
- name: maven-settings
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi-minimal:latest'
- name: mvn-settings
- resources: {}
- script: >
- #!/usr/bin/env bash
-
-
- [[ -f $(workspaces.maven-settings.path)/settings.xml ]] && \
-
- echo 'using existing $(workspaces.maven-settings.path)/settings.xml' &&
- exit 0
-
-
- cat > $(workspaces.maven-settings.path)/settings.xml <
-
-
-
-
-
-
-
-
-
-
- EOF
-
-
- xml=""
-
- if [ -n "$(params.PROXY_HOST)" -a -n "$(params.PROXY_PORT)" ]; then
- xml="\
- genproxy\
- true\
- $(params.PROXY_PROTOCOL)\
- $(params.PROXY_HOST)\
- $(params.PROXY_PORT)"
- if [ -n "$(params.PROXY_USER)" -a -n "$(params.PROXY_PASSWORD)" ]; then
- xml="$xml\
- $(params.PROXY_USER)\
- $(params.PROXY_PASSWORD)"
- fi
- if [ -n "$(params.PROXY_NON_PROXY_HOSTS)" ]; then
- xml="$xml\
- $(params.PROXY_NON_PROXY_HOSTS)"
- fi
- xml="$xml\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
-
-
- if [ -n "$(params.MAVEN_MIRROR_URL)" ]; then
- xml=" \
- mirror.default\
- $(params.MAVEN_MIRROR_URL)\
- central\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
- - args:
- - -Dmaven.repo.local=$(workspaces.source.path)/.m2
- - -f
- - $(params.SOURCE_DIR)
- - -s
- - $(workspaces.maven-settings.path)/settings.xml
- - site
- - -DskipTests=true
- command:
- - /usr/bin/mvn
- image: gcr.io/cloud-builders/mvn
- name: mvn-goals
- resources: {}
- workingDir: $(workspaces.source.path)
- - name: archive-site
- workingDir: $(workspaces.source.path)
- image: registry.access.redhat.com/ubi8/ubi:latest
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- script: |
- #!/usr/bin/env bash
-
- for f in $(find $(params.SOURCE_DIR)/target/site -type f); do
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME/${f} -X POST -F file=@${f} $(params.REPORTS_REPO_HOST)/upload; echo ""
- done
----
-# Source: pipelines/templates/app-pipeline/tasks/task-gatling.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: gatling
-spec:
- params:
- - name: DURATION
- description: The duration of running simulations
- type: string
- default: "30"
- - name: CONCURRENT_USERS
- description: The number of concurrent users
- type: string
- default: "10"
- - name: APP_URL
- description: The application under test url
- type: string
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- workspaces:
- - description: The workspace consisting of maven project.
- name: simulations
- steps:
- - name: run-tests
- image: quay.io/hybridcloudpatterns/gatling:latest
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- script: |
- #!/usr/bin/env bash
-
- set -x
-
- cd /opt/gatling/
- ls -lhrt
-
- # set simulation params
- export JAVA_OPTS="-DtestDuration=$(params.CONCURRENT_USERS) -DuserCount=$(params.DURATION) -Dserver=$(params.APP_URL)"
-
- # run simulation
- /opt/gatling/bin/gatling.sh -rd "Spring PetClinic Performance Test" -sf $(workspaces.simulations.path)
-
- # upload results
- REPORT=$(ls -td /opt/gatling/results/* | head -1)
- for f in $(find $REPORT/ -type f); do
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME${f#/opt/gatling/results} -X POST -F file=@${f} $(params.REPORTS_REPO_HOST)/upload; echo ""
- done
----
-# Source: pipelines/templates/app-pipeline/tasks/task-git-update-deployment.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: git-update-deployment
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: GIT_USERNAME
- type: string
- - name: GIT_PASSWORD
- type: string
- - name: CURRENT_IMAGE
- type: string
- - name: NEW_IMAGE
- type: string
- - name: NEW_DIGEST
- type: string
- - name: KUSTOMIZATION_PATH
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
-
- results:
- - name: commit
- description: The commit SHA
-
- steps:
- - name: git-clone
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- rm -rf git-update-digest-workdir
- git clone $(params.GIT_REPOSITORY) git-update-digest-workdir
-
- - name: update-digest
- image: k8s.gcr.io/kustomize/kustomize:v3.8.7
- workingDir: $(workspaces.workspace.path)
- script: |
- cd git-update-digest-workdir/$(params.KUSTOMIZATION_PATH)
- /app/kustomize edit set image $(params.CURRENT_IMAGE)=$(params.NEW_IMAGE)@$(params.NEW_DIGEST)
-
- echo "##########################"
- echo "### kustomization.yaml ###"
- echo "##########################"
- cat kustomization.yaml
-
- - name: git-commit
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- cd git-update-digest-workdir
- git config user.email "tekton-pipelines-ci@redhat.com"
- git config user.name "tekton-pipelines-ci"
-
- git status
- git add $(params.KUSTOMIZATION_PATH)/kustomization.yaml
- # git commit -m "[$(context.pipelineRun.name)] Image digest updated"
- git commit -m "[ci] Image digest updated"
-
- git remote add auth-origin $(echo $(params.GIT_REPOSITORY) | sed -E "s#http://(.*)#http://$(params.GIT_USERNAME):$(params.GIT_PASSWORD)@\1#g")
- git push auth-origin main
-
- RESULT_SHA="$(git rev-parse HEAD | tr -d '\n')"
- EXIT_CODE="$?"
- if [ "$EXIT_CODE" != 0 ]
- then
- exit $EXIT_CODE
- fi
- # Make sure we don't add a trailing newline to the result!
- echo -n "$RESULT_SHA" > $(results.commit.path)
----
-# Source: pipelines/templates/app-pipeline/tasks/task-github-pull-request.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: github-open-pr
- labels:
- app.kubernetes.io/version: "0.2"
- annotations:
- tekton.dev/categories: Git
- tekton.dev/pipelines.minVersion: "0.12.1"
- tekton.dev/tags: github
- tekton.dev/displayName: "open github pull request"
- tekton.dev/platforms: "linux/amd64,linux/s390x,linux/ppc64le"
-spec:
- description: >-
- This task will open a PR on Github based on several parameters.
- This could be useful in GitOps repositories for example.
-
- params:
- - name: GITHUB_HOST_URL
- description: |
- The GitHub host, adjust this if you run a GitHub enteprise.
- default: "api.github.com"
- type: string
-
- - name: API_PATH_PREFIX
- description: |
- The API path prefix, GitHub Enterprise has a prefix e.g. /api/v3
- default: ""
- type: string
-
- - name: REPO_FULL_NAME
- description: |
- The GitHub repository full name, e.g.: tektoncd/catalog
- type: string
-
- - name: GITHUB_TOKEN_SECRET_NAME
- description: |
- The name of the kubernetes secret that contains the GitHub token, default: github
- type: string
- default: github
-
- - name: GITHUB_TOKEN_SECRET_KEY
- description: |
- The key within the kubernetes secret that contains the GitHub token, default: token
- type: string
- default: token
-
- - name: AUTH_TYPE
- description: |
- The type of authentication to use. You could use the less secure "Basic" for example
- type: string
- default: Bearer
-
- - name: HEAD
- description: |
- The name of the branch where your changes are implemented.
- type: string
-
- - name: BASE
- description: |
- The name of the branch you want the changes pulled into.
- type: string
-
- - name: BODY
- description: |
- The body description of the pull request.
- type: string
-
- - name: TITLE
- description: |
- The title of the pull request.
- type: string
-
- results:
- - name: NUMBER
- description: Number of the created pull request.
-
- - name: URL
- description: URL of the created pull request.
-
- volumes:
- - name: githubtoken
- secret:
- secretName: $(params.GITHUB_TOKEN_SECRET_NAME)
-
- steps:
- - name: open-pr
- volumeMounts:
- - name: githubtoken
- readOnly: true
- mountPath: /etc/github-open-pr
- env:
- - name: PULLREQUEST_NUMBER_PATH
- value: $(results.NUMBER.path)
- - name: PULLREQUEST_URL_PATH
- value: $(results.URL.path)
-
- image: registry.access.redhat.com/ubi8/python-38:1-34.1599745032
- script: |
- #!/usr/libexec/platform-python
-
- """This script will open a PR on Github"""
-
- import json
- import os
- import sys
- import http.client
-
- github_token = open("/etc/github-open-pr/$(params.GITHUB_TOKEN_SECRET_KEY)", "r").read()
-
- open_pr_url = "$(params.API_PATH_PREFIX)" + "/repos/$(params.REPO_FULL_NAME)/pulls"
-
- data = {
- "head": "$(params.HEAD)",
- "base": "$(params.BASE)",
- "title": "$(params.TITLE)",
- "body": """$(params.BODY)"""
- }
- print("Sending this data to GitHub: ")
- print(data)
-
- authHeader = "$(params.AUTH_TYPE) " + github_token
-
- # This is for our fake github server
- if "$(params.GITHUB_HOST_URL)".startswith("http://"):
- conn = http.client.HTTPConnection("$(params.GITHUB_HOST_URL)"
- .replace("http://", ""))
- else:
- conn = http.client.HTTPSConnection("$(params.GITHUB_HOST_URL)")
-
- conn.request(
- "POST",
- open_pr_url,
- body=json.dumps(data),
- headers={
- "User-Agent": "TektonCD, the peaceful cat",
- "Authorization": authHeader,
- "Accept": "application/vnd.github.v3+json ",
- })
- resp = conn.getresponse()
- if not str(resp.status).startswith("2"):
- print("Error: %d" % (resp.status))
- print(resp.read())
- sys.exit(1)
- else:
- # https://docs.github.com/en/rest/reference/pulls#create-a-pull-request
- body = json.loads(resp.read().decode())
-
- open(os.environ.get('PULLREQUEST_NUMBER_PATH'), 'w').write(f'{body["number"]}')
- open(os.environ.get('PULLREQUEST_URL_PATH'), 'w').write(body["html_url"])
-
- print("GitHub pull request created for $(params.REPO_FULL_NAME): "
- f'number={body["number"]} url={body["html_url"]}')
----
-# Source: pipelines/templates/app-pipeline/tasks/task-mvn.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: build-tool
- name: maven
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to run a Maven build.
- params:
- - default: gcr.io/cloud-builders/mvn:3.5.0-jdk-8
- description: Maven base image
- name: MAVEN_IMAGE
- type: string
- - default:
- - package
- description: maven goals to run
- name: GOALS
- type: array
- - default: ''
- description: The Maven repository mirror url
- name: MAVEN_MIRROR_URL
- type: string
- - default: ''
- description: The username for the proxy server
- name: PROXY_USER
- type: string
- - default: ''
- description: The password for the proxy server
- name: PROXY_PASSWORD
- type: string
- - default: ''
- description: Port number for the proxy server
- name: PROXY_PORT
- type: string
- - default: ''
- description: Proxy server Host
- name: PROXY_HOST
- type: string
- - default: ''
- description: Non proxy server host
- name: PROXY_NON_PROXY_HOSTS
- type: string
- - default: http
- description: Protocol for the proxy ie http or https
- name: PROXY_PROTOCOL
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
- - description: The workspace consisting of the custom maven settings provided by the user.
- name: maven-settings
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi-minimal:latest'
- name: mvn-settings
- resources: {}
- script: >
- #!/usr/bin/env bash
-
-
- [[ -f $(workspaces.maven-settings.path)/settings.xml ]] && \
-
- echo 'using existing $(workspaces.maven-settings.path)/settings.xml' &&
- exit 0
-
-
- cat > $(workspaces.maven-settings.path)/settings.xml <
-
-
-
-
-
-
-
-
-
-
- EOF
-
-
- xml=""
-
- if [ -n "$(params.PROXY_HOST)" -a -n "$(params.PROXY_PORT)" ]; then
- xml="\
- genproxy\
- true\
- $(params.PROXY_PROTOCOL)\
- $(params.PROXY_HOST)\
- $(params.PROXY_PORT)"
- if [ -n "$(params.PROXY_USER)" -a -n "$(params.PROXY_PASSWORD)" ]; then
- xml="$xml\
- $(params.PROXY_USER)\
- $(params.PROXY_PASSWORD)"
- fi
- if [ -n "$(params.PROXY_NON_PROXY_HOSTS)" ]; then
- xml="$xml\
- $(params.PROXY_NON_PROXY_HOSTS)"
- fi
- xml="$xml\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
-
-
- if [ -n "$(params.MAVEN_MIRROR_URL)" ]; then
- xml=" \
- mirror.default\
- $(params.MAVEN_MIRROR_URL)\
- central\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
- - args:
- - -Dmaven.repo.local=$(workspaces.source.path)/.m2
- - '-s'
- - $(workspaces.maven-settings.path)/settings.xml
- - $(params.GOALS)
- command:
- - /usr/bin/mvn
- image: $(params.MAVEN_IMAGE)
- name: mvn-goals
- workingDir: $(workspaces.source.path)
- resources:
- requests:
- memory: 512Mi
- cpu: 200m
- limits:
- memory: 4Gi
- cpu: '1'
----
-# Source: pipelines/templates/app-pipeline/tasks/task-s2i-java-11-fixed.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/displayName: s2i java 11
- tekton.dev/pipelines.minVersion: 0.11.3
- tekton.dev/tags: s2i, java, workspace
- name: s2i-java-11-fixed
-spec:
- description: s2i-java-11 task clones a Git repository and builds and pushes a container
- image using S2I and a Java 11 builder image.
- params:
- - default: .
- description: The location of the path to run s2i from
- name: PATH_CONTEXT
- type: string
- - default: "true"
- description: Verify the TLS on the registry endpoint (for push/pull to a non-TLS
- registry)
- name: TLSVERIFY
- type: string
- - default: ""
- description: Additional Maven arguments
- name: MAVEN_ARGS_APPEND
- type: string
- - default: "false"
- description: Remove the Maven repository after the artifact is built
- name: MAVEN_CLEAR_REPO
- type: string
- - default: ""
- description: The base URL of a mirror used for retrieving artifacts
- name: MAVEN_MIRROR_URL
- type: string
- - description: Location of the repo where image has to be pushed
- name: IMAGE_NAME
- type: string
- - default: latest
- description: The tag of the image to be pushed
- name: IMAGE_TAG
- type: string
- results:
- - description: Digest of the image just built.
- name: IMAGE_DIGEST
- - description: URL of the image used by Tekton Chains to push the OCI images
- name: IMAGE_URL
- steps:
- - args:
- - |-
- echo "MAVEN_CLEAR_REPO=$(params.MAVEN_CLEAR_REPO)" > env-file
-
- [[ '$(params.MAVEN_ARGS_APPEND)' != "" ]] &&
- echo "MAVEN_ARGS_APPEND=$(params.MAVEN_ARGS_APPEND)" >> env-file
-
- [[ '$(params.MAVEN_MIRROR_URL)' != "" ]] &&
- echo "MAVEN_MIRROR_URL=$(params.MAVEN_MIRROR_URL)" >> env-file
-
- echo "Generated Env file"
- echo "------------------------------"
- cat env-file
- echo "------------------------------"
- command:
- - /bin/sh
- - -c
- image: registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: gen-env-file
- resources: {}
- volumeMounts:
- - mountPath: /env-params
- name: envparams
- workingDir: /env-params
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - s2i
- - build
- - $(params.PATH_CONTEXT)
- - image-registry.openshift-image-registry.svc:5000/openshift/java:11
- - --image-scripts-url
- - image:///usr/local/s2i
- - --as-dockerfile
- - /gen-source/Dockerfile.gen
- - --environment-file
- - /env-params/env-file
- image: registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: generate
- resources: {}
- volumeMounts:
- - mountPath: /gen-source
- name: gen-source
- - mountPath: /env-params
- name: envparams
- workingDir: $(workspaces.source.path)
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - bud
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --layers
- - -f
- - /gen-source/Dockerfile.gen
- - -t
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - -t
- - $(params.IMAGE_NAME):latest
- - .
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: build
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - /bin/sh
- - -c
- args:
- - |-
- buildah from --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) '$(params.IMAGE_NAME):$(params.IMAGE_TAG)' > imgname
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c `dnf update -y`
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *dnf*) $(rpm -qa *libsolv*) $(rpm -qa *hawkey*) $(rpm -qa yum*) $(rpm -qa *dnf*) $(rpm -qa *subscription-manager*)'
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *rpm*)'
- buildah commit --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) `cat imgname` '$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: update
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - /bin/sh
- - -c
- args:
- - |-
- buildah from --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) '$(params.IMAGE_NAME):$(params.IMAGE_TAG)' > imgname
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c `dnf update -y`
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *dnf*) $(rpm -qa *libsolv*) $(rpm -qa *hawkey*) $(rpm -qa yum*) $(rpm -qa *dnf*) $(rpm -qa *subscription-manager*)'
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *rpm*)'
- buildah commit --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) `cat imgname` '$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: remove-package-mgr
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - push
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - docker://$(params.IMAGE_NAME):$(params.IMAGE_TAG)
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-tag
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - push
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - docker://$(params.IMAGE_NAME):latest
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-latest
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: digest-to-results
- resources: {}
- script: cat $(workspaces.source.path)/image-digest | tee /tekton/results/IMAGE_DIGEST; echo quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic > /tekton/results/IMAGE_URL
- volumes:
- - emptyDir: {}
- name: varlibcontainers
- - emptyDir: {}
- name: gen-source
- - emptyDir: {}
- name: envparams
- workspaces:
- - mountPath: /workspace/source
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-s2i-java-11.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: s2i-java-11
- annotations:
- tekton.dev/displayName: s2i java 11
- tekton.dev/pipelines.minVersion: 0.11.3
- tekton.dev/tags: 's2i, java, workspace'
-spec:
- description: >-
- s2i-java-11 task clones a Git repository and builds and pushes a container
- image using S2I and a Java 11 builder image.
- params:
- - default: .
- description: The location of the path to run s2i from
- name: PATH_CONTEXT
- type: string
- - default: 'true'
- description: >-
- Verify the TLS on the registry endpoint (for push/pull to a non-TLS
- registry)
- name: TLSVERIFY
- type: string
- - default: ''
- description: Additional Maven arguments
- name: MAVEN_ARGS_APPEND
- type: string
- - default: 'false'
- description: Remove the Maven repository after the artifact is built
- name: MAVEN_CLEAR_REPO
- type: string
- - default: ''
- description: The base URL of a mirror used for retrieving artifacts
- name: MAVEN_MIRROR_URL
- type: string
- - description: Location of the repo where image has to be pushed
- name: IMAGE_NAME
- type: string
- - description: The tag of the image to be pushed
- name: IMAGE_TAG
- type: string
- default: "latest"
- results:
- - name: IMAGE_DIGEST
- description: Digest of the image just built.
- steps:
- - args:
- - |-
- echo "MAVEN_CLEAR_REPO=$(params.MAVEN_CLEAR_REPO)" > env-file
-
- [[ '$(params.MAVEN_ARGS_APPEND)' != "" ]] &&
- echo "MAVEN_ARGS_APPEND=$(params.MAVEN_ARGS_APPEND)" >> env-file
-
- [[ '$(params.MAVEN_MIRROR_URL)' != "" ]] &&
- echo "MAVEN_MIRROR_URL=$(params.MAVEN_MIRROR_URL)" >> env-file
-
- echo "Generated Env file"
- echo "------------------------------"
- cat env-file
- echo "------------------------------"
- command:
- - /bin/sh
- - '-c'
- image: >-
- registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: gen-env-file
- resources: {}
- volumeMounts:
- - mountPath: /env-params
- name: envparams
- workingDir: /env-params
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - s2i
- - build
- - $(params.PATH_CONTEXT)
- - 'image-registry.openshift-image-registry.svc:5000/openshift/java:11'
- - '--image-scripts-url'
- - 'image:///usr/local/s2i'
- - '--as-dockerfile'
- - /gen-source/Dockerfile.gen
- - '--environment-file'
- - /env-params/env-file
- image: >-
- registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: generate
- resources: {}
- volumeMounts:
- - mountPath: /gen-source
- name: gen-source
- - mountPath: /env-params
- name: envparams
- workingDir: $(workspaces.source.path)
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - buildah
- - bud
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - '--layers'
- - '-f'
- - /gen-source/Dockerfile.gen
- - '-t'
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - '-t'
- - $(params.IMAGE_NAME):latest
- - .
- image: >-
- registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: build
- resources: {}
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- - command:
- - buildah
- - push
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - 'docker://$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-tag
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - buildah
- - push
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - 'docker://$(params.IMAGE_NAME):latest'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-latest
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - name: digest-to-results
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- script: cat $(workspaces.source.path)/image-digest | tee /tekton/results/IMAGE_DIGEST
- volumes:
- - emptyDir: {}
- name: varlibcontainers
- - emptyDir: {}
- name: gen-source
- - emptyDir: {}
- name: envparams
- workspaces:
- - mountPath: /workspace/source
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-syft-sbom.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: build-tool
- name: syft-sbom
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to generate a SBOM file with Syft.
- params:
- - default: $(workspaces.source.path)
- description: Application folder to scan
- name: APP_PATH
- type: string
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi:latest'
- name: syft-scan
- resources: {}
- script: >
- #!/usr/bin/env bash
-
- echo '## Getting Syft ##'
-
- pwd
-
- curl -sSfL
- https://raw.githubusercontent.com/anchore/syft/main/install.sh | sh -s
- -- -b .
-
- chmod +x ./syft
-
- echo '## Scanning folder and generating SBOM ##'
-
- ./syft $(params.APP_PATH) -o spdx-json=sbom.json
-
- echo '## SBOM content ##'
-
- cat ./sbom.json
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-zap-proxy.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: zap-proxy
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- - name: APP_URL
- description: The application under test url
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- workspaces:
- - description: The workspace for the zap proxy task
- name: workspace
-
- steps:
- - name: zap-proxy
- image: quay.io/hybridcloudpatterns/zap2docker-stable
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- workingDir: $(workspaces.workspace.path)
- script: |
- #!/usr/bin/env bash
-
- set -x
-
- echo "Make the wrk directory available to save the reports"
- cd /zap
- mkdir /zap/wrk
-
- echo "Starting the pentesting..."
- /zap/zap-baseline.py -t $(params.APP_URL) -r $PIPELINERUN_NAME.html
-
- ls -lhrt /zap/wrk
-
- echo "Uploading the report into the report server"
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME/$PIPELINERUN_NAME.html -F file=@/zap/wrk/$PIPELINERUN_NAME.html -X POST $(params.REPORTS_REPO_HOST)/upload; echo ""
----
-# Source: pipelines/templates/chains/tekton-chain.yaml
-apiVersion: operator.tekton.dev/v1alpha1
-kind: TektonChain
-metadata:
- name: chain
-spec:
- targetNamespace: openshift-pipelines
diff --git a/tests/region-pipelines-industrial-edge-hub.expected.yaml b/tests/region-pipelines-industrial-edge-hub.expected.yaml
deleted file mode 100644
index c5fab07f..00000000
--- a/tests/region-pipelines-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,2472 +0,0 @@
----
-# Source: pipelines/templates/app-pipeline/rbac/pipeline-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-imagePullSecrets:
-- name: image-registry-credentials
-metadata:
- name: pipeline
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/syncOptions: ServerSideApply=true
-secrets:
- - name: acs-api-token
- - name: git-secret
- - name: quay-pull-secret
----
-# Source: pipelines/templates/app-pipeline/rbac/registry-credential-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-imagePullSecrets:
-- name: image-registry-credentials
-metadata:
- name: pipeline-svc
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-secrets:
- - name: quay-api-token
- - name: acs-api-token
- - name: quay-pull-secret
----
-# Source: pipelines/templates/app-pipeline/configmaps/argocd-en-cm.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: argocd-env-configmap
- namespace: devsecops-ci
-data:
- ARGOCD_SERVER: development-gitops-server.mypattern-development.svc:443
----
-# Source: pipelines/templates/app-pipeline/configmaps/maven-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: maven-settings
-data:
- settings.xml: |
-
-
-
-
- nexus
- admin
- admin123
-
-
-
-
- nexus
- nexus
- http://nexus:8081/repository/maven-public/
- *
-
-
-
----
-# Source: pipelines/templates/chains/tekton-chains-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: chains-config
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-options: ServerSideApply=true
-data:
- artifacts.oci.storage: 'oci'
- artifacts.taskrun.format: tekton
- artifacts.taskrun.storage: tekton
- artifacts.oci.format: simplesigning
- artifacts.oci.signer: cosign
----
-# Source: pipelines/templates/environment.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: environment
-data:
- DESCRIPTION: "Config keys for openshift-pipelines"
----
-# Source: pipelines/templates/app-pipeline/storageclass/vp-storageClass.yaml
-apiVersion: storage.k8s.io/v1
-kind: StorageClass
-allowVolumeExpansion: true
-metadata:
- name: default-rwo-vp
-parameters:
- encrypted: "true"
- type: default-rwo
-provisioner:
-reclaimPolicy: Delete
-volumeBindingMode: Immediate
----
-# Source: pipelines/templates/app-pipeline/pvcs/pipeline-pvc.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- name: pipeline-pvc
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- resources:
- requests:
- storage: 5Gi
- storageClassName: gp3-csi
- volumeMode: Filesystem
- accessModes:
- - ReadWriteOnce
----
-# Source: pipelines/templates/app-pipeline/rbac/imagestream-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: imagestream-view
-rules:
-- apiGroups:
- - image.openshift.io
- resources:
- - imagestreams
- verbs:
- - get
-- apiGroups:
- - image.openshift.io
- resources:
- - imagestreamimports
- verbs:
- - create
----
-# Source: pipelines/templates/app-pipeline/tasks/task-crda-scan.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: crda-scan
-spec:
- params:
- - default: pom.xml
- description: the path and manifest that should be scanned
- name: manifest
- type: string
- - default: spring-petclinic
- description: application folder name
- name: application_folder
- type: string
- steps:
- - image: quay.io/jchraibi/crda-image:0.1
- name: crda-code-scan
- resources: {}
- script: >
- #!/usr/bin/env bash
-
- set +x
-
- export NO_COLOR="True"
-
- echo "---" echo "Installing tar"
-
- chmod +x /crda > /dev/null
-
- echo "## Scanning application manifest $(params.manifest)"
-
- /crda config set consent_telemetry false
-
- /crda auth -t b6eb51e7-af6c-4bdb-b006-3005711316ca
-
- /crda analyse
- $(workspaces.source.path)/$(params.application_folder)/$(params.manifest)
-
- echo "## Scan finished ##"
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-image-scan-task.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-image-scan
-spec:
- params:
- - name: rox_central_endpoint
- type: string
- description: the address:port tuple for StackRox Central (example - rox.stackrox.io:443)
- default: 'central-stackrox.apps.hub.example.com:443'
- - name: rox_api_token
- type: string
- description: Secret containing the StackRox API token with CI permissions
- default: acs-api-token
- - name: image
- type: string
- description: Full name of image to scan (example -- gcr.io/rox/sample:5.0-rc1)
- - name: output_format
- type: string
- description: Output format (json | csv | table)
- default: json
- - name: image_digest
- description: Digest in sha256 hash format of the image to scan
- type: string
- steps:
- - name: rox-image-scan
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- name: $(params.rox_api_token)
- key: token
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- script: |
- #!/usr/bin/env bash
- set +x
- export NO_COLOR="True"
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN" https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output ./roxctl > /dev/null; echo "Getting roxctl"
- chmod +x ./roxctl > /dev/null
- echo "## Scanning image $(params.image)@$(params.image_digest)"
- ./roxctl image scan --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT --image $(params.image)@$(params.image_digest) --output $(params.output_format)
- echo "## Go to https://$ROX_CENTRAL_ENDPOINT/main/vulnerability-management/image/$(params.image_digest) to check more info"
----
-# Source: pipelines/templates/app-pipeline/tasks/task-rox-deployment-check.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-deployment-check
-spec:
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: rox_central_endpoint
- type: string
- description: Secret containing the address:port tuple for StackRox Central (example - rox.stackrox.io:443)
- default: 'central-stackrox.apps.hub.example.com:443'
- - name: rox_api_token
- type: string
- default: acs-api-token
- description: Secret containing the StackRox API token with CI permissions
- - name: file
- type: string
- description: YAML file in the deployfiles workspace
- - name: deployment_files_path
- type: string
- description: Path/Folder for the k8s deployment files to check
- results:
- - name: check_output
- description: Output of `roxctl deployment check`
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
- steps:
-
- - name: git-clone
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- rm -rf git-update-digest-workdir
- git clone $(params.GIT_REPOSITORY) git-update-digest-workdir
- cd git-update-digest-workdir/$(params.deployment_files_path)
-
- - name: rox-deployment-check
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- workingDir: $(workspaces.workspace.path)
- env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- name: $(params.rox_api_token)
- key: token
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- script: |
- #!/usr/bin/env bash
- set +x
- cd git-update-digest-workdir/$(params.deployment_files_path)
- cat $(params.file)
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN" https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output ./roxctl > /dev/null; echo "Getting roxctl"
- chmod +x ./roxctl > /dev/null
- ./roxctl deployment check --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT -f $(params.file)
----
-# Source: pipelines/templates/app-pipeline/tasks/task-rox-image-check.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-image-check
-spec:
- params:
- - description: >-
- Secret containing the address:port tuple for StackRox Central (example -
- rox.stackrox.io:443)
- name: rox_central_endpoint
- default: 'central-stackrox.apps.hub.example.com:443'
- type: string
- - description: Secret containing the StackRox API token with CI permissions
- name: rox_api_token
- type: string
- - description: 'Full name of image to scan (example -- gcr.io/rox/sample:5.0-rc1)'
- name: image
- type: string
- - name: image_digest
- description: Digest in sha256 hash format of the image to check
- type: string
- results:
- - description: Output of `roxctl image check`
- name: check_output
- steps:
- - env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- key: token
- name: $(params.rox_api_token)
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- name: rox-image-check
- resources: {}
- script: >-
- #!/usr/bin/env bash
-
- set +x
-
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN"
- https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output
- ./roxctl > /dev/null; echo "Getting roxctl"
-
- chmod +x ./roxctl > /dev/null
-
- ./roxctl image check --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT
- --image $(params.image)@$(params.image_digest)
----
-# Source: pipelines/templates/app-pipeline/imageStreams/imagestream-devsecops.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: spring-petclinic
- namespace: devsecops-ci
----
-# Source: pipelines/templates/app-pipeline/devsecops-rh-fixed.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: devsecops-rh-v2-fixed
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/staging
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: unit-tests
- params:
- - name: GOALS
- value:
- - package
- - -f
- - spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: code-analysis
- params:
- - name: GOALS
- value:
- - install
- - sonar:sonar
- - -f
- - spring-petclinic
- - -Dsonar.host.url=http://sonarqube:9000
- - -Dsonar.userHome=/tmp/sonar
- - -DskipTests=true
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: dependency-report
- params:
- - name: SOURCE_DIR
- value: spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: dependency-report
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - code-analysis
- - unit-tests
- - dependency-report
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11-fixed
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: gogs
- - name: GIT_PASSWORD
- value: gogs
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- #jrickard-value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: crda-scan
- params:
- - name: manifest
- value: pom.xml
- runAfter:
- - source-clone
- taskRef:
- kind: ClusterTask
- name: crda-scan
- workspaces:
- - name: source
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/devsecops-rh.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: devsecops-rh-v2
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/staging
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: unit-tests
- params:
- - name: GOALS
- value:
- - package
- - -f
- - spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: code-analysis
- params:
- - name: GOALS
- value:
- - install
- - sonar:sonar
- - -f
- - spring-petclinic
- - -Dsonar.host.url=http://sonarqube:9000
- - -Dsonar.userHome=/tmp/sonar
- - -DskipTests=true
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: dependency-report
- params:
- - name: SOURCE_DIR
- value: spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: dependency-report
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - code-analysis
- - unit-tests
- - dependency-report
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: gogs
- - name: GIT_PASSWORD
- value: gogs
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- #jrickard-value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: crda-scan
- params:
- - name: manifest
- value: pom.xml
- runAfter:
- - source-clone
- taskRef:
- kind: ClusterTask
- name: crda-scan
- workspaces:
- - name: source
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/simple-pipeline.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: simple-pipeline
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/stage
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - source-clone
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/tasks/task-create-promote-pull-request.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: create-promote-pull-request
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: GIT_USERNAME
- type: string
- - name: GIT_PASSWORD
- type: string
- - name: COPY_FROM_PATH
- type: string
- - name: COPY_TO_PATH
- type: string
- results:
- - description: The branch name used for pull-request
- name: branch_name
- steps:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- name: promote
- resources: {}
- script: >
- set -x
-
- rm -rf pull-request-workdir
-
- git clone $(params.GIT_REPOSITORY) pull-request-workdir
-
- cd pull-request-workdir
-
- git config user.email "pipelines-ci@redhat.com"
-
- git config user.name "pipelines-ci"
-
-
- branch_name=ci-$(context.taskRun.name)
-
- git checkout -b $branch_name
-
- echo -n "$branch_name" > $(results.branch_name.path)
-
-
- /bin/cp -rf $(params.COPY_FROM_PATH)/* $(params.COPY_TO_PATH)
-
-
- git status
-
- git add $(params.COPY_TO_PATH)
-
- git commit -m "[$(context.taskRun.name)] Promotion from
- $(params.COPY_FROM_PATH) to $(params.COPY_TO_PATH)"
-
-
- git remote add auth-origin $(echo $(params.GIT_REPOSITORY) | sed -E
- "s#http://(.*)#http://$(params.GIT_USERNAME):$(params.GIT_PASSWORD)@\1#g")
-
- git push -u auth-origin HEAD
- workingDir: $(workspaces.workspace.path)
- - image: quay.io/siamaksade/python-oc
- name: create-pull-request
- resources: {}
- script: >
- #!/usr/bin/env python3
-
-
- import os
-
- import requests
-
-
- gitea_user = "$(params.GIT_USERNAME)"
-
- gitea_pwd = "$(params.GIT_PASSWORD)"
-
- giteaURL = "http://gitea-AUTOMATED.apps.region.example.com"
-
-
- branch_result = open("$(results.branch_name.path)")
-
- git_branch = branch_result.read()
-
- branch_result.close()
-
-
- print("Git server: " + giteaURL)
-
- print("Branch name: " + git_branch)
-
-
- pr_title = "[$(context.taskRun.name)] Promote to STAGE environment"
-
- pr_body = "TaskRun $(context.taskRun.name)\\nPromoting application from
- DEV to STAGE environment"
-
- data_pr = '{"base": "master","body": "' + pr_body + '","head": "' +
- git_branch + '","title": "' + pr_title + '"}'
-
- headers = {'Content-Type': 'application/json'}
-
- resp = requests.post(url = giteaURL + "/api/v1/repos/" + gitea_user +
- "/spring-petclinic-config/pulls",
- headers = headers,
- auth = (gitea_user, gitea_pwd),
- data = data_pr)
-
-
- if resp.status_code != 200:
- print("Error creating pull-request (status code: {})".format(resp.status_code))
- print(resp.content)
- else:
- print("Created pull-request.")
- workingDir: $(workspaces.workspace.path)
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
----
-# Source: pipelines/templates/app-pipeline/tasks/task-dependency-report.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: dependency-report
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
-spec:
- params:
- - name: SOURCE_DIR
- description: The directory within the workspace where application source is located
- default: "."
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- - default: ''
- description: The Maven repository mirror url
- name: MAVEN_MIRROR_URL
- type: string
- - default: ''
- description: The username for the proxy server
- name: PROXY_USER
- type: string
- - default: ''
- description: The password for the proxy server
- name: PROXY_PASSWORD
- type: string
- - default: ''
- description: Port number for the proxy server
- name: PROXY_PORT
- type: string
- - default: ''
- description: Proxy server Host
- name: PROXY_HOST
- type: string
- - default: ''
- description: Non proxy server host
- name: PROXY_NON_PROXY_HOSTS
- type: string
- - default: http
- description: Protocol for the proxy ie http or https
- name: PROXY_PROTOCOL
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
- - description: The workspace consisting of the custom maven settings provided by the user.
- name: maven-settings
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi-minimal:latest'
- name: mvn-settings
- resources: {}
- script: >
- #!/usr/bin/env bash
-
-
- [[ -f $(workspaces.maven-settings.path)/settings.xml ]] && \
-
- echo 'using existing $(workspaces.maven-settings.path)/settings.xml' &&
- exit 0
-
-
- cat > $(workspaces.maven-settings.path)/settings.xml <
-
-
-
-
-
-
-
-
-
-
- EOF
-
-
- xml=""
-
- if [ -n "$(params.PROXY_HOST)" -a -n "$(params.PROXY_PORT)" ]; then
- xml="\
- genproxy\
- true\
- $(params.PROXY_PROTOCOL)\
- $(params.PROXY_HOST)\
- $(params.PROXY_PORT)"
- if [ -n "$(params.PROXY_USER)" -a -n "$(params.PROXY_PASSWORD)" ]; then
- xml="$xml\
- $(params.PROXY_USER)\
- $(params.PROXY_PASSWORD)"
- fi
- if [ -n "$(params.PROXY_NON_PROXY_HOSTS)" ]; then
- xml="$xml\
- $(params.PROXY_NON_PROXY_HOSTS)"
- fi
- xml="$xml\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
-
-
- if [ -n "$(params.MAVEN_MIRROR_URL)" ]; then
- xml=" \
- mirror.default\
- $(params.MAVEN_MIRROR_URL)\
- central\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
- - args:
- - -Dmaven.repo.local=$(workspaces.source.path)/.m2
- - -f
- - $(params.SOURCE_DIR)
- - -s
- - $(workspaces.maven-settings.path)/settings.xml
- - site
- - -DskipTests=true
- command:
- - /usr/bin/mvn
- image: gcr.io/cloud-builders/mvn
- name: mvn-goals
- resources: {}
- workingDir: $(workspaces.source.path)
- - name: archive-site
- workingDir: $(workspaces.source.path)
- image: registry.access.redhat.com/ubi8/ubi:latest
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- script: |
- #!/usr/bin/env bash
-
- for f in $(find $(params.SOURCE_DIR)/target/site -type f); do
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME/${f} -X POST -F file=@${f} $(params.REPORTS_REPO_HOST)/upload; echo ""
- done
----
-# Source: pipelines/templates/app-pipeline/tasks/task-gatling.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: gatling
-spec:
- params:
- - name: DURATION
- description: The duration of running simulations
- type: string
- default: "30"
- - name: CONCURRENT_USERS
- description: The number of concurrent users
- type: string
- default: "10"
- - name: APP_URL
- description: The application under test url
- type: string
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- workspaces:
- - description: The workspace consisting of maven project.
- name: simulations
- steps:
- - name: run-tests
- image: quay.io/hybridcloudpatterns/gatling:latest
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- script: |
- #!/usr/bin/env bash
-
- set -x
-
- cd /opt/gatling/
- ls -lhrt
-
- # set simulation params
- export JAVA_OPTS="-DtestDuration=$(params.CONCURRENT_USERS) -DuserCount=$(params.DURATION) -Dserver=$(params.APP_URL)"
-
- # run simulation
- /opt/gatling/bin/gatling.sh -rd "Spring PetClinic Performance Test" -sf $(workspaces.simulations.path)
-
- # upload results
- REPORT=$(ls -td /opt/gatling/results/* | head -1)
- for f in $(find $REPORT/ -type f); do
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME${f#/opt/gatling/results} -X POST -F file=@${f} $(params.REPORTS_REPO_HOST)/upload; echo ""
- done
----
-# Source: pipelines/templates/app-pipeline/tasks/task-git-update-deployment.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: git-update-deployment
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: GIT_USERNAME
- type: string
- - name: GIT_PASSWORD
- type: string
- - name: CURRENT_IMAGE
- type: string
- - name: NEW_IMAGE
- type: string
- - name: NEW_DIGEST
- type: string
- - name: KUSTOMIZATION_PATH
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
-
- results:
- - name: commit
- description: The commit SHA
-
- steps:
- - name: git-clone
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- rm -rf git-update-digest-workdir
- git clone $(params.GIT_REPOSITORY) git-update-digest-workdir
-
- - name: update-digest
- image: k8s.gcr.io/kustomize/kustomize:v3.8.7
- workingDir: $(workspaces.workspace.path)
- script: |
- cd git-update-digest-workdir/$(params.KUSTOMIZATION_PATH)
- /app/kustomize edit set image $(params.CURRENT_IMAGE)=$(params.NEW_IMAGE)@$(params.NEW_DIGEST)
-
- echo "##########################"
- echo "### kustomization.yaml ###"
- echo "##########################"
- cat kustomization.yaml
-
- - name: git-commit
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- cd git-update-digest-workdir
- git config user.email "tekton-pipelines-ci@redhat.com"
- git config user.name "tekton-pipelines-ci"
-
- git status
- git add $(params.KUSTOMIZATION_PATH)/kustomization.yaml
- # git commit -m "[$(context.pipelineRun.name)] Image digest updated"
- git commit -m "[ci] Image digest updated"
-
- git remote add auth-origin $(echo $(params.GIT_REPOSITORY) | sed -E "s#http://(.*)#http://$(params.GIT_USERNAME):$(params.GIT_PASSWORD)@\1#g")
- git push auth-origin main
-
- RESULT_SHA="$(git rev-parse HEAD | tr -d '\n')"
- EXIT_CODE="$?"
- if [ "$EXIT_CODE" != 0 ]
- then
- exit $EXIT_CODE
- fi
- # Make sure we don't add a trailing newline to the result!
- echo -n "$RESULT_SHA" > $(results.commit.path)
----
-# Source: pipelines/templates/app-pipeline/tasks/task-github-pull-request.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: github-open-pr
- labels:
- app.kubernetes.io/version: "0.2"
- annotations:
- tekton.dev/categories: Git
- tekton.dev/pipelines.minVersion: "0.12.1"
- tekton.dev/tags: github
- tekton.dev/displayName: "open github pull request"
- tekton.dev/platforms: "linux/amd64,linux/s390x,linux/ppc64le"
-spec:
- description: >-
- This task will open a PR on Github based on several parameters.
- This could be useful in GitOps repositories for example.
-
- params:
- - name: GITHUB_HOST_URL
- description: |
- The GitHub host, adjust this if you run a GitHub enteprise.
- default: "api.github.com"
- type: string
-
- - name: API_PATH_PREFIX
- description: |
- The API path prefix, GitHub Enterprise has a prefix e.g. /api/v3
- default: ""
- type: string
-
- - name: REPO_FULL_NAME
- description: |
- The GitHub repository full name, e.g.: tektoncd/catalog
- type: string
-
- - name: GITHUB_TOKEN_SECRET_NAME
- description: |
- The name of the kubernetes secret that contains the GitHub token, default: github
- type: string
- default: github
-
- - name: GITHUB_TOKEN_SECRET_KEY
- description: |
- The key within the kubernetes secret that contains the GitHub token, default: token
- type: string
- default: token
-
- - name: AUTH_TYPE
- description: |
- The type of authentication to use. You could use the less secure "Basic" for example
- type: string
- default: Bearer
-
- - name: HEAD
- description: |
- The name of the branch where your changes are implemented.
- type: string
-
- - name: BASE
- description: |
- The name of the branch you want the changes pulled into.
- type: string
-
- - name: BODY
- description: |
- The body description of the pull request.
- type: string
-
- - name: TITLE
- description: |
- The title of the pull request.
- type: string
-
- results:
- - name: NUMBER
- description: Number of the created pull request.
-
- - name: URL
- description: URL of the created pull request.
-
- volumes:
- - name: githubtoken
- secret:
- secretName: $(params.GITHUB_TOKEN_SECRET_NAME)
-
- steps:
- - name: open-pr
- volumeMounts:
- - name: githubtoken
- readOnly: true
- mountPath: /etc/github-open-pr
- env:
- - name: PULLREQUEST_NUMBER_PATH
- value: $(results.NUMBER.path)
- - name: PULLREQUEST_URL_PATH
- value: $(results.URL.path)
-
- image: registry.access.redhat.com/ubi8/python-38:1-34.1599745032
- script: |
- #!/usr/libexec/platform-python
-
- """This script will open a PR on Github"""
-
- import json
- import os
- import sys
- import http.client
-
- github_token = open("/etc/github-open-pr/$(params.GITHUB_TOKEN_SECRET_KEY)", "r").read()
-
- open_pr_url = "$(params.API_PATH_PREFIX)" + "/repos/$(params.REPO_FULL_NAME)/pulls"
-
- data = {
- "head": "$(params.HEAD)",
- "base": "$(params.BASE)",
- "title": "$(params.TITLE)",
- "body": """$(params.BODY)"""
- }
- print("Sending this data to GitHub: ")
- print(data)
-
- authHeader = "$(params.AUTH_TYPE) " + github_token
-
- # This is for our fake github server
- if "$(params.GITHUB_HOST_URL)".startswith("http://"):
- conn = http.client.HTTPConnection("$(params.GITHUB_HOST_URL)"
- .replace("http://", ""))
- else:
- conn = http.client.HTTPSConnection("$(params.GITHUB_HOST_URL)")
-
- conn.request(
- "POST",
- open_pr_url,
- body=json.dumps(data),
- headers={
- "User-Agent": "TektonCD, the peaceful cat",
- "Authorization": authHeader,
- "Accept": "application/vnd.github.v3+json ",
- })
- resp = conn.getresponse()
- if not str(resp.status).startswith("2"):
- print("Error: %d" % (resp.status))
- print(resp.read())
- sys.exit(1)
- else:
- # https://docs.github.com/en/rest/reference/pulls#create-a-pull-request
- body = json.loads(resp.read().decode())
-
- open(os.environ.get('PULLREQUEST_NUMBER_PATH'), 'w').write(f'{body["number"]}')
- open(os.environ.get('PULLREQUEST_URL_PATH'), 'w').write(body["html_url"])
-
- print("GitHub pull request created for $(params.REPO_FULL_NAME): "
- f'number={body["number"]} url={body["html_url"]}')
----
-# Source: pipelines/templates/app-pipeline/tasks/task-mvn.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: build-tool
- name: maven
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to run a Maven build.
- params:
- - default: gcr.io/cloud-builders/mvn:3.5.0-jdk-8
- description: Maven base image
- name: MAVEN_IMAGE
- type: string
- - default:
- - package
- description: maven goals to run
- name: GOALS
- type: array
- - default: ''
- description: The Maven repository mirror url
- name: MAVEN_MIRROR_URL
- type: string
- - default: ''
- description: The username for the proxy server
- name: PROXY_USER
- type: string
- - default: ''
- description: The password for the proxy server
- name: PROXY_PASSWORD
- type: string
- - default: ''
- description: Port number for the proxy server
- name: PROXY_PORT
- type: string
- - default: ''
- description: Proxy server Host
- name: PROXY_HOST
- type: string
- - default: ''
- description: Non proxy server host
- name: PROXY_NON_PROXY_HOSTS
- type: string
- - default: http
- description: Protocol for the proxy ie http or https
- name: PROXY_PROTOCOL
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
- - description: The workspace consisting of the custom maven settings provided by the user.
- name: maven-settings
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi-minimal:latest'
- name: mvn-settings
- resources: {}
- script: >
- #!/usr/bin/env bash
-
-
- [[ -f $(workspaces.maven-settings.path)/settings.xml ]] && \
-
- echo 'using existing $(workspaces.maven-settings.path)/settings.xml' &&
- exit 0
-
-
- cat > $(workspaces.maven-settings.path)/settings.xml <
-
-
-
-
-
-
-
-
-
-
- EOF
-
-
- xml=""
-
- if [ -n "$(params.PROXY_HOST)" -a -n "$(params.PROXY_PORT)" ]; then
- xml="\
- genproxy\
- true\
- $(params.PROXY_PROTOCOL)\
- $(params.PROXY_HOST)\
- $(params.PROXY_PORT)"
- if [ -n "$(params.PROXY_USER)" -a -n "$(params.PROXY_PASSWORD)" ]; then
- xml="$xml\
- $(params.PROXY_USER)\
- $(params.PROXY_PASSWORD)"
- fi
- if [ -n "$(params.PROXY_NON_PROXY_HOSTS)" ]; then
- xml="$xml\
- $(params.PROXY_NON_PROXY_HOSTS)"
- fi
- xml="$xml\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
-
-
- if [ -n "$(params.MAVEN_MIRROR_URL)" ]; then
- xml=" \
- mirror.default\
- $(params.MAVEN_MIRROR_URL)\
- central\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
- - args:
- - -Dmaven.repo.local=$(workspaces.source.path)/.m2
- - '-s'
- - $(workspaces.maven-settings.path)/settings.xml
- - $(params.GOALS)
- command:
- - /usr/bin/mvn
- image: $(params.MAVEN_IMAGE)
- name: mvn-goals
- workingDir: $(workspaces.source.path)
- resources:
- requests:
- memory: 512Mi
- cpu: 200m
- limits:
- memory: 4Gi
- cpu: '1'
----
-# Source: pipelines/templates/app-pipeline/tasks/task-s2i-java-11-fixed.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/displayName: s2i java 11
- tekton.dev/pipelines.minVersion: 0.11.3
- tekton.dev/tags: s2i, java, workspace
- name: s2i-java-11-fixed
-spec:
- description: s2i-java-11 task clones a Git repository and builds and pushes a container
- image using S2I and a Java 11 builder image.
- params:
- - default: .
- description: The location of the path to run s2i from
- name: PATH_CONTEXT
- type: string
- - default: "true"
- description: Verify the TLS on the registry endpoint (for push/pull to a non-TLS
- registry)
- name: TLSVERIFY
- type: string
- - default: ""
- description: Additional Maven arguments
- name: MAVEN_ARGS_APPEND
- type: string
- - default: "false"
- description: Remove the Maven repository after the artifact is built
- name: MAVEN_CLEAR_REPO
- type: string
- - default: ""
- description: The base URL of a mirror used for retrieving artifacts
- name: MAVEN_MIRROR_URL
- type: string
- - description: Location of the repo where image has to be pushed
- name: IMAGE_NAME
- type: string
- - default: latest
- description: The tag of the image to be pushed
- name: IMAGE_TAG
- type: string
- results:
- - description: Digest of the image just built.
- name: IMAGE_DIGEST
- - description: URL of the image used by Tekton Chains to push the OCI images
- name: IMAGE_URL
- steps:
- - args:
- - |-
- echo "MAVEN_CLEAR_REPO=$(params.MAVEN_CLEAR_REPO)" > env-file
-
- [[ '$(params.MAVEN_ARGS_APPEND)' != "" ]] &&
- echo "MAVEN_ARGS_APPEND=$(params.MAVEN_ARGS_APPEND)" >> env-file
-
- [[ '$(params.MAVEN_MIRROR_URL)' != "" ]] &&
- echo "MAVEN_MIRROR_URL=$(params.MAVEN_MIRROR_URL)" >> env-file
-
- echo "Generated Env file"
- echo "------------------------------"
- cat env-file
- echo "------------------------------"
- command:
- - /bin/sh
- - -c
- image: registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: gen-env-file
- resources: {}
- volumeMounts:
- - mountPath: /env-params
- name: envparams
- workingDir: /env-params
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - s2i
- - build
- - $(params.PATH_CONTEXT)
- - image-registry.openshift-image-registry.svc:5000/openshift/java:11
- - --image-scripts-url
- - image:///usr/local/s2i
- - --as-dockerfile
- - /gen-source/Dockerfile.gen
- - --environment-file
- - /env-params/env-file
- image: registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: generate
- resources: {}
- volumeMounts:
- - mountPath: /gen-source
- name: gen-source
- - mountPath: /env-params
- name: envparams
- workingDir: $(workspaces.source.path)
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - bud
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --layers
- - -f
- - /gen-source/Dockerfile.gen
- - -t
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - -t
- - $(params.IMAGE_NAME):latest
- - .
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: build
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - /bin/sh
- - -c
- args:
- - |-
- buildah from --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) '$(params.IMAGE_NAME):$(params.IMAGE_TAG)' > imgname
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c `dnf update -y`
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *dnf*) $(rpm -qa *libsolv*) $(rpm -qa *hawkey*) $(rpm -qa yum*) $(rpm -qa *dnf*) $(rpm -qa *subscription-manager*)'
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *rpm*)'
- buildah commit --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) `cat imgname` '$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: update
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - /bin/sh
- - -c
- args:
- - |-
- buildah from --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) '$(params.IMAGE_NAME):$(params.IMAGE_TAG)' > imgname
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c `dnf update -y`
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *dnf*) $(rpm -qa *libsolv*) $(rpm -qa *hawkey*) $(rpm -qa yum*) $(rpm -qa *dnf*) $(rpm -qa *subscription-manager*)'
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *rpm*)'
- buildah commit --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) `cat imgname` '$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: remove-package-mgr
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - push
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - docker://$(params.IMAGE_NAME):$(params.IMAGE_TAG)
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-tag
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - push
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - docker://$(params.IMAGE_NAME):latest
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-latest
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: digest-to-results
- resources: {}
- script: cat $(workspaces.source.path)/image-digest | tee /tekton/results/IMAGE_DIGEST; echo quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic > /tekton/results/IMAGE_URL
- volumes:
- - emptyDir: {}
- name: varlibcontainers
- - emptyDir: {}
- name: gen-source
- - emptyDir: {}
- name: envparams
- workspaces:
- - mountPath: /workspace/source
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-s2i-java-11.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: s2i-java-11
- annotations:
- tekton.dev/displayName: s2i java 11
- tekton.dev/pipelines.minVersion: 0.11.3
- tekton.dev/tags: 's2i, java, workspace'
-spec:
- description: >-
- s2i-java-11 task clones a Git repository and builds and pushes a container
- image using S2I and a Java 11 builder image.
- params:
- - default: .
- description: The location of the path to run s2i from
- name: PATH_CONTEXT
- type: string
- - default: 'true'
- description: >-
- Verify the TLS on the registry endpoint (for push/pull to a non-TLS
- registry)
- name: TLSVERIFY
- type: string
- - default: ''
- description: Additional Maven arguments
- name: MAVEN_ARGS_APPEND
- type: string
- - default: 'false'
- description: Remove the Maven repository after the artifact is built
- name: MAVEN_CLEAR_REPO
- type: string
- - default: ''
- description: The base URL of a mirror used for retrieving artifacts
- name: MAVEN_MIRROR_URL
- type: string
- - description: Location of the repo where image has to be pushed
- name: IMAGE_NAME
- type: string
- - description: The tag of the image to be pushed
- name: IMAGE_TAG
- type: string
- default: "latest"
- results:
- - name: IMAGE_DIGEST
- description: Digest of the image just built.
- steps:
- - args:
- - |-
- echo "MAVEN_CLEAR_REPO=$(params.MAVEN_CLEAR_REPO)" > env-file
-
- [[ '$(params.MAVEN_ARGS_APPEND)' != "" ]] &&
- echo "MAVEN_ARGS_APPEND=$(params.MAVEN_ARGS_APPEND)" >> env-file
-
- [[ '$(params.MAVEN_MIRROR_URL)' != "" ]] &&
- echo "MAVEN_MIRROR_URL=$(params.MAVEN_MIRROR_URL)" >> env-file
-
- echo "Generated Env file"
- echo "------------------------------"
- cat env-file
- echo "------------------------------"
- command:
- - /bin/sh
- - '-c'
- image: >-
- registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: gen-env-file
- resources: {}
- volumeMounts:
- - mountPath: /env-params
- name: envparams
- workingDir: /env-params
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - s2i
- - build
- - $(params.PATH_CONTEXT)
- - 'image-registry.openshift-image-registry.svc:5000/openshift/java:11'
- - '--image-scripts-url'
- - 'image:///usr/local/s2i'
- - '--as-dockerfile'
- - /gen-source/Dockerfile.gen
- - '--environment-file'
- - /env-params/env-file
- image: >-
- registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: generate
- resources: {}
- volumeMounts:
- - mountPath: /gen-source
- name: gen-source
- - mountPath: /env-params
- name: envparams
- workingDir: $(workspaces.source.path)
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - buildah
- - bud
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - '--layers'
- - '-f'
- - /gen-source/Dockerfile.gen
- - '-t'
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - '-t'
- - $(params.IMAGE_NAME):latest
- - .
- image: >-
- registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: build
- resources: {}
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- - command:
- - buildah
- - push
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - 'docker://$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-tag
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - buildah
- - push
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - 'docker://$(params.IMAGE_NAME):latest'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-latest
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - name: digest-to-results
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- script: cat $(workspaces.source.path)/image-digest | tee /tekton/results/IMAGE_DIGEST
- volumes:
- - emptyDir: {}
- name: varlibcontainers
- - emptyDir: {}
- name: gen-source
- - emptyDir: {}
- name: envparams
- workspaces:
- - mountPath: /workspace/source
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-syft-sbom.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: build-tool
- name: syft-sbom
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to generate a SBOM file with Syft.
- params:
- - default: $(workspaces.source.path)
- description: Application folder to scan
- name: APP_PATH
- type: string
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi:latest'
- name: syft-scan
- resources: {}
- script: >
- #!/usr/bin/env bash
-
- echo '## Getting Syft ##'
-
- pwd
-
- curl -sSfL
- https://raw.githubusercontent.com/anchore/syft/main/install.sh | sh -s
- -- -b .
-
- chmod +x ./syft
-
- echo '## Scanning folder and generating SBOM ##'
-
- ./syft $(params.APP_PATH) -o spdx-json=sbom.json
-
- echo '## SBOM content ##'
-
- cat ./sbom.json
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-zap-proxy.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: zap-proxy
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- - name: APP_URL
- description: The application under test url
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- workspaces:
- - description: The workspace for the zap proxy task
- name: workspace
-
- steps:
- - name: zap-proxy
- image: quay.io/hybridcloudpatterns/zap2docker-stable
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- workingDir: $(workspaces.workspace.path)
- script: |
- #!/usr/bin/env bash
-
- set -x
-
- echo "Make the wrk directory available to save the reports"
- cd /zap
- mkdir /zap/wrk
-
- echo "Starting the pentesting..."
- /zap/zap-baseline.py -t $(params.APP_URL) -r $PIPELINERUN_NAME.html
-
- ls -lhrt /zap/wrk
-
- echo "Uploading the report into the report server"
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME/$PIPELINERUN_NAME.html -F file=@/zap/wrk/$PIPELINERUN_NAME.html -X POST $(params.REPORTS_REPO_HOST)/upload; echo ""
----
-# Source: pipelines/templates/chains/tekton-chain.yaml
-apiVersion: operator.tekton.dev/v1alpha1
-kind: TektonChain
-metadata:
- name: chain
-spec:
- targetNamespace: openshift-pipelines
diff --git a/tests/region-pipelines-medical-diagnosis-hub.expected.yaml b/tests/region-pipelines-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index c5fab07f..00000000
--- a/tests/region-pipelines-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,2472 +0,0 @@
----
-# Source: pipelines/templates/app-pipeline/rbac/pipeline-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-imagePullSecrets:
-- name: image-registry-credentials
-metadata:
- name: pipeline
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/syncOptions: ServerSideApply=true
-secrets:
- - name: acs-api-token
- - name: git-secret
- - name: quay-pull-secret
----
-# Source: pipelines/templates/app-pipeline/rbac/registry-credential-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-imagePullSecrets:
-- name: image-registry-credentials
-metadata:
- name: pipeline-svc
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-secrets:
- - name: quay-api-token
- - name: acs-api-token
- - name: quay-pull-secret
----
-# Source: pipelines/templates/app-pipeline/configmaps/argocd-en-cm.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: argocd-env-configmap
- namespace: devsecops-ci
-data:
- ARGOCD_SERVER: development-gitops-server.mypattern-development.svc:443
----
-# Source: pipelines/templates/app-pipeline/configmaps/maven-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: maven-settings
-data:
- settings.xml: |
-
-
-
-
- nexus
- admin
- admin123
-
-
-
-
- nexus
- nexus
- http://nexus:8081/repository/maven-public/
- *
-
-
-
----
-# Source: pipelines/templates/chains/tekton-chains-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: chains-config
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-options: ServerSideApply=true
-data:
- artifacts.oci.storage: 'oci'
- artifacts.taskrun.format: tekton
- artifacts.taskrun.storage: tekton
- artifacts.oci.format: simplesigning
- artifacts.oci.signer: cosign
----
-# Source: pipelines/templates/environment.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: environment
-data:
- DESCRIPTION: "Config keys for openshift-pipelines"
----
-# Source: pipelines/templates/app-pipeline/storageclass/vp-storageClass.yaml
-apiVersion: storage.k8s.io/v1
-kind: StorageClass
-allowVolumeExpansion: true
-metadata:
- name: default-rwo-vp
-parameters:
- encrypted: "true"
- type: default-rwo
-provisioner:
-reclaimPolicy: Delete
-volumeBindingMode: Immediate
----
-# Source: pipelines/templates/app-pipeline/pvcs/pipeline-pvc.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- name: pipeline-pvc
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- resources:
- requests:
- storage: 5Gi
- storageClassName: gp3-csi
- volumeMode: Filesystem
- accessModes:
- - ReadWriteOnce
----
-# Source: pipelines/templates/app-pipeline/rbac/imagestream-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: imagestream-view
-rules:
-- apiGroups:
- - image.openshift.io
- resources:
- - imagestreams
- verbs:
- - get
-- apiGroups:
- - image.openshift.io
- resources:
- - imagestreamimports
- verbs:
- - create
----
-# Source: pipelines/templates/app-pipeline/tasks/task-crda-scan.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: crda-scan
-spec:
- params:
- - default: pom.xml
- description: the path and manifest that should be scanned
- name: manifest
- type: string
- - default: spring-petclinic
- description: application folder name
- name: application_folder
- type: string
- steps:
- - image: quay.io/jchraibi/crda-image:0.1
- name: crda-code-scan
- resources: {}
- script: >
- #!/usr/bin/env bash
-
- set +x
-
- export NO_COLOR="True"
-
- echo "---" echo "Installing tar"
-
- chmod +x /crda > /dev/null
-
- echo "## Scanning application manifest $(params.manifest)"
-
- /crda config set consent_telemetry false
-
- /crda auth -t b6eb51e7-af6c-4bdb-b006-3005711316ca
-
- /crda analyse
- $(workspaces.source.path)/$(params.application_folder)/$(params.manifest)
-
- echo "## Scan finished ##"
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-image-scan-task.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-image-scan
-spec:
- params:
- - name: rox_central_endpoint
- type: string
- description: the address:port tuple for StackRox Central (example - rox.stackrox.io:443)
- default: 'central-stackrox.apps.hub.example.com:443'
- - name: rox_api_token
- type: string
- description: Secret containing the StackRox API token with CI permissions
- default: acs-api-token
- - name: image
- type: string
- description: Full name of image to scan (example -- gcr.io/rox/sample:5.0-rc1)
- - name: output_format
- type: string
- description: Output format (json | csv | table)
- default: json
- - name: image_digest
- description: Digest in sha256 hash format of the image to scan
- type: string
- steps:
- - name: rox-image-scan
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- name: $(params.rox_api_token)
- key: token
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- script: |
- #!/usr/bin/env bash
- set +x
- export NO_COLOR="True"
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN" https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output ./roxctl > /dev/null; echo "Getting roxctl"
- chmod +x ./roxctl > /dev/null
- echo "## Scanning image $(params.image)@$(params.image_digest)"
- ./roxctl image scan --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT --image $(params.image)@$(params.image_digest) --output $(params.output_format)
- echo "## Go to https://$ROX_CENTRAL_ENDPOINT/main/vulnerability-management/image/$(params.image_digest) to check more info"
----
-# Source: pipelines/templates/app-pipeline/tasks/task-rox-deployment-check.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-deployment-check
-spec:
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: rox_central_endpoint
- type: string
- description: Secret containing the address:port tuple for StackRox Central (example - rox.stackrox.io:443)
- default: 'central-stackrox.apps.hub.example.com:443'
- - name: rox_api_token
- type: string
- default: acs-api-token
- description: Secret containing the StackRox API token with CI permissions
- - name: file
- type: string
- description: YAML file in the deployfiles workspace
- - name: deployment_files_path
- type: string
- description: Path/Folder for the k8s deployment files to check
- results:
- - name: check_output
- description: Output of `roxctl deployment check`
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
- steps:
-
- - name: git-clone
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- rm -rf git-update-digest-workdir
- git clone $(params.GIT_REPOSITORY) git-update-digest-workdir
- cd git-update-digest-workdir/$(params.deployment_files_path)
-
- - name: rox-deployment-check
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- workingDir: $(workspaces.workspace.path)
- env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- name: $(params.rox_api_token)
- key: token
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- script: |
- #!/usr/bin/env bash
- set +x
- cd git-update-digest-workdir/$(params.deployment_files_path)
- cat $(params.file)
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN" https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output ./roxctl > /dev/null; echo "Getting roxctl"
- chmod +x ./roxctl > /dev/null
- ./roxctl deployment check --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT -f $(params.file)
----
-# Source: pipelines/templates/app-pipeline/tasks/task-rox-image-check.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-image-check
-spec:
- params:
- - description: >-
- Secret containing the address:port tuple for StackRox Central (example -
- rox.stackrox.io:443)
- name: rox_central_endpoint
- default: 'central-stackrox.apps.hub.example.com:443'
- type: string
- - description: Secret containing the StackRox API token with CI permissions
- name: rox_api_token
- type: string
- - description: 'Full name of image to scan (example -- gcr.io/rox/sample:5.0-rc1)'
- name: image
- type: string
- - name: image_digest
- description: Digest in sha256 hash format of the image to check
- type: string
- results:
- - description: Output of `roxctl image check`
- name: check_output
- steps:
- - env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- key: token
- name: $(params.rox_api_token)
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- name: rox-image-check
- resources: {}
- script: >-
- #!/usr/bin/env bash
-
- set +x
-
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN"
- https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output
- ./roxctl > /dev/null; echo "Getting roxctl"
-
- chmod +x ./roxctl > /dev/null
-
- ./roxctl image check --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT
- --image $(params.image)@$(params.image_digest)
----
-# Source: pipelines/templates/app-pipeline/imageStreams/imagestream-devsecops.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: spring-petclinic
- namespace: devsecops-ci
----
-# Source: pipelines/templates/app-pipeline/devsecops-rh-fixed.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: devsecops-rh-v2-fixed
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/staging
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: unit-tests
- params:
- - name: GOALS
- value:
- - package
- - -f
- - spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: code-analysis
- params:
- - name: GOALS
- value:
- - install
- - sonar:sonar
- - -f
- - spring-petclinic
- - -Dsonar.host.url=http://sonarqube:9000
- - -Dsonar.userHome=/tmp/sonar
- - -DskipTests=true
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: dependency-report
- params:
- - name: SOURCE_DIR
- value: spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: dependency-report
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - code-analysis
- - unit-tests
- - dependency-report
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11-fixed
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: gogs
- - name: GIT_PASSWORD
- value: gogs
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- #jrickard-value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: crda-scan
- params:
- - name: manifest
- value: pom.xml
- runAfter:
- - source-clone
- taskRef:
- kind: ClusterTask
- name: crda-scan
- workspaces:
- - name: source
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/devsecops-rh.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: devsecops-rh-v2
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/staging
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: unit-tests
- params:
- - name: GOALS
- value:
- - package
- - -f
- - spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: code-analysis
- params:
- - name: GOALS
- value:
- - install
- - sonar:sonar
- - -f
- - spring-petclinic
- - -Dsonar.host.url=http://sonarqube:9000
- - -Dsonar.userHome=/tmp/sonar
- - -DskipTests=true
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: dependency-report
- params:
- - name: SOURCE_DIR
- value: spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: dependency-report
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - code-analysis
- - unit-tests
- - dependency-report
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: gogs
- - name: GIT_PASSWORD
- value: gogs
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- #jrickard-value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: crda-scan
- params:
- - name: manifest
- value: pom.xml
- runAfter:
- - source-clone
- taskRef:
- kind: ClusterTask
- name: crda-scan
- workspaces:
- - name: source
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/simple-pipeline.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: simple-pipeline
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/stage
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - source-clone
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/tasks/task-create-promote-pull-request.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: create-promote-pull-request
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: GIT_USERNAME
- type: string
- - name: GIT_PASSWORD
- type: string
- - name: COPY_FROM_PATH
- type: string
- - name: COPY_TO_PATH
- type: string
- results:
- - description: The branch name used for pull-request
- name: branch_name
- steps:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- name: promote
- resources: {}
- script: >
- set -x
-
- rm -rf pull-request-workdir
-
- git clone $(params.GIT_REPOSITORY) pull-request-workdir
-
- cd pull-request-workdir
-
- git config user.email "pipelines-ci@redhat.com"
-
- git config user.name "pipelines-ci"
-
-
- branch_name=ci-$(context.taskRun.name)
-
- git checkout -b $branch_name
-
- echo -n "$branch_name" > $(results.branch_name.path)
-
-
- /bin/cp -rf $(params.COPY_FROM_PATH)/* $(params.COPY_TO_PATH)
-
-
- git status
-
- git add $(params.COPY_TO_PATH)
-
- git commit -m "[$(context.taskRun.name)] Promotion from
- $(params.COPY_FROM_PATH) to $(params.COPY_TO_PATH)"
-
-
- git remote add auth-origin $(echo $(params.GIT_REPOSITORY) | sed -E
- "s#http://(.*)#http://$(params.GIT_USERNAME):$(params.GIT_PASSWORD)@\1#g")
-
- git push -u auth-origin HEAD
- workingDir: $(workspaces.workspace.path)
- - image: quay.io/siamaksade/python-oc
- name: create-pull-request
- resources: {}
- script: >
- #!/usr/bin/env python3
-
-
- import os
-
- import requests
-
-
- gitea_user = "$(params.GIT_USERNAME)"
-
- gitea_pwd = "$(params.GIT_PASSWORD)"
-
- giteaURL = "http://gitea-AUTOMATED.apps.region.example.com"
-
-
- branch_result = open("$(results.branch_name.path)")
-
- git_branch = branch_result.read()
-
- branch_result.close()
-
-
- print("Git server: " + giteaURL)
-
- print("Branch name: " + git_branch)
-
-
- pr_title = "[$(context.taskRun.name)] Promote to STAGE environment"
-
- pr_body = "TaskRun $(context.taskRun.name)\\nPromoting application from
- DEV to STAGE environment"
-
- data_pr = '{"base": "master","body": "' + pr_body + '","head": "' +
- git_branch + '","title": "' + pr_title + '"}'
-
- headers = {'Content-Type': 'application/json'}
-
- resp = requests.post(url = giteaURL + "/api/v1/repos/" + gitea_user +
- "/spring-petclinic-config/pulls",
- headers = headers,
- auth = (gitea_user, gitea_pwd),
- data = data_pr)
-
-
- if resp.status_code != 200:
- print("Error creating pull-request (status code: {})".format(resp.status_code))
- print(resp.content)
- else:
- print("Created pull-request.")
- workingDir: $(workspaces.workspace.path)
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
----
-# Source: pipelines/templates/app-pipeline/tasks/task-dependency-report.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: dependency-report
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
-spec:
- params:
- - name: SOURCE_DIR
- description: The directory within the workspace where application source is located
- default: "."
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- - default: ''
- description: The Maven repository mirror url
- name: MAVEN_MIRROR_URL
- type: string
- - default: ''
- description: The username for the proxy server
- name: PROXY_USER
- type: string
- - default: ''
- description: The password for the proxy server
- name: PROXY_PASSWORD
- type: string
- - default: ''
- description: Port number for the proxy server
- name: PROXY_PORT
- type: string
- - default: ''
- description: Proxy server Host
- name: PROXY_HOST
- type: string
- - default: ''
- description: Non proxy server host
- name: PROXY_NON_PROXY_HOSTS
- type: string
- - default: http
- description: Protocol for the proxy ie http or https
- name: PROXY_PROTOCOL
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
- - description: The workspace consisting of the custom maven settings provided by the user.
- name: maven-settings
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi-minimal:latest'
- name: mvn-settings
- resources: {}
- script: >
- #!/usr/bin/env bash
-
-
- [[ -f $(workspaces.maven-settings.path)/settings.xml ]] && \
-
- echo 'using existing $(workspaces.maven-settings.path)/settings.xml' &&
- exit 0
-
-
- cat > $(workspaces.maven-settings.path)/settings.xml <
-
-
-
-
-
-
-
-
-
-
- EOF
-
-
- xml=""
-
- if [ -n "$(params.PROXY_HOST)" -a -n "$(params.PROXY_PORT)" ]; then
- xml="\
- genproxy\
- true\
- $(params.PROXY_PROTOCOL)\
- $(params.PROXY_HOST)\
- $(params.PROXY_PORT)"
- if [ -n "$(params.PROXY_USER)" -a -n "$(params.PROXY_PASSWORD)" ]; then
- xml="$xml\
- $(params.PROXY_USER)\
- $(params.PROXY_PASSWORD)"
- fi
- if [ -n "$(params.PROXY_NON_PROXY_HOSTS)" ]; then
- xml="$xml\
- $(params.PROXY_NON_PROXY_HOSTS)"
- fi
- xml="$xml\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
-
-
- if [ -n "$(params.MAVEN_MIRROR_URL)" ]; then
- xml=" \
- mirror.default\
- $(params.MAVEN_MIRROR_URL)\
- central\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
- - args:
- - -Dmaven.repo.local=$(workspaces.source.path)/.m2
- - -f
- - $(params.SOURCE_DIR)
- - -s
- - $(workspaces.maven-settings.path)/settings.xml
- - site
- - -DskipTests=true
- command:
- - /usr/bin/mvn
- image: gcr.io/cloud-builders/mvn
- name: mvn-goals
- resources: {}
- workingDir: $(workspaces.source.path)
- - name: archive-site
- workingDir: $(workspaces.source.path)
- image: registry.access.redhat.com/ubi8/ubi:latest
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- script: |
- #!/usr/bin/env bash
-
- for f in $(find $(params.SOURCE_DIR)/target/site -type f); do
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME/${f} -X POST -F file=@${f} $(params.REPORTS_REPO_HOST)/upload; echo ""
- done
----
-# Source: pipelines/templates/app-pipeline/tasks/task-gatling.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: gatling
-spec:
- params:
- - name: DURATION
- description: The duration of running simulations
- type: string
- default: "30"
- - name: CONCURRENT_USERS
- description: The number of concurrent users
- type: string
- default: "10"
- - name: APP_URL
- description: The application under test url
- type: string
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- workspaces:
- - description: The workspace consisting of maven project.
- name: simulations
- steps:
- - name: run-tests
- image: quay.io/hybridcloudpatterns/gatling:latest
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- script: |
- #!/usr/bin/env bash
-
- set -x
-
- cd /opt/gatling/
- ls -lhrt
-
- # set simulation params
- export JAVA_OPTS="-DtestDuration=$(params.CONCURRENT_USERS) -DuserCount=$(params.DURATION) -Dserver=$(params.APP_URL)"
-
- # run simulation
- /opt/gatling/bin/gatling.sh -rd "Spring PetClinic Performance Test" -sf $(workspaces.simulations.path)
-
- # upload results
- REPORT=$(ls -td /opt/gatling/results/* | head -1)
- for f in $(find $REPORT/ -type f); do
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME${f#/opt/gatling/results} -X POST -F file=@${f} $(params.REPORTS_REPO_HOST)/upload; echo ""
- done
----
-# Source: pipelines/templates/app-pipeline/tasks/task-git-update-deployment.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: git-update-deployment
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: GIT_USERNAME
- type: string
- - name: GIT_PASSWORD
- type: string
- - name: CURRENT_IMAGE
- type: string
- - name: NEW_IMAGE
- type: string
- - name: NEW_DIGEST
- type: string
- - name: KUSTOMIZATION_PATH
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
-
- results:
- - name: commit
- description: The commit SHA
-
- steps:
- - name: git-clone
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- rm -rf git-update-digest-workdir
- git clone $(params.GIT_REPOSITORY) git-update-digest-workdir
-
- - name: update-digest
- image: k8s.gcr.io/kustomize/kustomize:v3.8.7
- workingDir: $(workspaces.workspace.path)
- script: |
- cd git-update-digest-workdir/$(params.KUSTOMIZATION_PATH)
- /app/kustomize edit set image $(params.CURRENT_IMAGE)=$(params.NEW_IMAGE)@$(params.NEW_DIGEST)
-
- echo "##########################"
- echo "### kustomization.yaml ###"
- echo "##########################"
- cat kustomization.yaml
-
- - name: git-commit
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- cd git-update-digest-workdir
- git config user.email "tekton-pipelines-ci@redhat.com"
- git config user.name "tekton-pipelines-ci"
-
- git status
- git add $(params.KUSTOMIZATION_PATH)/kustomization.yaml
- # git commit -m "[$(context.pipelineRun.name)] Image digest updated"
- git commit -m "[ci] Image digest updated"
-
- git remote add auth-origin $(echo $(params.GIT_REPOSITORY) | sed -E "s#http://(.*)#http://$(params.GIT_USERNAME):$(params.GIT_PASSWORD)@\1#g")
- git push auth-origin main
-
- RESULT_SHA="$(git rev-parse HEAD | tr -d '\n')"
- EXIT_CODE="$?"
- if [ "$EXIT_CODE" != 0 ]
- then
- exit $EXIT_CODE
- fi
- # Make sure we don't add a trailing newline to the result!
- echo -n "$RESULT_SHA" > $(results.commit.path)
----
-# Source: pipelines/templates/app-pipeline/tasks/task-github-pull-request.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: github-open-pr
- labels:
- app.kubernetes.io/version: "0.2"
- annotations:
- tekton.dev/categories: Git
- tekton.dev/pipelines.minVersion: "0.12.1"
- tekton.dev/tags: github
- tekton.dev/displayName: "open github pull request"
- tekton.dev/platforms: "linux/amd64,linux/s390x,linux/ppc64le"
-spec:
- description: >-
- This task will open a PR on Github based on several parameters.
- This could be useful in GitOps repositories for example.
-
- params:
- - name: GITHUB_HOST_URL
- description: |
- The GitHub host, adjust this if you run a GitHub enteprise.
- default: "api.github.com"
- type: string
-
- - name: API_PATH_PREFIX
- description: |
- The API path prefix, GitHub Enterprise has a prefix e.g. /api/v3
- default: ""
- type: string
-
- - name: REPO_FULL_NAME
- description: |
- The GitHub repository full name, e.g.: tektoncd/catalog
- type: string
-
- - name: GITHUB_TOKEN_SECRET_NAME
- description: |
- The name of the kubernetes secret that contains the GitHub token, default: github
- type: string
- default: github
-
- - name: GITHUB_TOKEN_SECRET_KEY
- description: |
- The key within the kubernetes secret that contains the GitHub token, default: token
- type: string
- default: token
-
- - name: AUTH_TYPE
- description: |
- The type of authentication to use. You could use the less secure "Basic" for example
- type: string
- default: Bearer
-
- - name: HEAD
- description: |
- The name of the branch where your changes are implemented.
- type: string
-
- - name: BASE
- description: |
- The name of the branch you want the changes pulled into.
- type: string
-
- - name: BODY
- description: |
- The body description of the pull request.
- type: string
-
- - name: TITLE
- description: |
- The title of the pull request.
- type: string
-
- results:
- - name: NUMBER
- description: Number of the created pull request.
-
- - name: URL
- description: URL of the created pull request.
-
- volumes:
- - name: githubtoken
- secret:
- secretName: $(params.GITHUB_TOKEN_SECRET_NAME)
-
- steps:
- - name: open-pr
- volumeMounts:
- - name: githubtoken
- readOnly: true
- mountPath: /etc/github-open-pr
- env:
- - name: PULLREQUEST_NUMBER_PATH
- value: $(results.NUMBER.path)
- - name: PULLREQUEST_URL_PATH
- value: $(results.URL.path)
-
- image: registry.access.redhat.com/ubi8/python-38:1-34.1599745032
- script: |
- #!/usr/libexec/platform-python
-
- """This script will open a PR on Github"""
-
- import json
- import os
- import sys
- import http.client
-
- github_token = open("/etc/github-open-pr/$(params.GITHUB_TOKEN_SECRET_KEY)", "r").read()
-
- open_pr_url = "$(params.API_PATH_PREFIX)" + "/repos/$(params.REPO_FULL_NAME)/pulls"
-
- data = {
- "head": "$(params.HEAD)",
- "base": "$(params.BASE)",
- "title": "$(params.TITLE)",
- "body": """$(params.BODY)"""
- }
- print("Sending this data to GitHub: ")
- print(data)
-
- authHeader = "$(params.AUTH_TYPE) " + github_token
-
- # This is for our fake github server
- if "$(params.GITHUB_HOST_URL)".startswith("http://"):
- conn = http.client.HTTPConnection("$(params.GITHUB_HOST_URL)"
- .replace("http://", ""))
- else:
- conn = http.client.HTTPSConnection("$(params.GITHUB_HOST_URL)")
-
- conn.request(
- "POST",
- open_pr_url,
- body=json.dumps(data),
- headers={
- "User-Agent": "TektonCD, the peaceful cat",
- "Authorization": authHeader,
- "Accept": "application/vnd.github.v3+json ",
- })
- resp = conn.getresponse()
- if not str(resp.status).startswith("2"):
- print("Error: %d" % (resp.status))
- print(resp.read())
- sys.exit(1)
- else:
- # https://docs.github.com/en/rest/reference/pulls#create-a-pull-request
- body = json.loads(resp.read().decode())
-
- open(os.environ.get('PULLREQUEST_NUMBER_PATH'), 'w').write(f'{body["number"]}')
- open(os.environ.get('PULLREQUEST_URL_PATH'), 'w').write(body["html_url"])
-
- print("GitHub pull request created for $(params.REPO_FULL_NAME): "
- f'number={body["number"]} url={body["html_url"]}')
----
-# Source: pipelines/templates/app-pipeline/tasks/task-mvn.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: build-tool
- name: maven
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to run a Maven build.
- params:
- - default: gcr.io/cloud-builders/mvn:3.5.0-jdk-8
- description: Maven base image
- name: MAVEN_IMAGE
- type: string
- - default:
- - package
- description: maven goals to run
- name: GOALS
- type: array
- - default: ''
- description: The Maven repository mirror url
- name: MAVEN_MIRROR_URL
- type: string
- - default: ''
- description: The username for the proxy server
- name: PROXY_USER
- type: string
- - default: ''
- description: The password for the proxy server
- name: PROXY_PASSWORD
- type: string
- - default: ''
- description: Port number for the proxy server
- name: PROXY_PORT
- type: string
- - default: ''
- description: Proxy server Host
- name: PROXY_HOST
- type: string
- - default: ''
- description: Non proxy server host
- name: PROXY_NON_PROXY_HOSTS
- type: string
- - default: http
- description: Protocol for the proxy ie http or https
- name: PROXY_PROTOCOL
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
- - description: The workspace consisting of the custom maven settings provided by the user.
- name: maven-settings
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi-minimal:latest'
- name: mvn-settings
- resources: {}
- script: >
- #!/usr/bin/env bash
-
-
- [[ -f $(workspaces.maven-settings.path)/settings.xml ]] && \
-
- echo 'using existing $(workspaces.maven-settings.path)/settings.xml' &&
- exit 0
-
-
- cat > $(workspaces.maven-settings.path)/settings.xml <
-
-
-
-
-
-
-
-
-
-
- EOF
-
-
- xml=""
-
- if [ -n "$(params.PROXY_HOST)" -a -n "$(params.PROXY_PORT)" ]; then
- xml="\
- genproxy\
- true\
- $(params.PROXY_PROTOCOL)\
- $(params.PROXY_HOST)\
- $(params.PROXY_PORT)"
- if [ -n "$(params.PROXY_USER)" -a -n "$(params.PROXY_PASSWORD)" ]; then
- xml="$xml\
- $(params.PROXY_USER)\
- $(params.PROXY_PASSWORD)"
- fi
- if [ -n "$(params.PROXY_NON_PROXY_HOSTS)" ]; then
- xml="$xml\
- $(params.PROXY_NON_PROXY_HOSTS)"
- fi
- xml="$xml\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
-
-
- if [ -n "$(params.MAVEN_MIRROR_URL)" ]; then
- xml=" \
- mirror.default\
- $(params.MAVEN_MIRROR_URL)\
- central\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
- - args:
- - -Dmaven.repo.local=$(workspaces.source.path)/.m2
- - '-s'
- - $(workspaces.maven-settings.path)/settings.xml
- - $(params.GOALS)
- command:
- - /usr/bin/mvn
- image: $(params.MAVEN_IMAGE)
- name: mvn-goals
- workingDir: $(workspaces.source.path)
- resources:
- requests:
- memory: 512Mi
- cpu: 200m
- limits:
- memory: 4Gi
- cpu: '1'
----
-# Source: pipelines/templates/app-pipeline/tasks/task-s2i-java-11-fixed.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/displayName: s2i java 11
- tekton.dev/pipelines.minVersion: 0.11.3
- tekton.dev/tags: s2i, java, workspace
- name: s2i-java-11-fixed
-spec:
- description: s2i-java-11 task clones a Git repository and builds and pushes a container
- image using S2I and a Java 11 builder image.
- params:
- - default: .
- description: The location of the path to run s2i from
- name: PATH_CONTEXT
- type: string
- - default: "true"
- description: Verify the TLS on the registry endpoint (for push/pull to a non-TLS
- registry)
- name: TLSVERIFY
- type: string
- - default: ""
- description: Additional Maven arguments
- name: MAVEN_ARGS_APPEND
- type: string
- - default: "false"
- description: Remove the Maven repository after the artifact is built
- name: MAVEN_CLEAR_REPO
- type: string
- - default: ""
- description: The base URL of a mirror used for retrieving artifacts
- name: MAVEN_MIRROR_URL
- type: string
- - description: Location of the repo where image has to be pushed
- name: IMAGE_NAME
- type: string
- - default: latest
- description: The tag of the image to be pushed
- name: IMAGE_TAG
- type: string
- results:
- - description: Digest of the image just built.
- name: IMAGE_DIGEST
- - description: URL of the image used by Tekton Chains to push the OCI images
- name: IMAGE_URL
- steps:
- - args:
- - |-
- echo "MAVEN_CLEAR_REPO=$(params.MAVEN_CLEAR_REPO)" > env-file
-
- [[ '$(params.MAVEN_ARGS_APPEND)' != "" ]] &&
- echo "MAVEN_ARGS_APPEND=$(params.MAVEN_ARGS_APPEND)" >> env-file
-
- [[ '$(params.MAVEN_MIRROR_URL)' != "" ]] &&
- echo "MAVEN_MIRROR_URL=$(params.MAVEN_MIRROR_URL)" >> env-file
-
- echo "Generated Env file"
- echo "------------------------------"
- cat env-file
- echo "------------------------------"
- command:
- - /bin/sh
- - -c
- image: registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: gen-env-file
- resources: {}
- volumeMounts:
- - mountPath: /env-params
- name: envparams
- workingDir: /env-params
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - s2i
- - build
- - $(params.PATH_CONTEXT)
- - image-registry.openshift-image-registry.svc:5000/openshift/java:11
- - --image-scripts-url
- - image:///usr/local/s2i
- - --as-dockerfile
- - /gen-source/Dockerfile.gen
- - --environment-file
- - /env-params/env-file
- image: registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: generate
- resources: {}
- volumeMounts:
- - mountPath: /gen-source
- name: gen-source
- - mountPath: /env-params
- name: envparams
- workingDir: $(workspaces.source.path)
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - bud
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --layers
- - -f
- - /gen-source/Dockerfile.gen
- - -t
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - -t
- - $(params.IMAGE_NAME):latest
- - .
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: build
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - /bin/sh
- - -c
- args:
- - |-
- buildah from --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) '$(params.IMAGE_NAME):$(params.IMAGE_TAG)' > imgname
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c `dnf update -y`
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *dnf*) $(rpm -qa *libsolv*) $(rpm -qa *hawkey*) $(rpm -qa yum*) $(rpm -qa *dnf*) $(rpm -qa *subscription-manager*)'
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *rpm*)'
- buildah commit --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) `cat imgname` '$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: update
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - /bin/sh
- - -c
- args:
- - |-
- buildah from --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) '$(params.IMAGE_NAME):$(params.IMAGE_TAG)' > imgname
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c `dnf update -y`
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *dnf*) $(rpm -qa *libsolv*) $(rpm -qa *hawkey*) $(rpm -qa yum*) $(rpm -qa *dnf*) $(rpm -qa *subscription-manager*)'
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *rpm*)'
- buildah commit --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) `cat imgname` '$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: remove-package-mgr
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - push
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - docker://$(params.IMAGE_NAME):$(params.IMAGE_TAG)
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-tag
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - push
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - docker://$(params.IMAGE_NAME):latest
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-latest
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: digest-to-results
- resources: {}
- script: cat $(workspaces.source.path)/image-digest | tee /tekton/results/IMAGE_DIGEST; echo quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic > /tekton/results/IMAGE_URL
- volumes:
- - emptyDir: {}
- name: varlibcontainers
- - emptyDir: {}
- name: gen-source
- - emptyDir: {}
- name: envparams
- workspaces:
- - mountPath: /workspace/source
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-s2i-java-11.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: s2i-java-11
- annotations:
- tekton.dev/displayName: s2i java 11
- tekton.dev/pipelines.minVersion: 0.11.3
- tekton.dev/tags: 's2i, java, workspace'
-spec:
- description: >-
- s2i-java-11 task clones a Git repository and builds and pushes a container
- image using S2I and a Java 11 builder image.
- params:
- - default: .
- description: The location of the path to run s2i from
- name: PATH_CONTEXT
- type: string
- - default: 'true'
- description: >-
- Verify the TLS on the registry endpoint (for push/pull to a non-TLS
- registry)
- name: TLSVERIFY
- type: string
- - default: ''
- description: Additional Maven arguments
- name: MAVEN_ARGS_APPEND
- type: string
- - default: 'false'
- description: Remove the Maven repository after the artifact is built
- name: MAVEN_CLEAR_REPO
- type: string
- - default: ''
- description: The base URL of a mirror used for retrieving artifacts
- name: MAVEN_MIRROR_URL
- type: string
- - description: Location of the repo where image has to be pushed
- name: IMAGE_NAME
- type: string
- - description: The tag of the image to be pushed
- name: IMAGE_TAG
- type: string
- default: "latest"
- results:
- - name: IMAGE_DIGEST
- description: Digest of the image just built.
- steps:
- - args:
- - |-
- echo "MAVEN_CLEAR_REPO=$(params.MAVEN_CLEAR_REPO)" > env-file
-
- [[ '$(params.MAVEN_ARGS_APPEND)' != "" ]] &&
- echo "MAVEN_ARGS_APPEND=$(params.MAVEN_ARGS_APPEND)" >> env-file
-
- [[ '$(params.MAVEN_MIRROR_URL)' != "" ]] &&
- echo "MAVEN_MIRROR_URL=$(params.MAVEN_MIRROR_URL)" >> env-file
-
- echo "Generated Env file"
- echo "------------------------------"
- cat env-file
- echo "------------------------------"
- command:
- - /bin/sh
- - '-c'
- image: >-
- registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: gen-env-file
- resources: {}
- volumeMounts:
- - mountPath: /env-params
- name: envparams
- workingDir: /env-params
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - s2i
- - build
- - $(params.PATH_CONTEXT)
- - 'image-registry.openshift-image-registry.svc:5000/openshift/java:11'
- - '--image-scripts-url'
- - 'image:///usr/local/s2i'
- - '--as-dockerfile'
- - /gen-source/Dockerfile.gen
- - '--environment-file'
- - /env-params/env-file
- image: >-
- registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: generate
- resources: {}
- volumeMounts:
- - mountPath: /gen-source
- name: gen-source
- - mountPath: /env-params
- name: envparams
- workingDir: $(workspaces.source.path)
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - buildah
- - bud
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - '--layers'
- - '-f'
- - /gen-source/Dockerfile.gen
- - '-t'
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - '-t'
- - $(params.IMAGE_NAME):latest
- - .
- image: >-
- registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: build
- resources: {}
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- - command:
- - buildah
- - push
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - 'docker://$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-tag
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - buildah
- - push
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - 'docker://$(params.IMAGE_NAME):latest'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-latest
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - name: digest-to-results
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- script: cat $(workspaces.source.path)/image-digest | tee /tekton/results/IMAGE_DIGEST
- volumes:
- - emptyDir: {}
- name: varlibcontainers
- - emptyDir: {}
- name: gen-source
- - emptyDir: {}
- name: envparams
- workspaces:
- - mountPath: /workspace/source
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-syft-sbom.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: build-tool
- name: syft-sbom
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to generate a SBOM file with Syft.
- params:
- - default: $(workspaces.source.path)
- description: Application folder to scan
- name: APP_PATH
- type: string
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi:latest'
- name: syft-scan
- resources: {}
- script: >
- #!/usr/bin/env bash
-
- echo '## Getting Syft ##'
-
- pwd
-
- curl -sSfL
- https://raw.githubusercontent.com/anchore/syft/main/install.sh | sh -s
- -- -b .
-
- chmod +x ./syft
-
- echo '## Scanning folder and generating SBOM ##'
-
- ./syft $(params.APP_PATH) -o spdx-json=sbom.json
-
- echo '## SBOM content ##'
-
- cat ./sbom.json
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-zap-proxy.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: zap-proxy
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- - name: APP_URL
- description: The application under test url
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- workspaces:
- - description: The workspace for the zap proxy task
- name: workspace
-
- steps:
- - name: zap-proxy
- image: quay.io/hybridcloudpatterns/zap2docker-stable
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- workingDir: $(workspaces.workspace.path)
- script: |
- #!/usr/bin/env bash
-
- set -x
-
- echo "Make the wrk directory available to save the reports"
- cd /zap
- mkdir /zap/wrk
-
- echo "Starting the pentesting..."
- /zap/zap-baseline.py -t $(params.APP_URL) -r $PIPELINERUN_NAME.html
-
- ls -lhrt /zap/wrk
-
- echo "Uploading the report into the report server"
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME/$PIPELINERUN_NAME.html -F file=@/zap/wrk/$PIPELINERUN_NAME.html -X POST $(params.REPORTS_REPO_HOST)/upload; echo ""
----
-# Source: pipelines/templates/chains/tekton-chain.yaml
-apiVersion: operator.tekton.dev/v1alpha1
-kind: TektonChain
-metadata:
- name: chain
-spec:
- targetNamespace: openshift-pipelines
diff --git a/tests/region-pipelines-naked.expected.yaml b/tests/region-pipelines-naked.expected.yaml
deleted file mode 100644
index 6b3101b2..00000000
--- a/tests/region-pipelines-naked.expected.yaml
+++ /dev/null
@@ -1,2472 +0,0 @@
----
-# Source: pipelines/templates/app-pipeline/rbac/pipeline-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-imagePullSecrets:
-- name: image-registry-credentials
-metadata:
- name: pipeline
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/syncOptions: ServerSideApply=true
-secrets:
- - name: acs-api-token
- - name: git-secret
- - name: quay-pull-secret
----
-# Source: pipelines/templates/app-pipeline/rbac/registry-credential-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-imagePullSecrets:
-- name: image-registry-credentials
-metadata:
- name: pipeline-svc
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-secrets:
- - name: quay-api-token
- - name: acs-api-token
- - name: quay-pull-secret
----
-# Source: pipelines/templates/app-pipeline/configmaps/argocd-en-cm.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: argocd-env-configmap
- namespace: devsecops-ci
-data:
- ARGOCD_SERVER: development-gitops-server.multicluster-devsecops-development.svc:443
----
-# Source: pipelines/templates/app-pipeline/configmaps/maven-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: maven-settings
-data:
- settings.xml: |
-
-
-
-
- nexus
- admin
- admin123
-
-
-
-
- nexus
- nexus
- http://nexus:8081/repository/maven-public/
- *
-
-
-
----
-# Source: pipelines/templates/chains/tekton-chains-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: chains-config
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-options: ServerSideApply=true
-data:
- artifacts.oci.storage: 'oci'
- artifacts.taskrun.format: tekton
- artifacts.taskrun.storage: tekton
- artifacts.oci.format: simplesigning
- artifacts.oci.signer: cosign
----
-# Source: pipelines/templates/environment.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: environment
-data:
- DESCRIPTION: "Config keys for openshift-pipelines"
----
-# Source: pipelines/templates/app-pipeline/storageclass/vp-storageClass.yaml
-apiVersion: storage.k8s.io/v1
-kind: StorageClass
-allowVolumeExpansion: true
-metadata:
- name: default-rwo-vp
-parameters:
- encrypted: "true"
- type: default-rwo
-provisioner:
-reclaimPolicy: Delete
-volumeBindingMode: Immediate
----
-# Source: pipelines/templates/app-pipeline/pvcs/pipeline-pvc.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- name: pipeline-pvc
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- resources:
- requests:
- storage: 5Gi
- storageClassName: gp3-csi
- volumeMode: Filesystem
- accessModes:
- - ReadWriteOnce
----
-# Source: pipelines/templates/app-pipeline/rbac/imagestream-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: imagestream-view
-rules:
-- apiGroups:
- - image.openshift.io
- resources:
- - imagestreams
- verbs:
- - get
-- apiGroups:
- - image.openshift.io
- resources:
- - imagestreamimports
- verbs:
- - create
----
-# Source: pipelines/templates/app-pipeline/tasks/task-crda-scan.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: crda-scan
-spec:
- params:
- - default: pom.xml
- description: the path and manifest that should be scanned
- name: manifest
- type: string
- - default: spring-petclinic
- description: application folder name
- name: application_folder
- type: string
- steps:
- - image: quay.io/jchraibi/crda-image:0.1
- name: crda-code-scan
- resources: {}
- script: >
- #!/usr/bin/env bash
-
- set +x
-
- export NO_COLOR="True"
-
- echo "---" echo "Installing tar"
-
- chmod +x /crda > /dev/null
-
- echo "## Scanning application manifest $(params.manifest)"
-
- /crda config set consent_telemetry false
-
- /crda auth -t b6eb51e7-af6c-4bdb-b006-3005711316ca
-
- /crda analyse
- $(workspaces.source.path)/$(params.application_folder)/$(params.manifest)
-
- echo "## Scan finished ##"
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-image-scan-task.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-image-scan
-spec:
- params:
- - name: rox_central_endpoint
- type: string
- description: the address:port tuple for StackRox Central (example - rox.stackrox.io:443)
- default: 'central-stackrox.:443'
- - name: rox_api_token
- type: string
- description: Secret containing the StackRox API token with CI permissions
- default: acs-api-token
- - name: image
- type: string
- description: Full name of image to scan (example -- gcr.io/rox/sample:5.0-rc1)
- - name: output_format
- type: string
- description: Output format (json | csv | table)
- default: json
- - name: image_digest
- description: Digest in sha256 hash format of the image to scan
- type: string
- steps:
- - name: rox-image-scan
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- name: $(params.rox_api_token)
- key: token
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- script: |
- #!/usr/bin/env bash
- set +x
- export NO_COLOR="True"
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN" https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output ./roxctl > /dev/null; echo "Getting roxctl"
- chmod +x ./roxctl > /dev/null
- echo "## Scanning image $(params.image)@$(params.image_digest)"
- ./roxctl image scan --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT --image $(params.image)@$(params.image_digest) --output $(params.output_format)
- echo "## Go to https://$ROX_CENTRAL_ENDPOINT/main/vulnerability-management/image/$(params.image_digest) to check more info"
----
-# Source: pipelines/templates/app-pipeline/tasks/task-rox-deployment-check.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-deployment-check
-spec:
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: rox_central_endpoint
- type: string
- description: Secret containing the address:port tuple for StackRox Central (example - rox.stackrox.io:443)
- default: 'central-stackrox.:443'
- - name: rox_api_token
- type: string
- default: acs-api-token
- description: Secret containing the StackRox API token with CI permissions
- - name: file
- type: string
- description: YAML file in the deployfiles workspace
- - name: deployment_files_path
- type: string
- description: Path/Folder for the k8s deployment files to check
- results:
- - name: check_output
- description: Output of `roxctl deployment check`
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
- steps:
-
- - name: git-clone
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- rm -rf git-update-digest-workdir
- git clone $(params.GIT_REPOSITORY) git-update-digest-workdir
- cd git-update-digest-workdir/$(params.deployment_files_path)
-
- - name: rox-deployment-check
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- workingDir: $(workspaces.workspace.path)
- env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- name: $(params.rox_api_token)
- key: token
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- script: |
- #!/usr/bin/env bash
- set +x
- cd git-update-digest-workdir/$(params.deployment_files_path)
- cat $(params.file)
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN" https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output ./roxctl > /dev/null; echo "Getting roxctl"
- chmod +x ./roxctl > /dev/null
- ./roxctl deployment check --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT -f $(params.file)
----
-# Source: pipelines/templates/app-pipeline/tasks/task-rox-image-check.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-image-check
-spec:
- params:
- - description: >-
- Secret containing the address:port tuple for StackRox Central (example -
- rox.stackrox.io:443)
- name: rox_central_endpoint
- default: 'central-stackrox.:443'
- type: string
- - description: Secret containing the StackRox API token with CI permissions
- name: rox_api_token
- type: string
- - description: 'Full name of image to scan (example -- gcr.io/rox/sample:5.0-rc1)'
- name: image
- type: string
- - name: image_digest
- description: Digest in sha256 hash format of the image to check
- type: string
- results:
- - description: Output of `roxctl image check`
- name: check_output
- steps:
- - env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- key: token
- name: $(params.rox_api_token)
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- name: rox-image-check
- resources: {}
- script: >-
- #!/usr/bin/env bash
-
- set +x
-
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN"
- https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output
- ./roxctl > /dev/null; echo "Getting roxctl"
-
- chmod +x ./roxctl > /dev/null
-
- ./roxctl image check --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT
- --image $(params.image)@$(params.image_digest)
----
-# Source: pipelines/templates/app-pipeline/imageStreams/imagestream-devsecops.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: spring-petclinic
- namespace: devsecops-ci
----
-# Source: pipelines/templates/app-pipeline/devsecops-rh-fixed.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: devsecops-rh-v2-fixed
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/staging
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: unit-tests
- params:
- - name: GOALS
- value:
- - package
- - -f
- - spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: code-analysis
- params:
- - name: GOALS
- value:
- - install
- - sonar:sonar
- - -f
- - spring-petclinic
- - -Dsonar.host.url=http://sonarqube:9000
- - -Dsonar.userHome=/tmp/sonar
- - -DskipTests=true
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: dependency-report
- params:
- - name: SOURCE_DIR
- value: spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: dependency-report
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - code-analysis
- - unit-tests
- - dependency-report
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- #jrickard - value: quay-registry-quay-quay-enterprise./openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise./devel/spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11-fixed
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise./openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise./devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise./openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise./devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: gogs
- - name: GIT_PASSWORD
- value: gogs
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- #jrickard-value: quay-registry-quay-quay-enterprise./openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise./devel/spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: crda-scan
- params:
- - name: manifest
- value: pom.xml
- runAfter:
- - source-clone
- taskRef:
- kind: ClusterTask
- name: crda-scan
- workspaces:
- - name: source
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/devsecops-rh.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: devsecops-rh-v2
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/staging
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: unit-tests
- params:
- - name: GOALS
- value:
- - package
- - -f
- - spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: code-analysis
- params:
- - name: GOALS
- value:
- - install
- - sonar:sonar
- - -f
- - spring-petclinic
- - -Dsonar.host.url=http://sonarqube:9000
- - -Dsonar.userHome=/tmp/sonar
- - -DskipTests=true
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: dependency-report
- params:
- - name: SOURCE_DIR
- value: spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: dependency-report
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - code-analysis
- - unit-tests
- - dependency-report
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- #jrickard - value: quay-registry-quay-quay-enterprise./openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise./devel/spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise./openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise./devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise./openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise./devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: gogs
- - name: GIT_PASSWORD
- value: gogs
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- #jrickard-value: quay-registry-quay-quay-enterprise./openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise./devel/spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: crda-scan
- params:
- - name: manifest
- value: pom.xml
- runAfter:
- - source-clone
- taskRef:
- kind: ClusterTask
- name: crda-scan
- workspaces:
- - name: source
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/simple-pipeline.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: simple-pipeline
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/stage
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - source-clone
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- value: quay-registry-quay-quay-enterprise./devel//spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- value: quay-registry-quay-quay-enterprise./devel//spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- value: quay-registry-quay-quay-enterprise./devel//spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- value: quay-registry-quay-quay-enterprise./devel//spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/tasks/task-create-promote-pull-request.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: create-promote-pull-request
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: GIT_USERNAME
- type: string
- - name: GIT_PASSWORD
- type: string
- - name: COPY_FROM_PATH
- type: string
- - name: COPY_TO_PATH
- type: string
- results:
- - description: The branch name used for pull-request
- name: branch_name
- steps:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- name: promote
- resources: {}
- script: >
- set -x
-
- rm -rf pull-request-workdir
-
- git clone $(params.GIT_REPOSITORY) pull-request-workdir
-
- cd pull-request-workdir
-
- git config user.email "pipelines-ci@redhat.com"
-
- git config user.name "pipelines-ci"
-
-
- branch_name=ci-$(context.taskRun.name)
-
- git checkout -b $branch_name
-
- echo -n "$branch_name" > $(results.branch_name.path)
-
-
- /bin/cp -rf $(params.COPY_FROM_PATH)/* $(params.COPY_TO_PATH)
-
-
- git status
-
- git add $(params.COPY_TO_PATH)
-
- git commit -m "[$(context.taskRun.name)] Promotion from
- $(params.COPY_FROM_PATH) to $(params.COPY_TO_PATH)"
-
-
- git remote add auth-origin $(echo $(params.GIT_REPOSITORY) | sed -E
- "s#http://(.*)#http://$(params.GIT_USERNAME):$(params.GIT_PASSWORD)@\1#g")
-
- git push -u auth-origin HEAD
- workingDir: $(workspaces.workspace.path)
- - image: quay.io/siamaksade/python-oc
- name: create-pull-request
- resources: {}
- script: >
- #!/usr/bin/env python3
-
-
- import os
-
- import requests
-
-
- gitea_user = "$(params.GIT_USERNAME)"
-
- gitea_pwd = "$(params.GIT_PASSWORD)"
-
- giteaURL = "http://gitea-AUTOMATED."
-
-
- branch_result = open("$(results.branch_name.path)")
-
- git_branch = branch_result.read()
-
- branch_result.close()
-
-
- print("Git server: " + giteaURL)
-
- print("Branch name: " + git_branch)
-
-
- pr_title = "[$(context.taskRun.name)] Promote to STAGE environment"
-
- pr_body = "TaskRun $(context.taskRun.name)\\nPromoting application from
- DEV to STAGE environment"
-
- data_pr = '{"base": "master","body": "' + pr_body + '","head": "' +
- git_branch + '","title": "' + pr_title + '"}'
-
- headers = {'Content-Type': 'application/json'}
-
- resp = requests.post(url = giteaURL + "/api/v1/repos/" + gitea_user +
- "/spring-petclinic-config/pulls",
- headers = headers,
- auth = (gitea_user, gitea_pwd),
- data = data_pr)
-
-
- if resp.status_code != 200:
- print("Error creating pull-request (status code: {})".format(resp.status_code))
- print(resp.content)
- else:
- print("Created pull-request.")
- workingDir: $(workspaces.workspace.path)
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
----
-# Source: pipelines/templates/app-pipeline/tasks/task-dependency-report.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: dependency-report
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
-spec:
- params:
- - name: SOURCE_DIR
- description: The directory within the workspace where application source is located
- default: "."
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- - default: ''
- description: The Maven repository mirror url
- name: MAVEN_MIRROR_URL
- type: string
- - default: ''
- description: The username for the proxy server
- name: PROXY_USER
- type: string
- - default: ''
- description: The password for the proxy server
- name: PROXY_PASSWORD
- type: string
- - default: ''
- description: Port number for the proxy server
- name: PROXY_PORT
- type: string
- - default: ''
- description: Proxy server Host
- name: PROXY_HOST
- type: string
- - default: ''
- description: Non proxy server host
- name: PROXY_NON_PROXY_HOSTS
- type: string
- - default: http
- description: Protocol for the proxy ie http or https
- name: PROXY_PROTOCOL
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
- - description: The workspace consisting of the custom maven settings provided by the user.
- name: maven-settings
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi-minimal:latest'
- name: mvn-settings
- resources: {}
- script: >
- #!/usr/bin/env bash
-
-
- [[ -f $(workspaces.maven-settings.path)/settings.xml ]] && \
-
- echo 'using existing $(workspaces.maven-settings.path)/settings.xml' &&
- exit 0
-
-
- cat > $(workspaces.maven-settings.path)/settings.xml <
-
-
-
-
-
-
-
-
-
-
- EOF
-
-
- xml=""
-
- if [ -n "$(params.PROXY_HOST)" -a -n "$(params.PROXY_PORT)" ]; then
- xml="\
- genproxy\
- true\
- $(params.PROXY_PROTOCOL)\
- $(params.PROXY_HOST)\
- $(params.PROXY_PORT)"
- if [ -n "$(params.PROXY_USER)" -a -n "$(params.PROXY_PASSWORD)" ]; then
- xml="$xml\
- $(params.PROXY_USER)\
- $(params.PROXY_PASSWORD)"
- fi
- if [ -n "$(params.PROXY_NON_PROXY_HOSTS)" ]; then
- xml="$xml\
- $(params.PROXY_NON_PROXY_HOSTS)"
- fi
- xml="$xml\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
-
-
- if [ -n "$(params.MAVEN_MIRROR_URL)" ]; then
- xml=" \
- mirror.default\
- $(params.MAVEN_MIRROR_URL)\
- central\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
- - args:
- - -Dmaven.repo.local=$(workspaces.source.path)/.m2
- - -f
- - $(params.SOURCE_DIR)
- - -s
- - $(workspaces.maven-settings.path)/settings.xml
- - site
- - -DskipTests=true
- command:
- - /usr/bin/mvn
- image: gcr.io/cloud-builders/mvn
- name: mvn-goals
- resources: {}
- workingDir: $(workspaces.source.path)
- - name: archive-site
- workingDir: $(workspaces.source.path)
- image: registry.access.redhat.com/ubi8/ubi:latest
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- script: |
- #!/usr/bin/env bash
-
- for f in $(find $(params.SOURCE_DIR)/target/site -type f); do
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME/${f} -X POST -F file=@${f} $(params.REPORTS_REPO_HOST)/upload; echo ""
- done
----
-# Source: pipelines/templates/app-pipeline/tasks/task-gatling.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: gatling
-spec:
- params:
- - name: DURATION
- description: The duration of running simulations
- type: string
- default: "30"
- - name: CONCURRENT_USERS
- description: The number of concurrent users
- type: string
- default: "10"
- - name: APP_URL
- description: The application under test url
- type: string
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- workspaces:
- - description: The workspace consisting of maven project.
- name: simulations
- steps:
- - name: run-tests
- image: quay.io/hybridcloudpatterns/gatling:latest
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- script: |
- #!/usr/bin/env bash
-
- set -x
-
- cd /opt/gatling/
- ls -lhrt
-
- # set simulation params
- export JAVA_OPTS="-DtestDuration=$(params.CONCURRENT_USERS) -DuserCount=$(params.DURATION) -Dserver=$(params.APP_URL)"
-
- # run simulation
- /opt/gatling/bin/gatling.sh -rd "Spring PetClinic Performance Test" -sf $(workspaces.simulations.path)
-
- # upload results
- REPORT=$(ls -td /opt/gatling/results/* | head -1)
- for f in $(find $REPORT/ -type f); do
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME${f#/opt/gatling/results} -X POST -F file=@${f} $(params.REPORTS_REPO_HOST)/upload; echo ""
- done
----
-# Source: pipelines/templates/app-pipeline/tasks/task-git-update-deployment.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: git-update-deployment
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: GIT_USERNAME
- type: string
- - name: GIT_PASSWORD
- type: string
- - name: CURRENT_IMAGE
- type: string
- - name: NEW_IMAGE
- type: string
- - name: NEW_DIGEST
- type: string
- - name: KUSTOMIZATION_PATH
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
-
- results:
- - name: commit
- description: The commit SHA
-
- steps:
- - name: git-clone
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- rm -rf git-update-digest-workdir
- git clone $(params.GIT_REPOSITORY) git-update-digest-workdir
-
- - name: update-digest
- image: k8s.gcr.io/kustomize/kustomize:v3.8.7
- workingDir: $(workspaces.workspace.path)
- script: |
- cd git-update-digest-workdir/$(params.KUSTOMIZATION_PATH)
- /app/kustomize edit set image $(params.CURRENT_IMAGE)=$(params.NEW_IMAGE)@$(params.NEW_DIGEST)
-
- echo "##########################"
- echo "### kustomization.yaml ###"
- echo "##########################"
- cat kustomization.yaml
-
- - name: git-commit
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- cd git-update-digest-workdir
- git config user.email "tekton-pipelines-ci@redhat.com"
- git config user.name "tekton-pipelines-ci"
-
- git status
- git add $(params.KUSTOMIZATION_PATH)/kustomization.yaml
- # git commit -m "[$(context.pipelineRun.name)] Image digest updated"
- git commit -m "[ci] Image digest updated"
-
- git remote add auth-origin $(echo $(params.GIT_REPOSITORY) | sed -E "s#http://(.*)#http://$(params.GIT_USERNAME):$(params.GIT_PASSWORD)@\1#g")
- git push auth-origin main
-
- RESULT_SHA="$(git rev-parse HEAD | tr -d '\n')"
- EXIT_CODE="$?"
- if [ "$EXIT_CODE" != 0 ]
- then
- exit $EXIT_CODE
- fi
- # Make sure we don't add a trailing newline to the result!
- echo -n "$RESULT_SHA" > $(results.commit.path)
----
-# Source: pipelines/templates/app-pipeline/tasks/task-github-pull-request.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: github-open-pr
- labels:
- app.kubernetes.io/version: "0.2"
- annotations:
- tekton.dev/categories: Git
- tekton.dev/pipelines.minVersion: "0.12.1"
- tekton.dev/tags: github
- tekton.dev/displayName: "open github pull request"
- tekton.dev/platforms: "linux/amd64,linux/s390x,linux/ppc64le"
-spec:
- description: >-
- This task will open a PR on Github based on several parameters.
- This could be useful in GitOps repositories for example.
-
- params:
- - name: GITHUB_HOST_URL
- description: |
- The GitHub host, adjust this if you run a GitHub enteprise.
- default: "api.github.com"
- type: string
-
- - name: API_PATH_PREFIX
- description: |
- The API path prefix, GitHub Enterprise has a prefix e.g. /api/v3
- default: ""
- type: string
-
- - name: REPO_FULL_NAME
- description: |
- The GitHub repository full name, e.g.: tektoncd/catalog
- type: string
-
- - name: GITHUB_TOKEN_SECRET_NAME
- description: |
- The name of the kubernetes secret that contains the GitHub token, default: github
- type: string
- default: github
-
- - name: GITHUB_TOKEN_SECRET_KEY
- description: |
- The key within the kubernetes secret that contains the GitHub token, default: token
- type: string
- default: token
-
- - name: AUTH_TYPE
- description: |
- The type of authentication to use. You could use the less secure "Basic" for example
- type: string
- default: Bearer
-
- - name: HEAD
- description: |
- The name of the branch where your changes are implemented.
- type: string
-
- - name: BASE
- description: |
- The name of the branch you want the changes pulled into.
- type: string
-
- - name: BODY
- description: |
- The body description of the pull request.
- type: string
-
- - name: TITLE
- description: |
- The title of the pull request.
- type: string
-
- results:
- - name: NUMBER
- description: Number of the created pull request.
-
- - name: URL
- description: URL of the created pull request.
-
- volumes:
- - name: githubtoken
- secret:
- secretName: $(params.GITHUB_TOKEN_SECRET_NAME)
-
- steps:
- - name: open-pr
- volumeMounts:
- - name: githubtoken
- readOnly: true
- mountPath: /etc/github-open-pr
- env:
- - name: PULLREQUEST_NUMBER_PATH
- value: $(results.NUMBER.path)
- - name: PULLREQUEST_URL_PATH
- value: $(results.URL.path)
-
- image: registry.access.redhat.com/ubi8/python-38:1-34.1599745032
- script: |
- #!/usr/libexec/platform-python
-
- """This script will open a PR on Github"""
-
- import json
- import os
- import sys
- import http.client
-
- github_token = open("/etc/github-open-pr/$(params.GITHUB_TOKEN_SECRET_KEY)", "r").read()
-
- open_pr_url = "$(params.API_PATH_PREFIX)" + "/repos/$(params.REPO_FULL_NAME)/pulls"
-
- data = {
- "head": "$(params.HEAD)",
- "base": "$(params.BASE)",
- "title": "$(params.TITLE)",
- "body": """$(params.BODY)"""
- }
- print("Sending this data to GitHub: ")
- print(data)
-
- authHeader = "$(params.AUTH_TYPE) " + github_token
-
- # This is for our fake github server
- if "$(params.GITHUB_HOST_URL)".startswith("http://"):
- conn = http.client.HTTPConnection("$(params.GITHUB_HOST_URL)"
- .replace("http://", ""))
- else:
- conn = http.client.HTTPSConnection("$(params.GITHUB_HOST_URL)")
-
- conn.request(
- "POST",
- open_pr_url,
- body=json.dumps(data),
- headers={
- "User-Agent": "TektonCD, the peaceful cat",
- "Authorization": authHeader,
- "Accept": "application/vnd.github.v3+json ",
- })
- resp = conn.getresponse()
- if not str(resp.status).startswith("2"):
- print("Error: %d" % (resp.status))
- print(resp.read())
- sys.exit(1)
- else:
- # https://docs.github.com/en/rest/reference/pulls#create-a-pull-request
- body = json.loads(resp.read().decode())
-
- open(os.environ.get('PULLREQUEST_NUMBER_PATH'), 'w').write(f'{body["number"]}')
- open(os.environ.get('PULLREQUEST_URL_PATH'), 'w').write(body["html_url"])
-
- print("GitHub pull request created for $(params.REPO_FULL_NAME): "
- f'number={body["number"]} url={body["html_url"]}')
----
-# Source: pipelines/templates/app-pipeline/tasks/task-mvn.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: build-tool
- name: maven
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to run a Maven build.
- params:
- - default: gcr.io/cloud-builders/mvn:3.5.0-jdk-8
- description: Maven base image
- name: MAVEN_IMAGE
- type: string
- - default:
- - package
- description: maven goals to run
- name: GOALS
- type: array
- - default: ''
- description: The Maven repository mirror url
- name: MAVEN_MIRROR_URL
- type: string
- - default: ''
- description: The username for the proxy server
- name: PROXY_USER
- type: string
- - default: ''
- description: The password for the proxy server
- name: PROXY_PASSWORD
- type: string
- - default: ''
- description: Port number for the proxy server
- name: PROXY_PORT
- type: string
- - default: ''
- description: Proxy server Host
- name: PROXY_HOST
- type: string
- - default: ''
- description: Non proxy server host
- name: PROXY_NON_PROXY_HOSTS
- type: string
- - default: http
- description: Protocol for the proxy ie http or https
- name: PROXY_PROTOCOL
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
- - description: The workspace consisting of the custom maven settings provided by the user.
- name: maven-settings
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi-minimal:latest'
- name: mvn-settings
- resources: {}
- script: >
- #!/usr/bin/env bash
-
-
- [[ -f $(workspaces.maven-settings.path)/settings.xml ]] && \
-
- echo 'using existing $(workspaces.maven-settings.path)/settings.xml' &&
- exit 0
-
-
- cat > $(workspaces.maven-settings.path)/settings.xml <
-
-
-
-
-
-
-
-
-
-
- EOF
-
-
- xml=""
-
- if [ -n "$(params.PROXY_HOST)" -a -n "$(params.PROXY_PORT)" ]; then
- xml="\
- genproxy\
- true\
- $(params.PROXY_PROTOCOL)\
- $(params.PROXY_HOST)\
- $(params.PROXY_PORT)"
- if [ -n "$(params.PROXY_USER)" -a -n "$(params.PROXY_PASSWORD)" ]; then
- xml="$xml\
- $(params.PROXY_USER)\
- $(params.PROXY_PASSWORD)"
- fi
- if [ -n "$(params.PROXY_NON_PROXY_HOSTS)" ]; then
- xml="$xml\
- $(params.PROXY_NON_PROXY_HOSTS)"
- fi
- xml="$xml\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
-
-
- if [ -n "$(params.MAVEN_MIRROR_URL)" ]; then
- xml=" \
- mirror.default\
- $(params.MAVEN_MIRROR_URL)\
- central\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
- - args:
- - -Dmaven.repo.local=$(workspaces.source.path)/.m2
- - '-s'
- - $(workspaces.maven-settings.path)/settings.xml
- - $(params.GOALS)
- command:
- - /usr/bin/mvn
- image: $(params.MAVEN_IMAGE)
- name: mvn-goals
- workingDir: $(workspaces.source.path)
- resources:
- requests:
- memory: 512Mi
- cpu: 200m
- limits:
- memory: 4Gi
- cpu: '1'
----
-# Source: pipelines/templates/app-pipeline/tasks/task-s2i-java-11-fixed.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/displayName: s2i java 11
- tekton.dev/pipelines.minVersion: 0.11.3
- tekton.dev/tags: s2i, java, workspace
- name: s2i-java-11-fixed
-spec:
- description: s2i-java-11 task clones a Git repository and builds and pushes a container
- image using S2I and a Java 11 builder image.
- params:
- - default: .
- description: The location of the path to run s2i from
- name: PATH_CONTEXT
- type: string
- - default: "true"
- description: Verify the TLS on the registry endpoint (for push/pull to a non-TLS
- registry)
- name: TLSVERIFY
- type: string
- - default: ""
- description: Additional Maven arguments
- name: MAVEN_ARGS_APPEND
- type: string
- - default: "false"
- description: Remove the Maven repository after the artifact is built
- name: MAVEN_CLEAR_REPO
- type: string
- - default: ""
- description: The base URL of a mirror used for retrieving artifacts
- name: MAVEN_MIRROR_URL
- type: string
- - description: Location of the repo where image has to be pushed
- name: IMAGE_NAME
- type: string
- - default: latest
- description: The tag of the image to be pushed
- name: IMAGE_TAG
- type: string
- results:
- - description: Digest of the image just built.
- name: IMAGE_DIGEST
- - description: URL of the image used by Tekton Chains to push the OCI images
- name: IMAGE_URL
- steps:
- - args:
- - |-
- echo "MAVEN_CLEAR_REPO=$(params.MAVEN_CLEAR_REPO)" > env-file
-
- [[ '$(params.MAVEN_ARGS_APPEND)' != "" ]] &&
- echo "MAVEN_ARGS_APPEND=$(params.MAVEN_ARGS_APPEND)" >> env-file
-
- [[ '$(params.MAVEN_MIRROR_URL)' != "" ]] &&
- echo "MAVEN_MIRROR_URL=$(params.MAVEN_MIRROR_URL)" >> env-file
-
- echo "Generated Env file"
- echo "------------------------------"
- cat env-file
- echo "------------------------------"
- command:
- - /bin/sh
- - -c
- image: registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: gen-env-file
- resources: {}
- volumeMounts:
- - mountPath: /env-params
- name: envparams
- workingDir: /env-params
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - s2i
- - build
- - $(params.PATH_CONTEXT)
- - image-registry.openshift-image-registry.svc:5000/openshift/java:11
- - --image-scripts-url
- - image:///usr/local/s2i
- - --as-dockerfile
- - /gen-source/Dockerfile.gen
- - --environment-file
- - /env-params/env-file
- image: registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: generate
- resources: {}
- volumeMounts:
- - mountPath: /gen-source
- name: gen-source
- - mountPath: /env-params
- name: envparams
- workingDir: $(workspaces.source.path)
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - bud
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --layers
- - -f
- - /gen-source/Dockerfile.gen
- - -t
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - -t
- - $(params.IMAGE_NAME):latest
- - .
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: build
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - /bin/sh
- - -c
- args:
- - |-
- buildah from --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) '$(params.IMAGE_NAME):$(params.IMAGE_TAG)' > imgname
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c `dnf update -y`
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *dnf*) $(rpm -qa *libsolv*) $(rpm -qa *hawkey*) $(rpm -qa yum*) $(rpm -qa *dnf*) $(rpm -qa *subscription-manager*)'
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *rpm*)'
- buildah commit --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) `cat imgname` '$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: update
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - /bin/sh
- - -c
- args:
- - |-
- buildah from --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) '$(params.IMAGE_NAME):$(params.IMAGE_TAG)' > imgname
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c `dnf update -y`
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *dnf*) $(rpm -qa *libsolv*) $(rpm -qa *hawkey*) $(rpm -qa yum*) $(rpm -qa *dnf*) $(rpm -qa *subscription-manager*)'
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *rpm*)'
- buildah commit --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) `cat imgname` '$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: remove-package-mgr
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - push
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - docker://$(params.IMAGE_NAME):$(params.IMAGE_TAG)
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-tag
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - push
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - docker://$(params.IMAGE_NAME):latest
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-latest
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: digest-to-results
- resources: {}
- script: cat $(workspaces.source.path)/image-digest | tee /tekton/results/IMAGE_DIGEST; echo quay-registry-quay-quay-enterprise./openshift_AUTOMATED/spring-petclinic > /tekton/results/IMAGE_URL
- volumes:
- - emptyDir: {}
- name: varlibcontainers
- - emptyDir: {}
- name: gen-source
- - emptyDir: {}
- name: envparams
- workspaces:
- - mountPath: /workspace/source
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-s2i-java-11.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: s2i-java-11
- annotations:
- tekton.dev/displayName: s2i java 11
- tekton.dev/pipelines.minVersion: 0.11.3
- tekton.dev/tags: 's2i, java, workspace'
-spec:
- description: >-
- s2i-java-11 task clones a Git repository and builds and pushes a container
- image using S2I and a Java 11 builder image.
- params:
- - default: .
- description: The location of the path to run s2i from
- name: PATH_CONTEXT
- type: string
- - default: 'true'
- description: >-
- Verify the TLS on the registry endpoint (for push/pull to a non-TLS
- registry)
- name: TLSVERIFY
- type: string
- - default: ''
- description: Additional Maven arguments
- name: MAVEN_ARGS_APPEND
- type: string
- - default: 'false'
- description: Remove the Maven repository after the artifact is built
- name: MAVEN_CLEAR_REPO
- type: string
- - default: ''
- description: The base URL of a mirror used for retrieving artifacts
- name: MAVEN_MIRROR_URL
- type: string
- - description: Location of the repo where image has to be pushed
- name: IMAGE_NAME
- type: string
- - description: The tag of the image to be pushed
- name: IMAGE_TAG
- type: string
- default: "latest"
- results:
- - name: IMAGE_DIGEST
- description: Digest of the image just built.
- steps:
- - args:
- - |-
- echo "MAVEN_CLEAR_REPO=$(params.MAVEN_CLEAR_REPO)" > env-file
-
- [[ '$(params.MAVEN_ARGS_APPEND)' != "" ]] &&
- echo "MAVEN_ARGS_APPEND=$(params.MAVEN_ARGS_APPEND)" >> env-file
-
- [[ '$(params.MAVEN_MIRROR_URL)' != "" ]] &&
- echo "MAVEN_MIRROR_URL=$(params.MAVEN_MIRROR_URL)" >> env-file
-
- echo "Generated Env file"
- echo "------------------------------"
- cat env-file
- echo "------------------------------"
- command:
- - /bin/sh
- - '-c'
- image: >-
- registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: gen-env-file
- resources: {}
- volumeMounts:
- - mountPath: /env-params
- name: envparams
- workingDir: /env-params
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - s2i
- - build
- - $(params.PATH_CONTEXT)
- - 'image-registry.openshift-image-registry.svc:5000/openshift/java:11'
- - '--image-scripts-url'
- - 'image:///usr/local/s2i'
- - '--as-dockerfile'
- - /gen-source/Dockerfile.gen
- - '--environment-file'
- - /env-params/env-file
- image: >-
- registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: generate
- resources: {}
- volumeMounts:
- - mountPath: /gen-source
- name: gen-source
- - mountPath: /env-params
- name: envparams
- workingDir: $(workspaces.source.path)
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - buildah
- - bud
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - '--layers'
- - '-f'
- - /gen-source/Dockerfile.gen
- - '-t'
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - '-t'
- - $(params.IMAGE_NAME):latest
- - .
- image: >-
- registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: build
- resources: {}
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- - command:
- - buildah
- - push
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - 'docker://$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-tag
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - buildah
- - push
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - 'docker://$(params.IMAGE_NAME):latest'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-latest
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - name: digest-to-results
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- script: cat $(workspaces.source.path)/image-digest | tee /tekton/results/IMAGE_DIGEST
- volumes:
- - emptyDir: {}
- name: varlibcontainers
- - emptyDir: {}
- name: gen-source
- - emptyDir: {}
- name: envparams
- workspaces:
- - mountPath: /workspace/source
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-syft-sbom.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: build-tool
- name: syft-sbom
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to generate a SBOM file with Syft.
- params:
- - default: $(workspaces.source.path)
- description: Application folder to scan
- name: APP_PATH
- type: string
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi:latest'
- name: syft-scan
- resources: {}
- script: >
- #!/usr/bin/env bash
-
- echo '## Getting Syft ##'
-
- pwd
-
- curl -sSfL
- https://raw.githubusercontent.com/anchore/syft/main/install.sh | sh -s
- -- -b .
-
- chmod +x ./syft
-
- echo '## Scanning folder and generating SBOM ##'
-
- ./syft $(params.APP_PATH) -o spdx-json=sbom.json
-
- echo '## SBOM content ##'
-
- cat ./sbom.json
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-zap-proxy.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: zap-proxy
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- - name: APP_URL
- description: The application under test url
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- workspaces:
- - description: The workspace for the zap proxy task
- name: workspace
-
- steps:
- - name: zap-proxy
- image: quay.io/hybridcloudpatterns/zap2docker-stable
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- workingDir: $(workspaces.workspace.path)
- script: |
- #!/usr/bin/env bash
-
- set -x
-
- echo "Make the wrk directory available to save the reports"
- cd /zap
- mkdir /zap/wrk
-
- echo "Starting the pentesting..."
- /zap/zap-baseline.py -t $(params.APP_URL) -r $PIPELINERUN_NAME.html
-
- ls -lhrt /zap/wrk
-
- echo "Uploading the report into the report server"
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME/$PIPELINERUN_NAME.html -F file=@/zap/wrk/$PIPELINERUN_NAME.html -X POST $(params.REPORTS_REPO_HOST)/upload; echo ""
----
-# Source: pipelines/templates/chains/tekton-chain.yaml
-apiVersion: operator.tekton.dev/v1alpha1
-kind: TektonChain
-metadata:
- name: chain
-spec:
- targetNamespace: openshift-pipelines
diff --git a/tests/region-pipelines-normal.expected.yaml b/tests/region-pipelines-normal.expected.yaml
deleted file mode 100644
index c5fab07f..00000000
--- a/tests/region-pipelines-normal.expected.yaml
+++ /dev/null
@@ -1,2472 +0,0 @@
----
-# Source: pipelines/templates/app-pipeline/rbac/pipeline-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-imagePullSecrets:
-- name: image-registry-credentials
-metadata:
- name: pipeline
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
- argocd.argoproj.io/syncOptions: ServerSideApply=true
-secrets:
- - name: acs-api-token
- - name: git-secret
- - name: quay-pull-secret
----
-# Source: pipelines/templates/app-pipeline/rbac/registry-credential-sa.yaml
-apiVersion: v1
-kind: ServiceAccount
-imagePullSecrets:
-- name: image-registry-credentials
-metadata:
- name: pipeline-svc
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-secrets:
- - name: quay-api-token
- - name: acs-api-token
- - name: quay-pull-secret
----
-# Source: pipelines/templates/app-pipeline/configmaps/argocd-en-cm.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: argocd-env-configmap
- namespace: devsecops-ci
-data:
- ARGOCD_SERVER: development-gitops-server.mypattern-development.svc:443
----
-# Source: pipelines/templates/app-pipeline/configmaps/maven-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: maven-settings
-data:
- settings.xml: |
-
-
-
-
- nexus
- admin
- admin123
-
-
-
-
- nexus
- nexus
- http://nexus:8081/repository/maven-public/
- *
-
-
-
----
-# Source: pipelines/templates/chains/tekton-chains-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: chains-config
- namespace: openshift-pipelines
- annotations:
- argocd.argoproj.io/sync-options: PruneLast=true
- argocd.argoproj.io/sync-options: ServerSideApply=true
-data:
- artifacts.oci.storage: 'oci'
- artifacts.taskrun.format: tekton
- artifacts.taskrun.storage: tekton
- artifacts.oci.format: simplesigning
- artifacts.oci.signer: cosign
----
-# Source: pipelines/templates/environment.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: environment
-data:
- DESCRIPTION: "Config keys for openshift-pipelines"
----
-# Source: pipelines/templates/app-pipeline/storageclass/vp-storageClass.yaml
-apiVersion: storage.k8s.io/v1
-kind: StorageClass
-allowVolumeExpansion: true
-metadata:
- name: default-rwo-vp
-parameters:
- encrypted: "true"
- type: default-rwo
-provisioner:
-reclaimPolicy: Delete
-volumeBindingMode: Immediate
----
-# Source: pipelines/templates/app-pipeline/pvcs/pipeline-pvc.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- name: pipeline-pvc
- namespace: devsecops-ci
- annotations:
- argocd.argoproj.io/compare-options: IgnoreExtraneous
-spec:
- resources:
- requests:
- storage: 5Gi
- storageClassName: gp3-csi
- volumeMode: Filesystem
- accessModes:
- - ReadWriteOnce
----
-# Source: pipelines/templates/app-pipeline/rbac/imagestream-role.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: Role
-metadata:
- name: imagestream-view
-rules:
-- apiGroups:
- - image.openshift.io
- resources:
- - imagestreams
- verbs:
- - get
-- apiGroups:
- - image.openshift.io
- resources:
- - imagestreamimports
- verbs:
- - create
----
-# Source: pipelines/templates/app-pipeline/tasks/task-crda-scan.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: crda-scan
-spec:
- params:
- - default: pom.xml
- description: the path and manifest that should be scanned
- name: manifest
- type: string
- - default: spring-petclinic
- description: application folder name
- name: application_folder
- type: string
- steps:
- - image: quay.io/jchraibi/crda-image:0.1
- name: crda-code-scan
- resources: {}
- script: >
- #!/usr/bin/env bash
-
- set +x
-
- export NO_COLOR="True"
-
- echo "---" echo "Installing tar"
-
- chmod +x /crda > /dev/null
-
- echo "## Scanning application manifest $(params.manifest)"
-
- /crda config set consent_telemetry false
-
- /crda auth -t b6eb51e7-af6c-4bdb-b006-3005711316ca
-
- /crda analyse
- $(workspaces.source.path)/$(params.application_folder)/$(params.manifest)
-
- echo "## Scan finished ##"
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-image-scan-task.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-image-scan
-spec:
- params:
- - name: rox_central_endpoint
- type: string
- description: the address:port tuple for StackRox Central (example - rox.stackrox.io:443)
- default: 'central-stackrox.apps.hub.example.com:443'
- - name: rox_api_token
- type: string
- description: Secret containing the StackRox API token with CI permissions
- default: acs-api-token
- - name: image
- type: string
- description: Full name of image to scan (example -- gcr.io/rox/sample:5.0-rc1)
- - name: output_format
- type: string
- description: Output format (json | csv | table)
- default: json
- - name: image_digest
- description: Digest in sha256 hash format of the image to scan
- type: string
- steps:
- - name: rox-image-scan
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- name: $(params.rox_api_token)
- key: token
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- script: |
- #!/usr/bin/env bash
- set +x
- export NO_COLOR="True"
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN" https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output ./roxctl > /dev/null; echo "Getting roxctl"
- chmod +x ./roxctl > /dev/null
- echo "## Scanning image $(params.image)@$(params.image_digest)"
- ./roxctl image scan --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT --image $(params.image)@$(params.image_digest) --output $(params.output_format)
- echo "## Go to https://$ROX_CENTRAL_ENDPOINT/main/vulnerability-management/image/$(params.image_digest) to check more info"
----
-# Source: pipelines/templates/app-pipeline/tasks/task-rox-deployment-check.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-deployment-check
-spec:
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: rox_central_endpoint
- type: string
- description: Secret containing the address:port tuple for StackRox Central (example - rox.stackrox.io:443)
- default: 'central-stackrox.apps.hub.example.com:443'
- - name: rox_api_token
- type: string
- default: acs-api-token
- description: Secret containing the StackRox API token with CI permissions
- - name: file
- type: string
- description: YAML file in the deployfiles workspace
- - name: deployment_files_path
- type: string
- description: Path/Folder for the k8s deployment files to check
- results:
- - name: check_output
- description: Output of `roxctl deployment check`
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
- steps:
-
- - name: git-clone
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- rm -rf git-update-digest-workdir
- git clone $(params.GIT_REPOSITORY) git-update-digest-workdir
- cd git-update-digest-workdir/$(params.deployment_files_path)
-
- - name: rox-deployment-check
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- workingDir: $(workspaces.workspace.path)
- env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- name: $(params.rox_api_token)
- key: token
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- script: |
- #!/usr/bin/env bash
- set +x
- cd git-update-digest-workdir/$(params.deployment_files_path)
- cat $(params.file)
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN" https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output ./roxctl > /dev/null; echo "Getting roxctl"
- chmod +x ./roxctl > /dev/null
- ./roxctl deployment check --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT -f $(params.file)
----
-# Source: pipelines/templates/app-pipeline/tasks/task-rox-image-check.yaml
-apiVersion: tekton.dev/v1beta1
-kind: ClusterTask
-metadata:
- name: rox-image-check
-spec:
- params:
- - description: >-
- Secret containing the address:port tuple for StackRox Central (example -
- rox.stackrox.io:443)
- name: rox_central_endpoint
- default: 'central-stackrox.apps.hub.example.com:443'
- type: string
- - description: Secret containing the StackRox API token with CI permissions
- name: rox_api_token
- type: string
- - description: 'Full name of image to scan (example -- gcr.io/rox/sample:5.0-rc1)'
- name: image
- type: string
- - name: image_digest
- description: Digest in sha256 hash format of the image to check
- type: string
- results:
- - description: Output of `roxctl image check`
- name: check_output
- steps:
- - env:
- - name: ROX_API_TOKEN
- valueFrom:
- secretKeyRef:
- key: token
- name: $(params.rox_api_token)
- - name: ROX_CENTRAL_ENDPOINT
- value: $(params.rox_central_endpoint)
- image: registry.access.redhat.com/ubi8/ubi-minimal:latest
- name: rox-image-check
- resources: {}
- script: >-
- #!/usr/bin/env bash
-
- set +x
-
- curl -k -L -H "Authorization: Bearer $ROX_API_TOKEN"
- https://$ROX_CENTRAL_ENDPOINT/api/cli/download/roxctl-linux --output
- ./roxctl > /dev/null; echo "Getting roxctl"
-
- chmod +x ./roxctl > /dev/null
-
- ./roxctl image check --insecure-skip-tls-verify -e $ROX_CENTRAL_ENDPOINT
- --image $(params.image)@$(params.image_digest)
----
-# Source: pipelines/templates/app-pipeline/imageStreams/imagestream-devsecops.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: spring-petclinic
- namespace: devsecops-ci
----
-# Source: pipelines/templates/app-pipeline/devsecops-rh-fixed.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: devsecops-rh-v2-fixed
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/staging
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: unit-tests
- params:
- - name: GOALS
- value:
- - package
- - -f
- - spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: code-analysis
- params:
- - name: GOALS
- value:
- - install
- - sonar:sonar
- - -f
- - spring-petclinic
- - -Dsonar.host.url=http://sonarqube:9000
- - -Dsonar.userHome=/tmp/sonar
- - -DskipTests=true
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: dependency-report
- params:
- - name: SOURCE_DIR
- value: spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: dependency-report
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - code-analysis
- - unit-tests
- - dependency-report
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11-fixed
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: gogs
- - name: GIT_PASSWORD
- value: gogs
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- #jrickard-value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: crda-scan
- params:
- - name: manifest
- value: pom.xml
- runAfter:
- - source-clone
- taskRef:
- kind: ClusterTask
- name: crda-scan
- workspaces:
- - name: source
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/devsecops-rh.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: devsecops-rh-v2
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/staging
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: unit-tests
- params:
- - name: GOALS
- value:
- - package
- - -f
- - spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: code-analysis
- params:
- - name: GOALS
- value:
- - install
- - sonar:sonar
- - -f
- - spring-petclinic
- - -Dsonar.host.url=http://sonarqube:9000
- - -Dsonar.userHome=/tmp/sonar
- - -DskipTests=true
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: dependency-report
- params:
- - name: SOURCE_DIR
- value: spring-petclinic
- runAfter:
- - crda-scan
- taskRef:
- kind: Task
- name: dependency-report
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - code-analysis
- - unit-tests
- - dependency-report
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- #jrickard - value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
-# jrickard removed
-# - name: rox_central_endpoint
-# value: roxsecrets
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: gogs
- - name: GIT_PASSWORD
- value: gogs
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- #jrickard-value: quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel/spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: crda-scan
- params:
- - name: manifest
- value: pom.xml
- runAfter:
- - source-clone
- taskRef:
- kind: ClusterTask
- name: crda-scan
- workspaces:
- - name: source
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/simple-pipeline.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Pipeline
-metadata:
- name: simple-pipeline
-spec:
- params:
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic
- description: The application git repository
- name: APP_SOURCE_GIT
- type: string
- - default: main
- description: The application git revision
- name: APP_SOURCE_REVISION
- type: string
- - default: https://github.com/hybrid-cloud-demos/spring-petclinic-config
- description: The application manifests git repository
- name: APP_MANIFESTS_GIT
- type: string
- - default: latest
- description: The application image tag to build
- name: APP_IMAGE_TAG
- type: string
- - default: devsecops-dev
- description: The namespace for Stage environments
- name: DEV_NAMESPACE
- type: string
- - default: https://github.com/hybrid-cloud-patterns/spring-petclinic-gatling
- description: The application test cases git repository
- name: APP_TESTS_GIT
- type: string
- - description: Git username to update GitOps files
- name: GIT_USERNAME
- type: string
- default: PLAINTEXT
- - description: Git password to update GitOps files
- name: GIT_PASSWORD
- type: string
- default: openshift
- - description: Copy FROM path
- name: FROM_PATH
- type: string
- default: environments/dev
- - description: Copy TO path
- name: TO_PATH
- type: string
- default: environments/stage
- tasks:
- - name: create-promote-pull-request
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: COPY_FROM_PATH
- value: $(params.FROM_PATH)
- - name: COPY_TO_PATH
- value: $(params.TO_PATH)
- runAfter:
- - pentesting-test
- - performance-test
- taskRef:
- kind: Task
- name: create-promote-pull-request
- workspaces:
- - name: workspace
- workspace: workspace
- - name: source-clone
- params:
- - name: url
- value: $(params.APP_SOURCE_GIT)
- - name: revision
- value: $(params.APP_SOURCE_REVISION)
- - name: depth
- value: "0"
- - name: subdirectory
- value: spring-petclinic
- - name: deleteExisting
- value: "true"
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: release-app
- params:
- - name: GOALS
- value:
- - deploy
- - -f
- - spring-petclinic
- - -DskipTests=true
- - -DaltDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-releases/
- - -DaltSnapshotDeploymentRepository=nexus::default::http://nexus:8081/repository/maven-snapshots/
- runAfter:
- - source-clone
- taskRef:
- kind: Task
- name: maven
- workspaces:
- - name: source
- workspace: workspace
- - name: maven-settings
- workspace: maven-settings
- - name: build-image
- params:
- - name: TLSVERIFY
- value: "false"
- - name: MAVEN_MIRROR_URL
- value: http://nexus:8081/repository/maven-public/
- - name: PATH_CONTEXT
- value: spring-petclinic/target
- - name: IMAGE_NAME
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: IMAGE_TAG
- value: $(params.APP_IMAGE_TAG)
- runAfter:
- - syft-sbom
- taskRef:
- kind: Task
- name: s2i-java-11
- workspaces:
- - name: source
- workspace: workspace
- - name: image-scan
- params:
- - name: image
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: output_format
- value: table
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-scan
- - name: image-check
- params:
- - name: image
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: rox_api_token
- value: acs-api-token
- - name: image_digest
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-image-check
- - name: deploy-check
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: rox_api_token
- value: acs-api-token
- - name: file
- value: deployment.yaml
- - name: deployment_files_path
- value: app
- runAfter:
- - build-image
- taskRef:
- kind: ClusterTask
- name: rox-deployment-check
- workspaces:
- - name: workspace
- workspace: workspace
- - name: update-deployment
- params:
- - name: GIT_REPOSITORY
- value: $(params.APP_MANIFESTS_GIT)
- - name: GIT_USERNAME
- value: $(params.GIT_USERNAME)
- - name: GIT_PASSWORD
- value: $(params.GIT_PASSWORD)
- - name: CURRENT_IMAGE
- value: quay.io/hybridcloudpatterns/spring-petclinic:latest
- - name: NEW_IMAGE
- value: quay-registry-quay-quay-enterprise.apps.hub.example.com/devel//spring-petclinic
- - name: NEW_DIGEST
- value: $(tasks.build-image.results.IMAGE_DIGEST)
- - name: KUSTOMIZATION_PATH
- value: environments/dev
- runAfter:
- - image-scan
- - image-check
- - deploy-check
- taskRef:
- kind: Task
- name: git-update-deployment
- workspaces:
- - name: workspace
- workspace: workspace
- - name: perf-tests-clone
- params:
- - name: url
- value: $(params.APP_TESTS_GIT)
- - name: subdirectory
- value: spring-petclinic-gatling
- - name: deleteExisting
- value: "true"
- runAfter:
- - update-deployment
- taskRef:
- kind: ClusterTask
- name: git-clone
- workspaces:
- - name: output
- workspace: workspace
- - name: pentesting-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: zap-proxy
- workspaces:
- - name: workspace
- workspace: workspace
- - name: performance-test
- params:
- - name: APP_URL
- value: http://spring-petclinic.$(params.DEV_NAMESPACE).svc.cluster.local:8080
- runAfter:
- - perf-tests-clone
- taskRef:
- kind: Task
- name: gatling
- workspaces:
- - name: simulations
- subPath: spring-petclinic-gatling
- workspace: workspace
- - name: syft-sbom
- params:
- - name: APP_PATH
- value: $(workspaces.source.path)
- runAfter:
- - release-app
- taskRef:
- kind: Task
- name: syft-sbom
- workspaces:
- - name: source
- workspace: workspace
- workspaces:
- - name: workspace
- - name: maven-settings
----
-# Source: pipelines/templates/app-pipeline/tasks/task-create-promote-pull-request.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: create-promote-pull-request
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: GIT_USERNAME
- type: string
- - name: GIT_PASSWORD
- type: string
- - name: COPY_FROM_PATH
- type: string
- - name: COPY_TO_PATH
- type: string
- results:
- - description: The branch name used for pull-request
- name: branch_name
- steps:
- - image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- name: promote
- resources: {}
- script: >
- set -x
-
- rm -rf pull-request-workdir
-
- git clone $(params.GIT_REPOSITORY) pull-request-workdir
-
- cd pull-request-workdir
-
- git config user.email "pipelines-ci@redhat.com"
-
- git config user.name "pipelines-ci"
-
-
- branch_name=ci-$(context.taskRun.name)
-
- git checkout -b $branch_name
-
- echo -n "$branch_name" > $(results.branch_name.path)
-
-
- /bin/cp -rf $(params.COPY_FROM_PATH)/* $(params.COPY_TO_PATH)
-
-
- git status
-
- git add $(params.COPY_TO_PATH)
-
- git commit -m "[$(context.taskRun.name)] Promotion from
- $(params.COPY_FROM_PATH) to $(params.COPY_TO_PATH)"
-
-
- git remote add auth-origin $(echo $(params.GIT_REPOSITORY) | sed -E
- "s#http://(.*)#http://$(params.GIT_USERNAME):$(params.GIT_PASSWORD)@\1#g")
-
- git push -u auth-origin HEAD
- workingDir: $(workspaces.workspace.path)
- - image: quay.io/siamaksade/python-oc
- name: create-pull-request
- resources: {}
- script: >
- #!/usr/bin/env python3
-
-
- import os
-
- import requests
-
-
- gitea_user = "$(params.GIT_USERNAME)"
-
- gitea_pwd = "$(params.GIT_PASSWORD)"
-
- giteaURL = "http://gitea-AUTOMATED.apps.region.example.com"
-
-
- branch_result = open("$(results.branch_name.path)")
-
- git_branch = branch_result.read()
-
- branch_result.close()
-
-
- print("Git server: " + giteaURL)
-
- print("Branch name: " + git_branch)
-
-
- pr_title = "[$(context.taskRun.name)] Promote to STAGE environment"
-
- pr_body = "TaskRun $(context.taskRun.name)\\nPromoting application from
- DEV to STAGE environment"
-
- data_pr = '{"base": "master","body": "' + pr_body + '","head": "' +
- git_branch + '","title": "' + pr_title + '"}'
-
- headers = {'Content-Type': 'application/json'}
-
- resp = requests.post(url = giteaURL + "/api/v1/repos/" + gitea_user +
- "/spring-petclinic-config/pulls",
- headers = headers,
- auth = (gitea_user, gitea_pwd),
- data = data_pr)
-
-
- if resp.status_code != 200:
- print("Error creating pull-request (status code: {})".format(resp.status_code))
- print(resp.content)
- else:
- print("Created pull-request.")
- workingDir: $(workspaces.workspace.path)
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
----
-# Source: pipelines/templates/app-pipeline/tasks/task-dependency-report.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: dependency-report
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
-spec:
- params:
- - name: SOURCE_DIR
- description: The directory within the workspace where application source is located
- default: "."
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- - default: ''
- description: The Maven repository mirror url
- name: MAVEN_MIRROR_URL
- type: string
- - default: ''
- description: The username for the proxy server
- name: PROXY_USER
- type: string
- - default: ''
- description: The password for the proxy server
- name: PROXY_PASSWORD
- type: string
- - default: ''
- description: Port number for the proxy server
- name: PROXY_PORT
- type: string
- - default: ''
- description: Proxy server Host
- name: PROXY_HOST
- type: string
- - default: ''
- description: Non proxy server host
- name: PROXY_NON_PROXY_HOSTS
- type: string
- - default: http
- description: Protocol for the proxy ie http or https
- name: PROXY_PROTOCOL
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
- - description: The workspace consisting of the custom maven settings provided by the user.
- name: maven-settings
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi-minimal:latest'
- name: mvn-settings
- resources: {}
- script: >
- #!/usr/bin/env bash
-
-
- [[ -f $(workspaces.maven-settings.path)/settings.xml ]] && \
-
- echo 'using existing $(workspaces.maven-settings.path)/settings.xml' &&
- exit 0
-
-
- cat > $(workspaces.maven-settings.path)/settings.xml <
-
-
-
-
-
-
-
-
-
-
- EOF
-
-
- xml=""
-
- if [ -n "$(params.PROXY_HOST)" -a -n "$(params.PROXY_PORT)" ]; then
- xml="\
- genproxy\
- true\
- $(params.PROXY_PROTOCOL)\
- $(params.PROXY_HOST)\
- $(params.PROXY_PORT)"
- if [ -n "$(params.PROXY_USER)" -a -n "$(params.PROXY_PASSWORD)" ]; then
- xml="$xml\
- $(params.PROXY_USER)\
- $(params.PROXY_PASSWORD)"
- fi
- if [ -n "$(params.PROXY_NON_PROXY_HOSTS)" ]; then
- xml="$xml\
- $(params.PROXY_NON_PROXY_HOSTS)"
- fi
- xml="$xml\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
-
-
- if [ -n "$(params.MAVEN_MIRROR_URL)" ]; then
- xml=" \
- mirror.default\
- $(params.MAVEN_MIRROR_URL)\
- central\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
- - args:
- - -Dmaven.repo.local=$(workspaces.source.path)/.m2
- - -f
- - $(params.SOURCE_DIR)
- - -s
- - $(workspaces.maven-settings.path)/settings.xml
- - site
- - -DskipTests=true
- command:
- - /usr/bin/mvn
- image: gcr.io/cloud-builders/mvn
- name: mvn-goals
- resources: {}
- workingDir: $(workspaces.source.path)
- - name: archive-site
- workingDir: $(workspaces.source.path)
- image: registry.access.redhat.com/ubi8/ubi:latest
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- script: |
- #!/usr/bin/env bash
-
- for f in $(find $(params.SOURCE_DIR)/target/site -type f); do
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME/${f} -X POST -F file=@${f} $(params.REPORTS_REPO_HOST)/upload; echo ""
- done
----
-# Source: pipelines/templates/app-pipeline/tasks/task-gatling.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: gatling
-spec:
- params:
- - name: DURATION
- description: The duration of running simulations
- type: string
- default: "30"
- - name: CONCURRENT_USERS
- description: The number of concurrent users
- type: string
- default: "10"
- - name: APP_URL
- description: The application under test url
- type: string
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- workspaces:
- - description: The workspace consisting of maven project.
- name: simulations
- steps:
- - name: run-tests
- image: quay.io/hybridcloudpatterns/gatling:latest
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- script: |
- #!/usr/bin/env bash
-
- set -x
-
- cd /opt/gatling/
- ls -lhrt
-
- # set simulation params
- export JAVA_OPTS="-DtestDuration=$(params.CONCURRENT_USERS) -DuserCount=$(params.DURATION) -Dserver=$(params.APP_URL)"
-
- # run simulation
- /opt/gatling/bin/gatling.sh -rd "Spring PetClinic Performance Test" -sf $(workspaces.simulations.path)
-
- # upload results
- REPORT=$(ls -td /opt/gatling/results/* | head -1)
- for f in $(find $REPORT/ -type f); do
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME${f#/opt/gatling/results} -X POST -F file=@${f} $(params.REPORTS_REPO_HOST)/upload; echo ""
- done
----
-# Source: pipelines/templates/app-pipeline/tasks/task-git-update-deployment.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: git-update-deployment
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: GIT_REPOSITORY
- type: string
- - name: GIT_USERNAME
- type: string
- - name: GIT_PASSWORD
- type: string
- - name: CURRENT_IMAGE
- type: string
- - name: NEW_IMAGE
- type: string
- - name: NEW_DIGEST
- type: string
- - name: KUSTOMIZATION_PATH
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: workspace
-
- results:
- - name: commit
- description: The commit SHA
-
- steps:
- - name: git-clone
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- rm -rf git-update-digest-workdir
- git clone $(params.GIT_REPOSITORY) git-update-digest-workdir
-
- - name: update-digest
- image: k8s.gcr.io/kustomize/kustomize:v3.8.7
- workingDir: $(workspaces.workspace.path)
- script: |
- cd git-update-digest-workdir/$(params.KUSTOMIZATION_PATH)
- /app/kustomize edit set image $(params.CURRENT_IMAGE)=$(params.NEW_IMAGE)@$(params.NEW_DIGEST)
-
- echo "##########################"
- echo "### kustomization.yaml ###"
- echo "##########################"
- cat kustomization.yaml
-
- - name: git-commit
- image: image-registry.openshift-image-registry.svc:5000/openshift/tools
- workingDir: $(workspaces.workspace.path)
- script: |
- cd git-update-digest-workdir
- git config user.email "tekton-pipelines-ci@redhat.com"
- git config user.name "tekton-pipelines-ci"
-
- git status
- git add $(params.KUSTOMIZATION_PATH)/kustomization.yaml
- # git commit -m "[$(context.pipelineRun.name)] Image digest updated"
- git commit -m "[ci] Image digest updated"
-
- git remote add auth-origin $(echo $(params.GIT_REPOSITORY) | sed -E "s#http://(.*)#http://$(params.GIT_USERNAME):$(params.GIT_PASSWORD)@\1#g")
- git push auth-origin main
-
- RESULT_SHA="$(git rev-parse HEAD | tr -d '\n')"
- EXIT_CODE="$?"
- if [ "$EXIT_CODE" != 0 ]
- then
- exit $EXIT_CODE
- fi
- # Make sure we don't add a trailing newline to the result!
- echo -n "$RESULT_SHA" > $(results.commit.path)
----
-# Source: pipelines/templates/app-pipeline/tasks/task-github-pull-request.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: github-open-pr
- labels:
- app.kubernetes.io/version: "0.2"
- annotations:
- tekton.dev/categories: Git
- tekton.dev/pipelines.minVersion: "0.12.1"
- tekton.dev/tags: github
- tekton.dev/displayName: "open github pull request"
- tekton.dev/platforms: "linux/amd64,linux/s390x,linux/ppc64le"
-spec:
- description: >-
- This task will open a PR on Github based on several parameters.
- This could be useful in GitOps repositories for example.
-
- params:
- - name: GITHUB_HOST_URL
- description: |
- The GitHub host, adjust this if you run a GitHub enteprise.
- default: "api.github.com"
- type: string
-
- - name: API_PATH_PREFIX
- description: |
- The API path prefix, GitHub Enterprise has a prefix e.g. /api/v3
- default: ""
- type: string
-
- - name: REPO_FULL_NAME
- description: |
- The GitHub repository full name, e.g.: tektoncd/catalog
- type: string
-
- - name: GITHUB_TOKEN_SECRET_NAME
- description: |
- The name of the kubernetes secret that contains the GitHub token, default: github
- type: string
- default: github
-
- - name: GITHUB_TOKEN_SECRET_KEY
- description: |
- The key within the kubernetes secret that contains the GitHub token, default: token
- type: string
- default: token
-
- - name: AUTH_TYPE
- description: |
- The type of authentication to use. You could use the less secure "Basic" for example
- type: string
- default: Bearer
-
- - name: HEAD
- description: |
- The name of the branch where your changes are implemented.
- type: string
-
- - name: BASE
- description: |
- The name of the branch you want the changes pulled into.
- type: string
-
- - name: BODY
- description: |
- The body description of the pull request.
- type: string
-
- - name: TITLE
- description: |
- The title of the pull request.
- type: string
-
- results:
- - name: NUMBER
- description: Number of the created pull request.
-
- - name: URL
- description: URL of the created pull request.
-
- volumes:
- - name: githubtoken
- secret:
- secretName: $(params.GITHUB_TOKEN_SECRET_NAME)
-
- steps:
- - name: open-pr
- volumeMounts:
- - name: githubtoken
- readOnly: true
- mountPath: /etc/github-open-pr
- env:
- - name: PULLREQUEST_NUMBER_PATH
- value: $(results.NUMBER.path)
- - name: PULLREQUEST_URL_PATH
- value: $(results.URL.path)
-
- image: registry.access.redhat.com/ubi8/python-38:1-34.1599745032
- script: |
- #!/usr/libexec/platform-python
-
- """This script will open a PR on Github"""
-
- import json
- import os
- import sys
- import http.client
-
- github_token = open("/etc/github-open-pr/$(params.GITHUB_TOKEN_SECRET_KEY)", "r").read()
-
- open_pr_url = "$(params.API_PATH_PREFIX)" + "/repos/$(params.REPO_FULL_NAME)/pulls"
-
- data = {
- "head": "$(params.HEAD)",
- "base": "$(params.BASE)",
- "title": "$(params.TITLE)",
- "body": """$(params.BODY)"""
- }
- print("Sending this data to GitHub: ")
- print(data)
-
- authHeader = "$(params.AUTH_TYPE) " + github_token
-
- # This is for our fake github server
- if "$(params.GITHUB_HOST_URL)".startswith("http://"):
- conn = http.client.HTTPConnection("$(params.GITHUB_HOST_URL)"
- .replace("http://", ""))
- else:
- conn = http.client.HTTPSConnection("$(params.GITHUB_HOST_URL)")
-
- conn.request(
- "POST",
- open_pr_url,
- body=json.dumps(data),
- headers={
- "User-Agent": "TektonCD, the peaceful cat",
- "Authorization": authHeader,
- "Accept": "application/vnd.github.v3+json ",
- })
- resp = conn.getresponse()
- if not str(resp.status).startswith("2"):
- print("Error: %d" % (resp.status))
- print(resp.read())
- sys.exit(1)
- else:
- # https://docs.github.com/en/rest/reference/pulls#create-a-pull-request
- body = json.loads(resp.read().decode())
-
- open(os.environ.get('PULLREQUEST_NUMBER_PATH'), 'w').write(f'{body["number"]}')
- open(os.environ.get('PULLREQUEST_URL_PATH'), 'w').write(body["html_url"])
-
- print("GitHub pull request created for $(params.REPO_FULL_NAME): "
- f'number={body["number"]} url={body["html_url"]}')
----
-# Source: pipelines/templates/app-pipeline/tasks/task-mvn.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: build-tool
- name: maven
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to run a Maven build.
- params:
- - default: gcr.io/cloud-builders/mvn:3.5.0-jdk-8
- description: Maven base image
- name: MAVEN_IMAGE
- type: string
- - default:
- - package
- description: maven goals to run
- name: GOALS
- type: array
- - default: ''
- description: The Maven repository mirror url
- name: MAVEN_MIRROR_URL
- type: string
- - default: ''
- description: The username for the proxy server
- name: PROXY_USER
- type: string
- - default: ''
- description: The password for the proxy server
- name: PROXY_PASSWORD
- type: string
- - default: ''
- description: Port number for the proxy server
- name: PROXY_PORT
- type: string
- - default: ''
- description: Proxy server Host
- name: PROXY_HOST
- type: string
- - default: ''
- description: Non proxy server host
- name: PROXY_NON_PROXY_HOSTS
- type: string
- - default: http
- description: Protocol for the proxy ie http or https
- name: PROXY_PROTOCOL
- type: string
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
- - description: The workspace consisting of the custom maven settings provided by the user.
- name: maven-settings
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi-minimal:latest'
- name: mvn-settings
- resources: {}
- script: >
- #!/usr/bin/env bash
-
-
- [[ -f $(workspaces.maven-settings.path)/settings.xml ]] && \
-
- echo 'using existing $(workspaces.maven-settings.path)/settings.xml' &&
- exit 0
-
-
- cat > $(workspaces.maven-settings.path)/settings.xml <
-
-
-
-
-
-
-
-
-
-
- EOF
-
-
- xml=""
-
- if [ -n "$(params.PROXY_HOST)" -a -n "$(params.PROXY_PORT)" ]; then
- xml="\
- genproxy\
- true\
- $(params.PROXY_PROTOCOL)\
- $(params.PROXY_HOST)\
- $(params.PROXY_PORT)"
- if [ -n "$(params.PROXY_USER)" -a -n "$(params.PROXY_PASSWORD)" ]; then
- xml="$xml\
- $(params.PROXY_USER)\
- $(params.PROXY_PASSWORD)"
- fi
- if [ -n "$(params.PROXY_NON_PROXY_HOSTS)" ]; then
- xml="$xml\
- $(params.PROXY_NON_PROXY_HOSTS)"
- fi
- xml="$xml\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
-
-
- if [ -n "$(params.MAVEN_MIRROR_URL)" ]; then
- xml=" \
- mirror.default\
- $(params.MAVEN_MIRROR_URL)\
- central\
- "
- sed -i "s||$xml|" $(workspaces.maven-settings.path)/settings.xml
- fi
- - args:
- - -Dmaven.repo.local=$(workspaces.source.path)/.m2
- - '-s'
- - $(workspaces.maven-settings.path)/settings.xml
- - $(params.GOALS)
- command:
- - /usr/bin/mvn
- image: $(params.MAVEN_IMAGE)
- name: mvn-goals
- workingDir: $(workspaces.source.path)
- resources:
- requests:
- memory: 512Mi
- cpu: 200m
- limits:
- memory: 4Gi
- cpu: '1'
----
-# Source: pipelines/templates/app-pipeline/tasks/task-s2i-java-11-fixed.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/displayName: s2i java 11
- tekton.dev/pipelines.minVersion: 0.11.3
- tekton.dev/tags: s2i, java, workspace
- name: s2i-java-11-fixed
-spec:
- description: s2i-java-11 task clones a Git repository and builds and pushes a container
- image using S2I and a Java 11 builder image.
- params:
- - default: .
- description: The location of the path to run s2i from
- name: PATH_CONTEXT
- type: string
- - default: "true"
- description: Verify the TLS on the registry endpoint (for push/pull to a non-TLS
- registry)
- name: TLSVERIFY
- type: string
- - default: ""
- description: Additional Maven arguments
- name: MAVEN_ARGS_APPEND
- type: string
- - default: "false"
- description: Remove the Maven repository after the artifact is built
- name: MAVEN_CLEAR_REPO
- type: string
- - default: ""
- description: The base URL of a mirror used for retrieving artifacts
- name: MAVEN_MIRROR_URL
- type: string
- - description: Location of the repo where image has to be pushed
- name: IMAGE_NAME
- type: string
- - default: latest
- description: The tag of the image to be pushed
- name: IMAGE_TAG
- type: string
- results:
- - description: Digest of the image just built.
- name: IMAGE_DIGEST
- - description: URL of the image used by Tekton Chains to push the OCI images
- name: IMAGE_URL
- steps:
- - args:
- - |-
- echo "MAVEN_CLEAR_REPO=$(params.MAVEN_CLEAR_REPO)" > env-file
-
- [[ '$(params.MAVEN_ARGS_APPEND)' != "" ]] &&
- echo "MAVEN_ARGS_APPEND=$(params.MAVEN_ARGS_APPEND)" >> env-file
-
- [[ '$(params.MAVEN_MIRROR_URL)' != "" ]] &&
- echo "MAVEN_MIRROR_URL=$(params.MAVEN_MIRROR_URL)" >> env-file
-
- echo "Generated Env file"
- echo "------------------------------"
- cat env-file
- echo "------------------------------"
- command:
- - /bin/sh
- - -c
- image: registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: gen-env-file
- resources: {}
- volumeMounts:
- - mountPath: /env-params
- name: envparams
- workingDir: /env-params
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - s2i
- - build
- - $(params.PATH_CONTEXT)
- - image-registry.openshift-image-registry.svc:5000/openshift/java:11
- - --image-scripts-url
- - image:///usr/local/s2i
- - --as-dockerfile
- - /gen-source/Dockerfile.gen
- - --environment-file
- - /env-params/env-file
- image: registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: generate
- resources: {}
- volumeMounts:
- - mountPath: /gen-source
- name: gen-source
- - mountPath: /env-params
- name: envparams
- workingDir: $(workspaces.source.path)
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - bud
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --layers
- - -f
- - /gen-source/Dockerfile.gen
- - -t
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - -t
- - $(params.IMAGE_NAME):latest
- - .
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: build
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - /bin/sh
- - -c
- args:
- - |-
- buildah from --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) '$(params.IMAGE_NAME):$(params.IMAGE_TAG)' > imgname
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c `dnf update -y`
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *dnf*) $(rpm -qa *libsolv*) $(rpm -qa *hawkey*) $(rpm -qa yum*) $(rpm -qa *dnf*) $(rpm -qa *subscription-manager*)'
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *rpm*)'
- buildah commit --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) `cat imgname` '$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: update
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - /bin/sh
- - -c
- args:
- - |-
- buildah from --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) '$(params.IMAGE_NAME):$(params.IMAGE_TAG)' > imgname
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c `dnf update -y`
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *dnf*) $(rpm -qa *libsolv*) $(rpm -qa *hawkey*) $(rpm -qa yum*) $(rpm -qa *dnf*) $(rpm -qa *subscription-manager*)'
- buildah run --user=root --storage-driver=vfs `cat imgname` -- sh -c 'rpm -e $(rpm -qa *rpm*)'
- buildah commit --storage-driver=vfs --tls-verify=$(params.TLSVERIFY) `cat imgname` '$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: remove-package-mgr
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - push
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - docker://$(params.IMAGE_NAME):$(params.IMAGE_TAG)
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-tag
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - command:
- - buildah
- - push
- - --storage-driver=vfs
- - --tls-verify=$(params.TLSVERIFY)
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - docker://$(params.IMAGE_NAME):latest
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-latest
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
-
- - image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: digest-to-results
- resources: {}
- script: cat $(workspaces.source.path)/image-digest | tee /tekton/results/IMAGE_DIGEST; echo quay-registry-quay-quay-enterprise.apps.hub.example.com/openshift_AUTOMATED/spring-petclinic > /tekton/results/IMAGE_URL
- volumes:
- - emptyDir: {}
- name: varlibcontainers
- - emptyDir: {}
- name: gen-source
- - emptyDir: {}
- name: envparams
- workspaces:
- - mountPath: /workspace/source
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-s2i-java-11.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- name: s2i-java-11
- annotations:
- tekton.dev/displayName: s2i java 11
- tekton.dev/pipelines.minVersion: 0.11.3
- tekton.dev/tags: 's2i, java, workspace'
-spec:
- description: >-
- s2i-java-11 task clones a Git repository and builds and pushes a container
- image using S2I and a Java 11 builder image.
- params:
- - default: .
- description: The location of the path to run s2i from
- name: PATH_CONTEXT
- type: string
- - default: 'true'
- description: >-
- Verify the TLS on the registry endpoint (for push/pull to a non-TLS
- registry)
- name: TLSVERIFY
- type: string
- - default: ''
- description: Additional Maven arguments
- name: MAVEN_ARGS_APPEND
- type: string
- - default: 'false'
- description: Remove the Maven repository after the artifact is built
- name: MAVEN_CLEAR_REPO
- type: string
- - default: ''
- description: The base URL of a mirror used for retrieving artifacts
- name: MAVEN_MIRROR_URL
- type: string
- - description: Location of the repo where image has to be pushed
- name: IMAGE_NAME
- type: string
- - description: The tag of the image to be pushed
- name: IMAGE_TAG
- type: string
- default: "latest"
- results:
- - name: IMAGE_DIGEST
- description: Digest of the image just built.
- steps:
- - args:
- - |-
- echo "MAVEN_CLEAR_REPO=$(params.MAVEN_CLEAR_REPO)" > env-file
-
- [[ '$(params.MAVEN_ARGS_APPEND)' != "" ]] &&
- echo "MAVEN_ARGS_APPEND=$(params.MAVEN_ARGS_APPEND)" >> env-file
-
- [[ '$(params.MAVEN_MIRROR_URL)' != "" ]] &&
- echo "MAVEN_MIRROR_URL=$(params.MAVEN_MIRROR_URL)" >> env-file
-
- echo "Generated Env file"
- echo "------------------------------"
- cat env-file
- echo "------------------------------"
- command:
- - /bin/sh
- - '-c'
- image: >-
- registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: gen-env-file
- resources: {}
- volumeMounts:
- - mountPath: /env-params
- name: envparams
- workingDir: /env-params
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - s2i
- - build
- - $(params.PATH_CONTEXT)
- - 'image-registry.openshift-image-registry.svc:5000/openshift/java:11'
- - '--image-scripts-url'
- - 'image:///usr/local/s2i'
- - '--as-dockerfile'
- - /gen-source/Dockerfile.gen
- - '--environment-file'
- - /env-params/env-file
- image: >-
- registry.redhat.io/ocp-tools-43-tech-preview/source-to-image-rhel8@sha256:562dbdac04ae9260e21d457585b3251fd8cc5310966f8fc544fb77dc544c92f8
- name: generate
- resources: {}
- volumeMounts:
- - mountPath: /gen-source
- name: gen-source
- - mountPath: /env-params
- name: envparams
- workingDir: $(workspaces.source.path)
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - buildah
- - bud
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - '--layers'
- - '-f'
- - /gen-source/Dockerfile.gen
- - '-t'
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - '-t'
- - $(params.IMAGE_NAME):latest
- - .
- image: >-
- registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: build
- resources: {}
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- - mountPath: /gen-source
- name: gen-source
- workingDir: /gen-source
- - command:
- - buildah
- - push
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - 'docker://$(params.IMAGE_NAME):$(params.IMAGE_TAG)'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-tag
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - command:
- - buildah
- - push
- - '--storage-driver=vfs'
- - '--tls-verify=$(params.TLSVERIFY)'
- - --digestfile
- - $(workspaces.source.path)/image-digest
- - $(params.IMAGE_NAME):$(params.IMAGE_TAG)
- - 'docker://$(params.IMAGE_NAME):latest'
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- name: push-latest
- resources: {}
- volumeMounts:
- - mountPath: /var/lib/containers
- name: varlibcontainers
- securityContext:
- capabilities:
- add: ["SETFCAP"]
- - name: digest-to-results
- image: registry.redhat.io/rhel8/buildah@sha256:180c4d9849b6ab0e5465d30d4f3a77765cf0d852ca1cb1efb59d6e8c9f90d467
- script: cat $(workspaces.source.path)/image-digest | tee /tekton/results/IMAGE_DIGEST
- volumes:
- - emptyDir: {}
- name: varlibcontainers
- - emptyDir: {}
- name: gen-source
- - emptyDir: {}
- name: envparams
- workspaces:
- - mountPath: /workspace/source
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-syft-sbom.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: build-tool
- name: syft-sbom
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to generate a SBOM file with Syft.
- params:
- - default: $(workspaces.source.path)
- description: Application folder to scan
- name: APP_PATH
- type: string
- steps:
- - image: 'registry.access.redhat.com/ubi8/ubi:latest'
- name: syft-scan
- resources: {}
- script: >
- #!/usr/bin/env bash
-
- echo '## Getting Syft ##'
-
- pwd
-
- curl -sSfL
- https://raw.githubusercontent.com/anchore/syft/main/install.sh | sh -s
- -- -b .
-
- chmod +x ./syft
-
- echo '## Scanning folder and generating SBOM ##'
-
- ./syft $(params.APP_PATH) -o spdx-json=sbom.json
-
- echo '## SBOM content ##'
-
- cat ./sbom.json
- workspaces:
- - description: The workspace consisting of maven project.
- name: source
----
-# Source: pipelines/templates/app-pipeline/tasks/task-zap-proxy.yaml
-apiVersion: tekton.dev/v1beta1
-kind: Task
-metadata:
- annotations:
- tekton.dev/pipelines.minVersion: 0.12.1
- tekton.dev/tags: git
- name: zap-proxy
- labels:
- app.kubernetes.io/version: '0.1'
- operator.tekton.dev/provider-type: community
-spec:
- description: This Task can be used to update image digest in a Git repo using kustomize
- params:
- - name: REPORTS_REPO_USERNAME
- description: The reports repository username
- default: reports
- - name: REPORTS_REPO_PASSWORD
- description: The reports repository password
- default: reports
- - name: APP_URL
- description: The application under test url
- - name: REPORTS_REPO_HOST
- description: The reports repository host based on https://github.com/chmouel/openshift-django-uploader
- default: http://reports-repo:8080
- workspaces:
- - description: The workspace for the zap proxy task
- name: workspace
-
- steps:
- - name: zap-proxy
- image: quay.io/hybridcloudpatterns/zap2docker-stable
- env:
- - name: PIPELINERUN_NAME
- valueFrom:
- fieldRef:
- fieldPath: metadata.labels['tekton.dev/pipelineRun']
- workingDir: $(workspaces.workspace.path)
- script: |
- #!/usr/bin/env bash
-
- set -x
-
- echo "Make the wrk directory available to save the reports"
- cd /zap
- mkdir /zap/wrk
-
- echo "Starting the pentesting..."
- /zap/zap-baseline.py -t $(params.APP_URL) -r $PIPELINERUN_NAME.html
-
- ls -lhrt /zap/wrk
-
- echo "Uploading the report into the report server"
- curl -u $(params.REPORTS_REPO_USERNAME):$(params.REPORTS_REPO_PASSWORD) -F path=$PIPELINERUN_NAME/$PIPELINERUN_NAME.html -F file=@/zap/wrk/$PIPELINERUN_NAME.html -X POST $(params.REPORTS_REPO_HOST)/upload; echo ""
----
-# Source: pipelines/templates/chains/tekton-chain.yaml
-apiVersion: operator.tekton.dev/v1alpha1
-kind: TektonChain
-metadata:
- name: chain
-spec:
- targetNamespace: openshift-pipelines
diff --git a/tests/region-quay-industrial-edge-factory.expected.yaml b/tests/region-quay-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 347b4ac6..00000000
--- a/tests/region-quay-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,58 +0,0 @@
----
-# Source: quay/templates/rbac/sa-quay-bridge.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: quay-bridge-sa
- namespace: openshift-operators
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/rbac/role-quay-bridge.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: quay-bridge-role
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
----
-# Source: quay/templates/rbac/rolebinding-quay-bridge.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-bridge-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-bridge-role
-subjects:
- - kind: ServiceAccount
- name: quay-bridge-sa
- namespace: openshift-operators
----
-# Source: quay/templates/bridge/quay-integration.yaml
-apiVersion: quay.redhat.com/v1
-kind: QuayIntegration
-metadata:
- name: quay
- annotations:
- argocd.argoproj.io/sync-wave: "8"
-spec:
- clusterID: openshift
- credentialsSecret:
- name: quay-integration
- namespace: openshift-operators
-# insecureRegistry: false
- insecureRegistry: true
- quayHostname: https://quay-registry-quay-quay-enterprise.apps.hub.example.com
diff --git a/tests/region-quay-industrial-edge-hub.expected.yaml b/tests/region-quay-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 347b4ac6..00000000
--- a/tests/region-quay-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,58 +0,0 @@
----
-# Source: quay/templates/rbac/sa-quay-bridge.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: quay-bridge-sa
- namespace: openshift-operators
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/rbac/role-quay-bridge.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: quay-bridge-role
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
----
-# Source: quay/templates/rbac/rolebinding-quay-bridge.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-bridge-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-bridge-role
-subjects:
- - kind: ServiceAccount
- name: quay-bridge-sa
- namespace: openshift-operators
----
-# Source: quay/templates/bridge/quay-integration.yaml
-apiVersion: quay.redhat.com/v1
-kind: QuayIntegration
-metadata:
- name: quay
- annotations:
- argocd.argoproj.io/sync-wave: "8"
-spec:
- clusterID: openshift
- credentialsSecret:
- name: quay-integration
- namespace: openshift-operators
-# insecureRegistry: false
- insecureRegistry: true
- quayHostname: https://quay-registry-quay-quay-enterprise.apps.hub.example.com
diff --git a/tests/region-quay-medical-diagnosis-hub.expected.yaml b/tests/region-quay-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 347b4ac6..00000000
--- a/tests/region-quay-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,58 +0,0 @@
----
-# Source: quay/templates/rbac/sa-quay-bridge.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: quay-bridge-sa
- namespace: openshift-operators
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/rbac/role-quay-bridge.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: quay-bridge-role
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
----
-# Source: quay/templates/rbac/rolebinding-quay-bridge.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-bridge-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-bridge-role
-subjects:
- - kind: ServiceAccount
- name: quay-bridge-sa
- namespace: openshift-operators
----
-# Source: quay/templates/bridge/quay-integration.yaml
-apiVersion: quay.redhat.com/v1
-kind: QuayIntegration
-metadata:
- name: quay
- annotations:
- argocd.argoproj.io/sync-wave: "8"
-spec:
- clusterID: openshift
- credentialsSecret:
- name: quay-integration
- namespace: openshift-operators
-# insecureRegistry: false
- insecureRegistry: true
- quayHostname: https://quay-registry-quay-quay-enterprise.apps.hub.example.com
diff --git a/tests/region-quay-naked.expected.yaml b/tests/region-quay-naked.expected.yaml
deleted file mode 100644
index 7ff96138..00000000
--- a/tests/region-quay-naked.expected.yaml
+++ /dev/null
@@ -1,58 +0,0 @@
----
-# Source: quay/templates/rbac/sa-quay-bridge.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: quay-bridge-sa
- namespace: openshift-operators
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/rbac/role-quay-bridge.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: quay-bridge-role
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
----
-# Source: quay/templates/rbac/rolebinding-quay-bridge.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-bridge-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-bridge-role
-subjects:
- - kind: ServiceAccount
- name: quay-bridge-sa
- namespace: openshift-operators
----
-# Source: quay/templates/bridge/quay-integration.yaml
-apiVersion: quay.redhat.com/v1
-kind: QuayIntegration
-metadata:
- name: quay
- annotations:
- argocd.argoproj.io/sync-wave: "8"
-spec:
- clusterID: openshift
- credentialsSecret:
- name: quay-integration
- namespace: openshift-operators
-# insecureRegistry: false
- insecureRegistry: true
- quayHostname: https://quay-registry-quay-quay-enterprise.AUTOMATIC
diff --git a/tests/region-quay-normal.expected.yaml b/tests/region-quay-normal.expected.yaml
deleted file mode 100644
index 347b4ac6..00000000
--- a/tests/region-quay-normal.expected.yaml
+++ /dev/null
@@ -1,58 +0,0 @@
----
-# Source: quay/templates/rbac/sa-quay-bridge.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- name: quay-bridge-sa
- namespace: openshift-operators
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
----
-# Source: quay/templates/rbac/role-quay-bridge.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
- name: quay-bridge-role
-rules:
- - apiGroups:
- - ""
- resources:
- - secrets
- verbs:
- - get
- - create
- - list
----
-# Source: quay/templates/rbac/rolebinding-quay-bridge.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- name: quay-bridge-binding
- annotations:
- argocd.argoproj.io/sync-wave: "-5"
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: quay-bridge-role
-subjects:
- - kind: ServiceAccount
- name: quay-bridge-sa
- namespace: openshift-operators
----
-# Source: quay/templates/bridge/quay-integration.yaml
-apiVersion: quay.redhat.com/v1
-kind: QuayIntegration
-metadata:
- name: quay
- annotations:
- argocd.argoproj.io/sync-wave: "8"
-spec:
- clusterID: openshift
- credentialsSecret:
- name: quay-integration
- namespace: openshift-operators
-# insecureRegistry: false
- insecureRegistry: true
- quayHostname: https://quay-registry-quay-quay-enterprise.apps.hub.example.com
diff --git a/tests/region-rekor-industrial-edge-factory.expected.yaml b/tests/region-rekor-industrial-edge-factory.expected.yaml
deleted file mode 100644
index c1155e84..00000000
--- a/tests/region-rekor-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: rekor/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: rekor
- namespace: openshift
- labels:
- app: rekor
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/rekor
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: rekor:latest
- triggers:
- - type: ImageChange
----
-# Source: rekor/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: rekor
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-rekor-industrial-edge-hub.expected.yaml b/tests/region-rekor-industrial-edge-hub.expected.yaml
deleted file mode 100644
index c1155e84..00000000
--- a/tests/region-rekor-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: rekor/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: rekor
- namespace: openshift
- labels:
- app: rekor
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/rekor
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: rekor:latest
- triggers:
- - type: ImageChange
----
-# Source: rekor/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: rekor
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-rekor-medical-diagnosis-hub.expected.yaml b/tests/region-rekor-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index c1155e84..00000000
--- a/tests/region-rekor-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: rekor/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: rekor
- namespace: openshift
- labels:
- app: rekor
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/rekor
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: rekor:latest
- triggers:
- - type: ImageChange
----
-# Source: rekor/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: rekor
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-rekor-naked.expected.yaml b/tests/region-rekor-naked.expected.yaml
deleted file mode 100644
index c1155e84..00000000
--- a/tests/region-rekor-naked.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: rekor/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: rekor
- namespace: openshift
- labels:
- app: rekor
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/rekor
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: rekor:latest
- triggers:
- - type: ImageChange
----
-# Source: rekor/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: rekor
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-rekor-normal.expected.yaml b/tests/region-rekor-normal.expected.yaml
deleted file mode 100644
index c1155e84..00000000
--- a/tests/region-rekor-normal.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: rekor/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: rekor
- namespace: openshift
- labels:
- app: rekor
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/rekor
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: rekor:latest
- triggers:
- - type: ImageChange
----
-# Source: rekor/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: rekor
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-reports-industrial-edge-factory.expected.yaml b/tests/region-reports-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 62416615..00000000
--- a/tests/region-reports-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,139 +0,0 @@
----
-# Source: reports/templates/reports-nginx-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: reports-repo-nginx-conf
- namespace: devsecops-ci
-data:
- nginx.conf: "types {\n text/plain yaml yml;\n}\n\nserver {\n listen 8080
- default_server;\n gzip on;\n\n\tlocation /upload {\n\t\tsatisfy any;\n\t\tauth_basic
- \"Welcome to the Jungle!\"; #For Basic Auth\n \tauth_basic_user_file conf.d/htpasswd;
- \ #For Basic Auth\n\t\tdeny all;\n\n\t\tproxy_set_header Host $host;\n\t\tproxy_set_header
- \ X-Real-IP $remote_addr;\n\t\tproxy_set_header X-Forwarded-Proto https;\n\t\tproxy_set_header
- \ X-Forwarded-For $remote_addr;\n\t\tproxy_set_header X-Forwarded-Host $remote_addr;\n\n\t\tproxy_pass
- http://localhost:9000;\n\t}\n\n\tlocation /private {\n\t\troot /fileuploads;\n\n\t\tsatisfy
- any;\n\t\tauth_basic \"Welcome to the Jungle!\"; #For Basic Auth\n \tauth_basic_user_file
- conf.d/htpasswd; #For Basic Auth\n\t\tdeny all;\n\n\t autoindex
- on;\n\t autoindex_exact_size off;\n\t autoindex_localtime on;\n\t}\n\n\tlocation
- / {\n\t\troot /fileuploads;\n\t autoindex on;\n\t autoindex_exact_size off;\n\t
- \ autoindex_localtime on;\n\t}\n}\n"
----
-# Source: reports/templates/deployment.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- labels:
- app: reports-repo
- name: reports-repo-pv
- namespace: devsecops-ci
-spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 5Gi
----
-# Source: reports/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- selector:
- app: reports-repo
- deployment: reports-repo
----
-# Source: reports/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- app: reports-repo
- app.kubernetes.io/instance: reports-repo
- app.kubernetes.io/name: reports-repo
- app.kubernetes.io/part-of: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: reports-repo
- deployment: reports-repo
- template:
- metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- spec:
- containers:
- - name: uploader
- image: quay.io/hybridcloudpatterns/go-simple-uploader:latest
- imagePullPolicy: IfNotPresent
- env:
- - name: UPLOADER_PORT
- value: "9000"
- - name: UPLOADER_DIRECTORY
- value: "/fileuploads"
- volumeMounts:
- - mountPath: /fileuploads
- name: staticfiles
- subPath:
- - name: nginx
- image: quay.io/hybridcloudpatterns/nginx:latest
- imagePullPolicy: IfNotPresent
- ports:
- - containerPort: 8080
- protocol: TCP
- volumeMounts:
- - mountPath: /etc/nginx/conf.d/nginx.conf
- name: nginx-conf
- subPath: nginx.conf
- - mountPath: /fileuploads
- name: staticfiles
- subPath:
- - mountPath: /etc/nginx/conf.d/htpasswd
- name: htpasswd
- subPath: htpasswd
- volumes:
- - name: nexus-data
- persistentVolumeClaim:
- claimName: nexus-pv
- volumes:
- - name: staticfiles
- persistentVolumeClaim:
- claimName: reports-repo-pv
- - configMap:
- defaultMode: 420
- name: reports-repo-nginx-conf
- name: nginx-conf
- - name: htpasswd
- secret:
- secretName: reports-nginx-htpasswd
----
-# Source: reports/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: reports-repo
- weight: 100
diff --git a/tests/region-reports-industrial-edge-hub.expected.yaml b/tests/region-reports-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 62416615..00000000
--- a/tests/region-reports-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,139 +0,0 @@
----
-# Source: reports/templates/reports-nginx-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: reports-repo-nginx-conf
- namespace: devsecops-ci
-data:
- nginx.conf: "types {\n text/plain yaml yml;\n}\n\nserver {\n listen 8080
- default_server;\n gzip on;\n\n\tlocation /upload {\n\t\tsatisfy any;\n\t\tauth_basic
- \"Welcome to the Jungle!\"; #For Basic Auth\n \tauth_basic_user_file conf.d/htpasswd;
- \ #For Basic Auth\n\t\tdeny all;\n\n\t\tproxy_set_header Host $host;\n\t\tproxy_set_header
- \ X-Real-IP $remote_addr;\n\t\tproxy_set_header X-Forwarded-Proto https;\n\t\tproxy_set_header
- \ X-Forwarded-For $remote_addr;\n\t\tproxy_set_header X-Forwarded-Host $remote_addr;\n\n\t\tproxy_pass
- http://localhost:9000;\n\t}\n\n\tlocation /private {\n\t\troot /fileuploads;\n\n\t\tsatisfy
- any;\n\t\tauth_basic \"Welcome to the Jungle!\"; #For Basic Auth\n \tauth_basic_user_file
- conf.d/htpasswd; #For Basic Auth\n\t\tdeny all;\n\n\t autoindex
- on;\n\t autoindex_exact_size off;\n\t autoindex_localtime on;\n\t}\n\n\tlocation
- / {\n\t\troot /fileuploads;\n\t autoindex on;\n\t autoindex_exact_size off;\n\t
- \ autoindex_localtime on;\n\t}\n}\n"
----
-# Source: reports/templates/deployment.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- labels:
- app: reports-repo
- name: reports-repo-pv
- namespace: devsecops-ci
-spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 5Gi
----
-# Source: reports/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- selector:
- app: reports-repo
- deployment: reports-repo
----
-# Source: reports/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- app: reports-repo
- app.kubernetes.io/instance: reports-repo
- app.kubernetes.io/name: reports-repo
- app.kubernetes.io/part-of: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: reports-repo
- deployment: reports-repo
- template:
- metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- spec:
- containers:
- - name: uploader
- image: quay.io/hybridcloudpatterns/go-simple-uploader:latest
- imagePullPolicy: IfNotPresent
- env:
- - name: UPLOADER_PORT
- value: "9000"
- - name: UPLOADER_DIRECTORY
- value: "/fileuploads"
- volumeMounts:
- - mountPath: /fileuploads
- name: staticfiles
- subPath:
- - name: nginx
- image: quay.io/hybridcloudpatterns/nginx:latest
- imagePullPolicy: IfNotPresent
- ports:
- - containerPort: 8080
- protocol: TCP
- volumeMounts:
- - mountPath: /etc/nginx/conf.d/nginx.conf
- name: nginx-conf
- subPath: nginx.conf
- - mountPath: /fileuploads
- name: staticfiles
- subPath:
- - mountPath: /etc/nginx/conf.d/htpasswd
- name: htpasswd
- subPath: htpasswd
- volumes:
- - name: nexus-data
- persistentVolumeClaim:
- claimName: nexus-pv
- volumes:
- - name: staticfiles
- persistentVolumeClaim:
- claimName: reports-repo-pv
- - configMap:
- defaultMode: 420
- name: reports-repo-nginx-conf
- name: nginx-conf
- - name: htpasswd
- secret:
- secretName: reports-nginx-htpasswd
----
-# Source: reports/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: reports-repo
- weight: 100
diff --git a/tests/region-reports-medical-diagnosis-hub.expected.yaml b/tests/region-reports-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 62416615..00000000
--- a/tests/region-reports-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,139 +0,0 @@
----
-# Source: reports/templates/reports-nginx-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: reports-repo-nginx-conf
- namespace: devsecops-ci
-data:
- nginx.conf: "types {\n text/plain yaml yml;\n}\n\nserver {\n listen 8080
- default_server;\n gzip on;\n\n\tlocation /upload {\n\t\tsatisfy any;\n\t\tauth_basic
- \"Welcome to the Jungle!\"; #For Basic Auth\n \tauth_basic_user_file conf.d/htpasswd;
- \ #For Basic Auth\n\t\tdeny all;\n\n\t\tproxy_set_header Host $host;\n\t\tproxy_set_header
- \ X-Real-IP $remote_addr;\n\t\tproxy_set_header X-Forwarded-Proto https;\n\t\tproxy_set_header
- \ X-Forwarded-For $remote_addr;\n\t\tproxy_set_header X-Forwarded-Host $remote_addr;\n\n\t\tproxy_pass
- http://localhost:9000;\n\t}\n\n\tlocation /private {\n\t\troot /fileuploads;\n\n\t\tsatisfy
- any;\n\t\tauth_basic \"Welcome to the Jungle!\"; #For Basic Auth\n \tauth_basic_user_file
- conf.d/htpasswd; #For Basic Auth\n\t\tdeny all;\n\n\t autoindex
- on;\n\t autoindex_exact_size off;\n\t autoindex_localtime on;\n\t}\n\n\tlocation
- / {\n\t\troot /fileuploads;\n\t autoindex on;\n\t autoindex_exact_size off;\n\t
- \ autoindex_localtime on;\n\t}\n}\n"
----
-# Source: reports/templates/deployment.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- labels:
- app: reports-repo
- name: reports-repo-pv
- namespace: devsecops-ci
-spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 5Gi
----
-# Source: reports/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- selector:
- app: reports-repo
- deployment: reports-repo
----
-# Source: reports/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- app: reports-repo
- app.kubernetes.io/instance: reports-repo
- app.kubernetes.io/name: reports-repo
- app.kubernetes.io/part-of: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: reports-repo
- deployment: reports-repo
- template:
- metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- spec:
- containers:
- - name: uploader
- image: quay.io/hybridcloudpatterns/go-simple-uploader:latest
- imagePullPolicy: IfNotPresent
- env:
- - name: UPLOADER_PORT
- value: "9000"
- - name: UPLOADER_DIRECTORY
- value: "/fileuploads"
- volumeMounts:
- - mountPath: /fileuploads
- name: staticfiles
- subPath:
- - name: nginx
- image: quay.io/hybridcloudpatterns/nginx:latest
- imagePullPolicy: IfNotPresent
- ports:
- - containerPort: 8080
- protocol: TCP
- volumeMounts:
- - mountPath: /etc/nginx/conf.d/nginx.conf
- name: nginx-conf
- subPath: nginx.conf
- - mountPath: /fileuploads
- name: staticfiles
- subPath:
- - mountPath: /etc/nginx/conf.d/htpasswd
- name: htpasswd
- subPath: htpasswd
- volumes:
- - name: nexus-data
- persistentVolumeClaim:
- claimName: nexus-pv
- volumes:
- - name: staticfiles
- persistentVolumeClaim:
- claimName: reports-repo-pv
- - configMap:
- defaultMode: 420
- name: reports-repo-nginx-conf
- name: nginx-conf
- - name: htpasswd
- secret:
- secretName: reports-nginx-htpasswd
----
-# Source: reports/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: reports-repo
- weight: 100
diff --git a/tests/region-reports-naked.expected.yaml b/tests/region-reports-naked.expected.yaml
deleted file mode 100644
index 62416615..00000000
--- a/tests/region-reports-naked.expected.yaml
+++ /dev/null
@@ -1,139 +0,0 @@
----
-# Source: reports/templates/reports-nginx-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: reports-repo-nginx-conf
- namespace: devsecops-ci
-data:
- nginx.conf: "types {\n text/plain yaml yml;\n}\n\nserver {\n listen 8080
- default_server;\n gzip on;\n\n\tlocation /upload {\n\t\tsatisfy any;\n\t\tauth_basic
- \"Welcome to the Jungle!\"; #For Basic Auth\n \tauth_basic_user_file conf.d/htpasswd;
- \ #For Basic Auth\n\t\tdeny all;\n\n\t\tproxy_set_header Host $host;\n\t\tproxy_set_header
- \ X-Real-IP $remote_addr;\n\t\tproxy_set_header X-Forwarded-Proto https;\n\t\tproxy_set_header
- \ X-Forwarded-For $remote_addr;\n\t\tproxy_set_header X-Forwarded-Host $remote_addr;\n\n\t\tproxy_pass
- http://localhost:9000;\n\t}\n\n\tlocation /private {\n\t\troot /fileuploads;\n\n\t\tsatisfy
- any;\n\t\tauth_basic \"Welcome to the Jungle!\"; #For Basic Auth\n \tauth_basic_user_file
- conf.d/htpasswd; #For Basic Auth\n\t\tdeny all;\n\n\t autoindex
- on;\n\t autoindex_exact_size off;\n\t autoindex_localtime on;\n\t}\n\n\tlocation
- / {\n\t\troot /fileuploads;\n\t autoindex on;\n\t autoindex_exact_size off;\n\t
- \ autoindex_localtime on;\n\t}\n}\n"
----
-# Source: reports/templates/deployment.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- labels:
- app: reports-repo
- name: reports-repo-pv
- namespace: devsecops-ci
-spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 5Gi
----
-# Source: reports/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- selector:
- app: reports-repo
- deployment: reports-repo
----
-# Source: reports/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- app: reports-repo
- app.kubernetes.io/instance: reports-repo
- app.kubernetes.io/name: reports-repo
- app.kubernetes.io/part-of: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: reports-repo
- deployment: reports-repo
- template:
- metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- spec:
- containers:
- - name: uploader
- image: quay.io/hybridcloudpatterns/go-simple-uploader:latest
- imagePullPolicy: IfNotPresent
- env:
- - name: UPLOADER_PORT
- value: "9000"
- - name: UPLOADER_DIRECTORY
- value: "/fileuploads"
- volumeMounts:
- - mountPath: /fileuploads
- name: staticfiles
- subPath:
- - name: nginx
- image: quay.io/hybridcloudpatterns/nginx:latest
- imagePullPolicy: IfNotPresent
- ports:
- - containerPort: 8080
- protocol: TCP
- volumeMounts:
- - mountPath: /etc/nginx/conf.d/nginx.conf
- name: nginx-conf
- subPath: nginx.conf
- - mountPath: /fileuploads
- name: staticfiles
- subPath:
- - mountPath: /etc/nginx/conf.d/htpasswd
- name: htpasswd
- subPath: htpasswd
- volumes:
- - name: nexus-data
- persistentVolumeClaim:
- claimName: nexus-pv
- volumes:
- - name: staticfiles
- persistentVolumeClaim:
- claimName: reports-repo-pv
- - configMap:
- defaultMode: 420
- name: reports-repo-nginx-conf
- name: nginx-conf
- - name: htpasswd
- secret:
- secretName: reports-nginx-htpasswd
----
-# Source: reports/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: reports-repo
- weight: 100
diff --git a/tests/region-reports-normal.expected.yaml b/tests/region-reports-normal.expected.yaml
deleted file mode 100644
index 62416615..00000000
--- a/tests/region-reports-normal.expected.yaml
+++ /dev/null
@@ -1,139 +0,0 @@
----
-# Source: reports/templates/reports-nginx-configmap.yaml
-apiVersion: v1
-kind: ConfigMap
-metadata:
- name: reports-repo-nginx-conf
- namespace: devsecops-ci
-data:
- nginx.conf: "types {\n text/plain yaml yml;\n}\n\nserver {\n listen 8080
- default_server;\n gzip on;\n\n\tlocation /upload {\n\t\tsatisfy any;\n\t\tauth_basic
- \"Welcome to the Jungle!\"; #For Basic Auth\n \tauth_basic_user_file conf.d/htpasswd;
- \ #For Basic Auth\n\t\tdeny all;\n\n\t\tproxy_set_header Host $host;\n\t\tproxy_set_header
- \ X-Real-IP $remote_addr;\n\t\tproxy_set_header X-Forwarded-Proto https;\n\t\tproxy_set_header
- \ X-Forwarded-For $remote_addr;\n\t\tproxy_set_header X-Forwarded-Host $remote_addr;\n\n\t\tproxy_pass
- http://localhost:9000;\n\t}\n\n\tlocation /private {\n\t\troot /fileuploads;\n\n\t\tsatisfy
- any;\n\t\tauth_basic \"Welcome to the Jungle!\"; #For Basic Auth\n \tauth_basic_user_file
- conf.d/htpasswd; #For Basic Auth\n\t\tdeny all;\n\n\t autoindex
- on;\n\t autoindex_exact_size off;\n\t autoindex_localtime on;\n\t}\n\n\tlocation
- / {\n\t\troot /fileuploads;\n\t autoindex on;\n\t autoindex_exact_size off;\n\t
- \ autoindex_localtime on;\n\t}\n}\n"
----
-# Source: reports/templates/deployment.yaml
-apiVersion: v1
-kind: PersistentVolumeClaim
-metadata:
- labels:
- app: reports-repo
- name: reports-repo-pv
- namespace: devsecops-ci
-spec:
- accessModes:
- - ReadWriteOnce
- resources:
- requests:
- storage: 5Gi
----
-# Source: reports/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- selector:
- app: reports-repo
- deployment: reports-repo
----
-# Source: reports/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- app: reports-repo
- app.kubernetes.io/instance: reports-repo
- app.kubernetes.io/name: reports-repo
- app.kubernetes.io/part-of: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: reports-repo
- deployment: reports-repo
- template:
- metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- spec:
- containers:
- - name: uploader
- image: quay.io/hybridcloudpatterns/go-simple-uploader:latest
- imagePullPolicy: IfNotPresent
- env:
- - name: UPLOADER_PORT
- value: "9000"
- - name: UPLOADER_DIRECTORY
- value: "/fileuploads"
- volumeMounts:
- - mountPath: /fileuploads
- name: staticfiles
- subPath:
- - name: nginx
- image: quay.io/hybridcloudpatterns/nginx:latest
- imagePullPolicy: IfNotPresent
- ports:
- - containerPort: 8080
- protocol: TCP
- volumeMounts:
- - mountPath: /etc/nginx/conf.d/nginx.conf
- name: nginx-conf
- subPath: nginx.conf
- - mountPath: /fileuploads
- name: staticfiles
- subPath:
- - mountPath: /etc/nginx/conf.d/htpasswd
- name: htpasswd
- subPath: htpasswd
- volumes:
- - name: nexus-data
- persistentVolumeClaim:
- claimName: nexus-pv
- volumes:
- - name: staticfiles
- persistentVolumeClaim:
- claimName: reports-repo-pv
- - configMap:
- defaultMode: 420
- name: reports-repo-nginx-conf
- name: nginx-conf
- - name: htpasswd
- secret:
- secretName: reports-nginx-htpasswd
----
-# Source: reports/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: reports-repo
- deployment: reports-repo
- name: reports-repo
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: reports-repo
- weight: 100
diff --git a/tests/region-rollouts-industrial-edge-factory.expected.yaml b/tests/region-rollouts-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 6463a588..00000000
--- a/tests/region-rollouts-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,14853 +0,0 @@
----
-# Source: rollouts/templates/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
----
-# Source: rollouts/templates/rollouts-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: argo-rollouts-notification-secret
----
-# Source: rollouts/templates/analysisRun-crd.yaml
-# This is an auto-generated file. DO NOT EDIT
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: analysisruns.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: AnalysisRun
- listKind: AnalysisRunList
- plural: analysisruns
- shortNames:
- - ar
- singular: analysisrun
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: AnalysisRun status
- jsonPath: .status.phase
- name: Status
- type: string
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- terminate:
- type: boolean
- required:
- - metrics
- type: object
- status:
- properties:
- dryRunSummary:
- properties:
- count:
- format: int32
- type: integer
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- successful:
- format: int32
- type: integer
- type: object
- message:
- type: string
- metricResults:
- items:
- properties:
- consecutiveError:
- format: int32
- type: integer
- count:
- format: int32
- type: integer
- dryRun:
- type: boolean
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- measurements:
- items:
- properties:
- finishedAt:
- format: date-time
- type: string
- message:
- type: string
- metadata:
- additionalProperties:
- type: string
- type: object
- phase:
- type: string
- resumeAt:
- format: date-time
- type: string
- startedAt:
- format: date-time
- type: string
- value:
- type: string
- required:
- - phase
- type: object
- type: array
- message:
- type: string
- metadata:
- additionalProperties:
- type: string
- type: object
- name:
- type: string
- phase:
- type: string
- successful:
- format: int32
- type: integer
- required:
- - name
- - phase
- type: object
- type: array
- phase:
- type: string
- runSummary:
- properties:
- count:
- format: int32
- type: integer
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- successful:
- format: int32
- type: integer
- type: object
- startedAt:
- format: date-time
- type: string
- required:
- - phase
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/analysisTemplate-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: analysistemplates.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: AnalysisTemplate
- listKind: AnalysisTemplateList
- plural: analysistemplates
- shortNames:
- - at
- singular: analysistemplate
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- required:
- - metrics
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/clusterAnalysisTemplate-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: clusteranalysistemplates.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: ClusterAnalysisTemplate
- listKind: ClusterAnalysisTemplateList
- plural: clusteranalysistemplates
- shortNames:
- - cat
- singular: clusteranalysistemplate
- preserveUnknownFields: false
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- required:
- - metrics
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/experiments-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: experiments.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: Experiment
- listKind: ExperimentList
- plural: experiments
- shortNames:
- - exp
- singular: experiment
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Experiment status
- jsonPath: .status.phase
- name: Status
- type: string
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- analyses:
- items:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- clusterScope:
- type: boolean
- name:
- type: string
- requiredForCompletion:
- type: boolean
- templateName:
- type: string
- required:
- - name
- - templateName
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- duration:
- type: string
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- progressDeadlineSeconds:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- templates:
- items:
- properties:
- minReadySeconds:
- format: int32
- type: integer
- name:
- type: string
- replicas:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- service:
- type: object
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- required:
- - name
- - selector
- - template
- type: object
- type: array
- terminate:
- type: boolean
- required:
- - templates
- type: object
- status:
- properties:
- analysisRuns:
- items:
- properties:
- analysisRun:
- type: string
- message:
- type: string
- name:
- type: string
- phase:
- type: string
- required:
- - analysisRun
- - name
- - phase
- type: object
- type: array
- availableAt:
- format: date-time
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- lastUpdateTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - lastTransitionTime
- - lastUpdateTime
- - message
- - reason
- - status
- - type
- type: object
- type: array
- message:
- type: string
- phase:
- type: string
- templateStatuses:
- items:
- properties:
- availableReplicas:
- format: int32
- type: integer
- collisionCount:
- format: int32
- type: integer
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- name:
- type: string
- podTemplateHash:
- type: string
- readyReplicas:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- serviceName:
- type: string
- status:
- type: string
- updatedReplicas:
- format: int32
- type: integer
- required:
- - availableReplicas
- - name
- - readyReplicas
- - replicas
- - updatedReplicas
- type: object
- type: array
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/rollout-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: rollouts.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: Rollout
- listKind: RolloutList
- plural: rollouts
- shortNames:
- - ro
- singular: rollout
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Number of desired pods
- jsonPath: .spec.replicas
- name: Desired
- type: integer
- - description: Total number of non-terminated pods targeted by this rollout
- jsonPath: .status.replicas
- name: Current
- type: integer
- - description: Total number of non-terminated pods targeted by this rollout that
- have the desired template spec
- jsonPath: .status.updatedReplicas
- name: Up-to-date
- type: integer
- - description: Total number of available pods (ready for at least minReadySeconds)
- targeted by this rollout
- jsonPath: .status.availableReplicas
- name: Available
- type: integer
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- analysis:
- properties:
- successfulRunHistoryLimit:
- format: int32
- type: integer
- unsuccessfulRunHistoryLimit:
- format: int32
- type: integer
- type: object
- minReadySeconds:
- format: int32
- type: integer
- paused:
- type: boolean
- progressDeadlineAbort:
- type: boolean
- progressDeadlineSeconds:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- restartAt:
- format: date-time
- type: string
- revisionHistoryLimit:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- strategy:
- properties:
- blueGreen:
- properties:
- abortScaleDownDelaySeconds:
- format: int32
- type: integer
- activeMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- activeService:
- type: string
- antiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- properties:
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- requiredDuringSchedulingIgnoredDuringExecution:
- type: object
- type: object
- autoPromotionEnabled:
- type: boolean
- autoPromotionSeconds:
- format: int32
- type: integer
- maxUnavailable:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- postPromotionAnalysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- prePromotionAnalysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- previewMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- previewReplicaCount:
- format: int32
- type: integer
- previewService:
- type: string
- scaleDownDelayRevisionLimit:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- required:
- - activeService
- type: object
- canary:
- properties:
- abortScaleDownDelaySeconds:
- format: int32
- type: integer
- analysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- startingStep:
- format: int32
- type: integer
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- antiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- properties:
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- requiredDuringSchedulingIgnoredDuringExecution:
- type: object
- type: object
- canaryMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- canaryService:
- type: string
- dynamicStableScale:
- type: boolean
- maxSurge:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- maxUnavailable:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- pingPong:
- properties:
- pingService:
- type: string
- pongService:
- type: string
- required:
- - pingService
- - pongService
- type: object
- scaleDownDelayRevisionLimit:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- stableMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- stableService:
- type: string
- steps:
- items:
- properties:
- analysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- experiment:
- properties:
- analyses:
- items:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- clusterScope:
- type: boolean
- name:
- type: string
- requiredForCompletion:
- type: boolean
- templateName:
- type: string
- required:
- - name
- - templateName
- type: object
- type: array
- duration:
- type: string
- templates:
- items:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- name:
- type: string
- replicas:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- specRef:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - name
- - specRef
- type: object
- type: array
- required:
- - templates
- type: object
- pause:
- properties:
- duration:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- type: object
- setCanaryScale:
- properties:
- matchTrafficWeight:
- type: boolean
- replicas:
- format: int32
- type: integer
- weight:
- format: int32
- type: integer
- type: object
- setHeaderRoute:
- properties:
- match:
- items:
- properties:
- headerName:
- type: string
- headerValue:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- required:
- - headerName
- - headerValue
- type: object
- type: array
- name:
- type: string
- type: object
- setMirrorRoute:
- properties:
- match:
- items:
- properties:
- headers:
- additionalProperties:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- type: object
- method:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- path:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- type: object
- type: array
- name:
- type: string
- percentage:
- format: int32
- type: integer
- required:
- - name
- type: object
- setWeight:
- format: int32
- type: integer
- type: object
- type: array
- trafficRouting:
- properties:
- alb:
- properties:
- annotationPrefix:
- type: string
- ingress:
- type: string
- rootService:
- type: string
- servicePort:
- format: int32
- type: integer
- stickinessConfig:
- properties:
- durationSeconds:
- format: int64
- type: integer
- enabled:
- type: boolean
- required:
- - durationSeconds
- - enabled
- type: object
- required:
- - ingress
- - servicePort
- type: object
- ambassador:
- properties:
- mappings:
- items:
- type: string
- type: array
- required:
- - mappings
- type: object
- appMesh:
- properties:
- virtualNodeGroup:
- properties:
- canaryVirtualNodeRef:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- stableVirtualNodeRef:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- required:
- - canaryVirtualNodeRef
- - stableVirtualNodeRef
- type: object
- virtualService:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- required:
- - name
- type: object
- type: object
- istio:
- properties:
- destinationRule:
- properties:
- canarySubsetName:
- type: string
- name:
- type: string
- stableSubsetName:
- type: string
- required:
- - canarySubsetName
- - name
- - stableSubsetName
- type: object
- virtualService:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- tlsRoutes:
- items:
- properties:
- port:
- format: int64
- type: integer
- sniHosts:
- items:
- type: string
- type: array
- type: object
- type: array
- required:
- - name
- type: object
- virtualServices:
- items:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- tlsRoutes:
- items:
- properties:
- port:
- format: int64
- type: integer
- sniHosts:
- items:
- type: string
- type: array
- type: object
- type: array
- required:
- - name
- type: object
- type: array
- type: object
- managedRoutes:
- items:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- type: array
- nginx:
- properties:
- additionalIngressAnnotations:
- additionalProperties:
- type: string
- type: object
- annotationPrefix:
- type: string
- stableIngress:
- type: string
- required:
- - stableIngress
- type: object
- smi:
- properties:
- rootService:
- type: string
- trafficSplitName:
- type: string
- type: object
- traefik:
- properties:
- weightedTraefikServiceName:
- type: string
- required:
- - weightedTraefikServiceName
- type: object
- type: object
- type: object
- type: object
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- items:
- x-kubernetes-preserve-unknown-fields: true
- type: array
- required:
- - containers
- type: object
- type: object
- workloadRef:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- name:
- type: string
- type: object
- type: object
- status:
- properties:
- HPAReplicas:
- format: int32
- type: integer
- abort:
- type: boolean
- abortedAt:
- format: date-time
- type: string
- alb:
- properties:
- canaryTargetGroup:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- loadBalancer:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- stableTargetGroup:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- type: object
- availableReplicas:
- format: int32
- type: integer
- blueGreen:
- properties:
- activeSelector:
- type: string
- postPromotionAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- prePromotionAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- previewSelector:
- type: string
- scaleUpPreviewCheckPoint:
- type: boolean
- type: object
- canary:
- properties:
- currentBackgroundAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- currentExperiment:
- type: string
- currentStepAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- stablePingPong:
- type: string
- weights:
- properties:
- additional:
- items:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- type: array
- canary:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- stable:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- verified:
- type: boolean
- required:
- - canary
- - stable
- type: object
- type: object
- collisionCount:
- format: int32
- type: integer
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- lastUpdateTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - lastTransitionTime
- - lastUpdateTime
- - message
- - reason
- - status
- - type
- type: object
- type: array
- controllerPause:
- type: boolean
- currentPodHash:
- type: string
- currentStepHash:
- type: string
- currentStepIndex:
- format: int32
- type: integer
- message:
- type: string
- observedGeneration:
- type: string
- pauseConditions:
- items:
- properties:
- reason:
- type: string
- startTime:
- format: date-time
- type: string
- required:
- - reason
- - startTime
- type: object
- type: array
- phase:
- type: string
- promoteFull:
- type: boolean
- readyReplicas:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- restartedAt:
- format: date-time
- type: string
- selector:
- type: string
- stableRS:
- type: string
- updatedReplicas:
- format: int32
- type: integer
- workloadObservedGeneration:
- type: string
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources:
- scale:
- labelSelectorPath: .status.selector
- specReplicasPath: .spec.replicas
- statusReplicasPath: .status.HPAReplicas
- status: {}
----
-# Source: rollouts/templates/argo-rollouts-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/status
- - rollouts/finalizers
- verbs:
- - get
- - list
- - watch
- - update
- - patch
-- apiGroups:
- - argoproj.io
- resources:
- - analysisruns
- - analysisruns/finalizers
- - experiments
- - experiments/finalizers
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - argoproj.io
- resources:
- - analysistemplates
- - clusteranalysistemplates
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - apps
- resources:
- - replicasets
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - ""
- - apps
- resources:
- - deployments
- - podtemplates
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - ""
- resources:
- - services
- verbs:
- - get
- - list
- - watch
- - patch
- - create
- - delete
-- apiGroups:
- - coordination.k8s.io
- resources:
- - leases
- verbs:
- - create
- - get
- - update
-- apiGroups:
- - ""
- resources:
- - secrets
- - configmaps
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - ""
- resources:
- - pods
- verbs:
- - list
- - update
- - watch
-- apiGroups:
- - ""
- resources:
- - pods/eviction
- verbs:
- - create
-- apiGroups:
- - ""
- resources:
- - events
- verbs:
- - create
- - update
- - patch
-- apiGroups:
- - networking.k8s.io
- - extensions
- resources:
- - ingresses
- verbs:
- - create
- - get
- - list
- - watch
- - patch
-- apiGroups:
- - batch
- resources:
- - jobs
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - networking.istio.io
- resources:
- - virtualservices
- - destinationrules
- verbs:
- - watch
- - get
- - update
- - patch
- - list
-- apiGroups:
- - split.smi-spec.io
- resources:
- - trafficsplits
- verbs:
- - create
- - watch
- - get
- - update
- - patch
-- apiGroups:
- - getambassador.io
- - x.getambassador.io
- resources:
- - mappings
- - ambassadormappings
- verbs:
- - create
- - watch
- - get
- - update
- - list
- - delete
-- apiGroups:
- - ""
- resources:
- - endpoints
- verbs:
- - get
-- apiGroups:
- - elbv2.k8s.aws
- resources:
- - targetgroupbindings
- verbs:
- - list
- - get
-- apiGroups:
- - appmesh.k8s.aws
- resources:
- - virtualservices
- verbs:
- - watch
- - get
- - list
-- apiGroups:
- - appmesh.k8s.aws
- resources:
- - virtualnodes
- - virtualrouters
- verbs:
- - watch
- - get
- - list
- - update
- - patch
-- apiGroups:
- - traefik.containo.us
- resources:
- - traefikservices
- verbs:
- - watch
- - get
- - update
----
-# Source: rollouts/templates/rollouts-aggregate-to-admin-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-admin
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
- name: argo-rollouts-aggregate-to-admin
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - rollouts/status
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - create
- - delete
- - deletecollection
- - get
- - list
- - patch
- - update
- - watch
----
-# Source: rollouts/templates/rollouts-aggregate-to-edit-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-edit
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- name: argo-rollouts-aggregate-to-edit
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - rollouts/status
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - create
- - delete
- - deletecollection
- - get
- - list
- - patch
- - update
- - watch
----
-# Source: rollouts/templates/rollouts-aggregate-to-view-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-view
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-view: "true"
- name: argo-rollouts-aggregate-to-view
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - get
- - list
- - watch
----
-# Source: rollouts/templates/clusterRoleBinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: argo-rollouts
-subjects:
-- kind: ServiceAccount
- name: argo-rollouts
- namespace: argo-rollouts
----
-# Source: rollouts/templates/rollouts-metrics-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app.kubernetes.io/component: server
- app.kubernetes.io/name: argo-rollouts-metrics
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts-metrics
-spec:
- ports:
- - name: metrics
- port: 8090
- protocol: TCP
- targetPort: 8090
- selector:
- app.kubernetes.io/name: argo-rollouts
----
-# Source: rollouts/templates/rollouts-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-spec:
- replicas: 1
- selector:
- matchLabels:
- app.kubernetes.io/name: argo-rollouts
- strategy:
- type: Recreate
- template:
- metadata:
- labels:
- app.kubernetes.io/name: argo-rollouts
- spec:
- containers:
- - image: quay.io/argoproj/argo-rollouts:v1.3.1
- imagePullPolicy: Always
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /healthz
- port: healthz
- initialDelaySeconds: 30
- periodSeconds: 20
- successThreshold: 1
- timeoutSeconds: 10
- name: argo-rollouts
- ports:
- - containerPort: 8090
- name: metrics
- - containerPort: 8080
- name: healthz
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /metrics
- port: metrics
- initialDelaySeconds: 10
- periodSeconds: 5
- successThreshold: 1
- timeoutSeconds: 4
- securityContext:
- runAsNonRoot: true
- serviceAccountName: argo-rollouts
diff --git a/tests/region-rollouts-industrial-edge-hub.expected.yaml b/tests/region-rollouts-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 6463a588..00000000
--- a/tests/region-rollouts-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,14853 +0,0 @@
----
-# Source: rollouts/templates/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
----
-# Source: rollouts/templates/rollouts-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: argo-rollouts-notification-secret
----
-# Source: rollouts/templates/analysisRun-crd.yaml
-# This is an auto-generated file. DO NOT EDIT
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: analysisruns.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: AnalysisRun
- listKind: AnalysisRunList
- plural: analysisruns
- shortNames:
- - ar
- singular: analysisrun
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: AnalysisRun status
- jsonPath: .status.phase
- name: Status
- type: string
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- terminate:
- type: boolean
- required:
- - metrics
- type: object
- status:
- properties:
- dryRunSummary:
- properties:
- count:
- format: int32
- type: integer
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- successful:
- format: int32
- type: integer
- type: object
- message:
- type: string
- metricResults:
- items:
- properties:
- consecutiveError:
- format: int32
- type: integer
- count:
- format: int32
- type: integer
- dryRun:
- type: boolean
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- measurements:
- items:
- properties:
- finishedAt:
- format: date-time
- type: string
- message:
- type: string
- metadata:
- additionalProperties:
- type: string
- type: object
- phase:
- type: string
- resumeAt:
- format: date-time
- type: string
- startedAt:
- format: date-time
- type: string
- value:
- type: string
- required:
- - phase
- type: object
- type: array
- message:
- type: string
- metadata:
- additionalProperties:
- type: string
- type: object
- name:
- type: string
- phase:
- type: string
- successful:
- format: int32
- type: integer
- required:
- - name
- - phase
- type: object
- type: array
- phase:
- type: string
- runSummary:
- properties:
- count:
- format: int32
- type: integer
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- successful:
- format: int32
- type: integer
- type: object
- startedAt:
- format: date-time
- type: string
- required:
- - phase
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/analysisTemplate-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: analysistemplates.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: AnalysisTemplate
- listKind: AnalysisTemplateList
- plural: analysistemplates
- shortNames:
- - at
- singular: analysistemplate
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- required:
- - metrics
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/clusterAnalysisTemplate-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: clusteranalysistemplates.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: ClusterAnalysisTemplate
- listKind: ClusterAnalysisTemplateList
- plural: clusteranalysistemplates
- shortNames:
- - cat
- singular: clusteranalysistemplate
- preserveUnknownFields: false
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- required:
- - metrics
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/experiments-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: experiments.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: Experiment
- listKind: ExperimentList
- plural: experiments
- shortNames:
- - exp
- singular: experiment
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Experiment status
- jsonPath: .status.phase
- name: Status
- type: string
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- analyses:
- items:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- clusterScope:
- type: boolean
- name:
- type: string
- requiredForCompletion:
- type: boolean
- templateName:
- type: string
- required:
- - name
- - templateName
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- duration:
- type: string
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- progressDeadlineSeconds:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- templates:
- items:
- properties:
- minReadySeconds:
- format: int32
- type: integer
- name:
- type: string
- replicas:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- service:
- type: object
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- required:
- - name
- - selector
- - template
- type: object
- type: array
- terminate:
- type: boolean
- required:
- - templates
- type: object
- status:
- properties:
- analysisRuns:
- items:
- properties:
- analysisRun:
- type: string
- message:
- type: string
- name:
- type: string
- phase:
- type: string
- required:
- - analysisRun
- - name
- - phase
- type: object
- type: array
- availableAt:
- format: date-time
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- lastUpdateTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - lastTransitionTime
- - lastUpdateTime
- - message
- - reason
- - status
- - type
- type: object
- type: array
- message:
- type: string
- phase:
- type: string
- templateStatuses:
- items:
- properties:
- availableReplicas:
- format: int32
- type: integer
- collisionCount:
- format: int32
- type: integer
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- name:
- type: string
- podTemplateHash:
- type: string
- readyReplicas:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- serviceName:
- type: string
- status:
- type: string
- updatedReplicas:
- format: int32
- type: integer
- required:
- - availableReplicas
- - name
- - readyReplicas
- - replicas
- - updatedReplicas
- type: object
- type: array
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/rollout-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: rollouts.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: Rollout
- listKind: RolloutList
- plural: rollouts
- shortNames:
- - ro
- singular: rollout
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Number of desired pods
- jsonPath: .spec.replicas
- name: Desired
- type: integer
- - description: Total number of non-terminated pods targeted by this rollout
- jsonPath: .status.replicas
- name: Current
- type: integer
- - description: Total number of non-terminated pods targeted by this rollout that
- have the desired template spec
- jsonPath: .status.updatedReplicas
- name: Up-to-date
- type: integer
- - description: Total number of available pods (ready for at least minReadySeconds)
- targeted by this rollout
- jsonPath: .status.availableReplicas
- name: Available
- type: integer
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- analysis:
- properties:
- successfulRunHistoryLimit:
- format: int32
- type: integer
- unsuccessfulRunHistoryLimit:
- format: int32
- type: integer
- type: object
- minReadySeconds:
- format: int32
- type: integer
- paused:
- type: boolean
- progressDeadlineAbort:
- type: boolean
- progressDeadlineSeconds:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- restartAt:
- format: date-time
- type: string
- revisionHistoryLimit:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- strategy:
- properties:
- blueGreen:
- properties:
- abortScaleDownDelaySeconds:
- format: int32
- type: integer
- activeMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- activeService:
- type: string
- antiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- properties:
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- requiredDuringSchedulingIgnoredDuringExecution:
- type: object
- type: object
- autoPromotionEnabled:
- type: boolean
- autoPromotionSeconds:
- format: int32
- type: integer
- maxUnavailable:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- postPromotionAnalysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- prePromotionAnalysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- previewMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- previewReplicaCount:
- format: int32
- type: integer
- previewService:
- type: string
- scaleDownDelayRevisionLimit:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- required:
- - activeService
- type: object
- canary:
- properties:
- abortScaleDownDelaySeconds:
- format: int32
- type: integer
- analysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- startingStep:
- format: int32
- type: integer
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- antiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- properties:
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- requiredDuringSchedulingIgnoredDuringExecution:
- type: object
- type: object
- canaryMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- canaryService:
- type: string
- dynamicStableScale:
- type: boolean
- maxSurge:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- maxUnavailable:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- pingPong:
- properties:
- pingService:
- type: string
- pongService:
- type: string
- required:
- - pingService
- - pongService
- type: object
- scaleDownDelayRevisionLimit:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- stableMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- stableService:
- type: string
- steps:
- items:
- properties:
- analysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- experiment:
- properties:
- analyses:
- items:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- clusterScope:
- type: boolean
- name:
- type: string
- requiredForCompletion:
- type: boolean
- templateName:
- type: string
- required:
- - name
- - templateName
- type: object
- type: array
- duration:
- type: string
- templates:
- items:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- name:
- type: string
- replicas:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- specRef:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - name
- - specRef
- type: object
- type: array
- required:
- - templates
- type: object
- pause:
- properties:
- duration:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- type: object
- setCanaryScale:
- properties:
- matchTrafficWeight:
- type: boolean
- replicas:
- format: int32
- type: integer
- weight:
- format: int32
- type: integer
- type: object
- setHeaderRoute:
- properties:
- match:
- items:
- properties:
- headerName:
- type: string
- headerValue:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- required:
- - headerName
- - headerValue
- type: object
- type: array
- name:
- type: string
- type: object
- setMirrorRoute:
- properties:
- match:
- items:
- properties:
- headers:
- additionalProperties:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- type: object
- method:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- path:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- type: object
- type: array
- name:
- type: string
- percentage:
- format: int32
- type: integer
- required:
- - name
- type: object
- setWeight:
- format: int32
- type: integer
- type: object
- type: array
- trafficRouting:
- properties:
- alb:
- properties:
- annotationPrefix:
- type: string
- ingress:
- type: string
- rootService:
- type: string
- servicePort:
- format: int32
- type: integer
- stickinessConfig:
- properties:
- durationSeconds:
- format: int64
- type: integer
- enabled:
- type: boolean
- required:
- - durationSeconds
- - enabled
- type: object
- required:
- - ingress
- - servicePort
- type: object
- ambassador:
- properties:
- mappings:
- items:
- type: string
- type: array
- required:
- - mappings
- type: object
- appMesh:
- properties:
- virtualNodeGroup:
- properties:
- canaryVirtualNodeRef:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- stableVirtualNodeRef:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- required:
- - canaryVirtualNodeRef
- - stableVirtualNodeRef
- type: object
- virtualService:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- required:
- - name
- type: object
- type: object
- istio:
- properties:
- destinationRule:
- properties:
- canarySubsetName:
- type: string
- name:
- type: string
- stableSubsetName:
- type: string
- required:
- - canarySubsetName
- - name
- - stableSubsetName
- type: object
- virtualService:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- tlsRoutes:
- items:
- properties:
- port:
- format: int64
- type: integer
- sniHosts:
- items:
- type: string
- type: array
- type: object
- type: array
- required:
- - name
- type: object
- virtualServices:
- items:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- tlsRoutes:
- items:
- properties:
- port:
- format: int64
- type: integer
- sniHosts:
- items:
- type: string
- type: array
- type: object
- type: array
- required:
- - name
- type: object
- type: array
- type: object
- managedRoutes:
- items:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- type: array
- nginx:
- properties:
- additionalIngressAnnotations:
- additionalProperties:
- type: string
- type: object
- annotationPrefix:
- type: string
- stableIngress:
- type: string
- required:
- - stableIngress
- type: object
- smi:
- properties:
- rootService:
- type: string
- trafficSplitName:
- type: string
- type: object
- traefik:
- properties:
- weightedTraefikServiceName:
- type: string
- required:
- - weightedTraefikServiceName
- type: object
- type: object
- type: object
- type: object
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- items:
- x-kubernetes-preserve-unknown-fields: true
- type: array
- required:
- - containers
- type: object
- type: object
- workloadRef:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- name:
- type: string
- type: object
- type: object
- status:
- properties:
- HPAReplicas:
- format: int32
- type: integer
- abort:
- type: boolean
- abortedAt:
- format: date-time
- type: string
- alb:
- properties:
- canaryTargetGroup:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- loadBalancer:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- stableTargetGroup:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- type: object
- availableReplicas:
- format: int32
- type: integer
- blueGreen:
- properties:
- activeSelector:
- type: string
- postPromotionAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- prePromotionAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- previewSelector:
- type: string
- scaleUpPreviewCheckPoint:
- type: boolean
- type: object
- canary:
- properties:
- currentBackgroundAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- currentExperiment:
- type: string
- currentStepAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- stablePingPong:
- type: string
- weights:
- properties:
- additional:
- items:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- type: array
- canary:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- stable:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- verified:
- type: boolean
- required:
- - canary
- - stable
- type: object
- type: object
- collisionCount:
- format: int32
- type: integer
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- lastUpdateTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - lastTransitionTime
- - lastUpdateTime
- - message
- - reason
- - status
- - type
- type: object
- type: array
- controllerPause:
- type: boolean
- currentPodHash:
- type: string
- currentStepHash:
- type: string
- currentStepIndex:
- format: int32
- type: integer
- message:
- type: string
- observedGeneration:
- type: string
- pauseConditions:
- items:
- properties:
- reason:
- type: string
- startTime:
- format: date-time
- type: string
- required:
- - reason
- - startTime
- type: object
- type: array
- phase:
- type: string
- promoteFull:
- type: boolean
- readyReplicas:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- restartedAt:
- format: date-time
- type: string
- selector:
- type: string
- stableRS:
- type: string
- updatedReplicas:
- format: int32
- type: integer
- workloadObservedGeneration:
- type: string
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources:
- scale:
- labelSelectorPath: .status.selector
- specReplicasPath: .spec.replicas
- statusReplicasPath: .status.HPAReplicas
- status: {}
----
-# Source: rollouts/templates/argo-rollouts-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/status
- - rollouts/finalizers
- verbs:
- - get
- - list
- - watch
- - update
- - patch
-- apiGroups:
- - argoproj.io
- resources:
- - analysisruns
- - analysisruns/finalizers
- - experiments
- - experiments/finalizers
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - argoproj.io
- resources:
- - analysistemplates
- - clusteranalysistemplates
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - apps
- resources:
- - replicasets
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - ""
- - apps
- resources:
- - deployments
- - podtemplates
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - ""
- resources:
- - services
- verbs:
- - get
- - list
- - watch
- - patch
- - create
- - delete
-- apiGroups:
- - coordination.k8s.io
- resources:
- - leases
- verbs:
- - create
- - get
- - update
-- apiGroups:
- - ""
- resources:
- - secrets
- - configmaps
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - ""
- resources:
- - pods
- verbs:
- - list
- - update
- - watch
-- apiGroups:
- - ""
- resources:
- - pods/eviction
- verbs:
- - create
-- apiGroups:
- - ""
- resources:
- - events
- verbs:
- - create
- - update
- - patch
-- apiGroups:
- - networking.k8s.io
- - extensions
- resources:
- - ingresses
- verbs:
- - create
- - get
- - list
- - watch
- - patch
-- apiGroups:
- - batch
- resources:
- - jobs
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - networking.istio.io
- resources:
- - virtualservices
- - destinationrules
- verbs:
- - watch
- - get
- - update
- - patch
- - list
-- apiGroups:
- - split.smi-spec.io
- resources:
- - trafficsplits
- verbs:
- - create
- - watch
- - get
- - update
- - patch
-- apiGroups:
- - getambassador.io
- - x.getambassador.io
- resources:
- - mappings
- - ambassadormappings
- verbs:
- - create
- - watch
- - get
- - update
- - list
- - delete
-- apiGroups:
- - ""
- resources:
- - endpoints
- verbs:
- - get
-- apiGroups:
- - elbv2.k8s.aws
- resources:
- - targetgroupbindings
- verbs:
- - list
- - get
-- apiGroups:
- - appmesh.k8s.aws
- resources:
- - virtualservices
- verbs:
- - watch
- - get
- - list
-- apiGroups:
- - appmesh.k8s.aws
- resources:
- - virtualnodes
- - virtualrouters
- verbs:
- - watch
- - get
- - list
- - update
- - patch
-- apiGroups:
- - traefik.containo.us
- resources:
- - traefikservices
- verbs:
- - watch
- - get
- - update
----
-# Source: rollouts/templates/rollouts-aggregate-to-admin-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-admin
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
- name: argo-rollouts-aggregate-to-admin
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - rollouts/status
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - create
- - delete
- - deletecollection
- - get
- - list
- - patch
- - update
- - watch
----
-# Source: rollouts/templates/rollouts-aggregate-to-edit-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-edit
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- name: argo-rollouts-aggregate-to-edit
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - rollouts/status
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - create
- - delete
- - deletecollection
- - get
- - list
- - patch
- - update
- - watch
----
-# Source: rollouts/templates/rollouts-aggregate-to-view-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-view
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-view: "true"
- name: argo-rollouts-aggregate-to-view
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - get
- - list
- - watch
----
-# Source: rollouts/templates/clusterRoleBinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: argo-rollouts
-subjects:
-- kind: ServiceAccount
- name: argo-rollouts
- namespace: argo-rollouts
----
-# Source: rollouts/templates/rollouts-metrics-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app.kubernetes.io/component: server
- app.kubernetes.io/name: argo-rollouts-metrics
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts-metrics
-spec:
- ports:
- - name: metrics
- port: 8090
- protocol: TCP
- targetPort: 8090
- selector:
- app.kubernetes.io/name: argo-rollouts
----
-# Source: rollouts/templates/rollouts-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-spec:
- replicas: 1
- selector:
- matchLabels:
- app.kubernetes.io/name: argo-rollouts
- strategy:
- type: Recreate
- template:
- metadata:
- labels:
- app.kubernetes.io/name: argo-rollouts
- spec:
- containers:
- - image: quay.io/argoproj/argo-rollouts:v1.3.1
- imagePullPolicy: Always
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /healthz
- port: healthz
- initialDelaySeconds: 30
- periodSeconds: 20
- successThreshold: 1
- timeoutSeconds: 10
- name: argo-rollouts
- ports:
- - containerPort: 8090
- name: metrics
- - containerPort: 8080
- name: healthz
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /metrics
- port: metrics
- initialDelaySeconds: 10
- periodSeconds: 5
- successThreshold: 1
- timeoutSeconds: 4
- securityContext:
- runAsNonRoot: true
- serviceAccountName: argo-rollouts
diff --git a/tests/region-rollouts-medical-diagnosis-hub.expected.yaml b/tests/region-rollouts-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 6463a588..00000000
--- a/tests/region-rollouts-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,14853 +0,0 @@
----
-# Source: rollouts/templates/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
----
-# Source: rollouts/templates/rollouts-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: argo-rollouts-notification-secret
----
-# Source: rollouts/templates/analysisRun-crd.yaml
-# This is an auto-generated file. DO NOT EDIT
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: analysisruns.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: AnalysisRun
- listKind: AnalysisRunList
- plural: analysisruns
- shortNames:
- - ar
- singular: analysisrun
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: AnalysisRun status
- jsonPath: .status.phase
- name: Status
- type: string
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- terminate:
- type: boolean
- required:
- - metrics
- type: object
- status:
- properties:
- dryRunSummary:
- properties:
- count:
- format: int32
- type: integer
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- successful:
- format: int32
- type: integer
- type: object
- message:
- type: string
- metricResults:
- items:
- properties:
- consecutiveError:
- format: int32
- type: integer
- count:
- format: int32
- type: integer
- dryRun:
- type: boolean
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- measurements:
- items:
- properties:
- finishedAt:
- format: date-time
- type: string
- message:
- type: string
- metadata:
- additionalProperties:
- type: string
- type: object
- phase:
- type: string
- resumeAt:
- format: date-time
- type: string
- startedAt:
- format: date-time
- type: string
- value:
- type: string
- required:
- - phase
- type: object
- type: array
- message:
- type: string
- metadata:
- additionalProperties:
- type: string
- type: object
- name:
- type: string
- phase:
- type: string
- successful:
- format: int32
- type: integer
- required:
- - name
- - phase
- type: object
- type: array
- phase:
- type: string
- runSummary:
- properties:
- count:
- format: int32
- type: integer
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- successful:
- format: int32
- type: integer
- type: object
- startedAt:
- format: date-time
- type: string
- required:
- - phase
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/analysisTemplate-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: analysistemplates.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: AnalysisTemplate
- listKind: AnalysisTemplateList
- plural: analysistemplates
- shortNames:
- - at
- singular: analysistemplate
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- required:
- - metrics
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/clusterAnalysisTemplate-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: clusteranalysistemplates.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: ClusterAnalysisTemplate
- listKind: ClusterAnalysisTemplateList
- plural: clusteranalysistemplates
- shortNames:
- - cat
- singular: clusteranalysistemplate
- preserveUnknownFields: false
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- required:
- - metrics
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/experiments-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: experiments.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: Experiment
- listKind: ExperimentList
- plural: experiments
- shortNames:
- - exp
- singular: experiment
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Experiment status
- jsonPath: .status.phase
- name: Status
- type: string
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- analyses:
- items:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- clusterScope:
- type: boolean
- name:
- type: string
- requiredForCompletion:
- type: boolean
- templateName:
- type: string
- required:
- - name
- - templateName
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- duration:
- type: string
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- progressDeadlineSeconds:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- templates:
- items:
- properties:
- minReadySeconds:
- format: int32
- type: integer
- name:
- type: string
- replicas:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- service:
- type: object
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- required:
- - name
- - selector
- - template
- type: object
- type: array
- terminate:
- type: boolean
- required:
- - templates
- type: object
- status:
- properties:
- analysisRuns:
- items:
- properties:
- analysisRun:
- type: string
- message:
- type: string
- name:
- type: string
- phase:
- type: string
- required:
- - analysisRun
- - name
- - phase
- type: object
- type: array
- availableAt:
- format: date-time
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- lastUpdateTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - lastTransitionTime
- - lastUpdateTime
- - message
- - reason
- - status
- - type
- type: object
- type: array
- message:
- type: string
- phase:
- type: string
- templateStatuses:
- items:
- properties:
- availableReplicas:
- format: int32
- type: integer
- collisionCount:
- format: int32
- type: integer
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- name:
- type: string
- podTemplateHash:
- type: string
- readyReplicas:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- serviceName:
- type: string
- status:
- type: string
- updatedReplicas:
- format: int32
- type: integer
- required:
- - availableReplicas
- - name
- - readyReplicas
- - replicas
- - updatedReplicas
- type: object
- type: array
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/rollout-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: rollouts.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: Rollout
- listKind: RolloutList
- plural: rollouts
- shortNames:
- - ro
- singular: rollout
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Number of desired pods
- jsonPath: .spec.replicas
- name: Desired
- type: integer
- - description: Total number of non-terminated pods targeted by this rollout
- jsonPath: .status.replicas
- name: Current
- type: integer
- - description: Total number of non-terminated pods targeted by this rollout that
- have the desired template spec
- jsonPath: .status.updatedReplicas
- name: Up-to-date
- type: integer
- - description: Total number of available pods (ready for at least minReadySeconds)
- targeted by this rollout
- jsonPath: .status.availableReplicas
- name: Available
- type: integer
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- analysis:
- properties:
- successfulRunHistoryLimit:
- format: int32
- type: integer
- unsuccessfulRunHistoryLimit:
- format: int32
- type: integer
- type: object
- minReadySeconds:
- format: int32
- type: integer
- paused:
- type: boolean
- progressDeadlineAbort:
- type: boolean
- progressDeadlineSeconds:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- restartAt:
- format: date-time
- type: string
- revisionHistoryLimit:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- strategy:
- properties:
- blueGreen:
- properties:
- abortScaleDownDelaySeconds:
- format: int32
- type: integer
- activeMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- activeService:
- type: string
- antiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- properties:
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- requiredDuringSchedulingIgnoredDuringExecution:
- type: object
- type: object
- autoPromotionEnabled:
- type: boolean
- autoPromotionSeconds:
- format: int32
- type: integer
- maxUnavailable:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- postPromotionAnalysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- prePromotionAnalysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- previewMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- previewReplicaCount:
- format: int32
- type: integer
- previewService:
- type: string
- scaleDownDelayRevisionLimit:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- required:
- - activeService
- type: object
- canary:
- properties:
- abortScaleDownDelaySeconds:
- format: int32
- type: integer
- analysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- startingStep:
- format: int32
- type: integer
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- antiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- properties:
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- requiredDuringSchedulingIgnoredDuringExecution:
- type: object
- type: object
- canaryMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- canaryService:
- type: string
- dynamicStableScale:
- type: boolean
- maxSurge:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- maxUnavailable:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- pingPong:
- properties:
- pingService:
- type: string
- pongService:
- type: string
- required:
- - pingService
- - pongService
- type: object
- scaleDownDelayRevisionLimit:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- stableMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- stableService:
- type: string
- steps:
- items:
- properties:
- analysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- experiment:
- properties:
- analyses:
- items:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- clusterScope:
- type: boolean
- name:
- type: string
- requiredForCompletion:
- type: boolean
- templateName:
- type: string
- required:
- - name
- - templateName
- type: object
- type: array
- duration:
- type: string
- templates:
- items:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- name:
- type: string
- replicas:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- specRef:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - name
- - specRef
- type: object
- type: array
- required:
- - templates
- type: object
- pause:
- properties:
- duration:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- type: object
- setCanaryScale:
- properties:
- matchTrafficWeight:
- type: boolean
- replicas:
- format: int32
- type: integer
- weight:
- format: int32
- type: integer
- type: object
- setHeaderRoute:
- properties:
- match:
- items:
- properties:
- headerName:
- type: string
- headerValue:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- required:
- - headerName
- - headerValue
- type: object
- type: array
- name:
- type: string
- type: object
- setMirrorRoute:
- properties:
- match:
- items:
- properties:
- headers:
- additionalProperties:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- type: object
- method:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- path:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- type: object
- type: array
- name:
- type: string
- percentage:
- format: int32
- type: integer
- required:
- - name
- type: object
- setWeight:
- format: int32
- type: integer
- type: object
- type: array
- trafficRouting:
- properties:
- alb:
- properties:
- annotationPrefix:
- type: string
- ingress:
- type: string
- rootService:
- type: string
- servicePort:
- format: int32
- type: integer
- stickinessConfig:
- properties:
- durationSeconds:
- format: int64
- type: integer
- enabled:
- type: boolean
- required:
- - durationSeconds
- - enabled
- type: object
- required:
- - ingress
- - servicePort
- type: object
- ambassador:
- properties:
- mappings:
- items:
- type: string
- type: array
- required:
- - mappings
- type: object
- appMesh:
- properties:
- virtualNodeGroup:
- properties:
- canaryVirtualNodeRef:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- stableVirtualNodeRef:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- required:
- - canaryVirtualNodeRef
- - stableVirtualNodeRef
- type: object
- virtualService:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- required:
- - name
- type: object
- type: object
- istio:
- properties:
- destinationRule:
- properties:
- canarySubsetName:
- type: string
- name:
- type: string
- stableSubsetName:
- type: string
- required:
- - canarySubsetName
- - name
- - stableSubsetName
- type: object
- virtualService:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- tlsRoutes:
- items:
- properties:
- port:
- format: int64
- type: integer
- sniHosts:
- items:
- type: string
- type: array
- type: object
- type: array
- required:
- - name
- type: object
- virtualServices:
- items:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- tlsRoutes:
- items:
- properties:
- port:
- format: int64
- type: integer
- sniHosts:
- items:
- type: string
- type: array
- type: object
- type: array
- required:
- - name
- type: object
- type: array
- type: object
- managedRoutes:
- items:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- type: array
- nginx:
- properties:
- additionalIngressAnnotations:
- additionalProperties:
- type: string
- type: object
- annotationPrefix:
- type: string
- stableIngress:
- type: string
- required:
- - stableIngress
- type: object
- smi:
- properties:
- rootService:
- type: string
- trafficSplitName:
- type: string
- type: object
- traefik:
- properties:
- weightedTraefikServiceName:
- type: string
- required:
- - weightedTraefikServiceName
- type: object
- type: object
- type: object
- type: object
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- items:
- x-kubernetes-preserve-unknown-fields: true
- type: array
- required:
- - containers
- type: object
- type: object
- workloadRef:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- name:
- type: string
- type: object
- type: object
- status:
- properties:
- HPAReplicas:
- format: int32
- type: integer
- abort:
- type: boolean
- abortedAt:
- format: date-time
- type: string
- alb:
- properties:
- canaryTargetGroup:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- loadBalancer:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- stableTargetGroup:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- type: object
- availableReplicas:
- format: int32
- type: integer
- blueGreen:
- properties:
- activeSelector:
- type: string
- postPromotionAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- prePromotionAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- previewSelector:
- type: string
- scaleUpPreviewCheckPoint:
- type: boolean
- type: object
- canary:
- properties:
- currentBackgroundAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- currentExperiment:
- type: string
- currentStepAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- stablePingPong:
- type: string
- weights:
- properties:
- additional:
- items:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- type: array
- canary:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- stable:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- verified:
- type: boolean
- required:
- - canary
- - stable
- type: object
- type: object
- collisionCount:
- format: int32
- type: integer
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- lastUpdateTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - lastTransitionTime
- - lastUpdateTime
- - message
- - reason
- - status
- - type
- type: object
- type: array
- controllerPause:
- type: boolean
- currentPodHash:
- type: string
- currentStepHash:
- type: string
- currentStepIndex:
- format: int32
- type: integer
- message:
- type: string
- observedGeneration:
- type: string
- pauseConditions:
- items:
- properties:
- reason:
- type: string
- startTime:
- format: date-time
- type: string
- required:
- - reason
- - startTime
- type: object
- type: array
- phase:
- type: string
- promoteFull:
- type: boolean
- readyReplicas:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- restartedAt:
- format: date-time
- type: string
- selector:
- type: string
- stableRS:
- type: string
- updatedReplicas:
- format: int32
- type: integer
- workloadObservedGeneration:
- type: string
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources:
- scale:
- labelSelectorPath: .status.selector
- specReplicasPath: .spec.replicas
- statusReplicasPath: .status.HPAReplicas
- status: {}
----
-# Source: rollouts/templates/argo-rollouts-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/status
- - rollouts/finalizers
- verbs:
- - get
- - list
- - watch
- - update
- - patch
-- apiGroups:
- - argoproj.io
- resources:
- - analysisruns
- - analysisruns/finalizers
- - experiments
- - experiments/finalizers
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - argoproj.io
- resources:
- - analysistemplates
- - clusteranalysistemplates
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - apps
- resources:
- - replicasets
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - ""
- - apps
- resources:
- - deployments
- - podtemplates
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - ""
- resources:
- - services
- verbs:
- - get
- - list
- - watch
- - patch
- - create
- - delete
-- apiGroups:
- - coordination.k8s.io
- resources:
- - leases
- verbs:
- - create
- - get
- - update
-- apiGroups:
- - ""
- resources:
- - secrets
- - configmaps
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - ""
- resources:
- - pods
- verbs:
- - list
- - update
- - watch
-- apiGroups:
- - ""
- resources:
- - pods/eviction
- verbs:
- - create
-- apiGroups:
- - ""
- resources:
- - events
- verbs:
- - create
- - update
- - patch
-- apiGroups:
- - networking.k8s.io
- - extensions
- resources:
- - ingresses
- verbs:
- - create
- - get
- - list
- - watch
- - patch
-- apiGroups:
- - batch
- resources:
- - jobs
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - networking.istio.io
- resources:
- - virtualservices
- - destinationrules
- verbs:
- - watch
- - get
- - update
- - patch
- - list
-- apiGroups:
- - split.smi-spec.io
- resources:
- - trafficsplits
- verbs:
- - create
- - watch
- - get
- - update
- - patch
-- apiGroups:
- - getambassador.io
- - x.getambassador.io
- resources:
- - mappings
- - ambassadormappings
- verbs:
- - create
- - watch
- - get
- - update
- - list
- - delete
-- apiGroups:
- - ""
- resources:
- - endpoints
- verbs:
- - get
-- apiGroups:
- - elbv2.k8s.aws
- resources:
- - targetgroupbindings
- verbs:
- - list
- - get
-- apiGroups:
- - appmesh.k8s.aws
- resources:
- - virtualservices
- verbs:
- - watch
- - get
- - list
-- apiGroups:
- - appmesh.k8s.aws
- resources:
- - virtualnodes
- - virtualrouters
- verbs:
- - watch
- - get
- - list
- - update
- - patch
-- apiGroups:
- - traefik.containo.us
- resources:
- - traefikservices
- verbs:
- - watch
- - get
- - update
----
-# Source: rollouts/templates/rollouts-aggregate-to-admin-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-admin
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
- name: argo-rollouts-aggregate-to-admin
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - rollouts/status
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - create
- - delete
- - deletecollection
- - get
- - list
- - patch
- - update
- - watch
----
-# Source: rollouts/templates/rollouts-aggregate-to-edit-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-edit
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- name: argo-rollouts-aggregate-to-edit
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - rollouts/status
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - create
- - delete
- - deletecollection
- - get
- - list
- - patch
- - update
- - watch
----
-# Source: rollouts/templates/rollouts-aggregate-to-view-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-view
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-view: "true"
- name: argo-rollouts-aggregate-to-view
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - get
- - list
- - watch
----
-# Source: rollouts/templates/clusterRoleBinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: argo-rollouts
-subjects:
-- kind: ServiceAccount
- name: argo-rollouts
- namespace: argo-rollouts
----
-# Source: rollouts/templates/rollouts-metrics-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app.kubernetes.io/component: server
- app.kubernetes.io/name: argo-rollouts-metrics
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts-metrics
-spec:
- ports:
- - name: metrics
- port: 8090
- protocol: TCP
- targetPort: 8090
- selector:
- app.kubernetes.io/name: argo-rollouts
----
-# Source: rollouts/templates/rollouts-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-spec:
- replicas: 1
- selector:
- matchLabels:
- app.kubernetes.io/name: argo-rollouts
- strategy:
- type: Recreate
- template:
- metadata:
- labels:
- app.kubernetes.io/name: argo-rollouts
- spec:
- containers:
- - image: quay.io/argoproj/argo-rollouts:v1.3.1
- imagePullPolicy: Always
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /healthz
- port: healthz
- initialDelaySeconds: 30
- periodSeconds: 20
- successThreshold: 1
- timeoutSeconds: 10
- name: argo-rollouts
- ports:
- - containerPort: 8090
- name: metrics
- - containerPort: 8080
- name: healthz
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /metrics
- port: metrics
- initialDelaySeconds: 10
- periodSeconds: 5
- successThreshold: 1
- timeoutSeconds: 4
- securityContext:
- runAsNonRoot: true
- serviceAccountName: argo-rollouts
diff --git a/tests/region-rollouts-naked.expected.yaml b/tests/region-rollouts-naked.expected.yaml
deleted file mode 100644
index 6463a588..00000000
--- a/tests/region-rollouts-naked.expected.yaml
+++ /dev/null
@@ -1,14853 +0,0 @@
----
-# Source: rollouts/templates/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
----
-# Source: rollouts/templates/rollouts-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: argo-rollouts-notification-secret
----
-# Source: rollouts/templates/analysisRun-crd.yaml
-# This is an auto-generated file. DO NOT EDIT
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: analysisruns.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: AnalysisRun
- listKind: AnalysisRunList
- plural: analysisruns
- shortNames:
- - ar
- singular: analysisrun
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: AnalysisRun status
- jsonPath: .status.phase
- name: Status
- type: string
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- terminate:
- type: boolean
- required:
- - metrics
- type: object
- status:
- properties:
- dryRunSummary:
- properties:
- count:
- format: int32
- type: integer
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- successful:
- format: int32
- type: integer
- type: object
- message:
- type: string
- metricResults:
- items:
- properties:
- consecutiveError:
- format: int32
- type: integer
- count:
- format: int32
- type: integer
- dryRun:
- type: boolean
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- measurements:
- items:
- properties:
- finishedAt:
- format: date-time
- type: string
- message:
- type: string
- metadata:
- additionalProperties:
- type: string
- type: object
- phase:
- type: string
- resumeAt:
- format: date-time
- type: string
- startedAt:
- format: date-time
- type: string
- value:
- type: string
- required:
- - phase
- type: object
- type: array
- message:
- type: string
- metadata:
- additionalProperties:
- type: string
- type: object
- name:
- type: string
- phase:
- type: string
- successful:
- format: int32
- type: integer
- required:
- - name
- - phase
- type: object
- type: array
- phase:
- type: string
- runSummary:
- properties:
- count:
- format: int32
- type: integer
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- successful:
- format: int32
- type: integer
- type: object
- startedAt:
- format: date-time
- type: string
- required:
- - phase
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/analysisTemplate-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: analysistemplates.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: AnalysisTemplate
- listKind: AnalysisTemplateList
- plural: analysistemplates
- shortNames:
- - at
- singular: analysistemplate
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- required:
- - metrics
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/clusterAnalysisTemplate-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: clusteranalysistemplates.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: ClusterAnalysisTemplate
- listKind: ClusterAnalysisTemplateList
- plural: clusteranalysistemplates
- shortNames:
- - cat
- singular: clusteranalysistemplate
- preserveUnknownFields: false
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- required:
- - metrics
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/experiments-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: experiments.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: Experiment
- listKind: ExperimentList
- plural: experiments
- shortNames:
- - exp
- singular: experiment
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Experiment status
- jsonPath: .status.phase
- name: Status
- type: string
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- analyses:
- items:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- clusterScope:
- type: boolean
- name:
- type: string
- requiredForCompletion:
- type: boolean
- templateName:
- type: string
- required:
- - name
- - templateName
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- duration:
- type: string
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- progressDeadlineSeconds:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- templates:
- items:
- properties:
- minReadySeconds:
- format: int32
- type: integer
- name:
- type: string
- replicas:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- service:
- type: object
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- required:
- - name
- - selector
- - template
- type: object
- type: array
- terminate:
- type: boolean
- required:
- - templates
- type: object
- status:
- properties:
- analysisRuns:
- items:
- properties:
- analysisRun:
- type: string
- message:
- type: string
- name:
- type: string
- phase:
- type: string
- required:
- - analysisRun
- - name
- - phase
- type: object
- type: array
- availableAt:
- format: date-time
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- lastUpdateTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - lastTransitionTime
- - lastUpdateTime
- - message
- - reason
- - status
- - type
- type: object
- type: array
- message:
- type: string
- phase:
- type: string
- templateStatuses:
- items:
- properties:
- availableReplicas:
- format: int32
- type: integer
- collisionCount:
- format: int32
- type: integer
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- name:
- type: string
- podTemplateHash:
- type: string
- readyReplicas:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- serviceName:
- type: string
- status:
- type: string
- updatedReplicas:
- format: int32
- type: integer
- required:
- - availableReplicas
- - name
- - readyReplicas
- - replicas
- - updatedReplicas
- type: object
- type: array
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/rollout-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: rollouts.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: Rollout
- listKind: RolloutList
- plural: rollouts
- shortNames:
- - ro
- singular: rollout
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Number of desired pods
- jsonPath: .spec.replicas
- name: Desired
- type: integer
- - description: Total number of non-terminated pods targeted by this rollout
- jsonPath: .status.replicas
- name: Current
- type: integer
- - description: Total number of non-terminated pods targeted by this rollout that
- have the desired template spec
- jsonPath: .status.updatedReplicas
- name: Up-to-date
- type: integer
- - description: Total number of available pods (ready for at least minReadySeconds)
- targeted by this rollout
- jsonPath: .status.availableReplicas
- name: Available
- type: integer
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- analysis:
- properties:
- successfulRunHistoryLimit:
- format: int32
- type: integer
- unsuccessfulRunHistoryLimit:
- format: int32
- type: integer
- type: object
- minReadySeconds:
- format: int32
- type: integer
- paused:
- type: boolean
- progressDeadlineAbort:
- type: boolean
- progressDeadlineSeconds:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- restartAt:
- format: date-time
- type: string
- revisionHistoryLimit:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- strategy:
- properties:
- blueGreen:
- properties:
- abortScaleDownDelaySeconds:
- format: int32
- type: integer
- activeMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- activeService:
- type: string
- antiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- properties:
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- requiredDuringSchedulingIgnoredDuringExecution:
- type: object
- type: object
- autoPromotionEnabled:
- type: boolean
- autoPromotionSeconds:
- format: int32
- type: integer
- maxUnavailable:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- postPromotionAnalysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- prePromotionAnalysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- previewMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- previewReplicaCount:
- format: int32
- type: integer
- previewService:
- type: string
- scaleDownDelayRevisionLimit:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- required:
- - activeService
- type: object
- canary:
- properties:
- abortScaleDownDelaySeconds:
- format: int32
- type: integer
- analysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- startingStep:
- format: int32
- type: integer
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- antiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- properties:
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- requiredDuringSchedulingIgnoredDuringExecution:
- type: object
- type: object
- canaryMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- canaryService:
- type: string
- dynamicStableScale:
- type: boolean
- maxSurge:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- maxUnavailable:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- pingPong:
- properties:
- pingService:
- type: string
- pongService:
- type: string
- required:
- - pingService
- - pongService
- type: object
- scaleDownDelayRevisionLimit:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- stableMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- stableService:
- type: string
- steps:
- items:
- properties:
- analysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- experiment:
- properties:
- analyses:
- items:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- clusterScope:
- type: boolean
- name:
- type: string
- requiredForCompletion:
- type: boolean
- templateName:
- type: string
- required:
- - name
- - templateName
- type: object
- type: array
- duration:
- type: string
- templates:
- items:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- name:
- type: string
- replicas:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- specRef:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - name
- - specRef
- type: object
- type: array
- required:
- - templates
- type: object
- pause:
- properties:
- duration:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- type: object
- setCanaryScale:
- properties:
- matchTrafficWeight:
- type: boolean
- replicas:
- format: int32
- type: integer
- weight:
- format: int32
- type: integer
- type: object
- setHeaderRoute:
- properties:
- match:
- items:
- properties:
- headerName:
- type: string
- headerValue:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- required:
- - headerName
- - headerValue
- type: object
- type: array
- name:
- type: string
- type: object
- setMirrorRoute:
- properties:
- match:
- items:
- properties:
- headers:
- additionalProperties:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- type: object
- method:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- path:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- type: object
- type: array
- name:
- type: string
- percentage:
- format: int32
- type: integer
- required:
- - name
- type: object
- setWeight:
- format: int32
- type: integer
- type: object
- type: array
- trafficRouting:
- properties:
- alb:
- properties:
- annotationPrefix:
- type: string
- ingress:
- type: string
- rootService:
- type: string
- servicePort:
- format: int32
- type: integer
- stickinessConfig:
- properties:
- durationSeconds:
- format: int64
- type: integer
- enabled:
- type: boolean
- required:
- - durationSeconds
- - enabled
- type: object
- required:
- - ingress
- - servicePort
- type: object
- ambassador:
- properties:
- mappings:
- items:
- type: string
- type: array
- required:
- - mappings
- type: object
- appMesh:
- properties:
- virtualNodeGroup:
- properties:
- canaryVirtualNodeRef:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- stableVirtualNodeRef:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- required:
- - canaryVirtualNodeRef
- - stableVirtualNodeRef
- type: object
- virtualService:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- required:
- - name
- type: object
- type: object
- istio:
- properties:
- destinationRule:
- properties:
- canarySubsetName:
- type: string
- name:
- type: string
- stableSubsetName:
- type: string
- required:
- - canarySubsetName
- - name
- - stableSubsetName
- type: object
- virtualService:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- tlsRoutes:
- items:
- properties:
- port:
- format: int64
- type: integer
- sniHosts:
- items:
- type: string
- type: array
- type: object
- type: array
- required:
- - name
- type: object
- virtualServices:
- items:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- tlsRoutes:
- items:
- properties:
- port:
- format: int64
- type: integer
- sniHosts:
- items:
- type: string
- type: array
- type: object
- type: array
- required:
- - name
- type: object
- type: array
- type: object
- managedRoutes:
- items:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- type: array
- nginx:
- properties:
- additionalIngressAnnotations:
- additionalProperties:
- type: string
- type: object
- annotationPrefix:
- type: string
- stableIngress:
- type: string
- required:
- - stableIngress
- type: object
- smi:
- properties:
- rootService:
- type: string
- trafficSplitName:
- type: string
- type: object
- traefik:
- properties:
- weightedTraefikServiceName:
- type: string
- required:
- - weightedTraefikServiceName
- type: object
- type: object
- type: object
- type: object
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- items:
- x-kubernetes-preserve-unknown-fields: true
- type: array
- required:
- - containers
- type: object
- type: object
- workloadRef:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- name:
- type: string
- type: object
- type: object
- status:
- properties:
- HPAReplicas:
- format: int32
- type: integer
- abort:
- type: boolean
- abortedAt:
- format: date-time
- type: string
- alb:
- properties:
- canaryTargetGroup:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- loadBalancer:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- stableTargetGroup:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- type: object
- availableReplicas:
- format: int32
- type: integer
- blueGreen:
- properties:
- activeSelector:
- type: string
- postPromotionAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- prePromotionAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- previewSelector:
- type: string
- scaleUpPreviewCheckPoint:
- type: boolean
- type: object
- canary:
- properties:
- currentBackgroundAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- currentExperiment:
- type: string
- currentStepAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- stablePingPong:
- type: string
- weights:
- properties:
- additional:
- items:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- type: array
- canary:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- stable:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- verified:
- type: boolean
- required:
- - canary
- - stable
- type: object
- type: object
- collisionCount:
- format: int32
- type: integer
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- lastUpdateTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - lastTransitionTime
- - lastUpdateTime
- - message
- - reason
- - status
- - type
- type: object
- type: array
- controllerPause:
- type: boolean
- currentPodHash:
- type: string
- currentStepHash:
- type: string
- currentStepIndex:
- format: int32
- type: integer
- message:
- type: string
- observedGeneration:
- type: string
- pauseConditions:
- items:
- properties:
- reason:
- type: string
- startTime:
- format: date-time
- type: string
- required:
- - reason
- - startTime
- type: object
- type: array
- phase:
- type: string
- promoteFull:
- type: boolean
- readyReplicas:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- restartedAt:
- format: date-time
- type: string
- selector:
- type: string
- stableRS:
- type: string
- updatedReplicas:
- format: int32
- type: integer
- workloadObservedGeneration:
- type: string
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources:
- scale:
- labelSelectorPath: .status.selector
- specReplicasPath: .spec.replicas
- statusReplicasPath: .status.HPAReplicas
- status: {}
----
-# Source: rollouts/templates/argo-rollouts-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/status
- - rollouts/finalizers
- verbs:
- - get
- - list
- - watch
- - update
- - patch
-- apiGroups:
- - argoproj.io
- resources:
- - analysisruns
- - analysisruns/finalizers
- - experiments
- - experiments/finalizers
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - argoproj.io
- resources:
- - analysistemplates
- - clusteranalysistemplates
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - apps
- resources:
- - replicasets
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - ""
- - apps
- resources:
- - deployments
- - podtemplates
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - ""
- resources:
- - services
- verbs:
- - get
- - list
- - watch
- - patch
- - create
- - delete
-- apiGroups:
- - coordination.k8s.io
- resources:
- - leases
- verbs:
- - create
- - get
- - update
-- apiGroups:
- - ""
- resources:
- - secrets
- - configmaps
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - ""
- resources:
- - pods
- verbs:
- - list
- - update
- - watch
-- apiGroups:
- - ""
- resources:
- - pods/eviction
- verbs:
- - create
-- apiGroups:
- - ""
- resources:
- - events
- verbs:
- - create
- - update
- - patch
-- apiGroups:
- - networking.k8s.io
- - extensions
- resources:
- - ingresses
- verbs:
- - create
- - get
- - list
- - watch
- - patch
-- apiGroups:
- - batch
- resources:
- - jobs
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - networking.istio.io
- resources:
- - virtualservices
- - destinationrules
- verbs:
- - watch
- - get
- - update
- - patch
- - list
-- apiGroups:
- - split.smi-spec.io
- resources:
- - trafficsplits
- verbs:
- - create
- - watch
- - get
- - update
- - patch
-- apiGroups:
- - getambassador.io
- - x.getambassador.io
- resources:
- - mappings
- - ambassadormappings
- verbs:
- - create
- - watch
- - get
- - update
- - list
- - delete
-- apiGroups:
- - ""
- resources:
- - endpoints
- verbs:
- - get
-- apiGroups:
- - elbv2.k8s.aws
- resources:
- - targetgroupbindings
- verbs:
- - list
- - get
-- apiGroups:
- - appmesh.k8s.aws
- resources:
- - virtualservices
- verbs:
- - watch
- - get
- - list
-- apiGroups:
- - appmesh.k8s.aws
- resources:
- - virtualnodes
- - virtualrouters
- verbs:
- - watch
- - get
- - list
- - update
- - patch
-- apiGroups:
- - traefik.containo.us
- resources:
- - traefikservices
- verbs:
- - watch
- - get
- - update
----
-# Source: rollouts/templates/rollouts-aggregate-to-admin-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-admin
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
- name: argo-rollouts-aggregate-to-admin
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - rollouts/status
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - create
- - delete
- - deletecollection
- - get
- - list
- - patch
- - update
- - watch
----
-# Source: rollouts/templates/rollouts-aggregate-to-edit-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-edit
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- name: argo-rollouts-aggregate-to-edit
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - rollouts/status
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - create
- - delete
- - deletecollection
- - get
- - list
- - patch
- - update
- - watch
----
-# Source: rollouts/templates/rollouts-aggregate-to-view-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-view
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-view: "true"
- name: argo-rollouts-aggregate-to-view
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - get
- - list
- - watch
----
-# Source: rollouts/templates/clusterRoleBinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: argo-rollouts
-subjects:
-- kind: ServiceAccount
- name: argo-rollouts
- namespace: argo-rollouts
----
-# Source: rollouts/templates/rollouts-metrics-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app.kubernetes.io/component: server
- app.kubernetes.io/name: argo-rollouts-metrics
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts-metrics
-spec:
- ports:
- - name: metrics
- port: 8090
- protocol: TCP
- targetPort: 8090
- selector:
- app.kubernetes.io/name: argo-rollouts
----
-# Source: rollouts/templates/rollouts-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-spec:
- replicas: 1
- selector:
- matchLabels:
- app.kubernetes.io/name: argo-rollouts
- strategy:
- type: Recreate
- template:
- metadata:
- labels:
- app.kubernetes.io/name: argo-rollouts
- spec:
- containers:
- - image: quay.io/argoproj/argo-rollouts:v1.3.1
- imagePullPolicy: Always
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /healthz
- port: healthz
- initialDelaySeconds: 30
- periodSeconds: 20
- successThreshold: 1
- timeoutSeconds: 10
- name: argo-rollouts
- ports:
- - containerPort: 8090
- name: metrics
- - containerPort: 8080
- name: healthz
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /metrics
- port: metrics
- initialDelaySeconds: 10
- periodSeconds: 5
- successThreshold: 1
- timeoutSeconds: 4
- securityContext:
- runAsNonRoot: true
- serviceAccountName: argo-rollouts
diff --git a/tests/region-rollouts-normal.expected.yaml b/tests/region-rollouts-normal.expected.yaml
deleted file mode 100644
index 6463a588..00000000
--- a/tests/region-rollouts-normal.expected.yaml
+++ /dev/null
@@ -1,14853 +0,0 @@
----
-# Source: rollouts/templates/serviceaccount.yaml
-apiVersion: v1
-kind: ServiceAccount
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
----
-# Source: rollouts/templates/rollouts-secret.yaml
-apiVersion: v1
-kind: Secret
-metadata:
- name: argo-rollouts-notification-secret
----
-# Source: rollouts/templates/analysisRun-crd.yaml
-# This is an auto-generated file. DO NOT EDIT
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: analysisruns.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: AnalysisRun
- listKind: AnalysisRunList
- plural: analysisruns
- shortNames:
- - ar
- singular: analysisrun
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: AnalysisRun status
- jsonPath: .status.phase
- name: Status
- type: string
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- terminate:
- type: boolean
- required:
- - metrics
- type: object
- status:
- properties:
- dryRunSummary:
- properties:
- count:
- format: int32
- type: integer
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- successful:
- format: int32
- type: integer
- type: object
- message:
- type: string
- metricResults:
- items:
- properties:
- consecutiveError:
- format: int32
- type: integer
- count:
- format: int32
- type: integer
- dryRun:
- type: boolean
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- measurements:
- items:
- properties:
- finishedAt:
- format: date-time
- type: string
- message:
- type: string
- metadata:
- additionalProperties:
- type: string
- type: object
- phase:
- type: string
- resumeAt:
- format: date-time
- type: string
- startedAt:
- format: date-time
- type: string
- value:
- type: string
- required:
- - phase
- type: object
- type: array
- message:
- type: string
- metadata:
- additionalProperties:
- type: string
- type: object
- name:
- type: string
- phase:
- type: string
- successful:
- format: int32
- type: integer
- required:
- - name
- - phase
- type: object
- type: array
- phase:
- type: string
- runSummary:
- properties:
- count:
- format: int32
- type: integer
- error:
- format: int32
- type: integer
- failed:
- format: int32
- type: integer
- inconclusive:
- format: int32
- type: integer
- successful:
- format: int32
- type: integer
- type: object
- startedAt:
- format: date-time
- type: string
- required:
- - phase
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/analysisTemplate-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: analysistemplates.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: AnalysisTemplate
- listKind: AnalysisTemplateList
- plural: analysistemplates
- shortNames:
- - at
- singular: analysistemplate
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- required:
- - metrics
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/clusterAnalysisTemplate-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: clusteranalysistemplates.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: ClusterAnalysisTemplate
- listKind: ClusterAnalysisTemplateList
- plural: clusteranalysistemplates
- shortNames:
- - cat
- singular: clusteranalysistemplate
- preserveUnknownFields: false
- scope: Cluster
- versions:
- - additionalPrinterColumns:
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- metrics:
- items:
- properties:
- consecutiveErrorLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- count:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- failureCondition:
- type: string
- failureLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- inconclusiveLimit:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- initialDelay:
- type: string
- interval:
- type: string
- name:
- type: string
- provider:
- properties:
- cloudWatch:
- properties:
- interval:
- type: string
- metricDataQueries:
- items:
- properties:
- expression:
- type: string
- id:
- type: string
- label:
- type: string
- metricStat:
- properties:
- metric:
- properties:
- dimensions:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- metricName:
- type: string
- namespace:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- stat:
- type: string
- unit:
- type: string
- type: object
- period:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- returnData:
- type: boolean
- type: object
- type: array
- required:
- - metricDataQueries
- type: object
- datadog:
- properties:
- interval:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- graphite:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- influxdb:
- properties:
- profile:
- type: string
- query:
- type: string
- type: object
- job:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- backoffLimit:
- format: int32
- type: integer
- completionMode:
- type: string
- completions:
- format: int32
- type: integer
- manualSelector:
- type: boolean
- parallelism:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- suspend:
- type: boolean
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- ttlSecondsAfterFinished:
- format: int32
- type: integer
- required:
- - template
- type: object
- required:
- - spec
- type: object
- kayenta:
- properties:
- address:
- type: string
- application:
- type: string
- canaryConfigName:
- type: string
- configurationAccountName:
- type: string
- metricsAccountName:
- type: string
- scopes:
- items:
- properties:
- controlScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- experimentScope:
- properties:
- end:
- type: string
- region:
- type: string
- scope:
- type: string
- start:
- type: string
- step:
- format: int64
- type: integer
- required:
- - end
- - region
- - scope
- - start
- - step
- type: object
- name:
- type: string
- required:
- - controlScope
- - experimentScope
- - name
- type: object
- type: array
- storageAccountName:
- type: string
- threshold:
- properties:
- marginal:
- format: int64
- type: integer
- pass:
- format: int64
- type: integer
- required:
- - marginal
- - pass
- type: object
- required:
- - address
- - application
- - canaryConfigName
- - configurationAccountName
- - metricsAccountName
- - scopes
- - storageAccountName
- - threshold
- type: object
- newRelic:
- properties:
- profile:
- type: string
- query:
- type: string
- required:
- - query
- type: object
- prometheus:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- wavefront:
- properties:
- address:
- type: string
- query:
- type: string
- type: object
- web:
- properties:
- body:
- type: string
- headers:
- items:
- properties:
- key:
- type: string
- value:
- type: string
- required:
- - key
- - value
- type: object
- type: array
- insecure:
- type: boolean
- jsonPath:
- type: string
- method:
- type: string
- timeoutSeconds:
- format: int64
- type: integer
- url:
- type: string
- required:
- - url
- type: object
- type: object
- successCondition:
- type: string
- required:
- - name
- - provider
- type: object
- type: array
- required:
- - metrics
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/experiments-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: experiments.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: Experiment
- listKind: ExperimentList
- plural: experiments
- shortNames:
- - exp
- singular: experiment
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Experiment status
- jsonPath: .status.phase
- name: Status
- type: string
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- analyses:
- items:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- required:
- - key
- - name
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- clusterScope:
- type: boolean
- name:
- type: string
- requiredForCompletion:
- type: boolean
- templateName:
- type: string
- required:
- - name
- - templateName
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- duration:
- type: string
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- progressDeadlineSeconds:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- templates:
- items:
- properties:
- minReadySeconds:
- format: int32
- type: integer
- name:
- type: string
- replicas:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- service:
- type: object
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- x-kubernetes-preserve-unknown-fields: true
- required:
- - containers
- type: object
- type: object
- required:
- - name
- - selector
- - template
- type: object
- type: array
- terminate:
- type: boolean
- required:
- - templates
- type: object
- status:
- properties:
- analysisRuns:
- items:
- properties:
- analysisRun:
- type: string
- message:
- type: string
- name:
- type: string
- phase:
- type: string
- required:
- - analysisRun
- - name
- - phase
- type: object
- type: array
- availableAt:
- format: date-time
- type: string
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- lastUpdateTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - lastTransitionTime
- - lastUpdateTime
- - message
- - reason
- - status
- - type
- type: object
- type: array
- message:
- type: string
- phase:
- type: string
- templateStatuses:
- items:
- properties:
- availableReplicas:
- format: int32
- type: integer
- collisionCount:
- format: int32
- type: integer
- lastTransitionTime:
- format: date-time
- type: string
- message:
- type: string
- name:
- type: string
- podTemplateHash:
- type: string
- readyReplicas:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- serviceName:
- type: string
- status:
- type: string
- updatedReplicas:
- format: int32
- type: integer
- required:
- - availableReplicas
- - name
- - readyReplicas
- - replicas
- - updatedReplicas
- type: object
- type: array
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources: {}
----
-# Source: rollouts/templates/rollout-crd.yaml
-apiVersion: apiextensions.k8s.io/v1
-kind: CustomResourceDefinition
-metadata:
- annotations:
- controller-gen.kubebuilder.io/version: v0.7.0
- name: rollouts.argoproj.io
-spec:
- group: argoproj.io
- names:
- kind: Rollout
- listKind: RolloutList
- plural: rollouts
- shortNames:
- - ro
- singular: rollout
- preserveUnknownFields: false
- scope: Namespaced
- versions:
- - additionalPrinterColumns:
- - description: Number of desired pods
- jsonPath: .spec.replicas
- name: Desired
- type: integer
- - description: Total number of non-terminated pods targeted by this rollout
- jsonPath: .status.replicas
- name: Current
- type: integer
- - description: Total number of non-terminated pods targeted by this rollout that
- have the desired template spec
- jsonPath: .status.updatedReplicas
- name: Up-to-date
- type: integer
- - description: Total number of available pods (ready for at least minReadySeconds)
- targeted by this rollout
- jsonPath: .status.availableReplicas
- name: Available
- type: integer
- - description: Time since resource was created
- jsonPath: .metadata.creationTimestamp
- name: Age
- type: date
- name: v1alpha1
- schema:
- openAPIV3Schema:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- metadata:
- type: object
- spec:
- properties:
- analysis:
- properties:
- successfulRunHistoryLimit:
- format: int32
- type: integer
- unsuccessfulRunHistoryLimit:
- format: int32
- type: integer
- type: object
- minReadySeconds:
- format: int32
- type: integer
- paused:
- type: boolean
- progressDeadlineAbort:
- type: boolean
- progressDeadlineSeconds:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- restartAt:
- format: date-time
- type: string
- revisionHistoryLimit:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- strategy:
- properties:
- blueGreen:
- properties:
- abortScaleDownDelaySeconds:
- format: int32
- type: integer
- activeMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- activeService:
- type: string
- antiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- properties:
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- requiredDuringSchedulingIgnoredDuringExecution:
- type: object
- type: object
- autoPromotionEnabled:
- type: boolean
- autoPromotionSeconds:
- format: int32
- type: integer
- maxUnavailable:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- postPromotionAnalysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- prePromotionAnalysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- previewMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- previewReplicaCount:
- format: int32
- type: integer
- previewService:
- type: string
- scaleDownDelayRevisionLimit:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- required:
- - activeService
- type: object
- canary:
- properties:
- abortScaleDownDelaySeconds:
- format: int32
- type: integer
- analysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- startingStep:
- format: int32
- type: integer
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- antiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- properties:
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- requiredDuringSchedulingIgnoredDuringExecution:
- type: object
- type: object
- canaryMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- canaryService:
- type: string
- dynamicStableScale:
- type: boolean
- maxSurge:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- maxUnavailable:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- pingPong:
- properties:
- pingService:
- type: string
- pongService:
- type: string
- required:
- - pingService
- - pongService
- type: object
- scaleDownDelayRevisionLimit:
- format: int32
- type: integer
- scaleDownDelaySeconds:
- format: int32
- type: integer
- stableMetadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- stableService:
- type: string
- steps:
- items:
- properties:
- analysis:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- dryRun:
- items:
- properties:
- metricName:
- type: string
- required:
- - metricName
- type: object
- type: array
- measurementRetention:
- items:
- properties:
- limit:
- format: int32
- type: integer
- metricName:
- type: string
- required:
- - limit
- - metricName
- type: object
- type: array
- templates:
- items:
- properties:
- clusterScope:
- type: boolean
- templateName:
- type: string
- type: object
- type: array
- type: object
- experiment:
- properties:
- analyses:
- items:
- properties:
- args:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- fieldRef:
- properties:
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- podTemplateHashValue:
- type: string
- type: object
- required:
- - name
- type: object
- type: array
- clusterScope:
- type: boolean
- name:
- type: string
- requiredForCompletion:
- type: boolean
- templateName:
- type: string
- required:
- - name
- - templateName
- type: object
- type: array
- duration:
- type: string
- templates:
- items:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- name:
- type: string
- replicas:
- format: int32
- type: integer
- selector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- specRef:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - name
- - specRef
- type: object
- type: array
- required:
- - templates
- type: object
- pause:
- properties:
- duration:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- type: object
- setCanaryScale:
- properties:
- matchTrafficWeight:
- type: boolean
- replicas:
- format: int32
- type: integer
- weight:
- format: int32
- type: integer
- type: object
- setHeaderRoute:
- properties:
- match:
- items:
- properties:
- headerName:
- type: string
- headerValue:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- required:
- - headerName
- - headerValue
- type: object
- type: array
- name:
- type: string
- type: object
- setMirrorRoute:
- properties:
- match:
- items:
- properties:
- headers:
- additionalProperties:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- type: object
- method:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- path:
- properties:
- exact:
- type: string
- prefix:
- type: string
- regex:
- type: string
- type: object
- type: object
- type: array
- name:
- type: string
- percentage:
- format: int32
- type: integer
- required:
- - name
- type: object
- setWeight:
- format: int32
- type: integer
- type: object
- type: array
- trafficRouting:
- properties:
- alb:
- properties:
- annotationPrefix:
- type: string
- ingress:
- type: string
- rootService:
- type: string
- servicePort:
- format: int32
- type: integer
- stickinessConfig:
- properties:
- durationSeconds:
- format: int64
- type: integer
- enabled:
- type: boolean
- required:
- - durationSeconds
- - enabled
- type: object
- required:
- - ingress
- - servicePort
- type: object
- ambassador:
- properties:
- mappings:
- items:
- type: string
- type: array
- required:
- - mappings
- type: object
- appMesh:
- properties:
- virtualNodeGroup:
- properties:
- canaryVirtualNodeRef:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- stableVirtualNodeRef:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- required:
- - canaryVirtualNodeRef
- - stableVirtualNodeRef
- type: object
- virtualService:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- required:
- - name
- type: object
- type: object
- istio:
- properties:
- destinationRule:
- properties:
- canarySubsetName:
- type: string
- name:
- type: string
- stableSubsetName:
- type: string
- required:
- - canarySubsetName
- - name
- - stableSubsetName
- type: object
- virtualService:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- tlsRoutes:
- items:
- properties:
- port:
- format: int64
- type: integer
- sniHosts:
- items:
- type: string
- type: array
- type: object
- type: array
- required:
- - name
- type: object
- virtualServices:
- items:
- properties:
- name:
- type: string
- routes:
- items:
- type: string
- type: array
- tlsRoutes:
- items:
- properties:
- port:
- format: int64
- type: integer
- sniHosts:
- items:
- type: string
- type: array
- type: object
- type: array
- required:
- - name
- type: object
- type: array
- type: object
- managedRoutes:
- items:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- type: array
- nginx:
- properties:
- additionalIngressAnnotations:
- additionalProperties:
- type: string
- type: object
- annotationPrefix:
- type: string
- stableIngress:
- type: string
- required:
- - stableIngress
- type: object
- smi:
- properties:
- rootService:
- type: string
- trafficSplitName:
- type: string
- type: object
- traefik:
- properties:
- weightedTraefikServiceName:
- type: string
- required:
- - weightedTraefikServiceName
- type: object
- type: object
- type: object
- type: object
- template:
- properties:
- metadata:
- properties:
- annotations:
- additionalProperties:
- type: string
- type: object
- labels:
- additionalProperties:
- type: string
- type: object
- type: object
- spec:
- properties:
- activeDeadlineSeconds:
- format: int64
- type: integer
- affinity:
- properties:
- nodeAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- preference:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- weight:
- format: int32
- type: integer
- required:
- - preference
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- properties:
- nodeSelectorTerms:
- items:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchFields:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- type: object
- type: array
- required:
- - nodeSelectorTerms
- type: object
- type: object
- podAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- podAntiAffinity:
- properties:
- preferredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- podAffinityTerm:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- weight:
- format: int32
- type: integer
- required:
- - podAffinityTerm
- - weight
- type: object
- type: array
- requiredDuringSchedulingIgnoredDuringExecution:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaceSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- namespaces:
- items:
- type: string
- type: array
- topologyKey:
- type: string
- required:
- - topologyKey
- type: object
- type: array
- type: object
- type: object
- automountServiceAccountToken:
- type: boolean
- containers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- dnsConfig:
- properties:
- nameservers:
- items:
- type: string
- type: array
- options:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- type: object
- type: array
- searches:
- items:
- type: string
- type: array
- type: object
- dnsPolicy:
- type: string
- enableServiceLinks:
- type: boolean
- ephemeralContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- targetContainerName:
- type: string
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- hostAliases:
- items:
- properties:
- hostnames:
- items:
- type: string
- type: array
- ip:
- type: string
- type: object
- type: array
- hostIPC:
- type: boolean
- hostNetwork:
- type: boolean
- hostPID:
- type: boolean
- hostname:
- type: string
- imagePullSecrets:
- items:
- properties:
- name:
- type: string
- type: object
- type: array
- initContainers:
- items:
- properties:
- args:
- items:
- type: string
- type: array
- command:
- items:
- type: string
- type: array
- env:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- valueFrom:
- properties:
- configMapKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- fieldRef:
- properties:
- apiVersion:
- type: string
- fieldPath:
- type: string
- required:
- - fieldPath
- type: object
- resourceFieldRef:
- properties:
- containerName:
- type: string
- divisor:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- resource:
- type: string
- required:
- - resource
- type: object
- secretKeyRef:
- properties:
- key:
- type: string
- name:
- type: string
- optional:
- type: boolean
- required:
- - key
- type: object
- type: object
- required:
- - name
- type: object
- type: array
- envFrom:
- items:
- properties:
- configMapRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- prefix:
- type: string
- secretRef:
- properties:
- name:
- type: string
- optional:
- type: boolean
- type: object
- type: object
- type: array
- image:
- type: string
- imagePullPolicy:
- type: string
- lifecycle:
- properties:
- postStart:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- preStop:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- type: object
- type: object
- livenessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- name:
- type: string
- ports:
- items:
- properties:
- containerPort:
- format: int32
- type: integer
- hostIP:
- type: string
- hostPort:
- format: int32
- type: integer
- name:
- type: string
- protocol:
- default: TCP
- type: string
- required:
- - containerPort
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - containerPort
- - protocol
- x-kubernetes-list-type: map
- readinessProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- resources:
- properties:
- limits:
- x-kubernetes-preserve-unknown-fields: true
- requests:
- x-kubernetes-preserve-unknown-fields: true
- type: object
- securityContext:
- properties:
- allowPrivilegeEscalation:
- type: boolean
- capabilities:
- properties:
- add:
- items:
- type: string
- type: array
- drop:
- items:
- type: string
- type: array
- type: object
- privileged:
- type: boolean
- procMount:
- type: string
- readOnlyRootFilesystem:
- type: boolean
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- startupProbe:
- properties:
- exec:
- properties:
- command:
- items:
- type: string
- type: array
- type: object
- failureThreshold:
- format: int32
- type: integer
- grpc:
- properties:
- port:
- format: int32
- type: integer
- service:
- type: string
- required:
- - port
- type: object
- httpGet:
- properties:
- host:
- type: string
- httpHeaders:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- path:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- scheme:
- type: string
- required:
- - port
- type: object
- initialDelaySeconds:
- format: int32
- type: integer
- periodSeconds:
- format: int32
- type: integer
- successThreshold:
- format: int32
- type: integer
- tcpSocket:
- properties:
- host:
- type: string
- port:
- anyOf:
- - type: integer
- - type: string
- x-kubernetes-int-or-string: true
- required:
- - port
- type: object
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- timeoutSeconds:
- format: int32
- type: integer
- type: object
- stdin:
- type: boolean
- stdinOnce:
- type: boolean
- terminationMessagePath:
- type: string
- terminationMessagePolicy:
- type: string
- tty:
- type: boolean
- volumeDevices:
- items:
- properties:
- devicePath:
- type: string
- name:
- type: string
- required:
- - devicePath
- - name
- type: object
- type: array
- volumeMounts:
- items:
- properties:
- mountPath:
- type: string
- mountPropagation:
- type: string
- name:
- type: string
- readOnly:
- type: boolean
- subPath:
- type: string
- subPathExpr:
- type: string
- required:
- - mountPath
- - name
- type: object
- type: array
- workingDir:
- type: string
- required:
- - name
- type: object
- type: array
- nodeName:
- type: string
- nodeSelector:
- additionalProperties:
- type: string
- type: object
- x-kubernetes-map-type: atomic
- os:
- properties:
- name:
- type: string
- required:
- - name
- type: object
- overhead:
- additionalProperties:
- anyOf:
- - type: integer
- - type: string
- pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
- x-kubernetes-int-or-string: true
- type: object
- preemptionPolicy:
- type: string
- priority:
- format: int32
- type: integer
- priorityClassName:
- type: string
- readinessGates:
- items:
- properties:
- conditionType:
- type: string
- required:
- - conditionType
- type: object
- type: array
- restartPolicy:
- type: string
- runtimeClassName:
- type: string
- schedulerName:
- type: string
- securityContext:
- properties:
- fsGroup:
- format: int64
- type: integer
- fsGroupChangePolicy:
- type: string
- runAsGroup:
- format: int64
- type: integer
- runAsNonRoot:
- type: boolean
- runAsUser:
- format: int64
- type: integer
- seLinuxOptions:
- properties:
- level:
- type: string
- role:
- type: string
- type:
- type: string
- user:
- type: string
- type: object
- seccompProfile:
- properties:
- localhostProfile:
- type: string
- type:
- type: string
- required:
- - type
- type: object
- supplementalGroups:
- items:
- format: int64
- type: integer
- type: array
- sysctls:
- items:
- properties:
- name:
- type: string
- value:
- type: string
- required:
- - name
- - value
- type: object
- type: array
- windowsOptions:
- properties:
- gmsaCredentialSpec:
- type: string
- gmsaCredentialSpecName:
- type: string
- hostProcess:
- type: boolean
- runAsUserName:
- type: string
- type: object
- type: object
- serviceAccount:
- type: string
- serviceAccountName:
- type: string
- setHostnameAsFQDN:
- type: boolean
- shareProcessNamespace:
- type: boolean
- subdomain:
- type: string
- terminationGracePeriodSeconds:
- format: int64
- type: integer
- tolerations:
- items:
- properties:
- effect:
- type: string
- key:
- type: string
- operator:
- type: string
- tolerationSeconds:
- format: int64
- type: integer
- value:
- type: string
- type: object
- type: array
- topologySpreadConstraints:
- items:
- properties:
- labelSelector:
- properties:
- matchExpressions:
- items:
- properties:
- key:
- type: string
- operator:
- type: string
- values:
- items:
- type: string
- type: array
- required:
- - key
- - operator
- type: object
- type: array
- matchLabels:
- additionalProperties:
- type: string
- type: object
- type: object
- maxSkew:
- format: int32
- type: integer
- minDomains:
- format: int32
- type: integer
- topologyKey:
- type: string
- whenUnsatisfiable:
- type: string
- required:
- - maxSkew
- - topologyKey
- - whenUnsatisfiable
- type: object
- type: array
- x-kubernetes-list-map-keys:
- - topologyKey
- - whenUnsatisfiable
- x-kubernetes-list-type: map
- volumes:
- items:
- x-kubernetes-preserve-unknown-fields: true
- type: array
- required:
- - containers
- type: object
- type: object
- workloadRef:
- properties:
- apiVersion:
- type: string
- kind:
- type: string
- name:
- type: string
- type: object
- type: object
- status:
- properties:
- HPAReplicas:
- format: int32
- type: integer
- abort:
- type: boolean
- abortedAt:
- format: date-time
- type: string
- alb:
- properties:
- canaryTargetGroup:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- loadBalancer:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- stableTargetGroup:
- properties:
- arn:
- type: string
- name:
- type: string
- required:
- - arn
- - name
- type: object
- type: object
- availableReplicas:
- format: int32
- type: integer
- blueGreen:
- properties:
- activeSelector:
- type: string
- postPromotionAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- prePromotionAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- previewSelector:
- type: string
- scaleUpPreviewCheckPoint:
- type: boolean
- type: object
- canary:
- properties:
- currentBackgroundAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- currentExperiment:
- type: string
- currentStepAnalysisRunStatus:
- properties:
- message:
- type: string
- name:
- type: string
- status:
- type: string
- required:
- - name
- - status
- type: object
- stablePingPong:
- type: string
- weights:
- properties:
- additional:
- items:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- type: array
- canary:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- stable:
- properties:
- podTemplateHash:
- type: string
- serviceName:
- type: string
- weight:
- format: int32
- type: integer
- required:
- - weight
- type: object
- verified:
- type: boolean
- required:
- - canary
- - stable
- type: object
- type: object
- collisionCount:
- format: int32
- type: integer
- conditions:
- items:
- properties:
- lastTransitionTime:
- format: date-time
- type: string
- lastUpdateTime:
- format: date-time
- type: string
- message:
- type: string
- reason:
- type: string
- status:
- type: string
- type:
- type: string
- required:
- - lastTransitionTime
- - lastUpdateTime
- - message
- - reason
- - status
- - type
- type: object
- type: array
- controllerPause:
- type: boolean
- currentPodHash:
- type: string
- currentStepHash:
- type: string
- currentStepIndex:
- format: int32
- type: integer
- message:
- type: string
- observedGeneration:
- type: string
- pauseConditions:
- items:
- properties:
- reason:
- type: string
- startTime:
- format: date-time
- type: string
- required:
- - reason
- - startTime
- type: object
- type: array
- phase:
- type: string
- promoteFull:
- type: boolean
- readyReplicas:
- format: int32
- type: integer
- replicas:
- format: int32
- type: integer
- restartedAt:
- format: date-time
- type: string
- selector:
- type: string
- stableRS:
- type: string
- updatedReplicas:
- format: int32
- type: integer
- workloadObservedGeneration:
- type: string
- type: object
- required:
- - spec
- type: object
- served: true
- storage: true
- subresources:
- scale:
- labelSelectorPath: .status.selector
- specReplicasPath: .spec.replicas
- statusReplicasPath: .status.HPAReplicas
- status: {}
----
-# Source: rollouts/templates/argo-rollouts-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/status
- - rollouts/finalizers
- verbs:
- - get
- - list
- - watch
- - update
- - patch
-- apiGroups:
- - argoproj.io
- resources:
- - analysisruns
- - analysisruns/finalizers
- - experiments
- - experiments/finalizers
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - argoproj.io
- resources:
- - analysistemplates
- - clusteranalysistemplates
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - apps
- resources:
- - replicasets
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - ""
- - apps
- resources:
- - deployments
- - podtemplates
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - ""
- resources:
- - services
- verbs:
- - get
- - list
- - watch
- - patch
- - create
- - delete
-- apiGroups:
- - coordination.k8s.io
- resources:
- - leases
- verbs:
- - create
- - get
- - update
-- apiGroups:
- - ""
- resources:
- - secrets
- - configmaps
- verbs:
- - get
- - list
- - watch
-- apiGroups:
- - ""
- resources:
- - pods
- verbs:
- - list
- - update
- - watch
-- apiGroups:
- - ""
- resources:
- - pods/eviction
- verbs:
- - create
-- apiGroups:
- - ""
- resources:
- - events
- verbs:
- - create
- - update
- - patch
-- apiGroups:
- - networking.k8s.io
- - extensions
- resources:
- - ingresses
- verbs:
- - create
- - get
- - list
- - watch
- - patch
-- apiGroups:
- - batch
- resources:
- - jobs
- verbs:
- - create
- - get
- - list
- - watch
- - update
- - patch
- - delete
-- apiGroups:
- - networking.istio.io
- resources:
- - virtualservices
- - destinationrules
- verbs:
- - watch
- - get
- - update
- - patch
- - list
-- apiGroups:
- - split.smi-spec.io
- resources:
- - trafficsplits
- verbs:
- - create
- - watch
- - get
- - update
- - patch
-- apiGroups:
- - getambassador.io
- - x.getambassador.io
- resources:
- - mappings
- - ambassadormappings
- verbs:
- - create
- - watch
- - get
- - update
- - list
- - delete
-- apiGroups:
- - ""
- resources:
- - endpoints
- verbs:
- - get
-- apiGroups:
- - elbv2.k8s.aws
- resources:
- - targetgroupbindings
- verbs:
- - list
- - get
-- apiGroups:
- - appmesh.k8s.aws
- resources:
- - virtualservices
- verbs:
- - watch
- - get
- - list
-- apiGroups:
- - appmesh.k8s.aws
- resources:
- - virtualnodes
- - virtualrouters
- verbs:
- - watch
- - get
- - list
- - update
- - patch
-- apiGroups:
- - traefik.containo.us
- resources:
- - traefikservices
- verbs:
- - watch
- - get
- - update
----
-# Source: rollouts/templates/rollouts-aggregate-to-admin-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-admin
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-admin: "true"
- name: argo-rollouts-aggregate-to-admin
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - rollouts/status
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - create
- - delete
- - deletecollection
- - get
- - list
- - patch
- - update
- - watch
----
-# Source: rollouts/templates/rollouts-aggregate-to-edit-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-edit
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-edit: "true"
- name: argo-rollouts-aggregate-to-edit
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - rollouts/status
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - create
- - delete
- - deletecollection
- - get
- - list
- - patch
- - update
- - watch
----
-# Source: rollouts/templates/rollouts-aggregate-to-view-clusterRole.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRole
-metadata:
- labels:
- app.kubernetes.io/component: aggregate-cluster-role
- app.kubernetes.io/name: argo-rollouts-aggregate-to-view
- app.kubernetes.io/part-of: argo-rollouts
- rbac.authorization.k8s.io/aggregate-to-view: "true"
- name: argo-rollouts-aggregate-to-view
-rules:
-- apiGroups:
- - argoproj.io
- resources:
- - rollouts
- - rollouts/scale
- - experiments
- - analysistemplates
- - clusteranalysistemplates
- - analysisruns
- verbs:
- - get
- - list
- - watch
----
-# Source: rollouts/templates/clusterRoleBinding.yaml
-apiVersion: rbac.authorization.k8s.io/v1
-kind: ClusterRoleBinding
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: ClusterRole
- name: argo-rollouts
-subjects:
-- kind: ServiceAccount
- name: argo-rollouts
- namespace: argo-rollouts
----
-# Source: rollouts/templates/rollouts-metrics-service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app.kubernetes.io/component: server
- app.kubernetes.io/name: argo-rollouts-metrics
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts-metrics
-spec:
- ports:
- - name: metrics
- port: 8090
- protocol: TCP
- targetPort: 8090
- selector:
- app.kubernetes.io/name: argo-rollouts
----
-# Source: rollouts/templates/rollouts-deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- labels:
- app.kubernetes.io/component: rollouts-controller
- app.kubernetes.io/name: argo-rollouts
- app.kubernetes.io/part-of: argo-rollouts
- name: argo-rollouts
-spec:
- replicas: 1
- selector:
- matchLabels:
- app.kubernetes.io/name: argo-rollouts
- strategy:
- type: Recreate
- template:
- metadata:
- labels:
- app.kubernetes.io/name: argo-rollouts
- spec:
- containers:
- - image: quay.io/argoproj/argo-rollouts:v1.3.1
- imagePullPolicy: Always
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /healthz
- port: healthz
- initialDelaySeconds: 30
- periodSeconds: 20
- successThreshold: 1
- timeoutSeconds: 10
- name: argo-rollouts
- ports:
- - containerPort: 8090
- name: metrics
- - containerPort: 8080
- name: healthz
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /metrics
- port: metrics
- initialDelaySeconds: 10
- periodSeconds: 5
- successThreshold: 1
- timeoutSeconds: 4
- securityContext:
- runAsNonRoot: true
- serviceAccountName: argo-rollouts
diff --git a/tests/region-roxctl-industrial-edge-factory.expected.yaml b/tests/region-roxctl-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 1c001ce0..00000000
--- a/tests/region-roxctl-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: roxctl/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: roxctl
- namespace: openshift
- labels:
- app: roxctl
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/roxctl
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: roxctl:latest
- triggers:
- - type: ImageChange
----
-# Source: roxctl/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: roxctl
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-roxctl-industrial-edge-hub.expected.yaml b/tests/region-roxctl-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 1c001ce0..00000000
--- a/tests/region-roxctl-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: roxctl/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: roxctl
- namespace: openshift
- labels:
- app: roxctl
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/roxctl
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: roxctl:latest
- triggers:
- - type: ImageChange
----
-# Source: roxctl/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: roxctl
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-roxctl-medical-diagnosis-hub.expected.yaml b/tests/region-roxctl-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 1c001ce0..00000000
--- a/tests/region-roxctl-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: roxctl/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: roxctl
- namespace: openshift
- labels:
- app: roxctl
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/roxctl
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: roxctl:latest
- triggers:
- - type: ImageChange
----
-# Source: roxctl/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: roxctl
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-roxctl-naked.expected.yaml b/tests/region-roxctl-naked.expected.yaml
deleted file mode 100644
index 1c001ce0..00000000
--- a/tests/region-roxctl-naked.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: roxctl/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: roxctl
- namespace: openshift
- labels:
- app: roxctl
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/roxctl
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: roxctl:latest
- triggers:
- - type: ImageChange
----
-# Source: roxctl/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: roxctl
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-roxctl-normal.expected.yaml b/tests/region-roxctl-normal.expected.yaml
deleted file mode 100644
index 1c001ce0..00000000
--- a/tests/region-roxctl-normal.expected.yaml
+++ /dev/null
@@ -1,46 +0,0 @@
----
-# Source: roxctl/templates/buildconfig.yaml
-apiVersion: build.openshift.io/v1
-kind: BuildConfig
-metadata:
- name: roxctl
- namespace: openshift
- labels:
- app: roxctl
-spec:
- source:
- type: Git
- git:
- uri: https://github.com/hybrid-cloud-demos/devsecops-tools
- contextDir: containerFiles/roxctl
- strategy:
- type: Docker
- dockerStrategy:
- dockerfilePath: Containerfile
- from:
- kind: ImageStreamTag
- namespace: openshift
- name: cli:latest
- output:
- to:
- kind: ImageStreamTag
- name: roxctl:latest
- triggers:
- - type: ImageChange
----
-# Source: roxctl/templates/imagestream.yaml
-apiVersion: image.openshift.io/v1
-kind: ImageStream
-metadata:
- name: roxctl
- namespace: openshift
-spec:
- lookupPolicy:
- local: false
- tags:
- - name: latest
- from:
- kind: DockerImage
- name: latest
- referencePolicy:
- type: Source
diff --git a/tests/region-sonarqube-industrial-edge-factory.expected.yaml b/tests/region-sonarqube-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 22bded77..00000000
--- a/tests/region-sonarqube-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,116 +0,0 @@
----
-# Source: sonarqube/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: sonarqube
- name: sonarqube
- namespace: devsecops-ci
-spec:
- ports:
- - name: 9000-tcp
- port: 9000
- protocol: TCP
- targetPort: 9000
- selector:
- app: sonarqube
- type: ClusterIP
----
-# Source: sonarqube/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: sonarqube
- namespace: devsecops-ci
- labels:
- app: sonarqube
- app.kubernetes.io/component: sonarqube
- app.kubernetes.io/instance: sonarqube
- app.kubernetes.io/name: sonarqube
- app.kubernetes.io/part-of: sonarqube
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: sonarqube
- template:
- metadata:
- labels:
- app: sonarqube
- spec:
- containers:
- - name: sonarqube
- imagePullPolicy: IfNotPresent
- image: quay.io/hybridcloudpatterns/sonarqube:8.3-community
- ports:
- - containerPort: 9000
- protocol: TCP
- volumeMounts:
- - mountPath: /opt/sq/temp
- name: sonarqube-temp
- - mountPath: /opt/sq/conf
- name: sonarqube-conf
- - mountPath: /opt/sq/data
- name: sonarqube-data
- - mountPath: /opt/sq/extensions
- name: sonarqube-extensions
- - mountPath: /opt/sq/logs
- name: sonarqube-logs
- livenessProbe:
- failureThreshold: 10
- httpGet:
- path: /
- port: 9000
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- readinessProbe:
- failureThreshold: 10
- httpGet:
- path: /
- port: 9000
- scheme: HTTP
- initialDelaySeconds: 10
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- resources:
- limits:
- cpu: 1
- memory: 4Gi
- requests:
- cpu: 200m
- memory: 512Mi
- volumes:
- - name: sonarqube-temp
- emptyDir: {}
- - name: sonarqube-conf
- emptyDir: {}
- - name: sonarqube-data
- emptyDir: {}
- - name: sonarqube-extensions
- emptyDir: {}
- - name: sonarqube-logs
- emptyDir: {}
----
-# Source: sonarqube/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: sonarqube
- name: sonarqube
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 9000-tcp
- tls:
- termination: edge
- to:
- kind: Service
- name: sonarqube
- weight: 100
- wildcardPolicy: None
diff --git a/tests/region-sonarqube-industrial-edge-hub.expected.yaml b/tests/region-sonarqube-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 22bded77..00000000
--- a/tests/region-sonarqube-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,116 +0,0 @@
----
-# Source: sonarqube/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: sonarqube
- name: sonarqube
- namespace: devsecops-ci
-spec:
- ports:
- - name: 9000-tcp
- port: 9000
- protocol: TCP
- targetPort: 9000
- selector:
- app: sonarqube
- type: ClusterIP
----
-# Source: sonarqube/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: sonarqube
- namespace: devsecops-ci
- labels:
- app: sonarqube
- app.kubernetes.io/component: sonarqube
- app.kubernetes.io/instance: sonarqube
- app.kubernetes.io/name: sonarqube
- app.kubernetes.io/part-of: sonarqube
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: sonarqube
- template:
- metadata:
- labels:
- app: sonarqube
- spec:
- containers:
- - name: sonarqube
- imagePullPolicy: IfNotPresent
- image: quay.io/hybridcloudpatterns/sonarqube:8.3-community
- ports:
- - containerPort: 9000
- protocol: TCP
- volumeMounts:
- - mountPath: /opt/sq/temp
- name: sonarqube-temp
- - mountPath: /opt/sq/conf
- name: sonarqube-conf
- - mountPath: /opt/sq/data
- name: sonarqube-data
- - mountPath: /opt/sq/extensions
- name: sonarqube-extensions
- - mountPath: /opt/sq/logs
- name: sonarqube-logs
- livenessProbe:
- failureThreshold: 10
- httpGet:
- path: /
- port: 9000
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- readinessProbe:
- failureThreshold: 10
- httpGet:
- path: /
- port: 9000
- scheme: HTTP
- initialDelaySeconds: 10
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- resources:
- limits:
- cpu: 1
- memory: 4Gi
- requests:
- cpu: 200m
- memory: 512Mi
- volumes:
- - name: sonarqube-temp
- emptyDir: {}
- - name: sonarqube-conf
- emptyDir: {}
- - name: sonarqube-data
- emptyDir: {}
- - name: sonarqube-extensions
- emptyDir: {}
- - name: sonarqube-logs
- emptyDir: {}
----
-# Source: sonarqube/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: sonarqube
- name: sonarqube
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 9000-tcp
- tls:
- termination: edge
- to:
- kind: Service
- name: sonarqube
- weight: 100
- wildcardPolicy: None
diff --git a/tests/region-sonarqube-medical-diagnosis-hub.expected.yaml b/tests/region-sonarqube-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 22bded77..00000000
--- a/tests/region-sonarqube-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,116 +0,0 @@
----
-# Source: sonarqube/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: sonarqube
- name: sonarqube
- namespace: devsecops-ci
-spec:
- ports:
- - name: 9000-tcp
- port: 9000
- protocol: TCP
- targetPort: 9000
- selector:
- app: sonarqube
- type: ClusterIP
----
-# Source: sonarqube/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: sonarqube
- namespace: devsecops-ci
- labels:
- app: sonarqube
- app.kubernetes.io/component: sonarqube
- app.kubernetes.io/instance: sonarqube
- app.kubernetes.io/name: sonarqube
- app.kubernetes.io/part-of: sonarqube
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: sonarqube
- template:
- metadata:
- labels:
- app: sonarqube
- spec:
- containers:
- - name: sonarqube
- imagePullPolicy: IfNotPresent
- image: quay.io/hybridcloudpatterns/sonarqube:8.3-community
- ports:
- - containerPort: 9000
- protocol: TCP
- volumeMounts:
- - mountPath: /opt/sq/temp
- name: sonarqube-temp
- - mountPath: /opt/sq/conf
- name: sonarqube-conf
- - mountPath: /opt/sq/data
- name: sonarqube-data
- - mountPath: /opt/sq/extensions
- name: sonarqube-extensions
- - mountPath: /opt/sq/logs
- name: sonarqube-logs
- livenessProbe:
- failureThreshold: 10
- httpGet:
- path: /
- port: 9000
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- readinessProbe:
- failureThreshold: 10
- httpGet:
- path: /
- port: 9000
- scheme: HTTP
- initialDelaySeconds: 10
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- resources:
- limits:
- cpu: 1
- memory: 4Gi
- requests:
- cpu: 200m
- memory: 512Mi
- volumes:
- - name: sonarqube-temp
- emptyDir: {}
- - name: sonarqube-conf
- emptyDir: {}
- - name: sonarqube-data
- emptyDir: {}
- - name: sonarqube-extensions
- emptyDir: {}
- - name: sonarqube-logs
- emptyDir: {}
----
-# Source: sonarqube/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: sonarqube
- name: sonarqube
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 9000-tcp
- tls:
- termination: edge
- to:
- kind: Service
- name: sonarqube
- weight: 100
- wildcardPolicy: None
diff --git a/tests/region-sonarqube-naked.expected.yaml b/tests/region-sonarqube-naked.expected.yaml
deleted file mode 100644
index 22bded77..00000000
--- a/tests/region-sonarqube-naked.expected.yaml
+++ /dev/null
@@ -1,116 +0,0 @@
----
-# Source: sonarqube/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: sonarqube
- name: sonarqube
- namespace: devsecops-ci
-spec:
- ports:
- - name: 9000-tcp
- port: 9000
- protocol: TCP
- targetPort: 9000
- selector:
- app: sonarqube
- type: ClusterIP
----
-# Source: sonarqube/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: sonarqube
- namespace: devsecops-ci
- labels:
- app: sonarqube
- app.kubernetes.io/component: sonarqube
- app.kubernetes.io/instance: sonarqube
- app.kubernetes.io/name: sonarqube
- app.kubernetes.io/part-of: sonarqube
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: sonarqube
- template:
- metadata:
- labels:
- app: sonarqube
- spec:
- containers:
- - name: sonarqube
- imagePullPolicy: IfNotPresent
- image: quay.io/hybridcloudpatterns/sonarqube:8.3-community
- ports:
- - containerPort: 9000
- protocol: TCP
- volumeMounts:
- - mountPath: /opt/sq/temp
- name: sonarqube-temp
- - mountPath: /opt/sq/conf
- name: sonarqube-conf
- - mountPath: /opt/sq/data
- name: sonarqube-data
- - mountPath: /opt/sq/extensions
- name: sonarqube-extensions
- - mountPath: /opt/sq/logs
- name: sonarqube-logs
- livenessProbe:
- failureThreshold: 10
- httpGet:
- path: /
- port: 9000
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- readinessProbe:
- failureThreshold: 10
- httpGet:
- path: /
- port: 9000
- scheme: HTTP
- initialDelaySeconds: 10
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- resources:
- limits:
- cpu: 1
- memory: 4Gi
- requests:
- cpu: 200m
- memory: 512Mi
- volumes:
- - name: sonarqube-temp
- emptyDir: {}
- - name: sonarqube-conf
- emptyDir: {}
- - name: sonarqube-data
- emptyDir: {}
- - name: sonarqube-extensions
- emptyDir: {}
- - name: sonarqube-logs
- emptyDir: {}
----
-# Source: sonarqube/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: sonarqube
- name: sonarqube
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 9000-tcp
- tls:
- termination: edge
- to:
- kind: Service
- name: sonarqube
- weight: 100
- wildcardPolicy: None
diff --git a/tests/region-sonarqube-normal.expected.yaml b/tests/region-sonarqube-normal.expected.yaml
deleted file mode 100644
index 22bded77..00000000
--- a/tests/region-sonarqube-normal.expected.yaml
+++ /dev/null
@@ -1,116 +0,0 @@
----
-# Source: sonarqube/templates/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: sonarqube
- name: sonarqube
- namespace: devsecops-ci
-spec:
- ports:
- - name: 9000-tcp
- port: 9000
- protocol: TCP
- targetPort: 9000
- selector:
- app: sonarqube
- type: ClusterIP
----
-# Source: sonarqube/templates/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- name: sonarqube
- namespace: devsecops-ci
- labels:
- app: sonarqube
- app.kubernetes.io/component: sonarqube
- app.kubernetes.io/instance: sonarqube
- app.kubernetes.io/name: sonarqube
- app.kubernetes.io/part-of: sonarqube
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: sonarqube
- template:
- metadata:
- labels:
- app: sonarqube
- spec:
- containers:
- - name: sonarqube
- imagePullPolicy: IfNotPresent
- image: quay.io/hybridcloudpatterns/sonarqube:8.3-community
- ports:
- - containerPort: 9000
- protocol: TCP
- volumeMounts:
- - mountPath: /opt/sq/temp
- name: sonarqube-temp
- - mountPath: /opt/sq/conf
- name: sonarqube-conf
- - mountPath: /opt/sq/data
- name: sonarqube-data
- - mountPath: /opt/sq/extensions
- name: sonarqube-extensions
- - mountPath: /opt/sq/logs
- name: sonarqube-logs
- livenessProbe:
- failureThreshold: 10
- httpGet:
- path: /
- port: 9000
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- readinessProbe:
- failureThreshold: 10
- httpGet:
- path: /
- port: 9000
- scheme: HTTP
- initialDelaySeconds: 10
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- resources:
- limits:
- cpu: 1
- memory: 4Gi
- requests:
- cpu: 200m
- memory: 512Mi
- volumes:
- - name: sonarqube-temp
- emptyDir: {}
- - name: sonarqube-conf
- emptyDir: {}
- - name: sonarqube-data
- emptyDir: {}
- - name: sonarqube-extensions
- emptyDir: {}
- - name: sonarqube-logs
- emptyDir: {}
----
-# Source: sonarqube/templates/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: sonarqube
- name: sonarqube
- namespace: devsecops-ci
-spec:
- port:
- targetPort: 9000-tcp
- tls:
- termination: edge
- to:
- kind: Service
- name: sonarqube
- weight: 100
- wildcardPolicy: None
diff --git a/tests/region-spring-petclinic-config-industrial-edge-factory.expected.yaml b/tests/region-spring-petclinic-config-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 824d42ad..00000000
--- a/tests/region-spring-petclinic-config-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,96 +0,0 @@
----
-# Source: spring-petclinic-config/templates/app/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- - name: 8443-tcp
- port: 8443
- protocol: TCP
- targetPort: 8443
- - name: 8778-tcp
- port: 8778
- protocol: TCP
- targetPort: 8778
- selector:
- app: spring-petclinic
- sessionAffinity: None
- type: ClusterIP
----
-# Source: spring-petclinic-config/templates/app/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- annotations:
- labels:
- app: spring-petclinic
- app.kubernetes.io/component: web
- app.kubernetes.io/instance: spring-petclinic
- app.kubernetes.io/name: spring-petclinic
- app.kubernetes.io/part-of: spring-petclinic
- app.openshift.io/runtime: java
- name: spring-petclinic
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: spring-petclinic
- template:
- metadata:
- labels:
- app: spring-petclinic
- spec:
- containers:
- - name: spring-petclinic
- imagePullPolicy: Always
- image: quay-registry-quay-quay-enterprise.apps.region.example.com/devel/spring-petclinic:latest
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- ports:
- - containerPort: 8080
- protocol: TCP
- - containerPort: 8443
- protocol: TCP
- - containerPort: 8778
- protocol: TCP
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 5
----
-# Source: spring-petclinic-config/templates/app/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: spring-petclinic
- weight: 100
diff --git a/tests/region-spring-petclinic-config-industrial-edge-hub.expected.yaml b/tests/region-spring-petclinic-config-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 824d42ad..00000000
--- a/tests/region-spring-petclinic-config-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,96 +0,0 @@
----
-# Source: spring-petclinic-config/templates/app/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- - name: 8443-tcp
- port: 8443
- protocol: TCP
- targetPort: 8443
- - name: 8778-tcp
- port: 8778
- protocol: TCP
- targetPort: 8778
- selector:
- app: spring-petclinic
- sessionAffinity: None
- type: ClusterIP
----
-# Source: spring-petclinic-config/templates/app/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- annotations:
- labels:
- app: spring-petclinic
- app.kubernetes.io/component: web
- app.kubernetes.io/instance: spring-petclinic
- app.kubernetes.io/name: spring-petclinic
- app.kubernetes.io/part-of: spring-petclinic
- app.openshift.io/runtime: java
- name: spring-petclinic
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: spring-petclinic
- template:
- metadata:
- labels:
- app: spring-petclinic
- spec:
- containers:
- - name: spring-petclinic
- imagePullPolicy: Always
- image: quay-registry-quay-quay-enterprise.apps.region.example.com/devel/spring-petclinic:latest
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- ports:
- - containerPort: 8080
- protocol: TCP
- - containerPort: 8443
- protocol: TCP
- - containerPort: 8778
- protocol: TCP
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 5
----
-# Source: spring-petclinic-config/templates/app/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: spring-petclinic
- weight: 100
diff --git a/tests/region-spring-petclinic-config-medical-diagnosis-hub.expected.yaml b/tests/region-spring-petclinic-config-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 824d42ad..00000000
--- a/tests/region-spring-petclinic-config-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,96 +0,0 @@
----
-# Source: spring-petclinic-config/templates/app/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- - name: 8443-tcp
- port: 8443
- protocol: TCP
- targetPort: 8443
- - name: 8778-tcp
- port: 8778
- protocol: TCP
- targetPort: 8778
- selector:
- app: spring-petclinic
- sessionAffinity: None
- type: ClusterIP
----
-# Source: spring-petclinic-config/templates/app/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- annotations:
- labels:
- app: spring-petclinic
- app.kubernetes.io/component: web
- app.kubernetes.io/instance: spring-petclinic
- app.kubernetes.io/name: spring-petclinic
- app.kubernetes.io/part-of: spring-petclinic
- app.openshift.io/runtime: java
- name: spring-petclinic
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: spring-petclinic
- template:
- metadata:
- labels:
- app: spring-petclinic
- spec:
- containers:
- - name: spring-petclinic
- imagePullPolicy: Always
- image: quay-registry-quay-quay-enterprise.apps.region.example.com/devel/spring-petclinic:latest
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- ports:
- - containerPort: 8080
- protocol: TCP
- - containerPort: 8443
- protocol: TCP
- - containerPort: 8778
- protocol: TCP
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 5
----
-# Source: spring-petclinic-config/templates/app/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: spring-petclinic
- weight: 100
diff --git a/tests/region-spring-petclinic-config-naked.expected.yaml b/tests/region-spring-petclinic-config-naked.expected.yaml
deleted file mode 100644
index 937191ac..00000000
--- a/tests/region-spring-petclinic-config-naked.expected.yaml
+++ /dev/null
@@ -1,96 +0,0 @@
----
-# Source: spring-petclinic-config/templates/app/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- - name: 8443-tcp
- port: 8443
- protocol: TCP
- targetPort: 8443
- - name: 8778-tcp
- port: 8778
- protocol: TCP
- targetPort: 8778
- selector:
- app: spring-petclinic
- sessionAffinity: None
- type: ClusterIP
----
-# Source: spring-petclinic-config/templates/app/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- annotations:
- labels:
- app: spring-petclinic
- app.kubernetes.io/component: web
- app.kubernetes.io/instance: spring-petclinic
- app.kubernetes.io/name: spring-petclinic
- app.kubernetes.io/part-of: spring-petclinic
- app.openshift.io/runtime: java
- name: spring-petclinic
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: spring-petclinic
- template:
- metadata:
- labels:
- app: spring-petclinic
- spec:
- containers:
- - name: spring-petclinic
- imagePullPolicy: Always
- image: quay-registry-quay-quay-enterprise.app.foo.com/devel/spring-petclinic:latest
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- ports:
- - containerPort: 8080
- protocol: TCP
- - containerPort: 8443
- protocol: TCP
- - containerPort: 8778
- protocol: TCP
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 5
----
-# Source: spring-petclinic-config/templates/app/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: spring-petclinic
- weight: 100
diff --git a/tests/region-spring-petclinic-config-normal.expected.yaml b/tests/region-spring-petclinic-config-normal.expected.yaml
deleted file mode 100644
index 824d42ad..00000000
--- a/tests/region-spring-petclinic-config-normal.expected.yaml
+++ /dev/null
@@ -1,96 +0,0 @@
----
-# Source: spring-petclinic-config/templates/app/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- - name: 8443-tcp
- port: 8443
- protocol: TCP
- targetPort: 8443
- - name: 8778-tcp
- port: 8778
- protocol: TCP
- targetPort: 8778
- selector:
- app: spring-petclinic
- sessionAffinity: None
- type: ClusterIP
----
-# Source: spring-petclinic-config/templates/app/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- annotations:
- labels:
- app: spring-petclinic
- app.kubernetes.io/component: web
- app.kubernetes.io/instance: spring-petclinic
- app.kubernetes.io/name: spring-petclinic
- app.kubernetes.io/part-of: spring-petclinic
- app.openshift.io/runtime: java
- name: spring-petclinic
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: spring-petclinic
- template:
- metadata:
- labels:
- app: spring-petclinic
- spec:
- containers:
- - name: spring-petclinic
- imagePullPolicy: Always
- image: quay-registry-quay-quay-enterprise.apps.region.example.com/devel/spring-petclinic:latest
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- ports:
- - containerPort: 8080
- protocol: TCP
- - containerPort: 8443
- protocol: TCP
- - containerPort: 8778
- protocol: TCP
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 5
----
-# Source: spring-petclinic-config/templates/app/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: spring-petclinic
- weight: 100
diff --git a/tests/region-stage-spring-petclinic-config-industrial-edge-factory.expected.yaml b/tests/region-stage-spring-petclinic-config-industrial-edge-factory.expected.yaml
deleted file mode 100644
index 6853812e..00000000
--- a/tests/region-stage-spring-petclinic-config-industrial-edge-factory.expected.yaml
+++ /dev/null
@@ -1,110 +0,0 @@
----
-# Source: spring-petclinic-config/templates/app/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- - name: 8443-tcp
- port: 8443
- protocol: TCP
- targetPort: 8443
- - name: 8778-tcp
- port: 8778
- protocol: TCP
- targetPort: 8778
- selector:
- app: spring-petclinic
- sessionAffinity: None
- type: ClusterIP
----
-# Source: spring-petclinic-config/templates/app/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- annotations:
- labels:
- app: spring-petclinic
- app.kubernetes.io/component: web
- app.kubernetes.io/instance: spring-petclinic
- app.kubernetes.io/name: spring-petclinic
- app.kubernetes.io/part-of: spring-petclinic
- app.openshift.io/runtime: java
- name: spring-petclinic
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: spring-petclinic
- template:
- metadata:
- labels:
- app: spring-petclinic
- spec:
- containers:
- - name: spring-petclinic
- imagePullPolicy: Always
- image: quay.io/siamaksade/spring-petclinic:latest
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- ports:
- - containerPort: 8080
- protocol: TCP
- - containerPort: 8443
- protocol: TCP
- - containerPort: 8778
- protocol: TCP
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 5
----
-# Source: spring-petclinic-config/templates/app/kustomization.yaml
-resources:
-- deployment.yaml
-- service.yaml
-- route.yaml
----
-# Source: spring-petclinic-config/templates/environments/dev/kustomization.yaml
-bases:
- - ../../app/
----
-# Source: spring-petclinic-config/templates/environments/stage/kustomization.yaml
-bases:
- - ../../app/
----
-# Source: spring-petclinic-config/templates/app/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: spring-petclinic
- weight: 100
diff --git a/tests/region-stage-spring-petclinic-config-industrial-edge-hub.expected.yaml b/tests/region-stage-spring-petclinic-config-industrial-edge-hub.expected.yaml
deleted file mode 100644
index 6853812e..00000000
--- a/tests/region-stage-spring-petclinic-config-industrial-edge-hub.expected.yaml
+++ /dev/null
@@ -1,110 +0,0 @@
----
-# Source: spring-petclinic-config/templates/app/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- - name: 8443-tcp
- port: 8443
- protocol: TCP
- targetPort: 8443
- - name: 8778-tcp
- port: 8778
- protocol: TCP
- targetPort: 8778
- selector:
- app: spring-petclinic
- sessionAffinity: None
- type: ClusterIP
----
-# Source: spring-petclinic-config/templates/app/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- annotations:
- labels:
- app: spring-petclinic
- app.kubernetes.io/component: web
- app.kubernetes.io/instance: spring-petclinic
- app.kubernetes.io/name: spring-petclinic
- app.kubernetes.io/part-of: spring-petclinic
- app.openshift.io/runtime: java
- name: spring-petclinic
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: spring-petclinic
- template:
- metadata:
- labels:
- app: spring-petclinic
- spec:
- containers:
- - name: spring-petclinic
- imagePullPolicy: Always
- image: quay.io/siamaksade/spring-petclinic:latest
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- ports:
- - containerPort: 8080
- protocol: TCP
- - containerPort: 8443
- protocol: TCP
- - containerPort: 8778
- protocol: TCP
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 5
----
-# Source: spring-petclinic-config/templates/app/kustomization.yaml
-resources:
-- deployment.yaml
-- service.yaml
-- route.yaml
----
-# Source: spring-petclinic-config/templates/environments/dev/kustomization.yaml
-bases:
- - ../../app/
----
-# Source: spring-petclinic-config/templates/environments/stage/kustomization.yaml
-bases:
- - ../../app/
----
-# Source: spring-petclinic-config/templates/app/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: spring-petclinic
- weight: 100
diff --git a/tests/region-stage-spring-petclinic-config-medical-diagnosis-hub.expected.yaml b/tests/region-stage-spring-petclinic-config-medical-diagnosis-hub.expected.yaml
deleted file mode 100644
index 6853812e..00000000
--- a/tests/region-stage-spring-petclinic-config-medical-diagnosis-hub.expected.yaml
+++ /dev/null
@@ -1,110 +0,0 @@
----
-# Source: spring-petclinic-config/templates/app/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- - name: 8443-tcp
- port: 8443
- protocol: TCP
- targetPort: 8443
- - name: 8778-tcp
- port: 8778
- protocol: TCP
- targetPort: 8778
- selector:
- app: spring-petclinic
- sessionAffinity: None
- type: ClusterIP
----
-# Source: spring-petclinic-config/templates/app/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- annotations:
- labels:
- app: spring-petclinic
- app.kubernetes.io/component: web
- app.kubernetes.io/instance: spring-petclinic
- app.kubernetes.io/name: spring-petclinic
- app.kubernetes.io/part-of: spring-petclinic
- app.openshift.io/runtime: java
- name: spring-petclinic
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: spring-petclinic
- template:
- metadata:
- labels:
- app: spring-petclinic
- spec:
- containers:
- - name: spring-petclinic
- imagePullPolicy: Always
- image: quay.io/siamaksade/spring-petclinic:latest
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- ports:
- - containerPort: 8080
- protocol: TCP
- - containerPort: 8443
- protocol: TCP
- - containerPort: 8778
- protocol: TCP
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 5
----
-# Source: spring-petclinic-config/templates/app/kustomization.yaml
-resources:
-- deployment.yaml
-- service.yaml
-- route.yaml
----
-# Source: spring-petclinic-config/templates/environments/dev/kustomization.yaml
-bases:
- - ../../app/
----
-# Source: spring-petclinic-config/templates/environments/stage/kustomization.yaml
-bases:
- - ../../app/
----
-# Source: spring-petclinic-config/templates/app/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: spring-petclinic
- weight: 100
diff --git a/tests/region-stage-spring-petclinic-config-naked.expected.yaml b/tests/region-stage-spring-petclinic-config-naked.expected.yaml
deleted file mode 100644
index 6853812e..00000000
--- a/tests/region-stage-spring-petclinic-config-naked.expected.yaml
+++ /dev/null
@@ -1,110 +0,0 @@
----
-# Source: spring-petclinic-config/templates/app/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- - name: 8443-tcp
- port: 8443
- protocol: TCP
- targetPort: 8443
- - name: 8778-tcp
- port: 8778
- protocol: TCP
- targetPort: 8778
- selector:
- app: spring-petclinic
- sessionAffinity: None
- type: ClusterIP
----
-# Source: spring-petclinic-config/templates/app/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- annotations:
- labels:
- app: spring-petclinic
- app.kubernetes.io/component: web
- app.kubernetes.io/instance: spring-petclinic
- app.kubernetes.io/name: spring-petclinic
- app.kubernetes.io/part-of: spring-petclinic
- app.openshift.io/runtime: java
- name: spring-petclinic
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: spring-petclinic
- template:
- metadata:
- labels:
- app: spring-petclinic
- spec:
- containers:
- - name: spring-petclinic
- imagePullPolicy: Always
- image: quay.io/siamaksade/spring-petclinic:latest
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- ports:
- - containerPort: 8080
- protocol: TCP
- - containerPort: 8443
- protocol: TCP
- - containerPort: 8778
- protocol: TCP
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 5
----
-# Source: spring-petclinic-config/templates/app/kustomization.yaml
-resources:
-- deployment.yaml
-- service.yaml
-- route.yaml
----
-# Source: spring-petclinic-config/templates/environments/dev/kustomization.yaml
-bases:
- - ../../app/
----
-# Source: spring-petclinic-config/templates/environments/stage/kustomization.yaml
-bases:
- - ../../app/
----
-# Source: spring-petclinic-config/templates/app/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: spring-petclinic
- weight: 100
diff --git a/tests/region-stage-spring-petclinic-config-normal.expected.yaml b/tests/region-stage-spring-petclinic-config-normal.expected.yaml
deleted file mode 100644
index 6853812e..00000000
--- a/tests/region-stage-spring-petclinic-config-normal.expected.yaml
+++ /dev/null
@@ -1,110 +0,0 @@
----
-# Source: spring-petclinic-config/templates/app/service.yaml
-apiVersion: v1
-kind: Service
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- ports:
- - name: 8080-tcp
- port: 8080
- protocol: TCP
- targetPort: 8080
- - name: 8443-tcp
- port: 8443
- protocol: TCP
- targetPort: 8443
- - name: 8778-tcp
- port: 8778
- protocol: TCP
- targetPort: 8778
- selector:
- app: spring-petclinic
- sessionAffinity: None
- type: ClusterIP
----
-# Source: spring-petclinic-config/templates/app/deployment.yaml
-apiVersion: apps/v1
-kind: Deployment
-metadata:
- annotations:
- labels:
- app: spring-petclinic
- app.kubernetes.io/component: web
- app.kubernetes.io/instance: spring-petclinic
- app.kubernetes.io/name: spring-petclinic
- app.kubernetes.io/part-of: spring-petclinic
- app.openshift.io/runtime: java
- name: spring-petclinic
-spec:
- replicas: 1
- selector:
- matchLabels:
- app: spring-petclinic
- template:
- metadata:
- labels:
- app: spring-petclinic
- spec:
- containers:
- - name: spring-petclinic
- imagePullPolicy: Always
- image: quay.io/siamaksade/spring-petclinic:latest
- livenessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 1
- ports:
- - containerPort: 8080
- protocol: TCP
- - containerPort: 8443
- protocol: TCP
- - containerPort: 8778
- protocol: TCP
- readinessProbe:
- failureThreshold: 3
- httpGet:
- path: /
- port: 8080
- scheme: HTTP
- initialDelaySeconds: 45
- periodSeconds: 10
- successThreshold: 1
- timeoutSeconds: 5
----
-# Source: spring-petclinic-config/templates/app/kustomization.yaml
-resources:
-- deployment.yaml
-- service.yaml
-- route.yaml
----
-# Source: spring-petclinic-config/templates/environments/dev/kustomization.yaml
-bases:
- - ../../app/
----
-# Source: spring-petclinic-config/templates/environments/stage/kustomization.yaml
-bases:
- - ../../app/
----
-# Source: spring-petclinic-config/templates/app/route.yaml
-apiVersion: route.openshift.io/v1
-kind: Route
-metadata:
- labels:
- app: spring-petclinic
- name: spring-petclinic
-spec:
- port:
- targetPort: 8080-tcp
- to:
- kind: Service
- name: spring-petclinic
- weight: 100