comms(mas): bootstrap admin client secret
This commit is contained in:
parent
eb3a6824e6
commit
ed23d831b9
@ -6,6 +6,8 @@ resources:
|
|||||||
- synapse-rendered.yaml
|
- synapse-rendered.yaml
|
||||||
- synapse-signingkey-ensure-job.yaml
|
- synapse-signingkey-ensure-job.yaml
|
||||||
- mas-configmap.yaml
|
- mas-configmap.yaml
|
||||||
|
- mas-admin-client-secret.yaml
|
||||||
|
- mas-admin-client-secret-ensure-job.yaml
|
||||||
- mas-deployment.yaml
|
- mas-deployment.yaml
|
||||||
- mas-ingress.yaml
|
- mas-ingress.yaml
|
||||||
- element-rendered.yaml
|
- element-rendered.yaml
|
||||||
|
|||||||
@ -0,0 +1,75 @@
|
|||||||
|
# services/communication/mas-admin-client-secret-ensure-job.yaml
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: mas-admin-client-secret-writer
|
||||||
|
namespace: comms
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: Role
|
||||||
|
metadata:
|
||||||
|
name: mas-admin-client-secret-writer
|
||||||
|
namespace: comms
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["secrets"]
|
||||||
|
resourceNames: ["mas-admin-client"]
|
||||||
|
verbs: ["get", "patch", "update"]
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: RoleBinding
|
||||||
|
metadata:
|
||||||
|
name: mas-admin-client-secret-writer
|
||||||
|
namespace: comms
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: Role
|
||||||
|
name: mas-admin-client-secret-writer
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: mas-admin-client-secret-writer
|
||||||
|
namespace: comms
|
||||||
|
---
|
||||||
|
apiVersion: batch/v1
|
||||||
|
kind: Job
|
||||||
|
metadata:
|
||||||
|
name: mas-admin-client-secret-ensure-1
|
||||||
|
namespace: comms
|
||||||
|
spec:
|
||||||
|
backoffLimit: 2
|
||||||
|
template:
|
||||||
|
spec:
|
||||||
|
serviceAccountName: mas-admin-client-secret-writer
|
||||||
|
restartPolicy: OnFailure
|
||||||
|
volumes:
|
||||||
|
- name: work
|
||||||
|
emptyDir: {}
|
||||||
|
initContainers:
|
||||||
|
- name: generate
|
||||||
|
image: alpine:3.20
|
||||||
|
command: ["/bin/sh", "-c"]
|
||||||
|
args:
|
||||||
|
- |
|
||||||
|
set -euo pipefail
|
||||||
|
umask 077
|
||||||
|
openssl rand -hex 32 > /work/client_secret
|
||||||
|
volumeMounts:
|
||||||
|
- name: work
|
||||||
|
mountPath: /work
|
||||||
|
containers:
|
||||||
|
- name: patch
|
||||||
|
image: bitnami/kubectl:latest
|
||||||
|
command: ["/bin/sh", "-c"]
|
||||||
|
args:
|
||||||
|
- |
|
||||||
|
set -euo pipefail
|
||||||
|
if kubectl -n comms get secret mas-admin-client -o jsonpath='{.data.client_secret}' 2>/dev/null | grep -q .; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
secret_b64="$(base64 /work/client_secret | tr -d '\n')"
|
||||||
|
payload="$(printf '{"data":{"client_secret":"%s"}}' "${secret_b64}")"
|
||||||
|
kubectl -n comms patch secret mas-admin-client --type=merge -p "${payload}" >/dev/null
|
||||||
|
volumeMounts:
|
||||||
|
- name: work
|
||||||
|
mountPath: /work
|
||||||
|
|
||||||
9
services/communication/mas-admin-client-secret.yaml
Normal file
9
services/communication/mas-admin-client-secret.yaml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# services/communication/mas-admin-client-secret.yaml
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: mas-admin-client
|
||||||
|
namespace: comms
|
||||||
|
type: Opaque
|
||||||
|
data: {}
|
||||||
|
|
||||||
Loading…
x
Reference in New Issue
Block a user