blob: 4b8e2e5fdd231c99ad170b288b8d381e9384e178 [file] [log] [blame]
krishnaa96544863d2021-05-11 18:29:49 +05301{{/*
2# Copyright (C) 2021 Wipro Limited.
3#
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15*/}}
16apiVersion: batch/v1
17kind: Job
18metadata:
19 name: {{ include "common.fullname" . }}-job
20 namespace: {{ include "common.namespace" . }}
21 labels:
22 app: {{ include "common.name" . }}
23 chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
24 release: {{ include "common.release" . }}
25 heritage: {{ .Release.Service }}
26spec:
27 backoffLimit: {{ .Values.backoffLimit }}
28 template:
29 metadata:
30 labels:
31 app: {{ include "common.name" . }}
32 release: {{ include "common.release" . }}
33 name: {{ include "common.name" . }}
34 spec:
35 initContainers:
36 - name: {{ include "common.name" . }}-readiness
37 command:
38 - /app/ready.py
39 args:
40 - --container-name
41 - {{ .Values.etcd.containerName }}
42 env:
43 - name: NAMESPACE
44 valueFrom:
45 fieldRef:
46 apiVersion: v1
47 fieldPath: metadata.namespace
48 image: {{ include "repositoryGenerator.image.readiness" . }}
49 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
50 containers:
51 - name: {{ include "common.name" . }}
52 image: {{ include "repositoryGenerator.dockerHubRepository" . }}/{{ .Values.image }}
53 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
54 command:
55 - /bin/sh
56 - -ec
57 - |
Andreas Geissler02398152022-05-10 10:30:11 +020058 {{- if include "common.onServiceMesh" . }}
59 echo "waiting 15s for istio side cars to be up"; sleep 15s;{{- end }}
krishnaa96544863d2021-05-11 18:29:49 +053060 # Create users
61 export ETCDCTL_ENDPOINTS=http://${ETCD_HOST}:${ETCD_PORT}
62 export ETCDCTL_API=3
63 echo "${ROOT_PASSWORD}" | etcdctl user add root --interactive=false
64 echo "${APP_PASSWORD}" | etcdctl user add ${APP_USER} --interactive=false
65
66 # Create roles
67 etcdctl role add ${APP_ROLE}
68 etcdctl role grant-permission ${APP_ROLE} --prefix=true readwrite ${KEY_PREFIX}
69
70 etcdctl user grant-role ${APP_USER} ${APP_ROLE}
71 etcdctl auth enable
72 env:
73 - name: ALLOW_NONE_AUTHENTICATION
74 value: "yes"
75 - name: ETCD_HOST
76 value: "{{ .Values.etcd.serviceName }}.{{ include "common.namespace" . }}"
77 - name: ETCD_PORT
78 value: "{{ .Values.etcd.port }}"
79 - name: ROOT_PASSWORD
80 {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "root-password" "key" "password" ) | indent 10 }}
81 - name: APP_USER
82 {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "app-creds" "key" "login") | indent 10 }}
83 - name: APP_PASSWORD
84 {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "app-creds" "key" "password") | indent 10 }}
85 - name: APP_ROLE
86 value: "{{ .Values.config.appRole }}"
87 - name: KEY_PREFIX
88 value: "{{ .Values.config.keyPrefix }}"
89 volumeMounts:
90 - mountPath: /etc/localtime
91 name: localtime
92 readOnly: true
miroslavmasaryka7ac7f02023-03-01 14:12:26 +010093 resources: {{ include "common.resources" . | nindent 10 }}
Andreas Geissler02398152022-05-10 10:30:11 +020094 {{ include "common.waitForJobContainer" . | indent 6 | trim }}
krishnaa96544863d2021-05-11 18:29:49 +053095 {{- if .Values.nodeSelector }}
96 nodeSelector: {{ toYaml .Values.nodeSelector | nindent 10 }}
97 {{- end -}}
98 {{- if .Values.affinity }}
99 affinity: {{ toYaml .Values.affinity | nindent 10 }}
100 {{- end }}
101 volumes:
102 - name: localtime
103 hostPath:
104 path: /etc/localtime
105 restartPolicy: Never
106 imagePullSecrets:
107 - name: "{{ include "common.namespace" . }}-docker-registry-key"