feat: add cpol for vluster secret sync
This commit is contained in:
@@ -0,0 +1,89 @@
|
||||
{{- $name := include "vCluster.releaseName" . -}}
|
||||
apiVersion: kyverno.io/v1
|
||||
kind: ClusterPolicy
|
||||
metadata:
|
||||
name: sync-atlantis-vcluster-secrets
|
||||
spec:
|
||||
background: true
|
||||
generateExistingOnPolicyUpdate: true
|
||||
rules:
|
||||
- name: sync-redis-secrets
|
||||
generate:
|
||||
apiVersion: v1
|
||||
namespace: '{{request.object.metadata.name}}'
|
||||
synchronize: true
|
||||
cloneList:
|
||||
namespace: redis
|
||||
kinds:
|
||||
- Secret
|
||||
selector:
|
||||
matchLabels:
|
||||
app.kubernetes.io/name: redis
|
||||
match:
|
||||
resources:
|
||||
kinds:
|
||||
- Namespace
|
||||
names:
|
||||
- "vcluster-009dba7e-*"
|
||||
selector:
|
||||
matchLabels:
|
||||
vcluster.loft.sh/vcluster-namespace: '{{ .Release.Namespace }}'
|
||||
- name: sync-rabbitmq-secrets
|
||||
generate:
|
||||
apiVersion: v1
|
||||
namespace: '{{request.object.metadata.name}}'
|
||||
synchronize: true
|
||||
cloneList:
|
||||
namespace: rabbitmq
|
||||
kinds:
|
||||
- Secret
|
||||
selector:
|
||||
matchLabels:
|
||||
clone: "true"
|
||||
match:
|
||||
resources:
|
||||
kinds:
|
||||
- Namespace
|
||||
names:
|
||||
- "vcluster-009dba7e-*"
|
||||
selector:
|
||||
matchLabels:
|
||||
vcluster.loft.sh/vcluster-namespace: '{{ .Release.Namespace }}'
|
||||
- name: sync-archmeister-superuser
|
||||
generate:
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
name: '{{ $name }}-archmeister-app'
|
||||
namespace: '{{request.object.metadata.name}}'
|
||||
synchronize: true
|
||||
clone:
|
||||
namespace: '{{ .Release.Namespace }}'
|
||||
name: '{{ $name }}-archmeister-superuser'
|
||||
match:
|
||||
resources:
|
||||
kinds:
|
||||
- Namespace
|
||||
names:
|
||||
- "vcluster-009dba7e-*"
|
||||
selector:
|
||||
matchLabels:
|
||||
vcluster.loft.sh/vcluster-namespace: '{{ .Release.Namespace }}'
|
||||
- name: sync-archmeister-env
|
||||
generate:
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
name: archmeister-env
|
||||
namespace: '{{request.object.metadata.name}}'
|
||||
synchronize: true
|
||||
clone:
|
||||
namespace: '{{ .Release.Namespace }}'
|
||||
name: archmeister-env
|
||||
match:
|
||||
resources:
|
||||
kinds:
|
||||
- Namespace
|
||||
names:
|
||||
- "vcluster-009dba7e-*"
|
||||
selector:
|
||||
matchLabels:
|
||||
vcluster.loft.sh/vcluster-namespace: '{{ .Release.Namespace }}'
|
||||
Reference in New Issue
Block a user