mirror of
https://github.com/truenas/charts.git
synced 2026-04-09 05:39:24 +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
48 lines
1.7 KiB
Smarty
48 lines
1.7 KiB
Smarty
{{/* Service - Get Selected Pod */}}
|
|
{{/* Call this template:
|
|
{{ include "ix.v1.common.lib.helpers.getSelectedPodValues" (dict "rootCtx" $rootCtx "objectData" $objectData) -}}
|
|
objectData: The object data of the service
|
|
rootCtx: The root context of the chart.
|
|
*/}}
|
|
|
|
{{- define "ix.v1.common.lib.helpers.getSelectedPodValues" -}}
|
|
{{- $rootCtx := .rootCtx -}}
|
|
{{- $objectData := .objectData -}}
|
|
{{- $caller := .caller -}}
|
|
|
|
{{- $podValues := dict -}}
|
|
{{- with $objectData.targetSelector -}}
|
|
{{- $podValues = mustDeepCopy (get $rootCtx.Values.workload .) -}}
|
|
|
|
{{- if not $podValues -}}
|
|
{{- fail (printf "%s - Selected pod [%s] is not defined" $caller .) -}}
|
|
{{- end -}}
|
|
|
|
{{- if not $podValues.enabled -}}
|
|
{{- fail (printf "%s - Selected pod [%s] is not enabled" $caller .) -}}
|
|
{{- end -}}
|
|
|
|
{{/* While we know the shortName from targetSelector, let's set it explicitly
|
|
So service can reference this directly, to match the behaviour of a service
|
|
without targetSelector defined (assumes "use primary") */}}
|
|
{{- $_ := set $podValues "shortName" . -}}
|
|
{{- else -}}
|
|
|
|
{{/* If no targetSelector is defined, we assume the service is using the primary pod */}}
|
|
{{/* Also no need to check for multiple primaries here, it's already done on the workload validation */}}
|
|
{{- range $podName, $pod := $rootCtx.Values.workload -}}
|
|
{{- if $pod.enabled -}}
|
|
{{- if $pod.primary -}}
|
|
{{- $podValues = mustDeepCopy $pod -}}
|
|
{{/* Set the shortName so service can use this on selector */}}
|
|
{{- $_ := set $podValues "shortName" $podName -}}
|
|
{{- end -}}
|
|
{{- end -}}
|
|
{{- end -}}
|
|
|
|
{{- end -}}
|
|
|
|
{{/* Return values in Json, to preserve types */}}
|
|
{{ $podValues | toJson }}
|
|
{{- end -}}
|