2019-11-21 09:43:00 +01:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
# NOTE: Parsing curl to tac to circumnvent "failed writing body"
|
|
|
|
# https://stackoverflow.com/questions/16703647/why-curl-return-and-error-23-failed-writing-body
|
|
|
|
|
|
|
|
set -e
|
|
|
|
set -u
|
|
|
|
set -o pipefail
|
|
|
|
|
|
|
|
SCRIPT_PATH="$( cd "$(dirname "$0")" && pwd -P )"
|
|
|
|
DVLBOX_PATH="$( cd "${SCRIPT_PATH}/../.." && pwd -P )"
|
|
|
|
# shellcheck disable=SC1090
|
|
|
|
. "${SCRIPT_PATH}/../scripts/.lib.sh"
|
|
|
|
|
|
|
|
RETRIES=10
|
2020-11-08 15:52:32 +01:00
|
|
|
DISABLED_VERSIONS=("")
|
2019-11-21 09:43:00 +01:00
|
|
|
|
|
|
|
|
|
|
|
echo
|
|
|
|
echo "# --------------------------------------------------------------------------------------------------"
|
|
|
|
echo "# [Vendor] Adminer: PostgreSQL"
|
|
|
|
echo "# --------------------------------------------------------------------------------------------------"
|
|
|
|
echo
|
|
|
|
|
|
|
|
|
|
|
|
# -------------------------------------------------------------------------------------------------
|
|
|
|
# Pre-check
|
|
|
|
# -------------------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
PHP_VERSION="$( get_php_version "${DVLBOX_PATH}" )"
|
|
|
|
if [[ ${DISABLED_VERSIONS[*]} =~ ${PHP_VERSION} ]]; then
|
|
|
|
printf "[SKIP] Skipping all checks for PHP %s\\n" "${PHP_VERSION}"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
# -------------------------------------------------------------------------------------------------
|
|
|
|
# ENTRYPOINT
|
|
|
|
# -------------------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
###
|
|
|
|
### Get required env values
|
|
|
|
###
|
|
|
|
HOST_PORT_HTTPD="$( "${SCRIPT_PATH}/../scripts/env-getvar.sh" "HOST_PORT_HTTPD" )"
|
|
|
|
|
|
|
|
|
|
|
|
###
|
|
|
|
### Retrieve URL for current Adminer version.
|
|
|
|
###
|
|
|
|
printf "[TEST] Retrieve Adminer URL"
|
|
|
|
if ! URL="$( run "\
|
|
|
|
curl -sS --fail 'http://localhost:${HOST_PORT_HTTPD}/index.php' \
|
|
|
|
| tac \
|
|
|
|
| tac \
|
2020-11-08 15:42:43 +01:00
|
|
|
| grep -Eo '/vendor/adminer-[.0-9]+-en(-php8)?\\.php'" \
|
2019-11-21 09:43:00 +01:00
|
|
|
"${RETRIES}" "" "0" )"; then
|
|
|
|
printf "\\r[FAILED] Retrieve Adminer URL\\n"
|
|
|
|
run "curl -sS 'http://localhost:${HOST_PORT_HTTPD}/index.php' || true"
|
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
printf "\\r[OK] Retrieve Adminer URL: %s\\n" "${URL}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
###
|
|
|
|
### Ensure given Adminer version works
|
|
|
|
###
|
|
|
|
printf "[TEST] Fetch %s" "${URL}"
|
|
|
|
if ! run "\
|
|
|
|
curl -sS --fail 'http://localhost:${HOST_PORT_HTTPD}${URL}' \
|
|
|
|
| tac \
|
|
|
|
| tac \
|
|
|
|
| grep -Ei 'Login.+Adminer' >/dev/null" \
|
|
|
|
"${RETRIES}" "" "0"; then
|
|
|
|
printf "\\r[FAILED] Fetch %s\\n" "${URL}"
|
|
|
|
run "curl -sS 'http://localhost:${HOST_PORT_HTTPD}${URL}' || true"
|
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
printf "\\r[OK] Fetch %s\\n" "${URL}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
###
|
|
|
|
### Test Adminer PostgreSQL login
|
|
|
|
###
|
|
|
|
PGSQL_ROOT_USER="$( "${SCRIPT_PATH}/../scripts/env-getvar.sh" "PGSQL_ROOT_USER" )"
|
|
|
|
PGSQL_ROOT_PASSWORD="$( "${SCRIPT_PATH}/../scripts/env-getvar.sh" "PGSQL_ROOT_PASSWORD" )"
|
|
|
|
|
|
|
|
printf "[TEST] Adminer PgSQL login"
|
|
|
|
if ! run "\
|
|
|
|
curl -sS --fail -c cookie.txt -b cookie.txt \
|
|
|
|
-L \
|
|
|
|
--data 'auth[driver]=pgsql' \
|
|
|
|
--data 'auth[server]=pgsql' \
|
|
|
|
--data 'auth[username]=${PGSQL_ROOT_USER}' \
|
|
|
|
--data 'auth[password]=${PGSQL_ROOT_PASSWORD}' \
|
|
|
|
--data 'auth[db]=' \
|
|
|
|
'http://localhost:${HOST_PORT_HTTPD}${URL}?pgsql=pgsql' \
|
|
|
|
| tac \
|
|
|
|
| tac \
|
|
|
|
| grep -Ei 'Database.+Collation.+Tables' >/dev/null" \
|
|
|
|
"${RETRIES}" "" "0"; then
|
|
|
|
printf "\\r[FAIL] Adminer PgSQL login\\n"
|
|
|
|
run "curl -sS -c cookie.txt -b cookie.txt \
|
|
|
|
-L \
|
|
|
|
--data 'auth[driver]=pgsql' \
|
|
|
|
--data 'auth[server]=pgsql' \
|
|
|
|
--data 'auth[username]=${PGSQL_ROOT_USER}' \
|
|
|
|
--data 'auth[password]=${PGSQL_ROOT_PASSWORD}' \
|
|
|
|
--data 'auth[db]=' \
|
|
|
|
'http://localhost:${HOST_PORT_HTTPD}${URL}?pgsql=pgsql' || true" "1"
|
|
|
|
run "curl -sS -I -c cookie.txt -b cookie.txt \
|
|
|
|
-L \
|
|
|
|
--data 'auth[driver]=pgsql' \
|
|
|
|
--data 'auth[server]=pgsql' \
|
|
|
|
--data 'auth[username]=${PGSQL_ROOT_USER}' \
|
|
|
|
--data 'auth[password]=${PGSQL_ROOT_PASSWORD}' \
|
|
|
|
--data 'auth[db]=' \
|
|
|
|
'http://localhost:${HOST_PORT_HTTPD}${URL}?pgsql=pgsql' || true" "1"
|
|
|
|
rm -f cookie.txt
|
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
printf "\\r[OK] Adminer PgSQL login\\n"
|
|
|
|
fi
|
|
|
|
rm -f cookie.txt
|