feat(tls): add tls support to helm-toolkit
This patch set: - allows options in the bootstrap job to load the proper TLS secret into the proper envvar so the openstack client can connect properly to perform bootstrap; - adds in certificates to make rally work properly with TLS endpoints; - adds methods to handle TLS secret volume and volumeMount; - updates ingress to handle secure backends. Change-Id: I322cda393f18bfeed0b9f8b1827d101f60d6bdeb Signed-off-by: Tin Lam <tin@irrational.io>
This commit is contained in:
parent
5e316a9ba0
commit
7cb3ef69ae
@ -19,44 +19,46 @@ examples:
|
|||||||
- values: |
|
- values: |
|
||||||
endpoints:
|
endpoints:
|
||||||
dashboard:
|
dashboard:
|
||||||
certs:
|
host_fqdn_override:
|
||||||
horizon-internal-cert:
|
default:
|
||||||
secretName: horizon-tls-apache
|
host: null
|
||||||
duration: 2160h
|
tls:
|
||||||
organization:
|
secretName: keystone-tls-api
|
||||||
- ACME
|
issuerRef:
|
||||||
commonName: horizon-int.openstack.svc.cluster.local
|
name: ca-issuer
|
||||||
keySize: 2048
|
duration: 2160h
|
||||||
usages:
|
organization:
|
||||||
- server auth
|
- ACME
|
||||||
- client auth
|
commonName: keystone-api.openstack.svc.cluster.local
|
||||||
dnsNames:
|
keySize: 2048
|
||||||
- cluster.local
|
usages:
|
||||||
issuerRef:
|
- server auth
|
||||||
name: ca-issuer
|
- client auth
|
||||||
kind: Issuer
|
dnsNames:
|
||||||
|
- cluster.local
|
||||||
|
issuerRef:
|
||||||
|
name: ca-issuer
|
||||||
usage: |
|
usage: |
|
||||||
{{- $opts := dict "envAll" . "service" "dashboard" "type" "internal" "certName" "horizon-internal-cert" -}}
|
{{- $opts := dict "envAll" . "service" "dashboard" "type" "internal" -}}
|
||||||
{{ $opts | include "helm-toolkit.manifests.certificates" }}
|
{{ $opts | include "helm-toolkit.manifests.certificates" }}
|
||||||
return: |
|
return: |
|
||||||
---
|
---
|
||||||
apiVersion: cert-manager.io/v1alpha3
|
apiVersion: cert-manager.io/v1alpha3
|
||||||
kind: Certificate
|
kind: Certificate
|
||||||
metadata:
|
metadata:
|
||||||
name: horizon_internal_cert
|
name: keystone-tls-api
|
||||||
namespace: NAMESPACE
|
namespace: NAMESPACE
|
||||||
spec:
|
spec:
|
||||||
commonName: horizon-int.openstack.svc.cluster.local
|
commonName: keystone-api.openstack.svc.cluster.local
|
||||||
dnsNames:
|
dnsNames:
|
||||||
- cluster.local
|
- cluster.local
|
||||||
duration: 2160h
|
duration: 2160h
|
||||||
issuerRef:
|
issuerRef:
|
||||||
kind: Issuer
|
|
||||||
name: ca-issuer
|
name: ca-issuer
|
||||||
keySize: 2048
|
keySize: 2048
|
||||||
organization:
|
organization:
|
||||||
- ACME
|
- ACME
|
||||||
secretName: horizon-tls-apache
|
secretName: keystone-tls-api
|
||||||
usages:
|
usages:
|
||||||
- server auth
|
- server auth
|
||||||
- client auth
|
- client auth
|
||||||
@ -66,37 +68,36 @@ examples:
|
|||||||
{{- $envAll := index . "envAll" -}}
|
{{- $envAll := index . "envAll" -}}
|
||||||
{{- $service := index . "service" -}}
|
{{- $service := index . "service" -}}
|
||||||
{{- $type := index . "type" | default "" -}}
|
{{- $type := index . "type" | default "" -}}
|
||||||
{{- $name := index . "certName" -}}
|
{{- $slice := index $envAll.Values.endpoints $service "host_fqdn_override" "default" "tls" -}}
|
||||||
{{- $slice := index $envAll.Values.endpoints $service "certs" $name -}}
|
|
||||||
{{/* Put in some sensible default value if one is not provided by values.yaml */}}
|
{{/* Put in some sensible default value if one is not provided by values.yaml */}}
|
||||||
{{/* If a dnsNames list is not in the values.yaml, it can be overridden by a passed-in parameter.
|
{{/* If a dnsNames list is not in the values.yaml, it can be overridden by a passed-in parameter.
|
||||||
This allows user to use other HTK method to determine the URI and pass that into this method.*/}}
|
This allows user to use other HTK method to determine the URI and pass that into this method.*/}}
|
||||||
{{- if not (hasKey $slice "dnsNames") -}}
|
{{- if not (hasKey $slice "dnsNames") -}}
|
||||||
{{- $hostName := tuple $service $type $envAll | include "helm-toolkit.endpoints.hostname_short_endpoint_lookup" -}}
|
{{- $hostName := tuple $service $type $envAll | include "helm-toolkit.endpoints.hostname_short_endpoint_lookup" -}}
|
||||||
{{- $dnsNames := list $hostName (printf "%s.%s" $hostName $envAll.Release.Namespace) (printf "%s.%s.svc.%s" $hostName $envAll.Release.Namespace $envAll.Values.endpoints.cluster_domain_suffix) -}}
|
{{- $dnsNames := list $hostName (printf "%s.%s" $hostName $envAll.Release.Namespace) (printf "%s.%s.svc.%s" $hostName $envAll.Release.Namespace $envAll.Values.endpoints.cluster_domain_suffix) -}}
|
||||||
{{- $_ := $dnsNames | set (index $envAll.Values.endpoints $service "certs" $name) "dnsNames" -}}
|
{{- $_ := $dnsNames | set (index $envAll.Values.endpoints $service "host_fqdn_override" "default" "tls") "dnsNames" -}}
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
{{/* Default keySize to 4096. This can be overridden. */}}
|
{{/* Default keySize to 4096. This can be overridden. */}}
|
||||||
{{- if not (hasKey $slice "keySize") -}}
|
{{- if not (hasKey $slice "keySize") -}}
|
||||||
{{- $_ := ( printf "%d" 4096 | atoi ) | set (index $envAll.Values.endpoints $service "certs" $name) "keySize" -}}
|
{{- $_ := ( printf "%d" 4096 | atoi ) | set (index $envAll.Values.endpoints $service "host_fqdn_override" "default" "tls") "keySize" -}}
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
{{/* Default keySize to 3 months. Note the min is 720h. This can be overridden. */}}
|
{{/* Default keySize to 3 months. Note the min is 720h. This can be overridden. */}}
|
||||||
{{- if not (hasKey $slice "duration") -}}
|
{{- if not (hasKey $slice "duration") -}}
|
||||||
{{- $_ := printf "%s" "2190h" | set (index $envAll.Values.endpoints $service "certs" $name) "duration" -}}
|
{{- $_ := printf "%s" "2190h" | set (index $envAll.Values.endpoints $service "host_fqdn_override" "default" "tls") "duration" -}}
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
{{/* Default renewBefore to 15 days. This can be overridden. */}}
|
{{/* Default renewBefore to 15 days. This can be overridden. */}}
|
||||||
{{- if not (hasKey $slice "renewBefore") -}}
|
{{- if not (hasKey $slice "renewBefore") -}}
|
||||||
{{- $_ := printf "%s" "360h" | set (index $envAll.Values.endpoints $service "certs" $name) "renewBefore" -}}
|
{{- $_ := printf "%s" "360h" | set (index $envAll.Values.endpoints $service "host_fqdn_override" "default" "tls") "renewBefore" -}}
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
{{/* Default the usage to server auth and client auth. This can be overridden. */}}
|
{{/* Default the usage to server auth and client auth. This can be overridden. */}}
|
||||||
{{- if not (hasKey $slice "usages") -}}
|
{{- if not (hasKey $slice "usages") -}}
|
||||||
{{- $_ := (list "server auth" "client auth") | set (index $envAll.Values.endpoints $service "certs" $name) "usages" -}}
|
{{- $_ := (list "server auth" "client auth") | set (index $envAll.Values.endpoints $service "host_fqdn_override" "default" "tls") "usages" -}}
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
---
|
---
|
||||||
apiVersion: cert-manager.io/v1alpha3
|
apiVersion: cert-manager.io/v1alpha3
|
||||||
kind: Certificate
|
kind: Certificate
|
||||||
metadata:
|
metadata:
|
||||||
name: {{ $name | replace "_" "-" }}
|
name: {{ index $envAll.Values.endpoints $service "host_fqdn_override" "default" "tls" "secretName" }}
|
||||||
namespace: {{ $envAll.Release.Namespace }}
|
namespace: {{ $envAll.Release.Namespace }}
|
||||||
spec:
|
spec:
|
||||||
{{ $slice | toYaml | indent 2 }}
|
{{ $slice | toYaml | indent 2 }}
|
||||||
|
@ -219,6 +219,97 @@ examples:
|
|||||||
backend:
|
backend:
|
||||||
serviceName: barbican-api
|
serviceName: barbican-api
|
||||||
servicePort: b-api
|
servicePort: b-api
|
||||||
|
- values: |
|
||||||
|
network:
|
||||||
|
api:
|
||||||
|
ingress:
|
||||||
|
public: true
|
||||||
|
classes:
|
||||||
|
namespace: "nginx"
|
||||||
|
cluster: "nginx-cluster"
|
||||||
|
annotations:
|
||||||
|
nginx.ingress.kubernetes.io/secure-backends: "true"
|
||||||
|
nginx.ingress.kubernetes.io/backend-protocol: "https"
|
||||||
|
secrets:
|
||||||
|
tls:
|
||||||
|
key_manager:
|
||||||
|
api:
|
||||||
|
public: barbican-tls-public
|
||||||
|
internal: barbican-tls-api
|
||||||
|
endpoints:
|
||||||
|
cluster_domain_suffix: cluster.local
|
||||||
|
key_manager:
|
||||||
|
name: barbican
|
||||||
|
hosts:
|
||||||
|
default: barbican-api
|
||||||
|
public:
|
||||||
|
host: barbican
|
||||||
|
tls:
|
||||||
|
crt: |
|
||||||
|
FOO-CRT
|
||||||
|
key: |
|
||||||
|
FOO-KEY
|
||||||
|
ca: |
|
||||||
|
FOO-CA_CRT
|
||||||
|
host_fqdn_override:
|
||||||
|
default: null
|
||||||
|
path:
|
||||||
|
default: /
|
||||||
|
scheme:
|
||||||
|
default: http
|
||||||
|
public: https
|
||||||
|
port:
|
||||||
|
api:
|
||||||
|
default: 9311
|
||||||
|
public: 80
|
||||||
|
certs:
|
||||||
|
barbican_tls_api:
|
||||||
|
secretName: barbican-tls-api
|
||||||
|
issuerRef:
|
||||||
|
name: ca-issuer
|
||||||
|
kind: Issuer
|
||||||
|
usage: |
|
||||||
|
{{- include "helm-toolkit.manifests.ingress" ( dict "envAll" . "backendServiceType" "key-manager" "backendPort" "b-api" "endpoint" "public" "certIssuer" "ca-issuer" ) -}}
|
||||||
|
return: |
|
||||||
|
---
|
||||||
|
apiVersion: extensions/v1beta1
|
||||||
|
kind: Ingress
|
||||||
|
metadata:
|
||||||
|
name: barbican
|
||||||
|
annotations:
|
||||||
|
kubernetes.io/ingress.class: "nginx"
|
||||||
|
cert-manager.io/issuer: ca-issuer
|
||||||
|
nginx.ingress.kubernetes.io/backend-protocol: https
|
||||||
|
nginx.ingress.kubernetes.io/secure-backends: "true"
|
||||||
|
spec:
|
||||||
|
tls:
|
||||||
|
- secretName: barbican-tls-public-certmanager
|
||||||
|
hosts:
|
||||||
|
- barbican
|
||||||
|
- barbican.default
|
||||||
|
- barbican.default.svc.cluster.local
|
||||||
|
rules:
|
||||||
|
- host: barbican
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /
|
||||||
|
backend:
|
||||||
|
serviceName: barbican-api
|
||||||
|
servicePort: b-api
|
||||||
|
- host: barbican.default
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /
|
||||||
|
backend:
|
||||||
|
serviceName: barbican-api
|
||||||
|
servicePort: b-api
|
||||||
|
- host: barbican.default.svc.cluster.local
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /
|
||||||
|
backend:
|
||||||
|
serviceName: barbican-api
|
||||||
|
servicePort: b-api
|
||||||
*/}}
|
*/}}
|
||||||
|
|
||||||
{{- define "helm-toolkit.manifests.ingress._host_rules" -}}
|
{{- define "helm-toolkit.manifests.ingress._host_rules" -}}
|
||||||
@ -240,6 +331,7 @@ examples:
|
|||||||
{{- $backendServiceType := index . "backendServiceType" -}}
|
{{- $backendServiceType := index . "backendServiceType" -}}
|
||||||
{{- $backendPort := index . "backendPort" -}}
|
{{- $backendPort := index . "backendPort" -}}
|
||||||
{{- $endpoint := index . "endpoint" | default "public" -}}
|
{{- $endpoint := index . "endpoint" | default "public" -}}
|
||||||
|
{{- $certIssuer := index . "certIssuer" | default "" -}}
|
||||||
{{- $ingressName := tuple $backendServiceType $endpoint $envAll | include "helm-toolkit.endpoints.hostname_short_endpoint_lookup" }}
|
{{- $ingressName := tuple $backendServiceType $endpoint $envAll | include "helm-toolkit.endpoints.hostname_short_endpoint_lookup" }}
|
||||||
{{- $backendName := tuple $backendServiceType "internal" $envAll | include "helm-toolkit.endpoints.hostname_short_endpoint_lookup" }}
|
{{- $backendName := tuple $backendServiceType "internal" $envAll | include "helm-toolkit.endpoints.hostname_short_endpoint_lookup" }}
|
||||||
{{- $hostName := tuple $backendServiceType $endpoint $envAll | include "helm-toolkit.endpoints.hostname_short_endpoint_lookup" }}
|
{{- $hostName := tuple $backendServiceType $endpoint $envAll | include "helm-toolkit.endpoints.hostname_short_endpoint_lookup" }}
|
||||||
@ -251,9 +343,22 @@ metadata:
|
|||||||
name: {{ $ingressName }}
|
name: {{ $ingressName }}
|
||||||
annotations:
|
annotations:
|
||||||
kubernetes.io/ingress.class: {{ index $envAll.Values.network $backendService "ingress" "classes" "namespace" | quote }}
|
kubernetes.io/ingress.class: {{ index $envAll.Values.network $backendService "ingress" "classes" "namespace" | quote }}
|
||||||
|
{{- if $certIssuer }}
|
||||||
|
cert-manager.io/issuer: {{ $certIssuer }}
|
||||||
|
{{- end }}
|
||||||
{{ toYaml (index $envAll.Values.network $backendService "ingress" "annotations") | indent 4 }}
|
{{ toYaml (index $envAll.Values.network $backendService "ingress" "annotations") | indent 4 }}
|
||||||
spec:
|
spec:
|
||||||
{{- $host := index $envAll.Values.endpoints ( $backendServiceType | replace "-" "_" ) "hosts" }}
|
{{- $host := index $envAll.Values.endpoints ( $backendServiceType | replace "-" "_" ) "hosts" }}
|
||||||
|
{{- if $certIssuer }}
|
||||||
|
{{- $secretName := index $envAll.Values.secrets "tls" ( $backendServiceType | replace "-" "_" ) $backendService $endpoint }}
|
||||||
|
{{- $_ := required "You need to specify a secret in your values for the endpoint" $secretName }}
|
||||||
|
tls:
|
||||||
|
- secretName: {{ printf "%s-ing" $secretName }}
|
||||||
|
hosts:
|
||||||
|
{{- range $key1, $vHost := tuple $hostName (printf "%s.%s" $hostName $envAll.Release.Namespace) (printf "%s.%s.svc.%s" $hostName $envAll.Release.Namespace $envAll.Values.endpoints.cluster_domain_suffix) }}
|
||||||
|
- {{ $vHost }}
|
||||||
|
{{- end }}
|
||||||
|
{{- else }}
|
||||||
{{- if hasKey $host $endpoint }}
|
{{- if hasKey $host $endpoint }}
|
||||||
{{- $endpointHost := index $host $endpoint }}
|
{{- $endpointHost := index $host $endpoint }}
|
||||||
{{- if kindIs "map" $endpointHost }}
|
{{- if kindIs "map" $endpointHost }}
|
||||||
@ -270,6 +375,7 @@ spec:
|
|||||||
{{- end }}
|
{{- end }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
rules:
|
rules:
|
||||||
{{- range $key1, $vHost := tuple $hostName (printf "%s.%s" $hostName $envAll.Release.Namespace) (printf "%s.%s.svc.%s" $hostName $envAll.Release.Namespace $envAll.Values.endpoints.cluster_domain_suffix) }}
|
{{- range $key1, $vHost := tuple $hostName (printf "%s.%s" $hostName $envAll.Release.Namespace) (printf "%s.%s.svc.%s" $hostName $envAll.Release.Namespace $envAll.Values.endpoints.cluster_domain_suffix) }}
|
||||||
|
@ -27,6 +27,7 @@ limitations under the License.
|
|||||||
{{- $configMapEtc := index . "configMapEtc" | default (printf "%s-%s" $serviceName "etc" ) -}}
|
{{- $configMapEtc := index . "configMapEtc" | default (printf "%s-%s" $serviceName "etc" ) -}}
|
||||||
{{- $configFile := index . "configFile" | default (printf "/etc/%s/%s.conf" $serviceName $serviceName ) -}}
|
{{- $configFile := index . "configFile" | default (printf "/etc/%s/%s.conf" $serviceName $serviceName ) -}}
|
||||||
{{- $logConfigFile := index . "logConfigFile" | default (printf "/etc/%s/logging.conf" $serviceName ) -}}
|
{{- $logConfigFile := index . "logConfigFile" | default (printf "/etc/%s/logging.conf" $serviceName ) -}}
|
||||||
|
{{- $tlsSecret := index . "tlsSecret" | default "" -}}
|
||||||
{{- $keystoneUser := index . "keystoneUser" | default $serviceName -}}
|
{{- $keystoneUser := index . "keystoneUser" | default $serviceName -}}
|
||||||
{{- $openrc := index . "openrc" | default "true" -}}
|
{{- $openrc := index . "openrc" | default "true" -}}
|
||||||
{{- $secretBin := index . "secretBin" -}}
|
{{- $secretBin := index . "secretBin" -}}
|
||||||
@ -66,7 +67,7 @@ spec:
|
|||||||
{{ tuple $envAll $envAll.Values.pod.resources.jobs.bootstrap | include "helm-toolkit.snippets.kubernetes_resources" | indent 10 }}
|
{{ tuple $envAll $envAll.Values.pod.resources.jobs.bootstrap | include "helm-toolkit.snippets.kubernetes_resources" | indent 10 }}
|
||||||
{{- if eq $openrc "true" }}
|
{{- if eq $openrc "true" }}
|
||||||
env:
|
env:
|
||||||
{{- with $env := dict "ksUserSecret" ( index $envAll.Values.secrets.identity $keystoneUser ) }}
|
{{- with $env := dict "ksUserSecret" ( index $envAll.Values.secrets.identity $keystoneUser ) "useCA" (ne $tlsSecret "") }}
|
||||||
{{- include "helm-toolkit.snippets.keystone_openrc_env_vars" $env | indent 12 }}
|
{{- include "helm-toolkit.snippets.keystone_openrc_env_vars" $env | indent 12 }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
@ -91,6 +92,7 @@ spec:
|
|||||||
mountPath: {{ $logConfigFile | quote }}
|
mountPath: {{ $logConfigFile | quote }}
|
||||||
subPath: {{ base $logConfigFile | quote }}
|
subPath: {{ base $logConfigFile | quote }}
|
||||||
readOnly: true
|
readOnly: true
|
||||||
|
{{ dict "enabled" (ne $tlsSecret "") "name" $tlsSecret | include "helm-toolkit.snippets.tls_volume_mount" | indent 12 }}
|
||||||
{{- if $podVolMounts }}
|
{{- if $podVolMounts }}
|
||||||
{{ $podVolMounts | toYaml | indent 12 }}
|
{{ $podVolMounts | toYaml | indent 12 }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
@ -112,7 +114,8 @@ spec:
|
|||||||
- name: bootstrap-conf
|
- name: bootstrap-conf
|
||||||
secret:
|
secret:
|
||||||
secretName: {{ $configMapEtc | quote }}
|
secretName: {{ $configMapEtc | quote }}
|
||||||
defaultMode: 292
|
defaultMode: 0444
|
||||||
|
{{- dict "enabled" (ne $tlsSecret "") "name" $tlsSecret | include "helm-toolkit.snippets.tls_volume" | indent 8 }}
|
||||||
{{- if $podVols }}
|
{{- if $podVols }}
|
||||||
{{ $podVols | toYaml | indent 8 }}
|
{{ $podVols | toYaml | indent 8 }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
@ -24,6 +24,7 @@ limitations under the License.
|
|||||||
{{- $nodeSelector := index . "nodeSelector" | default ( dict $envAll.Values.labels.job.node_selector_key $envAll.Values.labels.job.node_selector_value ) -}}
|
{{- $nodeSelector := index . "nodeSelector" | default ( dict $envAll.Values.labels.job.node_selector_key $envAll.Values.labels.job.node_selector_value ) -}}
|
||||||
{{- $configMapBin := index . "configMapBin" | default (printf "%s-%s" $serviceName "bin" ) -}}
|
{{- $configMapBin := index . "configMapBin" | default (printf "%s-%s" $serviceName "bin" ) -}}
|
||||||
{{- $secretBin := index . "secretBin" -}}
|
{{- $secretBin := index . "secretBin" -}}
|
||||||
|
{{- $tlsSecret := index . "tlsSecret" | default "" -}}
|
||||||
{{- $backoffLimit := index . "backoffLimit" | default "1000" -}}
|
{{- $backoffLimit := index . "backoffLimit" | default "1000" -}}
|
||||||
{{- $activeDeadlineSeconds := index . "activeDeadlineSeconds" -}}
|
{{- $activeDeadlineSeconds := index . "activeDeadlineSeconds" -}}
|
||||||
{{- $serviceNamePretty := $serviceName | replace "_" "-" -}}
|
{{- $serviceNamePretty := $serviceName | replace "_" "-" -}}
|
||||||
@ -71,8 +72,9 @@ spec:
|
|||||||
mountPath: /tmp/ks-endpoints.sh
|
mountPath: /tmp/ks-endpoints.sh
|
||||||
subPath: ks-endpoints.sh
|
subPath: ks-endpoints.sh
|
||||||
readOnly: true
|
readOnly: true
|
||||||
|
{{ dict "enabled" true "name" $tlsSecret "ca" true | include "helm-toolkit.snippets.tls_volume_mount" | indent 12 }}
|
||||||
env:
|
env:
|
||||||
{{- with $env := dict "ksUserSecret" $envAll.Values.secrets.identity.admin }}
|
{{- with $env := dict "ksUserSecret" $envAll.Values.secrets.identity.admin "useCA" (ne $tlsSecret "") }}
|
||||||
{{- include "helm-toolkit.snippets.keystone_openrc_env_vars" $env | indent 12 }}
|
{{- include "helm-toolkit.snippets.keystone_openrc_env_vars" $env | indent 12 }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
- name: OS_SVC_ENDPOINT
|
- name: OS_SVC_ENDPOINT
|
||||||
@ -98,4 +100,5 @@ spec:
|
|||||||
name: {{ $configMapBin | quote }}
|
name: {{ $configMapBin | quote }}
|
||||||
defaultMode: 365
|
defaultMode: 365
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
{{- dict "enabled" true "name" $tlsSecret | include "helm-toolkit.snippets.tls_volume" | indent 8 }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
@ -24,6 +24,7 @@ limitations under the License.
|
|||||||
{{- $nodeSelector := index . "nodeSelector" | default ( dict $envAll.Values.labels.job.node_selector_key $envAll.Values.labels.job.node_selector_value ) -}}
|
{{- $nodeSelector := index . "nodeSelector" | default ( dict $envAll.Values.labels.job.node_selector_key $envAll.Values.labels.job.node_selector_value ) -}}
|
||||||
{{- $configMapBin := index . "configMapBin" | default (printf "%s-%s" $serviceName "bin" ) -}}
|
{{- $configMapBin := index . "configMapBin" | default (printf "%s-%s" $serviceName "bin" ) -}}
|
||||||
{{- $secretBin := index . "secretBin" -}}
|
{{- $secretBin := index . "secretBin" -}}
|
||||||
|
{{- $tlsSecret := index . "tlsSecret" | default "" -}}
|
||||||
{{- $backoffLimit := index . "backoffLimit" | default "1000" -}}
|
{{- $backoffLimit := index . "backoffLimit" | default "1000" -}}
|
||||||
{{- $activeDeadlineSeconds := index . "activeDeadlineSeconds" -}}
|
{{- $activeDeadlineSeconds := index . "activeDeadlineSeconds" -}}
|
||||||
{{- $serviceNamePretty := $serviceName | replace "_" "-" -}}
|
{{- $serviceNamePretty := $serviceName | replace "_" "-" -}}
|
||||||
@ -70,8 +71,9 @@ spec:
|
|||||||
mountPath: /tmp/ks-service.sh
|
mountPath: /tmp/ks-service.sh
|
||||||
subPath: ks-service.sh
|
subPath: ks-service.sh
|
||||||
readOnly: true
|
readOnly: true
|
||||||
|
{{ dict "enabled" true "name" $tlsSecret "ca" true | include "helm-toolkit.snippets.tls_volume_mount" | indent 12 }}
|
||||||
env:
|
env:
|
||||||
{{- with $env := dict "ksUserSecret" $envAll.Values.secrets.identity.admin }}
|
{{- with $env := dict "ksUserSecret" $envAll.Values.secrets.identity.admin "useCA" (ne $tlsSecret "") }}
|
||||||
{{- include "helm-toolkit.snippets.keystone_openrc_env_vars" $env | indent 12 }}
|
{{- include "helm-toolkit.snippets.keystone_openrc_env_vars" $env | indent 12 }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
- name: OS_SERVICE_NAME
|
- name: OS_SERVICE_NAME
|
||||||
@ -92,4 +94,5 @@ spec:
|
|||||||
name: {{ $configMapBin | quote }}
|
name: {{ $configMapBin | quote }}
|
||||||
defaultMode: 365
|
defaultMode: 365
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
{{- dict "enabled" true "name" $tlsSecret | include "helm-toolkit.snippets.tls_volume" | indent 8 }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
@ -24,6 +24,7 @@ limitations under the License.
|
|||||||
{{- $configMapBin := index . "configMapBin" | default (printf "%s-%s" $serviceName "bin" ) -}}
|
{{- $configMapBin := index . "configMapBin" | default (printf "%s-%s" $serviceName "bin" ) -}}
|
||||||
{{- $serviceUser := index . "serviceUser" | default $serviceName -}}
|
{{- $serviceUser := index . "serviceUser" | default $serviceName -}}
|
||||||
{{- $secretBin := index . "secretBin" -}}
|
{{- $secretBin := index . "secretBin" -}}
|
||||||
|
{{- $tlsSecret := index . "tlsSecret" | default "" -}}
|
||||||
{{- $backoffLimit := index . "backoffLimit" | default "1000" -}}
|
{{- $backoffLimit := index . "backoffLimit" | default "1000" -}}
|
||||||
{{- $activeDeadlineSeconds := index . "activeDeadlineSeconds" -}}
|
{{- $activeDeadlineSeconds := index . "activeDeadlineSeconds" -}}
|
||||||
{{- $serviceUserPretty := $serviceUser | replace "_" "-" -}}
|
{{- $serviceUserPretty := $serviceUser | replace "_" "-" -}}
|
||||||
@ -69,8 +70,9 @@ spec:
|
|||||||
mountPath: /tmp/ks-user.sh
|
mountPath: /tmp/ks-user.sh
|
||||||
subPath: ks-user.sh
|
subPath: ks-user.sh
|
||||||
readOnly: true
|
readOnly: true
|
||||||
|
{{ dict "enabled" true "name" $tlsSecret "ca" true | include "helm-toolkit.snippets.tls_volume_mount" | indent 12 }}
|
||||||
env:
|
env:
|
||||||
{{- with $env := dict "ksUserSecret" $envAll.Values.secrets.identity.admin }}
|
{{- with $env := dict "ksUserSecret" $envAll.Values.secrets.identity.admin "useCA" (ne $tlsSecret "") }}
|
||||||
{{- include "helm-toolkit.snippets.keystone_openrc_env_vars" $env | indent 12 }}
|
{{- include "helm-toolkit.snippets.keystone_openrc_env_vars" $env | indent 12 }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
- name: SERVICE_OS_SERVICE_NAME
|
- name: SERVICE_OS_SERVICE_NAME
|
||||||
@ -98,4 +100,5 @@ spec:
|
|||||||
name: {{ $configMapBin | quote }}
|
name: {{ $configMapBin | quote }}
|
||||||
defaultMode: 365
|
defaultMode: 365
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
{{- dict "enabled" true "name" $tlsSecret | include "helm-toolkit.snippets.tls_volume" | indent 8 }}
|
||||||
{{- end -}}
|
{{- end -}}
|
||||||
|
@ -66,7 +66,7 @@ cat > /tmp/rally-config.json << EOF
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"https_insecure": false,
|
"https_insecure": false,
|
||||||
"https_cacert": ""
|
"https_cacert": "${OS_CACERT}"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
EOF
|
EOF
|
||||||
|
@ -70,9 +70,15 @@ return: |
|
|||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: example-keystone-admin
|
name: example-keystone-admin
|
||||||
key: OS_PASSWORD
|
key: OS_PASSWORD
|
||||||
|
- name: OS_CACERT
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: example-keystone-admin
|
||||||
|
key: OS_CACERT
|
||||||
*/}}
|
*/}}
|
||||||
|
|
||||||
{{- define "helm-toolkit.snippets.keystone_openrc_env_vars" }}
|
{{- define "helm-toolkit.snippets.keystone_openrc_env_vars" }}
|
||||||
|
{{- $useCA := .useCA -}}
|
||||||
{{- $ksUserSecret := .ksUserSecret }}
|
{{- $ksUserSecret := .ksUserSecret }}
|
||||||
- name: OS_IDENTITY_API_VERSION
|
- name: OS_IDENTITY_API_VERSION
|
||||||
value: "3"
|
value: "3"
|
||||||
@ -126,4 +132,11 @@ return: |
|
|||||||
secretKeyRef:
|
secretKeyRef:
|
||||||
name: {{ $ksUserSecret }}
|
name: {{ $ksUserSecret }}
|
||||||
key: OS_DEFAULT_DOMAIN
|
key: OS_DEFAULT_DOMAIN
|
||||||
|
{{- if $useCA }}
|
||||||
|
- name: OS_CACERT
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: {{ $ksUserSecret }}
|
||||||
|
key: OS_CACERT
|
||||||
|
{{- end }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
@ -26,4 +26,7 @@ OS_USER_DOMAIN_NAME: {{ $userContext.user_domain_name | b64enc }}
|
|||||||
OS_USERNAME: {{ $userContext.username | b64enc }}
|
OS_USERNAME: {{ $userContext.username | b64enc }}
|
||||||
OS_PASSWORD: {{ $userContext.password | b64enc }}
|
OS_PASSWORD: {{ $userContext.password | b64enc }}
|
||||||
OS_DEFAULT_DOMAIN: {{ $userContext.default_domain_id | default "default" | b64enc }}
|
OS_DEFAULT_DOMAIN: {{ $userContext.default_domain_id | default "default" | b64enc }}
|
||||||
|
{{- if $userContext.cacert }}
|
||||||
|
OS_CACERT: {{ $userContext.cacert | b64enc }}
|
||||||
|
{{- end }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
@ -21,7 +21,7 @@ values: |
|
|||||||
identity:
|
identity:
|
||||||
service_user: example-keystone-user
|
service_user: example-keystone-user
|
||||||
usage: |
|
usage: |
|
||||||
{{ include "helm-toolkit.snippets.keystone_user_create_env_vars" ( dict "ksUserSecret" .Values.secrets.identity.service_user ) }}
|
{{ include "helm-toolkit.snippets.keystone_user_create_env_vars" ( dict "ksUserSecret" .Values.secrets.identity.service_user "useCA" true ) }}
|
||||||
return: |
|
return: |
|
||||||
- name: SERVICE_OS_REGION_NAME
|
- name: SERVICE_OS_REGION_NAME
|
||||||
valueFrom:
|
valueFrom:
|
||||||
|
47
helm-toolkit/templates/snippets/_tls_volume.tpl
Normal file
47
helm-toolkit/templates/snippets/_tls_volume.tpl
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
{{/*
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/}}
|
||||||
|
{{/*
|
||||||
|
abstract: |
|
||||||
|
Renders a secret volume for tls.
|
||||||
|
|
||||||
|
Dictionary Parameters:
|
||||||
|
enabled: boolean check if you want to conditional disable this snippet (optional)
|
||||||
|
name: name of the volume (required)
|
||||||
|
secretName: name of a kuberentes/tls secret, if not specified, use the volume name (optional)
|
||||||
|
|
||||||
|
values: |
|
||||||
|
manifests:
|
||||||
|
certificates: true
|
||||||
|
|
||||||
|
usage: |
|
||||||
|
{{- $opts := dict "enabled" "true" "name" "glance-tls-api" -}}
|
||||||
|
{{- $opts | include "helm-toolkit.snippets.tls_volume" -}}
|
||||||
|
|
||||||
|
return: |
|
||||||
|
- name: glance-tls-api
|
||||||
|
secret:
|
||||||
|
secretName: glance-tls-api
|
||||||
|
defaultMode: 292
|
||||||
|
*/}}
|
||||||
|
{{- define "helm-toolkit.snippets.tls_volume" }}
|
||||||
|
{{- $enabled := index . "enabled" -}}
|
||||||
|
{{- $name := index . "name" -}}
|
||||||
|
{{- $secretName := index . "secretName" | default $name -}}
|
||||||
|
{{- if and $enabled (ne $name "") }}
|
||||||
|
- name: {{ $name }}
|
||||||
|
secret:
|
||||||
|
secretName: {{ $secretName }}
|
||||||
|
defaultMode: 292
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
82
helm-toolkit/templates/snippets/_tls_volume_mount.tpl
Normal file
82
helm-toolkit/templates/snippets/_tls_volume_mount.tpl
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
{{/*
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/}}
|
||||||
|
{{/*
|
||||||
|
abstract: |
|
||||||
|
Renders a volume mount for TLS key, cert and CA.
|
||||||
|
|
||||||
|
Dictionary Parameters:
|
||||||
|
enabled: boolean check if you want to conditional disable this snippet (optional)
|
||||||
|
name: name that of the volume and should match the volume name (required)
|
||||||
|
path: path to place tls.crt tls.key ca.crt, do not suffix with '/' (required)
|
||||||
|
certs: a tuple containing a nonempty subset of {tls.crt, tls.key, ca.crt}.
|
||||||
|
the default is the full set. (optional)
|
||||||
|
|
||||||
|
values: |
|
||||||
|
manifests:
|
||||||
|
certificates: true
|
||||||
|
|
||||||
|
usage: |
|
||||||
|
{{- $opts := dict "enabled" .Values.manifests.certificates "name" "glance-tls-api" "path" "/etc/glance/certs" -}}
|
||||||
|
{{- $opts | include "helm-toolkit.snippets.tls_volume_mount" -}}
|
||||||
|
|
||||||
|
return: |
|
||||||
|
- name: glance-tls-api
|
||||||
|
mountPath: /etc/glance/certs/tls.crt
|
||||||
|
subPath: tls.crt
|
||||||
|
readOnly: true
|
||||||
|
- name: glance-tls-api
|
||||||
|
mountPath: /etc/glance/certs/tls.key
|
||||||
|
subPath: tls.key
|
||||||
|
readOnly: true
|
||||||
|
- name: glance-tls-api
|
||||||
|
mountPath: /etc/glance/certs/ca.crt
|
||||||
|
subPath: ca.crt
|
||||||
|
readOnly: true
|
||||||
|
|
||||||
|
abstract: |
|
||||||
|
This mounts a specific issuing CA only for service validation
|
||||||
|
|
||||||
|
usage: |
|
||||||
|
{{- $opts := dict "enabled" .Values.manifests.certificates "name" "glance-tls-api" "ca" true -}}
|
||||||
|
{{- $opts | include "helm-toolkit.snippets.tls_volume_mount" -}}
|
||||||
|
|
||||||
|
return: |
|
||||||
|
- name: glance-tls-api
|
||||||
|
mountPath: /etc/ssl/certs/openstack-helm.crt
|
||||||
|
subPath: ca.crt
|
||||||
|
readOnly: true
|
||||||
|
*/}}
|
||||||
|
{{- define "helm-toolkit.snippets.tls_volume_mount" }}
|
||||||
|
{{- $enabled := index . "enabled" -}}
|
||||||
|
{{- $name := index . "name" -}}
|
||||||
|
{{- $path := index . "path" | default "" -}}
|
||||||
|
{{- $certs := index . "certs" | default ( tuple "tls.crt" "tls.key" "ca.crt" ) }}
|
||||||
|
{{- if $enabled }}
|
||||||
|
{{- if and (eq $path "") (ne $name "") }}
|
||||||
|
- name: {{ $name }}
|
||||||
|
mountPath: "/etc/ssl/certs/openstack-helm.crt"
|
||||||
|
subPath: ca.crt
|
||||||
|
readOnly: true
|
||||||
|
{{- else }}
|
||||||
|
{{- if ne $name "" }}
|
||||||
|
{{- range $key, $value := $certs }}
|
||||||
|
- name: {{ $name }}
|
||||||
|
mountPath: {{ printf "%s/%s" $path $value }}
|
||||||
|
subPath: {{ $value }}
|
||||||
|
readOnly: true
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
Loading…
Reference in New Issue
Block a user