blob: 47c13af86e3eb10a30df964e9a5e1b1a259e63be [file] [log] [blame]
Sylvain Desbureaux47eb4d22020-12-10 12:15:27 +01001{{/*
Sylvain Desbureaux70070412020-11-09 21:58:48 +01002# Copyright © 2018 Amdocs, AT&T
3# Modifications Copyright © 2018 Bell Canada
Sylvain Desbureaux1e997192021-02-28 14:59:22 +01004# Modifications Copyright © 2020-2021 Orange
Sylvain Desbureaux70070412020-11-09 21:58:48 +01005#
6# Licensed under the Apache License, Version 2.0 (the "License");
7# you may not use this file except in compliance with the License.
8# You may obtain a copy of the License at
9#
10# http://www.apache.org/licenses/LICENSE-2.0
11#
12# Unless required by applicable law or agreed to in writing, software
13# distributed under the License is distributed on an "AS IS" BASIS,
14# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15# See the License for the specific language governing permissions and
16# limitations under the License.
Sylvain Desbureaux47eb4d22020-12-10 12:15:27 +010017*/}}
Sylvain Desbureaux70070412020-11-09 21:58:48 +010018
19apiVersion: apps/v1
20kind: Deployment
21metadata:
22 name: {{ include "common.fullname" . }}
23 namespace: {{ include "common.namespace" . }}
24 labels:
25 app: {{ include "common.name" . }}
26 chart: {{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}
27 release: {{ include "common.release" . }}
28 heritage: {{ .Release.Service }}
29spec:
30 replicas: {{ .Values.replicaCount }}
31 selector:
32 matchLabels:
33 app: {{ include "common.name" . }}
34 template:
35 metadata:
36 labels:
37 app: {{ include "common.name" . }}
38 release: {{ include "common.release" . }}
39 name: {{ include "common.name" . }}
40 spec:
41 {{- if .Values.nodeSelector }}
Sylvain Desbureaux1e997192021-02-28 14:59:22 +010042 nodeSelector: {{ toYaml .Values.nodeSelector | nindent 8 }}
Sylvain Desbureaux70070412020-11-09 21:58:48 +010043 {{- end -}}
44 {{- if .Values.affinity }}
Sylvain Desbureaux1e997192021-02-28 14:59:22 +010045 affinity: {{ toYaml .Values.affinity | nindent 8 }}
46 {{- end }}
47 {{- if .Values.global.aafEnabled }}
48 initContainers: {{ include "common.certInitializer.initContainer" . | nindent 6 }}
49 - command:
50 - sh
51 args:
52 - -c
53 - |
54 echo "*** retrieve Truststore and Keystore password"
55 export $(cat {{ .Values.certInitializer.appMountPath }}/local/mycreds.prop | xargs -0)
56 echo "*** obfuscate them "
57 export KEYSTORE_PLAIN_PASSWORD=${KEYSTORE_PLAIN_PASSWORD}
58 export TRUSTSTORE_PLAIN_PASSWORD=${TRUSTSTORE_PLAIN_PASSWORD}
Radoslaw Chmiel88534f12022-02-28 21:33:01 +010059 export JETTY_UTIL_JAR=$(find /usr/local/jetty/lib/ -regextype sed -regex ".*jetty-util-[0-9].*.jar")
60 export KEYSTORE_PASSWORD=`java -cp ${JETTY_UTIL_JAR} org.eclipse.jetty.util.security.Password ${KEYSTORE_PLAIN_PASSWORD} 2>&1 | grep "OBF:"`
61 export TRUSTSTORE_PASSWORD=`java -cp ${JETTY_UTIL_JAR} org.eclipse.jetty.util.security.Password ${TRUSTSTORE_PLAIN_PASSWORD} 2>&1 | grep "OBF:"`
Sylvain Desbureaux1e997192021-02-28 14:59:22 +010062 echo "KEYSTORE_PASSWORD=${KEYSTORE_PASSWORD}" >> {{ .Values.certInitializer.appMountPath }}/local/mycreds.prop
63 echo "TRUSTSTORE_PASSWORD=${TRUSTSTORE_PASSWORD}" >> {{ .Values.certInitializer.appMountPath }}/local/mycreds.prop
64 image: {{ include "repositoryGenerator.image.jetty" . }}
65 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
66 name: {{ include "common.name" . }}-obfuscate
67 volumeMounts: {{ include "common.certInitializer.volumeMount" . | nindent 8 }}
68 securityContext:
69 runAsUser: {{ .Values.securityContext.user_id }}
70 - command:
71 - sh
72 args:
73 - -c
74 - |
75 echo "*** Set obfuscated Truststore and Keystore password into configuration file"
76 export $(cat {{ .Values.certInitializer.appMountPath }}/local/mycreds.prop | xargs -0)
77 cd /config-input
78 for PFILE in `ls -1`
79 do
80 envsubst <${PFILE} >/config/${PFILE}
81 done
82 volumeMounts: {{ include "common.certInitializer.volumeMount" . | nindent 8 }}
83 - mountPath: /config-input
84 name: prop-config-input
85 - mountPath: /config
86 name: prop-config
87 image: {{ include "repositoryGenerator.image.envsubst" . }}
88 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
89 name: {{ include "common.name" . }}-update-config
Sylvain Desbureaux70070412020-11-09 21:58:48 +010090 {{- end }}
91 containers:
92 - name: {{ include "common.name" . }}
Sylvain Desbureaux5b651322020-12-07 15:34:15 +010093 image: {{ include "repositoryGenerator.repository" . }}/{{ .Values.image }}
Sylvain Desbureaux70070412020-11-09 21:58:48 +010094 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
95 env:
96 - name: CONFIG_HOME
97 value: /opt/app/model-loader/config/
Sylvain Desbureaux1e997192021-02-28 14:59:22 +010098 volumeMounts: {{ include "common.certInitializer.volumeMount" . | nindent 8 }}
Sylvain Desbureaux70070412020-11-09 21:58:48 +010099 - mountPath: /etc/localtime
100 name: localtime
101 readOnly: true
102 - mountPath: /opt/app/model-loader/config/model-loader.properties
103 subPath: model-loader.properties
Sylvain Desbureaux1e997192021-02-28 14:59:22 +0100104 name: prop-config
Sylvain Desbureaux70070412020-11-09 21:58:48 +0100105 - mountPath: /opt/app/model-loader/config/auth/
Sylvain Desbureaux1e997192021-02-28 14:59:22 +0100106 name: auth-config
Maciej Wereskid523d122021-09-21 11:22:13 +0200107 - mountPath: {{ .Values.log.path }}
108 name: logs
Sylvain Desbureaux70070412020-11-09 21:58:48 +0100109 - mountPath: /opt/app/model-loader/logback.xml
Sylvain Desbureaux1e997192021-02-28 14:59:22 +0100110 name: log-config
Sylvain Desbureaux70070412020-11-09 21:58:48 +0100111 subPath: logback.xml
Sylvain Desbureaux1e997192021-02-28 14:59:22 +0100112 resources: {{ include "common.resources" . | nindent 10 }}
Sylvain Desbureaux70070412020-11-09 21:58:48 +0100113 # side car containers
Maciej Wereskid523d122021-09-21 11:22:13 +0200114 {{ include "common.log.sidecar" . | nindent 6 }}
farida azmyd8937332021-03-09 12:20:42 +0200115 serviceAccountName: {{ include "common.fullname" (dict "suffix" "read" "dot" . )}}
Sylvain Desbureaux1e997192021-02-28 14:59:22 +0100116 volumes: {{ include "common.certInitializer.volumes" . | nindent 6 }}
Sylvain Desbureaux70070412020-11-09 21:58:48 +0100117 - name: localtime
118 hostPath:
119 path: /etc/localtime
Sylvain Desbureaux1e997192021-02-28 14:59:22 +0100120 - name: prop-config
othman touijer51176672021-12-01 16:21:18 +0100121 {{- if .Values.global.aafEnabled }}
Sylvain Desbureaux1e997192021-02-28 14:59:22 +0100122 emptyDir:
123 medium: Memory
othman touijer51176672021-12-01 16:21:18 +0100124 - name: prop-config-input
125 {{- end }}
126 configMap:
127 name: {{ include "common.fullname" . }}-prop
Sylvain Desbureaux1e997192021-02-28 14:59:22 +0100128 - name: auth-config
Sylvain Desbureaux70070412020-11-09 21:58:48 +0100129 secret:
130 secretName: {{ include "common.fullname" . }}
Maciej Wereskid523d122021-09-21 11:22:13 +0200131 - name: logs
Sylvain Desbureaux70070412020-11-09 21:58:48 +0100132 emptyDir: {}
Maciej Wereskid523d122021-09-21 11:22:13 +0200133 {{ include "common.log.volumes" (dict "dot" . "configMapNamePrefix" (tpl .Values.logConfigMapNamePrefix .)) | nindent 6 }}
Sylvain Desbureaux1e997192021-02-28 14:59:22 +0100134 - name: log-config
Sylvain Desbureaux70070412020-11-09 21:58:48 +0100135 configMap:
Sylvain Desbureaux5b651322020-12-07 15:34:15 +0100136 name: {{ include "common.fullname" . }}-log
Sylvain Desbureaux70070412020-11-09 21:58:48 +0100137 restartPolicy: {{ .Values.global.restartPolicy | default .Values.restartPolicy }}
138 imagePullSecrets:
139 - name: "{{ include "common.namespace" . }}-docker-registry-key"