From 82976fd5205b8a0101f6609764dd34526104814a Mon Sep 17 00:00:00 2001 From: Manu Miu Date: Sat, 28 Nov 2020 16:40:26 +1000 Subject: [PATCH] [IMP] add option to customize wait-for-psql.py timeout Allow users to pass a custom timeout value for the `wait-for-psql.py` script to the container via the `PSQL_TIMEOUT` environment variable. The timeout of 30 seconds still remains the default. --- 12.0/entrypoint.sh | 16 +++++++++++----- 13.0/entrypoint.sh | 16 +++++++++++----- 14.0/entrypoint.sh | 16 +++++++++++----- 3 files changed, 33 insertions(+), 15 deletions(-) diff --git a/12.0/entrypoint.sh b/12.0/entrypoint.sh index 6dd42c4..1d6df0d 100755 --- a/12.0/entrypoint.sh +++ b/12.0/entrypoint.sh @@ -8,17 +8,23 @@ set -e : ${PORT:=${DB_PORT_5432_TCP_PORT:=5432}} : ${USER:=${DB_ENV_POSTGRES_USER:=${POSTGRES_USER:='odoo'}}} : ${PASSWORD:=${DB_ENV_POSTGRES_PASSWORD:=${POSTGRES_PASSWORD:='odoo'}}} +: ${PSQL_TIMEOUT:=${DB_INIT_TIMEOUT:=30}} DB_ARGS=() function check_config() { param="$1" value="$2" - if grep -q -E "^\s*\b${param}\b\s*=" "$ODOO_RC" ; then - value=$(grep -E "^\s*\b${param}\b\s*=" "$ODOO_RC" |cut -d " " -f3|sed 's/["\n\r]//g') - fi; + if grep -q -E "^\s*\b${param}\b\s*=" "$ODOO_RC"; then + value=$( + grep -E "^\s*\b${param}\b\s*=" "$ODOO_RC" \ + | cut -d " " -f3 \ + | sed 's/["\n\r]//g' + ) + fi DB_ARGS+=("--${param}") DB_ARGS+=("${value}") } + check_config "db_host" "$HOST" check_config "db_port" "$PORT" check_config "db_user" "$USER" @@ -30,12 +36,12 @@ case "$1" in if [[ "$1" == "scaffold" ]] ; then exec odoo "$@" else - wait-for-psql.py ${DB_ARGS[@]} --timeout=30 + wait-for-psql.py ${DB_ARGS[@]} --timeout=$PSQL_TIMEOUT exec odoo "$@" "${DB_ARGS[@]}" fi ;; -*) - wait-for-psql.py ${DB_ARGS[@]} --timeout=30 + wait-for-psql.py ${DB_ARGS[@]} --timeout=$PSQL_TIMEOUT exec odoo "$@" "${DB_ARGS[@]}" ;; *) diff --git a/13.0/entrypoint.sh b/13.0/entrypoint.sh index 6dd42c4..1d6df0d 100755 --- a/13.0/entrypoint.sh +++ b/13.0/entrypoint.sh @@ -8,17 +8,23 @@ set -e : ${PORT:=${DB_PORT_5432_TCP_PORT:=5432}} : ${USER:=${DB_ENV_POSTGRES_USER:=${POSTGRES_USER:='odoo'}}} : ${PASSWORD:=${DB_ENV_POSTGRES_PASSWORD:=${POSTGRES_PASSWORD:='odoo'}}} +: ${PSQL_TIMEOUT:=${DB_INIT_TIMEOUT:=30}} DB_ARGS=() function check_config() { param="$1" value="$2" - if grep -q -E "^\s*\b${param}\b\s*=" "$ODOO_RC" ; then - value=$(grep -E "^\s*\b${param}\b\s*=" "$ODOO_RC" |cut -d " " -f3|sed 's/["\n\r]//g') - fi; + if grep -q -E "^\s*\b${param}\b\s*=" "$ODOO_RC"; then + value=$( + grep -E "^\s*\b${param}\b\s*=" "$ODOO_RC" \ + | cut -d " " -f3 \ + | sed 's/["\n\r]//g' + ) + fi DB_ARGS+=("--${param}") DB_ARGS+=("${value}") } + check_config "db_host" "$HOST" check_config "db_port" "$PORT" check_config "db_user" "$USER" @@ -30,12 +36,12 @@ case "$1" in if [[ "$1" == "scaffold" ]] ; then exec odoo "$@" else - wait-for-psql.py ${DB_ARGS[@]} --timeout=30 + wait-for-psql.py ${DB_ARGS[@]} --timeout=$PSQL_TIMEOUT exec odoo "$@" "${DB_ARGS[@]}" fi ;; -*) - wait-for-psql.py ${DB_ARGS[@]} --timeout=30 + wait-for-psql.py ${DB_ARGS[@]} --timeout=$PSQL_TIMEOUT exec odoo "$@" "${DB_ARGS[@]}" ;; *) diff --git a/14.0/entrypoint.sh b/14.0/entrypoint.sh index 6dd42c4..1d6df0d 100755 --- a/14.0/entrypoint.sh +++ b/14.0/entrypoint.sh @@ -8,17 +8,23 @@ set -e : ${PORT:=${DB_PORT_5432_TCP_PORT:=5432}} : ${USER:=${DB_ENV_POSTGRES_USER:=${POSTGRES_USER:='odoo'}}} : ${PASSWORD:=${DB_ENV_POSTGRES_PASSWORD:=${POSTGRES_PASSWORD:='odoo'}}} +: ${PSQL_TIMEOUT:=${DB_INIT_TIMEOUT:=30}} DB_ARGS=() function check_config() { param="$1" value="$2" - if grep -q -E "^\s*\b${param}\b\s*=" "$ODOO_RC" ; then - value=$(grep -E "^\s*\b${param}\b\s*=" "$ODOO_RC" |cut -d " " -f3|sed 's/["\n\r]//g') - fi; + if grep -q -E "^\s*\b${param}\b\s*=" "$ODOO_RC"; then + value=$( + grep -E "^\s*\b${param}\b\s*=" "$ODOO_RC" \ + | cut -d " " -f3 \ + | sed 's/["\n\r]//g' + ) + fi DB_ARGS+=("--${param}") DB_ARGS+=("${value}") } + check_config "db_host" "$HOST" check_config "db_port" "$PORT" check_config "db_user" "$USER" @@ -30,12 +36,12 @@ case "$1" in if [[ "$1" == "scaffold" ]] ; then exec odoo "$@" else - wait-for-psql.py ${DB_ARGS[@]} --timeout=30 + wait-for-psql.py ${DB_ARGS[@]} --timeout=$PSQL_TIMEOUT exec odoo "$@" "${DB_ARGS[@]}" fi ;; -*) - wait-for-psql.py ${DB_ARGS[@]} --timeout=30 + wait-for-psql.py ${DB_ARGS[@]} --timeout=$PSQL_TIMEOUT exec odoo "$@" "${DB_ARGS[@]}" ;; *)