| {{- if .Values.keystone.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: keystone |
| labels: |
| {{- include "osm.labels" . | nindent 4 }} |
| spec: |
| replicas: {{ .Values.keystone.replicaCount | default .Values.global.replicaCount }} |
| selector: |
| matchLabels: |
| app.kubernetes.io/component: keystone |
| {{- include "osm.selectorLabels" . | nindent 6 }} |
| template: |
| metadata: |
| {{- with .Values.global.podAnnotations }} |
| annotations: |
| {{- toYaml . | nindent 8 }} |
| {{- end }} |
| labels: |
| app.kubernetes.io/component: keystone |
| {{- 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 }} |
| containers: |
| - name: keystone |
| securityContext: |
| # readOnlyRootFilesystem: true |
| allowPrivilegeEscalation: false |
| runAsNonRoot: true |
| {{- toYaml .Values.global.securityContext | nindent 12 }} |
| image: {{ include "osm.keystone.image" . }} |
| imagePullPolicy: {{ .Values.global.image.pullPolicy }} |
| ports: |
| - containerPort: 5000 |
| protocol: TCP |
| resources: |
| limits: |
| memory: 1024Mi |
| requests: |
| memory: 128Mi |
| envFrom: |
| - configMapRef: |
| name: {{ include "osm.fullname" . }}-keystone-configmap |
| {{- if not .Values.keystone.useOsmSecret }} |
| - secretRef: |
| name: {{ .Values.keystone.secretName | default "keystone-secret" }} |
| {{- else }} |
| env: |
| - name: ROOT_DB_PASSWORD |
| valueFrom: |
| secretKeyRef: |
| name: {{ include "osm.fullname" . }}-secret |
| key: OSM_MYSQL_ROOT_PASSWORD |
| - name: KEYSTONE_DB_PASSWORD |
| valueFrom: |
| secretKeyRef: |
| name: {{ include "osm.fullname" . }}-secret |
| key: OSM_KEYSTONE_DB_PASSWORD |
| - name: SERVICE_PASSWORD |
| valueFrom: |
| secretKeyRef: |
| name: {{ include "osm.fullname" . }}-secret |
| key: OSM_SERVICE_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 }} |