blob: b732fad508c35110b8bd45b6d2810d8b016d348f [file] [log] [blame]
saul.gill7124a4b2021-09-09 12:02:49 +01001{{/*
2# ============LICENSE_START=======================================================
efiacor6910bbe2023-03-03 14:53:16 +00003# Copyright (C) 2021-2023 Nordix Foundation.
saul.gill7124a4b2021-09-09 12:02:49 +01004# ================================================================================
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# SPDX-License-Identifier: Apache-2.0
18# ============LICENSE_END=========================================================
19*/}}
20
21apiVersion: apps/v1
22kind: Deployment
23metadata: {{- include "common.resourceMetadata" . | nindent 2 }}
24spec:
25 selector: {{- include "common.selectors" . | nindent 4 }}
26 replicas: {{ .Values.replicaCount }}
27 template:
28 metadata: {{- include "common.templateMetadata" . | nindent 6 }}
29 spec:
30 initContainers:
31 - command:
32 - /app/ready.py
33 args:
34 - --job-name
35 - {{ include "common.release" . }}-policy-galera-config
36 env:
37 - name: NAMESPACE
38 valueFrom:
39 fieldRef:
40 apiVersion: v1
41 fieldPath: metadata.namespace
42 image: {{ include "repositoryGenerator.image.readiness" . }}
43 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
efiacor6910bbe2023-03-03 14:53:16 +000044 name: {{ include "common.name" . }}-galera-config-readiness
Andreas Geissler47537432024-02-27 08:55:23 +010045 resources:
46 limits:
47 cpu: "100m"
Andreas Geissler8cbb3d92024-03-12 16:44:56 +010048 memory: "500Mi"
Andreas Geissler47537432024-02-27 08:55:23 +010049 requests:
50 cpu: "3m"
Andreas Geissler8cbb3d92024-03-12 16:44:56 +010051 memory: "20Mi"
saul.gill7124a4b2021-09-09 12:02:49 +010052 - command:
53 - sh
54 args:
55 - -c
56 - "cd /config-input && for PFILE in `ls -1`; do envsubst <${PFILE} >/config/${PFILE}; done"
57 env:
58 - name: SQL_USER
59 {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-secret" "key" "login") | indent 10 }}
60 - name: SQL_PASSWORD
61 {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "db-secret" "key" "password") | indent 10 }}
62 - name: RUNTIME_USER
63 {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "runtime-secret" "key" "login") | indent 10 }}
64 - name: RUNTIME_PASSWORD
65 {{- include "common.secret.envFromSecretFast" (dict "global" . "uid" "runtime-secret" "key" "password") | indent 10 }}
efiacor6910bbe2023-03-03 14:53:16 +000066 - name: SASL_JAAS_CONFIG
67 valueFrom:
68 secretKeyRef:
69 name: {{ include "common.name" . }}-ku
70 key: sasl.jaas.config
saul.gill7124a4b2021-09-09 12:02:49 +010071 volumeMounts:
72 - mountPath: /config-input
FrancescoFioraEst9c79e262022-02-22 13:12:19 +000073 name: ac-runtime-config
saul.gill7124a4b2021-09-09 12:02:49 +010074 - mountPath: /config
FrancescoFioraEst9c79e262022-02-22 13:12:19 +000075 name: ac-runtime-config-processed
saul.gill7124a4b2021-09-09 12:02:49 +010076 image: {{ include "repositoryGenerator.image.envsubst" . }}
77 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
78 name: {{ include "common.name" . }}-update-config
saul.gill7124a4b2021-09-09 12:02:49 +010079 containers:
80 - name: {{ include "common.name" . }}
81 image: {{ include "repositoryGenerator.repository" . }}/{{ .Values.image }}
82 imagePullPolicy: {{ .Values.global.pullPolicy | default .Values.pullPolicy }}
FrancescoFioraEst9c79e262022-02-22 13:12:19 +000083 command: ["/opt/app/policy/clamp/bin/acm-runtime.sh"]
84 args: ["/opt/app/policy/clamp/etc/mounted/acRuntimeParameters.yaml"]
saul.gill7124a4b2021-09-09 12:02:49 +010085 ports: {{ include "common.containerPorts" . | nindent 12 }}
86 # disable liveness probe when breakpoints set in debugger
87 # so K8s doesn't restart unresponsive container
88 {{- if eq .Values.liveness.enabled true }}
89 livenessProbe:
90 tcpSocket:
91 port: {{ .Values.liveness.port }}
92 initialDelaySeconds: {{ .Values.liveness.initialDelaySeconds }}
93 periodSeconds: {{ .Values.liveness.periodSeconds }}
94 {{ end -}}
95 readinessProbe:
96 tcpSocket:
97 port: {{ .Values.readiness.port }}
98 initialDelaySeconds: {{ .Values.readiness.initialDelaySeconds }}
99 periodSeconds: {{ .Values.readiness.periodSeconds }}
100 volumeMounts:
saul.gill7124a4b2021-09-09 12:02:49 +0100101 - mountPath: /etc/localtime
102 name: localtime
103 readOnly: true
104 - mountPath: /opt/app/policy/clamp/etc/mounted
FrancescoFioraEst9c79e262022-02-22 13:12:19 +0000105 name: ac-runtime-config-processed
miroslavmasaryka7ac7f02023-03-01 14:12:26 +0100106 resources: {{ include "common.resources" . | nindent 12 }}
saul.gill7124a4b2021-09-09 12:02:49 +0100107 {{- if .Values.nodeSelector }}
108 nodeSelector:
109{{ toYaml .Values.nodeSelector | indent 10 }}
110 {{- end -}}
111 {{- if .Values.affinity }}
112 affinity:
113{{ toYaml .Values.affinity | indent 10 }}
114 {{- end }}
115 serviceAccountName: {{ include "common.fullname" (dict "suffix" "read" "dot" . )}}
116 volumes:
saul.gill7124a4b2021-09-09 12:02:49 +0100117 - name: localtime
118 hostPath:
119 path: /etc/localtime
FrancescoFioraEst9c79e262022-02-22 13:12:19 +0000120 - name: ac-runtime-config
saul.gill7124a4b2021-09-09 12:02:49 +0100121 configMap:
122 name: {{ include "common.fullname" . }}-configmap
123 defaultMode: 0755
FrancescoFioraEst9c79e262022-02-22 13:12:19 +0000124 - name: ac-runtime-config-processed
saul.gill7124a4b2021-09-09 12:02:49 +0100125 emptyDir:
126 medium: Memory
Andreas Geisslerbd0d31a2024-03-20 09:51:32 +0100127 {{- include "common.imagePullSecrets" . | nindent 6 }}