{{- if .Values.controller.enabled -}} {{- if (semverCompare ">=1.9-0" (substr 1 -1 .Capabilities.KubeVersion.GitVersion)) }} apiVersion: apps/v1 {{- else }} apiVersion: extensions/v1beta1 {{- end }} kind: Deployment metadata: name: neuvector-controller-pod namespace: {{ .Release.Namespace }} labels: chart: {{ template "neuvector.chart" . }} release: {{ .Release.Name }} heritage: {{ .Release.Service }} {{- with .Values.controller.annotations }} annotations: {{ toYaml . | indent 4 }} {{- end }} spec: replicas: {{ .Values.controller.replicas }} minReadySeconds: 60 strategy: {{ toYaml .Values.controller.strategy | indent 4 }} selector: matchLabels: app: neuvector-controller-pod template: metadata: labels: app: neuvector-controller-pod release: {{ .Release.Name }} spec: {{- if .Values.controller.affinity }} affinity: {{ toYaml .Values.controller.affinity | indent 8 }} {{- end }} {{- if .Values.controller.tolerations }} tolerations: {{ toYaml .Values.controller.tolerations | indent 8 }} {{- end }} {{- if .Values.controller.nodeSelector }} nodeSelector: {{ toYaml .Values.controller.nodeSelector | indent 8 }} {{- end }} {{- if .Values.controller.schedulerName }} schedulerName: {{ .Values.controller.schedulerName }} {{- end }} {{- if .Values.imagePullSecrets }} imagePullSecrets: - name: {{ .Values.imagePullSecrets }} {{- end }} {{- if .Values.controller.priorityClassName }} priorityClassName: {{ .Values.controller.priorityClassName }} {{- end }} serviceAccountName: {{ .Values.serviceAccount }} serviceAccount: {{ .Values.serviceAccount }} containers: - name: neuvector-controller-pod image: {{ template "system_default_registry" . }}{{ .Values.controller.image.repository }}:{{ .Values.controller.image.tag }} securityContext: privileged: true resources: {{- if .Values.controller.resources }} {{ toYaml .Values.controller.resources | indent 12 }} {{- else }} {{ toYaml .Values.resources | indent 12 }} {{- end }} readinessProbe: exec: command: - cat - /tmp/ready initialDelaySeconds: 5 periodSeconds: 5 env: - name: CLUSTER_JOIN_ADDR value: neuvector-svc-controller.{{ .Release.Namespace }} - name: CLUSTER_ADVERTISED_ADDR valueFrom: fieldRef: fieldPath: status.podIP - name: CLUSTER_BIND_ADDR valueFrom: fieldRef: fieldPath: status.podIP {{- if .Values.controller.ranchersso.enabled }} - name: RANCHER_SSO value: "1" - name: RANCHER_EP value: "{{ .Values.global.cattle.url }}" {{- end }} {{- if or .Values.controller.pvc.enabled .Values.controller.azureFileShare.enabled }} - name: CTRL_PERSIST_CONFIG value: "1" {{- end }} {{- with .Values.controller.env }} {{- toYaml . | nindent 12 }} {{- end }} volumeMounts: - mountPath: /var/neuvector name: nv-share readOnly: false {{- if .Values.containerd.enabled }} - mountPath: /var/run/containerd/containerd.sock {{- else if .Values.k3s.enabled }} - mountPath: /var/run/containerd/containerd.sock {{- else if .Values.bottlerocket.enabled }} - mountPath: /var/run/containerd/containerd.sock {{- else if .Values.crio.enabled }} - mountPath: /var/run/crio/crio.sock {{- else }} - mountPath: /var/run/docker.sock {{- end }} name: runtime-sock readOnly: true - mountPath: /host/proc name: proc-vol readOnly: true - mountPath: /host/cgroup name: cgroup-vol readOnly: true - mountPath: /etc/config name: config-volume readOnly: true {{- if .Values.controller.certificate.secret }} - mountPath: /etc/neuvector/certs/ssl-cert.key subPath: {{ .Values.controller.certificate.keyFile }} name: cert readOnly: true - mountPath: /etc/neuvector/certs/ssl-cert.pem subPath: {{ .Values.controller.certificate.pemFile }} name: cert readOnly: true {{- end }} terminationGracePeriodSeconds: 300 restartPolicy: Always volumes: - name: nv-share {{- if .Values.controller.pvc.enabled }} persistentVolumeClaim: claimName: neuvector-data {{- else if .Values.controller.azureFileShare.enabled }} azureFile: secretName: {{ .Values.controller.azureFileShare.secretName }} shareName: {{ .Values.controller.azureFileShare.shareName }} readOnly: false {{- else }} hostPath: path: /var/neuvector {{- end }} - name: runtime-sock hostPath: {{- if .Values.containerd.enabled }} path: {{ .Values.containerd.path }} {{- else if .Values.crio.enabled }} path: {{ .Values.crio.path }} {{- else if .Values.k3s.enabled }} path: {{ .Values.k3s.runtimePath }} {{- else if .Values.bottlerocket.enabled }} path: {{ .Values.bottlerocket.runtimePath }} {{- else }} path: {{ .Values.docker.path }} {{- end }} - name: proc-vol hostPath: path: /proc - name: cgroup-vol hostPath: path: /sys/fs/cgroup - name: config-volume projected: sources: - configMap: name: neuvector-init optional: true - secret: name: neuvector-init optional: true {{- if .Values.controller.certificate.secret }} - name: cert secret: secretName: {{ .Values.controller.certificate.secret }} {{- end }} {{- if gt (int .Values.controller.disruptionbudget) 0 }} --- apiVersion: policy/v1beta1 kind: PodDisruptionBudget metadata: name: neuvector-controller-pdb namespace: neuvector spec: minAvailable: {{ .Values.controller.disruptionbudget }} selector: matchLabels: app: neuvector-controller-pod {{- end }} {{- end }}