59 lines
2.2 KiB
Smarty
59 lines
2.2 KiB
Smarty
|
{{/* Secret Class */}}
|
||
|
{{/* Call this template:
|
||
|
{{ include "tc.v1.common.class.secret" (dict "rootCtx" $ "objectData" $objectData) }}
|
||
|
|
||
|
rootCtx: The root context of the chart.
|
||
|
objectData:
|
||
|
name: The name of the secret.
|
||
|
labels: The labels of the secret.
|
||
|
annotations: The annotations of the secret.
|
||
|
type: The type of the secret.
|
||
|
data: The data of the secret.
|
||
|
namespace: The namespace of the secret. (Optional)
|
||
|
*/}}
|
||
|
|
||
|
{{- define "tc.v1.common.class.secret" -}}
|
||
|
|
||
|
{{- $rootCtx := .rootCtx -}}
|
||
|
{{- $objectData := .objectData -}}
|
||
|
{{- $secretType := "Opaque" -}}
|
||
|
|
||
|
{{- if eq $objectData.type "certificate" -}}
|
||
|
{{- $secretType = "kubernetes.io/tls" -}}
|
||
|
{{- else if eq $objectData.type "imagePullSecret" -}}
|
||
|
{{- $secretType = "kubernetes.io/dockerconfigjson" -}}
|
||
|
{{- else if $objectData.type -}}
|
||
|
{{- $secretType = $objectData.type -}}
|
||
|
{{- end }}
|
||
|
---
|
||
|
apiVersion: v1
|
||
|
kind: Secret
|
||
|
type: {{ $secretType }}
|
||
|
metadata:
|
||
|
name: {{ $objectData.name }}
|
||
|
namespace: {{ include "tc.v1.common.lib.metadata.namespace" (dict "rootCtx" $rootCtx "objectData" $objectData "caller" "Secret") }}
|
||
|
{{- $labels := (mustMerge ($objectData.labels | default dict) (include "tc.v1.common.lib.metadata.allLabels" $rootCtx | fromYaml)) -}}
|
||
|
{{- with (include "tc.v1.common.lib.metadata.render" (dict "rootCtx" $rootCtx "labels" $labels) | trim) }}
|
||
|
labels:
|
||
|
{{- . | nindent 4 }}
|
||
|
{{- end -}}
|
||
|
{{- $annotations := (mustMerge ($objectData.annotations | default dict) (include "tc.v1.common.lib.metadata.allAnnotations" $rootCtx | fromYaml)) -}}
|
||
|
{{- with (include "tc.v1.common.lib.metadata.render" (dict "rootCtx" $rootCtx "annotations" $annotations) | trim) }}
|
||
|
annotations:
|
||
|
{{- . | nindent 4 }}
|
||
|
{{- end -}}
|
||
|
{{- if (mustHas $objectData.type (list "certificate" "imagePullSecret")) }}
|
||
|
data:
|
||
|
{{- if eq $objectData.type "certificate" }}
|
||
|
tls.crt: {{ $objectData.data.certificate | trim | b64enc }}
|
||
|
tls.key: {{ $objectData.data.privatekey | trim | b64enc }}
|
||
|
{{- else if eq $objectData.type "imagePullSecret" }}
|
||
|
.dockerconfigjson: {{ $objectData.data | trim | b64enc }}
|
||
|
{{- end -}}
|
||
|
{{- else }}
|
||
|
stringData:
|
||
|
{{- tpl (toYaml $objectData.data) $rootCtx | nindent 2 }}
|
||
|
{{/* This comment is here to add a new line */}}
|
||
|
{{- end -}}
|
||
|
{{- end -}}
|