2023-07-24 13:33:29 +00:00
|
|
|
{{/* Define the configmap */}}
|
|
|
|
{{- define "guacamole.configmap" -}}
|
|
|
|
{{/* https://github.com/apache/guacamole-client/blob/master/guacamole-docker/bin/start.sh */}}
|
|
|
|
{{/* https://guacamole.apache.org/doc/gug/guacamole-docker.html */}}
|
|
|
|
{{- $fullname := include "tc.v1.common.lib.chart.names.fullname" $ }}
|
|
|
|
guacamole-config:
|
|
|
|
enabled: true
|
|
|
|
data:
|
|
|
|
RECORDING_SEARCH_PATH: /var/lib/guacamole/recordings
|
2023-07-29 09:29:44 +00:00
|
|
|
{{/*
|
|
|
|
https://github.com/apache/guacamole-client/blob/bffc5fbdd5e2bb7a777f55c819a1d4d858829cb7/guacamole-docker/bin/start.sh#L1038
|
|
|
|
TomCat uses the war name as the context path. ROOT.war is the default and means the context path is /.
|
|
|
|
*/}}
|
|
|
|
WEBAPP_CONTEXT: ROOT
|
2023-07-24 13:33:29 +00:00
|
|
|
{{/* GuacD */}}
|
|
|
|
GUACD_HOSTNAME: {{ printf "%v-guacd" $fullname }}
|
|
|
|
GUACD_PORT: {{ .Values.service.guacd.ports.guacd.port | quote }}
|
|
|
|
{{/* Database */}}
|
|
|
|
POSTGRESQL_PORT: "5432"
|
|
|
|
POSTGRESQL_DATABASE: {{ .Values.cnpg.main.database }}
|
|
|
|
POSTGRESQL_USER: {{ .Values.cnpg.main.user }}
|
|
|
|
POSTGRESQL_HOSTNAME: {{ .Values.cnpg.main.creds.host }}
|
|
|
|
POSTGRESQL_PASSWORD: {{ .Values.cnpg.main.creds.password | trimAll "\"" }}
|
|
|
|
{{/* LDAP */}}
|
|
|
|
{{- if (get .Values.guacamole "ldap").LDAP_HOSTNAME }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_HOSTNAME" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_PORT" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_ENCRYPTION_METHOD" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_USER_BASE_DN" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_USER_SEARCH_FILTER" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_GROUP_BASE_DN" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_GROUP_SEARCH_FILTER" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_GROUP_NAME_ATTRIBUTE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_MEMBER_ATTRIBUTE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_MEMBER_ATTRIBUTE_TYPE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_SEARCH_BIND_DN" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_SEARCH_BIND_PASSWORD" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_USERNAME_ATTRIBUTE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_USER_ATTRIBUTES" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_CONFIG_BASE_DN" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_DEREFERENCE_ALIASES" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_FOLLOW_REFERRALS" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_MAX_REFERRAL_HOPS" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_MAX_SEARCH_RESULTS" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "ldap" "key" "LDAP_OPERATION_TIMEOUT" "rootCtx" $) }}
|
|
|
|
{{- end }}
|
|
|
|
{{/* Header */}}
|
|
|
|
{{- if (get .Values.guacamole "header").HEADER_ENABLED }}
|
|
|
|
{{ include "guac.env" (dict "ob" "header" "key" "HEADER_ENABLED" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "header" "key" "HTTP_AUTH_HEADER" "rootCtx" $) }}
|
|
|
|
{{- end }}
|
|
|
|
{{/* SAML */}}
|
|
|
|
{{- if or
|
|
|
|
(and ((get .Values.guacamole "saml").SAML_ENTITY_ID) ((get .Values.guacamole "saml").SAML_CALLBACK_URL))
|
|
|
|
((get .Values.guacamole "saml").SAML_IDP_METADATA_URL) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "saml" "key" "SAML_IDP_METADATA_URL" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "saml" "key" "SAML_IDP_URL" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "saml" "key" "SAML_ENTITY_ID" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "saml" "key" "SAML_CALLBACK_URL" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "saml" "key" "SAML_STRICT" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "saml" "key" "SAML_DEBUG" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "saml" "key" "SAML_COMPRESS_REQUEST" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "saml" "key" "SAML_COMPRESS_RESPONSE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "saml" "key" "SAML_GROUP_ATTRIBUTE" "rootCtx" $) }}
|
|
|
|
{{- end }}
|
|
|
|
{{/* Proxy */}}
|
|
|
|
{{- if (get .Values.guacamole "proxy").REMOTE_IP_VALVE_ENABLED }}
|
|
|
|
{{ include "guac.env" (dict "ob" "proxy" "key" "REMOTE_IP_VALVE_ENABLED" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "proxy" "key" "PROXY_ALLOWED_IPS_REGEX" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "proxy" "key" "PROXY_IP_HEADER" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "proxy" "key" "PROXY_PROTOCOL_HEADER" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "proxy" "key" "PROXY_BY_HEADER" "rootCtx" $) }}
|
|
|
|
{{- end }}
|
|
|
|
{{/* General */}}
|
|
|
|
{{ include "guac.env" (dict "ob" "general" "key" "EXTENSION_PRIORITY" "rootCtx" $) }}
|
|
|
|
{{/* TOTP */}}
|
|
|
|
{{- if (get .Values.guacamole "totp").TOTP_ENABLED }}
|
|
|
|
{{ include "guac.env" (dict "ob" "totp" "key" "TOTP_ENABLED" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "totp" "key" "TOTP_ISSUER" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "totp" "key" "TOTP_DIGITS" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "totp" "key" "TOTP_PERIOD" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "totp" "key" "TOTP_MODE" "rootCtx" $) }}
|
|
|
|
{{- end }}
|
|
|
|
{{/* DUO */}}
|
|
|
|
{{- if (get .Values.guacamole "duo").DUO_API_HOSTNAME }}
|
|
|
|
{{ include "guac.env" (dict "ob" "duo" "key" "DUO_API_HOSTNAME" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "duo" "key" "DUO_INTEGRATION_KEY" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "duo" "key" "DUO_SECRET_KEY" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "duo" "key" "DUO_APPLICATION_KEY" "rootCtx" $) }}
|
|
|
|
{{- end }}
|
|
|
|
{{/* API */}}
|
|
|
|
{{ include "guac.env" (dict "ob" "api" "key" "API_SESSION_TIMEOUT" "rootCtx" $) }}
|
|
|
|
{{/* RADIUS */}}
|
|
|
|
{{- if (get .Values.guacamole "radius").SHARED_SECRET }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_HOSTNAME" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_AUTH_PORT" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_SHARED_SECRET" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_AUTH_PROTOCOL" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_KEY_TYPE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_KEY_TYPE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_KEY_PASSWORD" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_CA_FILE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_CA_TYPE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_CA_PASSWORD" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_TRUST_ALL" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_RETRIES" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_TIMEOUT" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_EAP_TTLS_INNER_PROTOCOL" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "radius" "key" "RADIUS_NAS_IP" "rootCtx" $) }}
|
|
|
|
{{- end }}
|
|
|
|
{{/* OPENID */}}
|
|
|
|
{{- if (get .Values.guacamole "openid").OPENID_AUTHORIZATION_ENDPOINT }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_AUTHORIZATION_ENDPOINT" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_JWKS_ENDPOINT" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_ISSUER" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_CLIENT_ID" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_REDIRECT_URI" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_USERNAME_CLAIM_TYPE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_GROUPS_CLAIM_TYPE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_SCOPE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_ALLOWED_CLOCK_SKEW" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_MAX_TOKEN_VALIDITY" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "openid" "key" "OPENID_MAX_NONCE_VALIDITY" "rootCtx" $) }}
|
|
|
|
{{- end }}
|
|
|
|
{{/* CAS */}}
|
|
|
|
{{- if (get .Values.guacamole "cas").CAS_AUTHORIZATION_ENDPOINT }}
|
|
|
|
{{ include "guac.env" (dict "ob" "cas" "key" "CAS_AUTHORIZATION_ENDPOINT" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "cas" "key" "CAS_REDIRECT_URI" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "cas" "key" "CAS_CLEARPASS_KEY" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "cas" "key" "CAS_GROUP_ATTRIBUTE" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "cas" "key" "CAS_GROUP_FORMAT" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "cas" "key" "CAS_GROUP_LDAP_BASE_DN" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "cas" "key" "CAS_GROUP_LDAP_ATTRIBUTE" "rootCtx" $) }}
|
|
|
|
{{- end }}
|
|
|
|
{{/* JSON */}}
|
|
|
|
{{- if (get .Values.guacamole "json").JSON_SECRET_KEY }}
|
|
|
|
{{ include "guac.env" (dict "ob" "json" "key" "JSON_SECRET_KEY" "rootCtx" $) }}
|
|
|
|
{{ include "guac.env" (dict "ob" "json" "key" "JSON_TRUSTED_NETWORKS" "rootCtx" $) }}
|
|
|
|
{{- end }}
|
|
|
|
db-init:
|
|
|
|
enabled: true
|
|
|
|
data:
|
|
|
|
{{- $filename := "/tc-init/initdb.sql" }}
|
|
|
|
create-seed.sh: |
|
|
|
|
echo "Creating [{{ $filename }}] file..."
|
|
|
|
/opt/guacamole/bin/initdb.sh --postgresql > {{ $filename }}
|
|
|
|
if [ -f {{ $filename }} ]; then
|
|
|
|
echo "File [{{ $filename }}] created successfully!"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
echo "File [{{ $filename }}] failed to create."
|
|
|
|
exit 1
|
|
|
|
apply-seed.sh: |
|
|
|
|
export PGPASSWORD="$POSTGRESQL_PASSWORD"
|
|
|
|
until
|
|
|
|
pg_isready --username="$POSTGRESQL_USER" --host="$POSTGRESQL_HOSTNAME" --port="$POSTGRESQL_PORT"
|
|
|
|
do
|
|
|
|
echo "Waiting for PostgreSQL to start..."
|
|
|
|
sleep 2
|
|
|
|
done
|
|
|
|
psql --host="$POSTGRESQL_HOSTNAME" --port="$POSTGRESQL_PORT" \
|
|
|
|
--username="$POSTGRESQL_USER" --dbname="$POSTGRESQL_DATABASE" \
|
|
|
|
--no-password --command='SELECT * FROM public.guacamole_user' \
|
|
|
|
--output=/dev/null --quiet
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
echo "Database already initialized."
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
if [ ! -f {{ $filename }} ]; then
|
|
|
|
echo "File [{{ $filename }}] does not exist."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
echo "Initializing database from [{{ $filename }}] file..."
|
|
|
|
psql --host="$POSTGRESQL_HOSTNAME" --port="$POSTGRESQL_PORT" \
|
|
|
|
--username="$POSTGRESQL_USER" --dbname="$POSTGRESQL_DATABASE" \
|
|
|
|
--no-password --quiet --output=/dev/null --file={{ $filename }}
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
echo "Database initialized successfully!"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
echo "Database failed to initialize."
|
|
|
|
exit 1
|
|
|
|
{{- end -}}
|
|
|
|
|
|
|
|
{{- define "guac.env" -}}
|
|
|
|
{{- $key := .key -}}
|
|
|
|
{{- $ob := .ob -}}
|
|
|
|
{{- $rootCtx := .rootCtx -}}
|
|
|
|
{{- $object := (get $rootCtx.Values.guacamole $ob) -}}
|
|
|
|
|
|
|
|
{{- if $object -}}
|
|
|
|
{{- if hasKey $object $key -}}
|
|
|
|
{{- if not (kindIs "invalid" $key) -}}
|
|
|
|
{{- printf "%v: %v" $key (get $object $key | quote) -}}
|
|
|
|
{{- end -}}
|
|
|
|
{{- end -}}
|
|
|
|
{{- end -}}
|
|
|
|
{{- end -}}
|