|
| 1 | +{{- if not .Values.api.secretKeyFromExistingSecret.enabled -}} |
| 2 | +apiVersion: batch/v1 |
| 3 | +kind: Job |
| 4 | +metadata: |
| 5 | + name: {{ include "flagsmith.api.secretKeySecretName" . }} |
| 6 | + namespace: {{ .Release.Namespace | quote }} |
| 7 | + labels: |
| 8 | + {{- include "flagsmith.labels" . | nindent 4 }} |
| 9 | + app.kubernetes.io/component: django-secret-init |
| 10 | + annotations: |
| 11 | + "helm.sh/hook": pre-install,pre-upgrade |
| 12 | + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded |
| 13 | +spec: |
| 14 | + ttlSecondsAfterFinished: 60 |
| 15 | + template: |
| 16 | + metadata: |
| 17 | + name: {{ include "flagsmith.api.secretKeySecretName" . }} |
| 18 | + labels: |
| 19 | + {{- include "flagsmith.labels" . | nindent 8 }} |
| 20 | + app.kubernetes.io/component: django-secret-init |
| 21 | + spec: |
| 22 | + restartPolicy: OnFailure |
| 23 | + serviceAccountName: {{ include "flagsmith.api.secretKeySecretName" . }} |
| 24 | + containers: |
| 25 | + - name: secret-creator |
| 26 | + image: bitnami/kubectl:latest |
| 27 | + imagePullPolicy: IfNotPresent |
| 28 | + command: |
| 29 | + - /bin/sh |
| 30 | + - -c |
| 31 | + - | |
| 32 | + SECRET_NAME={{ include "flagsmith.api.secretKeySecretName" . }} |
| 33 | + NAMESPACE={{ .Release.Namespace }} |
| 34 | + echo "Checking for secret $SECRET_NAME in namespace $NAMESPACE" |
| 35 | + # Attempt to get the secret; if it fails (exit code != 0), create it. |
| 36 | + if ! kubectl get secret "$SECRET_NAME" -n "$NAMESPACE" -o name; then |
| 37 | + echo "Secret $SECRET_NAME not found. Creating..." |
| 38 | + # Generate a 64-character hex key (32 bytes) |
| 39 | + GENERATED_KEY=$(openssl rand -hex 32) |
| 40 | + kubectl create secret generic "$SECRET_NAME" -n "$NAMESPACE" \ |
| 41 | + --from-literal=django-secret-key="$GENERATED_KEY" \ |
| 42 | + --dry-run=client -o yaml | kubectl apply -f - |
| 43 | + echo "Secret $SECRET_NAME created." |
| 44 | + else |
| 45 | + echo "Secret $SECRET_NAME already exists. No action taken." |
| 46 | + fi |
| 47 | +{{- end }} |
0 commit comments