mirror of
https://github.com/pgadmin-org/pgadmin4.git
synced 2025-01-24 07:16:52 -06:00
Allow to pass PGADMIN_CONFIG_CONFIG_DATABASE_URI from docker secrets. #5869
This commit is contained in:
parent
6cccb5da31
commit
1fe840fcac
@ -191,6 +191,7 @@ COPY DEPENDENCIES /pgadmin4/DEPENDENCIES
|
|||||||
# Install runtime dependencies and configure everything in one RUN step
|
# Install runtime dependencies and configure everything in one RUN step
|
||||||
RUN apk add --no-cache \
|
RUN apk add --no-cache \
|
||||||
python3 \
|
python3 \
|
||||||
|
bash \
|
||||||
py3-pip \
|
py3-pip \
|
||||||
postfix \
|
postfix \
|
||||||
krb5-libs \
|
krb5-libs \
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/bin/sh
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
# Fixup the passwd file, in case we're on OpenShift
|
# Fixup the passwd file, in case we're on OpenShift
|
||||||
if ! whoami > /dev/null 2>&1; then
|
if ! whoami > /dev/null 2>&1; then
|
||||||
@ -9,6 +9,30 @@ if ! whoami > /dev/null 2>&1; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# usage: file_env VAR [DEFAULT] ie: file_env 'XYZ_DB_PASSWORD' 'example'
|
||||||
|
# (will allow for "$XYZ_DB_PASSWORD_FILE" to fill in the value of
|
||||||
|
# "$XYZ_DB_PASSWORD" from a file, for Docker's secrets feature)
|
||||||
|
function file_env() {
|
||||||
|
local var="$1"
|
||||||
|
local fileVar="${var}_FILE"
|
||||||
|
if [ "${!var:-}" ] && [ "${!fileVar:-}" ]; then
|
||||||
|
printf >&2 'error: both %s and %s are set (but are exclusive)\n' "$var" "$fileVar"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
local val="$def"
|
||||||
|
if [ "${!var:-}" ]; then
|
||||||
|
val="${!var}"
|
||||||
|
elif [ "${!fileVar:-}" ]; then
|
||||||
|
val="$(< "${!fileVar}")"
|
||||||
|
fi
|
||||||
|
export "$var"="$val"
|
||||||
|
unset "$fileVar"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Set values for config variables that can be passed using secrets
|
||||||
|
file_env PGADMIN_CONFIG_CONFIG_DATABASE_URI
|
||||||
|
file_env PGADMIN_DEFAULT_PASSWORD
|
||||||
|
|
||||||
# Populate config_distro.py. This has some default config, as well as anything
|
# Populate config_distro.py. This has some default config, as well as anything
|
||||||
# provided by the user through the PGADMIN_CONFIG_* environment variables.
|
# provided by the user through the PGADMIN_CONFIG_* environment variables.
|
||||||
# Only update the file on first launch. The empty file is created during the
|
# Only update the file on first launch. The empty file is created during the
|
||||||
@ -40,7 +64,7 @@ fi
|
|||||||
# Check whether the external configuration database exists if it is being used.
|
# Check whether the external configuration database exists if it is being used.
|
||||||
external_config_db_exists="False"
|
external_config_db_exists="False"
|
||||||
if [ -n "${PGADMIN_CONFIG_CONFIG_DATABASE_URI}" ]; then
|
if [ -n "${PGADMIN_CONFIG_CONFIG_DATABASE_URI}" ]; then
|
||||||
external_config_db_exists=$(cd /pgadmin4/pgadmin/utils && /venv/bin/python3 -c "from check_external_config_db import check_external_config_db; val = check_external_config_db(${PGADMIN_CONFIG_CONFIG_DATABASE_URI}); print(val)")
|
external_config_db_exists=$(cd /pgadmin4/pgadmin/utils && /venv/bin/python3 -c "from check_external_config_db import check_external_config_db; val = check_external_config_db("${PGADMIN_CONFIG_CONFIG_DATABASE_URI}"); print(val)")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -f /var/lib/pgadmin/pgadmin4.db ] && [ "${external_config_db_exists}" = "False" ]; then
|
if [ ! -f /var/lib/pgadmin/pgadmin4.db ] && [ "${external_config_db_exists}" = "False" ]; then
|
||||||
@ -59,7 +83,6 @@ if [ ! -f /var/lib/pgadmin/pgadmin4.db ] && [ "${external_config_db_exists}" = "
|
|||||||
ALLOW_SPECIAL_EMAIL_DOMAINS=${PGADMIN_CONFIG_ALLOW_SPECIAL_EMAIL_DOMAINS}
|
ALLOW_SPECIAL_EMAIL_DOMAINS=${PGADMIN_CONFIG_ALLOW_SPECIAL_EMAIL_DOMAINS}
|
||||||
fi
|
fi
|
||||||
email_config="{'CHECK_EMAIL_DELIVERABILITY': ${CHECK_EMAIL_DELIVERABILITY}, 'ALLOW_SPECIAL_EMAIL_DOMAINS': ${ALLOW_SPECIAL_EMAIL_DOMAINS}}"
|
email_config="{'CHECK_EMAIL_DELIVERABILITY': ${CHECK_EMAIL_DELIVERABILITY}, 'ALLOW_SPECIAL_EMAIL_DOMAINS': ${ALLOW_SPECIAL_EMAIL_DOMAINS}}"
|
||||||
# email_config="{'CHECK_EMAIL_DELIVERABILITY': ${CHECK_EMAIL_DELIVERABILITY}}"
|
|
||||||
echo "email config is ${email_config}"
|
echo "email config is ${email_config}"
|
||||||
is_valid_email=$(cd /pgadmin4/pgadmin/utils && /venv/bin/python3 -c "from validation_utils import validate_email; val = validate_email('${PGADMIN_DEFAULT_EMAIL}', ${email_config}); print(val)")
|
is_valid_email=$(cd /pgadmin4/pgadmin/utils && /venv/bin/python3 -c "from validation_utils import validate_email; val = validate_email('${PGADMIN_DEFAULT_EMAIL}', ${email_config}); print(val)")
|
||||||
if echo "${is_valid_email}" | grep "False" > /dev/null; then
|
if echo "${is_valid_email}" | grep "False" > /dev/null; then
|
||||||
@ -69,12 +92,6 @@ if [ ! -f /var/lib/pgadmin/pgadmin4.db ] && [ "${external_config_db_exists}" = "
|
|||||||
# Switch back to root directory for further process
|
# Switch back to root directory for further process
|
||||||
cd /pgadmin4
|
cd /pgadmin4
|
||||||
|
|
||||||
# Read secret contents
|
|
||||||
if [ -n "${PGADMIN_DEFAULT_PASSWORD_FILE}" ]; then
|
|
||||||
PGADMIN_DEFAULT_PASSWORD=$(cat "${PGADMIN_DEFAULT_PASSWORD_FILE}")
|
|
||||||
export PGADMIN_DEFAULT_PASSWORD
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Set the default username and password in a
|
# Set the default username and password in a
|
||||||
# backwards compatible way
|
# backwards compatible way
|
||||||
export PGADMIN_SETUP_EMAIL="${PGADMIN_DEFAULT_EMAIL}"
|
export PGADMIN_SETUP_EMAIL="${PGADMIN_DEFAULT_EMAIL}"
|
||||||
|
Loading…
Reference in New Issue
Block a user