| {{- if .Values.ro.enabled -}} |
| ####################################################################################### |
| # Copyright ETSI Contributors and Others. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or |
| # implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| ####################################################################################### |
| apiVersion: apps/v1 |
| kind: Deployment |
| metadata: |
| name: ro |
| labels: |
| {{- include "osm.labels" . | nindent 4 }} |
| spec: |
| replicas: {{ .Values.ro.replicaCount | default .Values.global.replicaCount }} |
| selector: |
| matchLabels: |
| app.kubernetes.io/component: ro |
| {{- include "osm.selectorLabels" . | nindent 6 }} |
| template: |
| metadata: |
| {{- with .Values.global.podAnnotations }} |
| annotations: |
| {{- toYaml . | nindent 8 }} |
| {{- end }} |
| labels: |
| app.kubernetes.io/component: ro |
| {{- include "osm.selectorLabels" . | nindent 8 }} |
| spec: |
| {{- with .Values.global.imagePullSecrets }} |
| imagePullSecrets: |
| {{- toYaml . | nindent 8 }} |
| {{- end }} |
| serviceAccountName: {{ include "osm.serviceAccountName" . }} |
| securityContext: |
| {{- toYaml .Values.global.podSecurityContext | nindent 8 }} |
| initContainers: |
| - name: kafka-mongo-test |
| image: alpine:latest |
| command: ["sh", "-c", "until (nc -zvw1 kafka 9092 && nc -zvw1 mongodb-k8s 27017); do sleep 3; done; exit 0"] |
| containers: |
| - name: ro |
| securityContext: |
| # readOnlyRootFilesystem: true |
| allowPrivilegeEscalation: false |
| runAsNonRoot: true |
| {{- toYaml .Values.global.securityContext | nindent 12 }} |
| image: {{ include "osm.ro.image" . }} |
| imagePullPolicy: {{ .Values.global.image.pullPolicy }} |
| ports: |
| - containerPort: 9090 |
| protocol: TCP |
| resources: |
| limits: |
| memory: 1024Mi |
| requests: |
| memory: 128Mi |
| envFrom: |
| - configMapRef: |
| name: {{ include "osm.fullname" . }}-ro-configmap |
| {{- if not .Values.ro.useOsmSecret }} |
| - secretRef: |
| name: {{ .Values.ro.secretName | default "ro-secret" }} |
| {{- else }} |
| env: |
| - name: OSMRO_DATABASE_COMMONKEY |
| valueFrom: |
| secretKeyRef: |
| name: {{ include "osm.fullname" . }}-secret |
| key: OSM_DATABASE_COMMONKEY |
| - name: RO_DB_ROOT_PASSWORD |
| valueFrom: |
| secretKeyRef: |
| name: mysql |
| key: mysql-root-password |
| {{- end }} |
| {{- with .Values.global.nodeSelector }} |
| nodeSelector: |
| {{- toYaml . | nindent 8 }} |
| {{- end }} |
| {{- with .Values.global.affinity }} |
| affinity: |
| {{- toYaml . | nindent 8 }} |
| {{- end }} |
| {{- with .Values.global.tolerations }} |
| tolerations: |
| {{- toYaml . | nindent 8 }} |
| {{- end }} |
| {{- end }} |