mirror of
https://github.com/cwinfo/powerdns-admin.git
synced 2025-01-24 02:34:39 +00:00
72 lines
2.4 KiB
Bash
Executable File
72 lines
2.4 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -o errexit
|
|
set -o pipefail
|
|
|
|
|
|
# == Vars
|
|
#
|
|
DB_MIGRATION_DIR='/powerdns-admin/migrations'
|
|
if [[ -z ${PDNS_PROTO} ]];
|
|
then PDNS_PROTO="http"
|
|
fi
|
|
|
|
if [[ -z ${PDNS_PORT} ]];
|
|
then PDNS_PORT=8081
|
|
fi
|
|
|
|
|
|
|
|
# Wait for us to be able to connect to MySQL before proceeding
|
|
echo "===> Waiting for $PDA_DB_HOST MySQL service"
|
|
until nc -zv \
|
|
$PDA_DB_HOST \
|
|
$PDA_DB_PORT;
|
|
do
|
|
echo "MySQL ($PDA_DB_HOST) is unavailable - sleeping"
|
|
sleep 1
|
|
done
|
|
|
|
|
|
echo "===> DB management"
|
|
# Go in Workdir
|
|
cd /powerdns-admin
|
|
|
|
if [ ! -d "${DB_MIGRATION_DIR}" ]; then
|
|
echo "---> Running DB Init"
|
|
flask db init --directory ${DB_MIGRATION_DIR}
|
|
flask db migrate -m "Init DB" --directory ${DB_MIGRATION_DIR}
|
|
flask db upgrade --directory ${DB_MIGRATION_DIR}
|
|
./init_data.py
|
|
|
|
else
|
|
echo "---> Running DB Migration"
|
|
set +e
|
|
flask db migrate -m "Upgrade DB Schema" --directory ${DB_MIGRATION_DIR}
|
|
flask db upgrade --directory ${DB_MIGRATION_DIR}
|
|
set -e
|
|
fi
|
|
|
|
echo "===> Update PDNS API connection info"
|
|
# initial setting if not available in the DB
|
|
mysql -h${PDA_DB_HOST} -u${PDA_DB_USER} -p${PDA_DB_PASSWORD} -P${PDA_DB_PORT} ${PDA_DB_NAME} -e "INSERT INTO setting (name, value) SELECT * FROM (SELECT 'pdns_api_url', '${PDNS_PROTO}://${PDNS_HOST}:${PDNS_PORT}') AS tmp WHERE NOT EXISTS (SELECT name FROM setting WHERE name = 'pdns_api_url') LIMIT 1;"
|
|
mysql -h${PDA_DB_HOST} -u${PDA_DB_USER} -p${PDA_DB_PASSWORD} -P${PDA_DB_PORT} ${PDA_DB_NAME} -e "INSERT INTO setting (name, value) SELECT * FROM (SELECT 'pdns_api_key', '${PDNS_API_KEY}') AS tmp WHERE NOT EXISTS (SELECT name FROM setting WHERE name = 'pdns_api_key') LIMIT 1;"
|
|
|
|
# update pdns api setting if .env is changed.
|
|
mysql -h${PDA_DB_HOST} -u${PDA_DB_USER} -p${PDA_DB_PASSWORD} -P${PDA_DB_PORT} ${PDA_DB_NAME} -e "UPDATE setting SET value='${PDNS_PROTO}://${PDNS_HOST}:${PDNS_PORT}' WHERE name='pdns_api_url';"
|
|
mysql -h${PDA_DB_HOST} -u${PDA_DB_USER} -p${PDA_DB_PASSWORD} -P${PDA_DB_PORT} ${PDA_DB_NAME} -e "UPDATE setting SET value='${PDNS_API_KEY}' WHERE name='pdns_api_key';"
|
|
|
|
echo "===> Assets management"
|
|
echo "---> Running Yarn"
|
|
chown -R www-data:www-data /powerdns-admin/app/static
|
|
chown -R www-data:www-data /powerdns-admin/node_modules
|
|
su -s /bin/bash -c 'yarn install --pure-lockfile' www-data
|
|
|
|
echo "---> Running Flask assets"
|
|
chown -R www-data:www-data /powerdns-admin/logs
|
|
su -s /bin/bash -c 'flask assets build' www-data
|
|
|
|
|
|
echo "===> Start supervisor"
|
|
/usr/bin/supervisord -c /etc/supervisord.conf
|