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