2019-10-09 07:30:39 -04:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
# set the postgres database host, port, user and password according to the environment
|
|
|
|
# and pass them as arguments to the odoo process if not present in the config file
|
|
|
|
: ${HOST:=${DB_PORT_5432_TCP_ADDR:='db'}}
|
|
|
|
: ${PORT:=${DB_PORT_5432_TCP_PORT:=5432}}
|
|
|
|
: ${USER:=${DB_ENV_POSTGRES_USER:=${POSTGRES_USER:='odoo'}}}
|
|
|
|
: ${PASSWORD:=${DB_ENV_POSTGRES_PASSWORD:=${POSTGRES_PASSWORD:='odoo'}}}
|
2020-11-28 01:40:26 -05:00
|
|
|
: ${PSQL_TIMEOUT:=${DB_INIT_TIMEOUT:=30}}
|
2019-10-09 07:30:39 -04:00
|
|
|
|
|
|
|
DB_ARGS=()
|
|
|
|
function check_config() {
|
|
|
|
param="$1"
|
|
|
|
value="$2"
|
2020-11-28 01:40:26 -05:00
|
|
|
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
|
2019-10-25 14:46:46 -04:00
|
|
|
DB_ARGS+=("--${param}")
|
|
|
|
DB_ARGS+=("${value}")
|
2019-10-09 07:30:39 -04:00
|
|
|
}
|
2020-11-28 01:40:26 -05:00
|
|
|
|
2019-10-09 07:30:39 -04:00
|
|
|
check_config "db_host" "$HOST"
|
|
|
|
check_config "db_port" "$PORT"
|
|
|
|
check_config "db_user" "$USER"
|
|
|
|
check_config "db_password" "$PASSWORD"
|
|
|
|
|
|
|
|
case "$1" in
|
|
|
|
-- | odoo)
|
|
|
|
shift
|
|
|
|
if [[ "$1" == "scaffold" ]] ; then
|
|
|
|
exec odoo "$@"
|
|
|
|
else
|
2020-11-28 01:40:26 -05:00
|
|
|
wait-for-psql.py ${DB_ARGS[@]} --timeout=$PSQL_TIMEOUT
|
2019-10-09 07:30:39 -04:00
|
|
|
exec odoo "$@" "${DB_ARGS[@]}"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
-*)
|
2020-11-28 01:40:26 -05:00
|
|
|
wait-for-psql.py ${DB_ARGS[@]} --timeout=$PSQL_TIMEOUT
|
2019-10-09 07:30:39 -04:00
|
|
|
exec odoo "$@" "${DB_ARGS[@]}"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
exec "$@"
|
|
|
|
esac
|
|
|
|
|
|
|
|
exit 1
|