Files
engine/lib/common/bootstrap/charts/pleco/templates/deployment.yaml
2022-03-17 12:07:50 +01:00

180 lines
6.3 KiB
YAML

{{- $kubefullname := include "kubernetes.fullname" . }}
apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ include "kubernetes.fullname" . }}
labels:
{{- include "kubernetes.labels" . | nindent 4 }}
spec:
replicas: {{ .Values.replicaCount }}
selector:
matchLabels:
{{- include "kubernetes.selectorLabels" . | nindent 6 }}
template:
metadata:
annotations:
checksum/config: {{ include (print $.Template.BasePath "/secret.yaml") . | sha256sum }}
{{- with .Values.podAnnotations }}
{{- toYaml . | nindent 8 }}
{{- end }}
labels:
{{- include "kubernetes.selectorLabels" . | nindent 8 }}
spec:
{{- with .Values.imagePullSecrets }}
imagePullSecrets:
{{- toYaml . | nindent 8 }}
{{- end }}
serviceAccountName: {{ include "kubernetes.serviceAccountName" . }}
securityContext:
{{- toYaml .Values.podSecurityContext | nindent 8 }}
containers:
- name: {{ .Chart.Name }}
securityContext:
{{- toYaml .Values.securityContext | nindent 12 }}
image: "{{ .Values.image.repository }}:{{ .Values.image.plecoImageTag | default .Chart.AppVersion }}"
imagePullPolicy: {{ .Values.image.pullPolicy }}
command: [ "pleco", "start", {{ .Values.cloudProvider | quote }} ]
args:
- --level
- {{ .Values.environmentVariables.LOG_LEVEL | default "info" }}
{{ if eq .Values.enabledFeatures.disableDryRun true }}
- --check-interval
- "{{ .Values.enabledFeatures.checkInterval | default 120 }}"
{{ end }}
{{ if eq .Values.enabledFeatures.disableDryRun true }}
- --disable-dry-run
{{ end }}
{{ if .Values.enabledFeatures.kubernetes }}
- --kube-conn
- {{ .Values.enabledFeatures.kubernetes }}
{{ end }}
{{ if eq .Values.enabledFeatures.s3 true }}
- --enable-s3
{{ end }}
# AWS features
{{ if eq .Values.cloudProvider "aws" }}
{{ if .Values.awsFeatures.awsRegions }}
- --aws-regions
- "{{ join "," .Values.awsFeatures.awsRegions }}"
{{ end }}
{{ if eq .Values.awsFeatures.rds true}}
- --enable-rds
{{ end }}
{{ if eq .Values.awsFeatures.elasticache true}}
- --enable-elasticache
{{ end }}
{{ if eq .Values.awsFeatures.documentdb true}}
- --enable-documentdb
{{ end }}
{{ if eq .Values.awsFeatures.eks true}}
- --enable-eks
{{ end }}
{{ if eq .Values.awsFeatures.vpc true}}
- --enable-vpc
{{ end }}
{{ if or (eq .Values.awsFeatures.elb true) (eq .Values.awsFeatures.eks true)}}
- --enable-elb
{{ end }}
{{ if or (eq .Values.awsFeatures.ebs true) (eq .Values.awsFeatures.eks true)}}
- --enable-ebs
{{ end }}
{{ if or (eq .Values.awsFeatures.kms true)}}
- --enable-kms
{{ end }}
{{ if or (eq .Values.awsFeatures.cloudwatchLogs true)}}
- --enable-cloudwatch-logs
{{ end }}
{{ if or (eq .Values.awsFeatures.iam true)}}
- --enable-iam
{{ end }}
{{ if or (eq .Values.awsFeatures.sshKeys true)}}
- --enable-ssh-keys
{{ end }}
{{ if or (eq .Values.awsFeatures.ecr true)}}
- --enable-ecr
{{ end }}
{{ if or (eq .Values.awsFeatures.sfn true)}}
- --enable-sfn
{{ end }}
{{ if or (eq .Values.awsFeatures.sqs true)}}
- --enable-sqs
{{ end }}
{{ if or (eq .Values.awsFeatures.lambda true)}}
- --enable-lambda
{{ end }}
{{- end }}
# Scaleway features
{{ if eq .Values.cloudProvider "scaleway" }}
{{ if .Values.scwFeatures.scwZones }}
- --scw-zones
- "{{ join "," .Values.scwFeatures.scwZones }}"
{{ end }}
{{ if eq .Values.scwFeatures.cr true}}
- --enable-cr
{{ end }}
{{ if eq .Values.scwFeatures.cluster true }}
- --enable-cluster
{{ end }}
{{ if eq .Values.scwFeatures.lb true }}
- --enable-lb
{{ end }}
{{ if eq .Values.scwFeatures.db true }}
- --enable-db
{{ end }}
{{ if eq .Values.scwFeatures.volume true }}
- --enable-volume
{{ end }}
{{ if eq .Values.scwFeatures.sg true }}
- --enable-sg
{{ end }}
{{- end }}
# Digital Ocean features
{{ if eq .Values.cloudProvider "do" }}
{{ if .Values.doFeatures.doRegions }}
- --do-regions
- "{{ join "," .Values.doFeatures.doRegions }}"
{{ end }}
{{ if eq .Values.doFeatures.cluster true }}
- --enable-cluster
{{ end }}
{{ if eq .Values.doFeatures.lb true }}
- --enable-lb
{{ end }}
{{ if eq .Values.doFeatures.db true }}
- --enable-db
{{ end }}
{{ if eq .Values.doFeatures.volume true }}
- --enable-volume
{{ end }}
{{ if eq .Values.doFeatures.firewall true }}
- --enable-firewall
{{ end }}
{{ if eq .Values.doFeatures.vpc true }}
- --enable-vpc
{{ end }}
{{- end }}
env:
{{ range $key, $value := .Values.environmentVariables -}}
- name: "{{ $key }}"
valueFrom:
secretKeyRef:
name: {{ $kubefullname }}
key: {{ $key }}
{{ end }}
resources:
{{- toYaml .Values.resources | nindent 12 }}
{{- with .Values.nodeSelector }}
nodeSelector:
{{- toYaml . | nindent 8 }}
{{- end }}
{{- with .Values.affinity }}
affinity:
{{- toYaml . | nindent 8 }}
{{- end }}
{{- with .Values.tolerations }}
tolerations:
{{- toYaml . | nindent 8 }}
{{- end }}