_secrets.tpl 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. {{/*
  2. Copyright VMware, Inc.
  3. SPDX-License-Identifier: APACHE-2.0
  4. */}}
  5. {{/* vim: set filetype=mustache: */}}
  6. {{/*
  7. Generate secret name.
  8. Usage:
  9. {{ include "common.secrets.name" (dict "existingSecret" .Values.path.to.the.existingSecret "defaultNameSuffix" "mySuffix" "context" $) }}
  10. Params:
  11. - existingSecret - ExistingSecret/String - Optional. The path to the existing secrets in the values.yaml given by the user
  12. to be used instead of the default one. Allows for it to be of type String (just the secret name) for backwards compatibility.
  13. +info: https://github.com/bitnami/charts/tree/main/bitnami/common#existingsecret
  14. - defaultNameSuffix - String - Optional. It is used only if we have several secrets in the same deployment.
  15. - context - Dict - Required. The context for the template evaluation.
  16. */}}
  17. {{- define "common.secrets.name" -}}
  18. {{- $name := (include "common.names.fullname" .context) -}}
  19. {{- if .defaultNameSuffix -}}
  20. {{- $name = printf "%s-%s" $name .defaultNameSuffix | trunc 63 | trimSuffix "-" -}}
  21. {{- end -}}
  22. {{- with .existingSecret -}}
  23. {{- if not (typeIs "string" .) -}}
  24. {{- with .name -}}
  25. {{- $name = . -}}
  26. {{- end -}}
  27. {{- else -}}
  28. {{- $name = . -}}
  29. {{- end -}}
  30. {{- end -}}
  31. {{- printf "%s" $name -}}
  32. {{- end -}}
  33. {{/*
  34. Generate secret key.
  35. Usage:
  36. {{ include "common.secrets.key" (dict "existingSecret" .Values.path.to.the.existingSecret "key" "keyName") }}
  37. Params:
  38. - existingSecret - ExistingSecret/String - Optional. The path to the existing secrets in the values.yaml given by the user
  39. to be used instead of the default one. Allows for it to be of type String (just the secret name) for backwards compatibility.
  40. +info: https://github.com/bitnami/charts/tree/main/bitnami/common#existingsecret
  41. - key - String - Required. Name of the key in the secret.
  42. */}}
  43. {{- define "common.secrets.key" -}}
  44. {{- $key := .key -}}
  45. {{- if .existingSecret -}}
  46. {{- if not (typeIs "string" .existingSecret) -}}
  47. {{- if .existingSecret.keyMapping -}}
  48. {{- $key = index .existingSecret.keyMapping $.key -}}
  49. {{- end -}}
  50. {{- end }}
  51. {{- end -}}
  52. {{- printf "%s" $key -}}
  53. {{- end -}}
  54. {{/*
  55. Generate secret password or retrieve one if already created.
  56. Usage:
  57. {{ include "common.secrets.passwords.manage" (dict "secret" "secret-name" "key" "keyName" "providedValues" (list "path.to.password1" "path.to.password2") "length" 10 "strong" false "chartName" "chartName" "context" $) }}
  58. Params:
  59. - secret - String - Required - Name of the 'Secret' resource where the password is stored.
  60. - key - String - Required - Name of the key in the secret.
  61. - providedValues - List<String> - Required - The path to the validating value in the values.yaml, e.g: "mysql.password". Will pick first parameter with a defined value.
  62. - length - int - Optional - Length of the generated random password.
  63. - strong - Boolean - Optional - Whether to add symbols to the generated random password.
  64. - chartName - String - Optional - Name of the chart used when said chart is deployed as a subchart.
  65. - context - Context - Required - Parent context.
  66. - failOnNew - Boolean - Optional - Default to true. If set to false, skip errors adding new keys to existing secrets.
  67. - skipB64enc - Boolean - Optional - Default to false. If set to true, no the secret will not be base64 encrypted.
  68. - skipQuote - Boolean - Optional - Default to false. If set to true, no quotes will be added around the secret.
  69. The order in which this function returns a secret password:
  70. 1. Already existing 'Secret' resource
  71. (If a 'Secret' resource is found under the name provided to the 'secret' parameter to this function and that 'Secret' resource contains a key with the name passed as the 'key' parameter to this function then the value of this existing secret password will be returned)
  72. 2. Password provided via the values.yaml
  73. (If one of the keys passed to the 'providedValues' parameter to this function is a valid path to a key in the values.yaml and has a value, the value of the first key with a value will be returned)
  74. 3. Randomly generated secret password
  75. (A new random secret password with the length specified in the 'length' parameter will be generated and returned)
  76. */}}
  77. {{- define "common.secrets.passwords.manage" -}}
  78. {{- $password := "" }}
  79. {{- $subchart := "" }}
  80. {{- $chartName := default "" .chartName }}
  81. {{- $passwordLength := default 10 .length }}
  82. {{- $providedPasswordKey := include "common.utils.getKeyFromList" (dict "keys" .providedValues "context" $.context) }}
  83. {{- $providedPasswordValue := include "common.utils.getValueFromKey" (dict "key" $providedPasswordKey "context" $.context) }}
  84. {{- $secretData := (lookup "v1" "Secret" (include "common.names.namespace" .context) .secret).data }}
  85. {{- if $secretData }}
  86. {{- if hasKey $secretData .key }}
  87. {{- $password = index $secretData .key | b64dec }}
  88. {{- else if not (eq .failOnNew false) }}
  89. {{- printf "\nPASSWORDS ERROR: The secret \"%s\" does not contain the key \"%s\"\n" .secret .key | fail -}}
  90. {{- else if $providedPasswordValue }}
  91. {{- $password = $providedPasswordValue | toString }}
  92. {{- end -}}
  93. {{- else if $providedPasswordValue }}
  94. {{- $password = $providedPasswordValue | toString }}
  95. {{- else }}
  96. {{- if .context.Values.enabled }}
  97. {{- $subchart = $chartName }}
  98. {{- end -}}
  99. {{- $requiredPassword := dict "valueKey" $providedPasswordKey "secret" .secret "field" .key "subchart" $subchart "context" $.context -}}
  100. {{- $requiredPasswordError := include "common.validations.values.single.empty" $requiredPassword -}}
  101. {{- $passwordValidationErrors := list $requiredPasswordError -}}
  102. {{- include "common.errors.upgrade.passwords.empty" (dict "validationErrors" $passwordValidationErrors "context" $.context) -}}
  103. {{- if .strong }}
  104. {{- $subStr := list (lower (randAlpha 1)) (randNumeric 1) (upper (randAlpha 1)) | join "_" }}
  105. {{- $password = randAscii $passwordLength }}
  106. {{- $password = regexReplaceAllLiteral "\\W" $password "@" | substr 5 $passwordLength }}
  107. {{- $password = printf "%s%s" $subStr $password | toString | shuffle }}
  108. {{- else }}
  109. {{- $password = randAlphaNum $passwordLength }}
  110. {{- end }}
  111. {{- end -}}
  112. {{- if not .skipB64enc }}
  113. {{- $password = $password | b64enc }}
  114. {{- end -}}
  115. {{- if .skipQuote -}}
  116. {{- printf "%s" $password -}}
  117. {{- else -}}
  118. {{- printf "%s" $password | quote -}}
  119. {{- end -}}
  120. {{- end -}}
  121. {{/*
  122. Reuses the value from an existing secret, otherwise sets its value to a default value.
  123. Usage:
  124. {{ include "common.secrets.lookup" (dict "secret" "secret-name" "key" "keyName" "defaultValue" .Values.myValue "context" $) }}
  125. Params:
  126. - secret - String - Required - Name of the 'Secret' resource where the password is stored.
  127. - key - String - Required - Name of the key in the secret.
  128. - defaultValue - String - Required - The path to the validating value in the values.yaml, e.g: "mysql.password". Will pick first parameter with a defined value.
  129. - context - Context - Required - Parent context.
  130. */}}
  131. {{- define "common.secrets.lookup" -}}
  132. {{- $value := "" -}}
  133. {{- $secretData := (lookup "v1" "Secret" (include "common.names.namespace" .context) .secret).data -}}
  134. {{- if and $secretData (hasKey $secretData .key) -}}
  135. {{- $value = index $secretData .key -}}
  136. {{- else if .defaultValue -}}
  137. {{- $value = .defaultValue | toString | b64enc -}}
  138. {{- end -}}
  139. {{- if $value -}}
  140. {{- printf "%s" $value -}}
  141. {{- end -}}
  142. {{- end -}}
  143. {{/*
  144. Returns whether a previous generated secret already exists
  145. Usage:
  146. {{ include "common.secrets.exists" (dict "secret" "secret-name" "context" $) }}
  147. Params:
  148. - secret - String - Required - Name of the 'Secret' resource where the password is stored.
  149. - context - Context - Required - Parent context.
  150. */}}
  151. {{- define "common.secrets.exists" -}}
  152. {{- $secret := (lookup "v1" "Secret" (include "common.names.namespace" .context) .secret) }}
  153. {{- if $secret }}
  154. {{- true -}}
  155. {{- end -}}
  156. {{- end -}}