mirror of
https://github.com/truenas/charts.git
synced 2026-05-01 22:11:04 +08:00
* Adapt charts CI and improve/fix common * add check on permissions contaienr * add postgres template * update comments * Update create_app.sh * add check * update script * auto gen item.yaml from Chart,yaml * rename readme on dest * duplicate readme from the same source * correct comment * reoder * remove extra space * keep both README and app-readme * update regex, to also allow 2 letter names, which is also valid * No need to check host network if there aren't any pod values * use same pattern as the pod.name label (not prepending release-name * update deps * add chart dirs to ci * Add a validation to check if there is any yaml errors after merging files * update charts path on ci * common/1.0.0/ -> common/ * update common-test dep path * temp update create_app script * make permissions container name configurable, incase we want to change order of execution * update naming convention * fix typo and a missed name change * do not allow `--` in names
49 lines
1.7 KiB
Smarty
49 lines
1.7 KiB
Smarty
{{/* Returns Service Account Name */}}
|
|
{{/* Call this template:
|
|
{{ include "ix.v1.common.lib.pod.serviceAccountName" (dict "rootCtx" $ "objectData" $objectData) }}
|
|
rootCtx: The root context of the chart.
|
|
objectData: The object data to be used to render the Pod.
|
|
*/}}
|
|
{{- define "ix.v1.common.lib.pod.serviceAccountName" -}}
|
|
{{- $rootCtx := .rootCtx -}}
|
|
{{- $objectData := .objectData -}}
|
|
|
|
{{- $saName := "default" -}}
|
|
{{- $saNameCount := 0 -}}
|
|
|
|
{{- range $name, $serviceAccount := $rootCtx.Values.serviceAccount -}}
|
|
{{- $tempName := include "ix.v1.common.lib.chart.names.fullname" $rootCtx -}}
|
|
|
|
{{- if not $serviceAccount.primary -}}
|
|
{{- $tempName = (printf "%s-%s" $tempName $name) -}}
|
|
{{- end -}}
|
|
|
|
{{- if $serviceAccount.enabled -}}
|
|
{{/* If targetSelectAll is true */}}
|
|
{{- if $serviceAccount.targetSelectAll -}}
|
|
{{- $saName = $tempName -}}
|
|
{{- $saNameCount = add1 $saNameCount -}}
|
|
|
|
{{/* Else if targetSelector is a list */}}
|
|
{{- else if (kindIs "slice" $serviceAccount.targetSelector) -}}
|
|
{{- if (mustHas $objectData.shortName $serviceAccount.targetSelector) -}}
|
|
{{- $saName = $tempName -}}
|
|
{{- $saNameCount = add1 $saNameCount -}}
|
|
{{- end -}}
|
|
|
|
{{/* If not targetSelectAll or targetSelector, but is the primary pod */}}
|
|
{{- else if $objectData.primary -}}
|
|
{{- $saName = $tempName -}}
|
|
{{- $saNameCount = add1 $saNameCount -}}
|
|
{{- end -}}
|
|
|
|
{{- end -}}
|
|
{{- end -}}
|
|
|
|
{{- if gt $saNameCount 1 -}}
|
|
{{- fail (printf "Expected at most 1 ServiceAccount to be assigned on a pod [%s]. But [%v] were assigned" $objectData.shortName $saNameCount) -}}
|
|
{{- end -}}
|
|
|
|
{{- $saName -}}
|
|
{{- end -}}
|