Merge "[UUI] Service Mesh Compliance for UUI"
[oom.git] / kubernetes / sdnc / components / sdnc-ansible-server / templates / deployment.yaml
1 {{/*
2 # Copyright © 2017 Amdocs, Bell Canada
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 */}}
16
17 apiVersion: apps/v1
18 kind: Deployment
19 metadata: {{- include "common.resourceMetadata" . | nindent 2 }}
20 spec:
21   selector:
22     matchLabels:
23       app: {{ include "common.name" . }}
24   replicas: {{ .Values.replicaCount }}
25   selector: {{- include "common.selectors" . | nindent 4 }}
26   template:
27     metadata: {{- include "common.templateMetadata" . | nindent 6 }}
28     spec:
29       initContainers:
30       - command:
31         - sh
32         args:
33         - -c
34         - "cd /config-input && for PFILE in `ls -1 .`; do envsubst <${PFILE} >/config/${PFILE}; done"
35         env:
36         - name: DB_USER
37           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-secret" "key" "login") | indent 10 }}
38         - name: DB_PASSWORD
39           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-secret" "key" "password") | indent 10 }}
40         - name: REST_USER
41           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "rest-creds" "key" "login") | indent 10 }}
42         - name: REST_PASSWORD
43           {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "rest-creds" "key" "password") | indent 10 }}
44         volumeMounts:
45         - mountPath: /config-input
46           name: config-input
47         - mountPath: /config
48           name: config
49         image: {{ include "repositoryGenerator.image.envsubst" . }}
50         imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
51         name: {{ include "common.name" . }}-update-config
52
53       - command:
54         - /app/ready.py
55         args:
56         - --container-name
57         - {{ .Values.config.sdncChartName }}
58         env:
59         - name: NAMESPACE
60           valueFrom:
61             fieldRef:
62               apiVersion: v1
63               fieldPath: metadata.namespace
64         image: {{ include "repositoryGenerator.image.readiness" . }}
65         imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
66         name: {{ include "common.name" . }}-readiness
67       containers:
68         - name: {{ include "common.name" . }}
69           command: ["/bin/bash"]
70           args: ["-c", "cd /opt/ansible-server && ./startAnsibleServer.sh"]
71
72           image: {{ include "repositoryGenerator.repository" . }}/{{ .Values.image }}
73           imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
74           ports:
75           - containerPort: {{ .Values.service.internalPort }}
76           # disable liveness probe when breakpoints set in debugger
77           # so K8s doesn't restart unresponsive container
78           {{ if .Values.liveness.enabled }}
79           livenessProbe:
80             tcpSocket:
81               port: {{ .Values.service.internalPort }}
82             initialDelaySeconds: {{ .Values.liveness.initialDelaySeconds }}
83             periodSeconds: {{ .Values.liveness.periodSeconds }}
84           {{ end }}
85           readinessProbe:
86             tcpSocket:
87               port: {{ .Values.service.internalPort }}
88             initialDelaySeconds: {{ .Values.readiness.initialDelaySeconds }}
89             periodSeconds: {{ .Values.readiness.periodSeconds }}
90           volumeMounts:
91           - mountPath: /etc/localtime
92             name: localtime
93             readOnly: true
94           - mountPath: {{ .Values.config.configDir }}/RestServer_config
95             name: config
96             subPath: RestServer_config
97           resources: {{ include "common.resources" . | nindent 12 }}
98       {{- if .Values.nodeSelector }}
99       nodeSelector: {{ toYaml .Values.nodeSelector | nindent 8 }}
100       {{- end }}
101       {{- if .Values.affinity }}
102       affinity: {{ toYaml .Values.affinity | nindent 8 }}
103       {{- end }}
104       serviceAccountName: {{ include "common.fullname" (dict "suffix" "read" "dot" . )}}
105       volumes:
106         - name: localtime
107           hostPath:
108             path: /etc/localtime
109         - name: config-input
110           configMap:
111             name: {{ include "common.fullname" . }}
112             defaultMode: 0644
113         - name: config
114           emptyDir:
115             medium: Memory
116       imagePullSecrets:
117       - name: "{{ include "common.namespace" . }}-docker-registry-key"