2c4a0d2563fdc31298781e56de0c647e3927c3fc
[oom.git] / kubernetes / so / components / so-mariadb / templates / job.yaml
1 {{/*
2 # Copyright © 2017 Amdocs, Bell Canada
3 # Modifications Copyright (C) 2022/23 Nordix Foundation
4 #
5 # Licensed under the Apache License, Version 2.0 (the "License");
6 # you may not use this file except in compliance with the License.
7 # You may obtain a copy of the License at
8 #
9 #       http://www.apache.org/licenses/LICENSE-2.0
10 #
11 # Unless required by applicable law or agreed to in writing, software
12 # distributed under the License is distributed on an "AS IS" BASIS,
13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 # See the License for the specific language governing permissions and
15 # limitations under the License.
16 */}}
17 {{- if .Values.global.migration.enabled }}
18 apiVersion: batch/v1
19 kind: Job
20 metadata:
21   name: {{ include "common.fullname" . }}-backup
22   namespace: {{ include "common.namespace" . }}
23   labels:
24     app: {{ include "common.name" . }}
25     chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
26     release: {{ include "common.release" . }}
27     heritage: {{ .Release.Service }}
28   annotations:
29     "helm.sh/hook": pre-upgrade,pre-install
30     "helm.sh/hook-weight": "1"
31     "helm.sh/hook-delete-policy": before-hook-creation
32 spec:
33   backoffLimit: 20
34   template:
35     metadata:
36       labels:
37         app: {{ include "common.name" . }}
38         release: {{ include "common.release" . }}
39       name: {{ include "common.name" . }}
40     spec:
41       containers:
42       - name: {{ include "common.fullname" . }}
43         image: {{ include "repositoryGenerator.image.mariadb" . }}
44         imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
45         env:
46         - name: DB_HOST
47           value: {{ .Values.global.migration.dbHost }}
48         - name: DB_USER
49           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-backup-creds" "key" "login") | indent 10 }}
50         - name: DB_PORT
51           value: "{{ .Values.global.migration.dbPort }}"
52         - name: DB_PASS
53           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-backup-creds" "key" "password") | indent 10 }}
54         command:
55         - /bin/bash
56         - -c
57         - |
58           {{- if include "common.onServiceMesh" . }}
59           echo "waiting 15s for istio side cars to be up"; sleep 15s;{{- end }}
60           mysqldump -vv --user=${DB_USER} --password=${DB_PASS} --host=${DB_HOST} --port=${DB_PORT} --databases --single-transaction --quick --lock-tables=false catalogdb requestdb nfvo cnfm > /var/data/mariadb/backup-`date +%s`.sql
61         volumeMounts:
62         - mountPath: /etc/localtime
63           name: localtime
64           readOnly: true
65         - name: backup-storage
66           mountPath: /var/data/mariadb
67       {{ include "common.waitForJobContainer" . | indent 6 | trim }}
68       serviceAccountName: {{ include "common.fullname" (dict "suffix" "read" "dot" . )}}
69       volumes:
70       - name: localtime
71         hostPath:
72           path: /etc/localtime
73       - name: backup-storage
74         persistentVolumeClaim:
75           claimName: {{ include "common.fullname" . }}-migration
76       {{- include "common.imagePullSecrets" . | nindent 6 }}
77       restartPolicy: Never
78 ---
79 {{- end }}
80 apiVersion: batch/v1
81 kind: Job
82 metadata:
83   name: {{ include "common.fullname" . }}-config-job
84   namespace: {{ include "common.namespace" . }}
85   labels:
86     app: {{ include "common.name" . }}
87     chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
88     release: {{ include "common.release" . }}
89     heritage: {{ .Release.Service }}
90   annotations:
91     "helm.sh/hook": post-upgrade,post-rollback,post-install
92     "helm.sh/hook-weight": "0"
93     "helm.sh/hook-delete-policy": before-hook-creation
94 spec:
95   backoffLimit: 20
96   template:
97     metadata:
98       labels:
99         app: {{ include "common.name" . }}-job
100         release: {{ include "common.release" . }}
101       name: {{ include "common.name" . }}
102     spec:
103       initContainers: {{ include "common.readinessCheck.waitFor" . | nindent 6 }}
104       containers:
105       - name: {{ include "common.name" . }}-config
106         image: {{ include "repositoryGenerator.repository" . }}/{{ .Values.image }}
107         imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
108         command:
109         - /bin/bash
110         - -c
111         - >
112           {{- if include "common.onServiceMesh" . }}
113           echo "waiting 15s for istio side cars to be up"; sleep 15s;{{- end }}
114           mysql() { /usr/bin/mysql  -h ${DB_HOST} -P ${DB_PORT} "$@"; };
115           export -f mysql;
116           mysql --user=root --password=${MYSQL_ROOT_PASSWORD} requestdb -e exit > /dev/null 2>&1 {{ if not .Values.global.migration.enabled }} && echo "Database already initialized!!!" && exit 0 {{ end }};
117           for f in /docker-entrypoint-initdb.d/*; do case "$f" in  *.sh) echo "$0: running $f"; . "$f" ;;  *.sql) echo "$0: running $f"; "${mysql[@]}" < "$f"; echo ;; *.sql.gz) echo "$0: running $f"; gunzip -c "$f" | "${mysql[@]}"; echo ;;  *) echo "$0: ignoring $f" ;;  esac; echo; done;
118           {{- if .Values.global.migration.enabled }}
119           mysql -vv --user=root --password=${MYSQL_ROOT_PASSWORD} < `ls -tr /var/data/mariadb/* | tail -1`;
120           {{- end }}
121         env:
122         - name: DB_HOST
123           value: {{ include "common.mariadbService" . }}
124         - name: DB_PORT
125           value: {{ include "common.mariadbPort" . | quote }}
126         - name: MYSQL_ROOT_PASSWORD
127           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-root-pass" "key" "password") | indent 10 }}
128         - name: DB_USER
129           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-user-creds" "key" "login") | indent 10 }}
130         - name: DB_PASSWORD
131           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-user-creds" "key" "password") | indent 10 }}
132         - name: DB_ADMIN
133           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-admin-creds" "key" "login") | indent 10 }}
134         - name: DB_ADMIN_PASSWORD
135           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-admin-creds" "key" "password") | indent 10 }}
136         - name: CAMUNDA_DB_USER
137           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "camunda-db-creds" "key" "login") | indent 10 }}
138         - name: CAMUNDA_DB_PASSWORD
139           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "camunda-db-creds" "key" "password") | indent 10 }}
140         - name: REQUEST_DB_USER
141           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "request-db-creds" "key" "login") | indent 10 }}
142         - name: REQUEST_DB_PASSWORD
143           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "request-db-creds" "key" "password") | indent 10 }}
144         - name: CATALOG_DB_USER
145           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "catalog-db-creds" "key" "login") | indent 10 }}
146         - name: CATALOG_DB_PASSWORD
147           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "catalog-db-creds" "key" "password") | indent 10 }}
148         - name: NFVO_DB_USER
149           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "nfvo-db-creds" "key" "login") | indent 10 }}
150         - name: NFVO_DB_PASSWORD
151           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "nfvo-db-creds" "key" "password") | indent 10 }}
152         - name: CNFM_DB_USER
153           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "cnfm-db-creds" "key" "login") | indent 10 }}
154         - name: CNFM_DB_PASSWORD
155           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "cnfm-db-creds" "key" "password") | indent 10 }}
156         volumeMounts:
157         - mountPath: /etc/localtime
158           name: localtime
159           readOnly: true
160         - name: docker-entrypoint-initdb-d-sh
161           mountPath: "/docker-entrypoint-initdb.d"
162         - name: docker-entrypoint-initdb-d-sql
163           mountPath: "/docker-entrypoint-initdb.d/db-sql-scripts"
164         {{- if .Values.global.migration.enabled }}
165         - name: backup-storage
166           mountPath: /var/data/mariadb
167         {{- end }}
168         resources: {{ include "common.resources" . | nindent 10 }}
169       {{ include "common.waitForJobContainer" . | indent 6 | trim }}
170       {{- if .Values.nodeSelector }}
171       nodeSelector:
172 {{ toYaml .Values.nodeSelector | indent 10 }}
173       {{- end -}}
174       {{- if .Values.affinity }}
175       affinity:
176 {{ toYaml .Values.affinity | indent 10 }}
177       {{- end }}
178       serviceAccountName: {{ include "common.fullname" (dict "suffix" "read" "dot" . )}}
179       volumes:
180       - name: localtime
181         hostPath:
182           path: /etc/localtime
183       - name: docker-entrypoint-initdb-d-sh
184         configMap:
185           name: {{ include "common.fullname" . }}-mariadb-sh
186       - name: docker-entrypoint-initdb-d-sql
187         configMap:
188           name: {{ include "common.fullname" . }}-mariadb-sql
189       {{- if .Values.global.migration.enabled }}
190       - name: backup-storage
191         persistentVolumeClaim:
192           claimName: {{ include "common.fullname" . }}-migration
193       {{- end }}
194       restartPolicy: Never
195       {{- include "common.imagePullSecrets" . | nindent 6 }}