2017-07-07 13:02:43 +00:00
|
|
|
#!/bin/bash
|
|
|
|
set -e
|
|
|
|
|
2017-07-18 11:55:37 +00:00
|
|
|
chmod +x /parseurl.py
|
2017-07-18 15:33:05 +00:00
|
|
|
/parseurl.py ETHERPAD_DB_
|
2017-07-18 11:55:37 +00:00
|
|
|
eval $(/parseurl.py ETHERPAD_DB_)
|
2017-07-07 13:02:43 +00:00
|
|
|
|
|
|
|
# ETHERPAD_DB_PASSWORD is mandatory in mysql container, so we're not offering
|
|
|
|
# any default. If we're linked to MySQL through legacy link, then we can try
|
|
|
|
# using the password from the env variable MYSQL_ENV_MYSQL_ROOT_PASSWORD
|
2017-07-18 11:55:37 +00:00
|
|
|
# if [ "$ETHERPAD_DB_USERNAME" = 'root' ]; then
|
|
|
|
# : ${ETHERPAD_DB_PASSWORD:=$MYSQL_ENV_MYSQL_ROOT_PASSWORD}
|
|
|
|
# fi
|
|
|
|
|
|
|
|
if [ -z "$ETHERPAD_DB_USERNAME" ]; then
|
|
|
|
echo >&2 'error: missing required ETHERPAD_DB_USERNAME environment variable'
|
|
|
|
echo >&2 ' Did you forget to -e ETHERPAD_DB_USERNAME=... ?'
|
|
|
|
exit 1
|
2017-07-07 13:02:43 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "$ETHERPAD_DB_PASSWORD" ]; then
|
|
|
|
echo >&2 'error: missing required ETHERPAD_DB_PASSWORD environment variable'
|
|
|
|
echo >&2 ' Did you forget to -e ETHERPAD_DB_PASSWORD=... ?'
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
: ${ETHERPAD_TITLE:=Etherpad}
|
|
|
|
: ${ETHERPAD_PORT:=9001}
|
|
|
|
: ${ETHERPAD_SESSION_KEY:=$(
|
|
|
|
node -p "require('crypto').randomBytes(32).toString('hex')")}
|
|
|
|
|
|
|
|
# Check if database already exists
|
2017-07-18 11:55:37 +00:00
|
|
|
RESULT=`mysql -u${ETHERPAD_DB_USERNAME} -p${ETHERPAD_DB_PASSWORD} \
|
2017-07-07 13:02:43 +00:00
|
|
|
-h${ETHERPAD_DB_HOST} --skip-column-names \
|
|
|
|
-e "SHOW DATABASES LIKE '${ETHERPAD_DB_NAME}'"`
|
|
|
|
|
|
|
|
if [ "$RESULT" != $ETHERPAD_DB_NAME ]; then
|
|
|
|
# mysql database does not exist, create it
|
|
|
|
echo "Creating database ${ETHERPAD_DB_NAME}"
|
|
|
|
|
2017-07-18 11:55:37 +00:00
|
|
|
mysql -u${ETHERPAD_DB_USERNAME} -p${ETHERPAD_DB_PASSWORD} -h${ETHERPAD_DB_HOST} \
|
2017-07-07 13:02:43 +00:00
|
|
|
-e "create database ${ETHERPAD_DB_NAME}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ! -f settings.json ]; then
|
|
|
|
|
|
|
|
cat <<- EOF > settings.json
|
|
|
|
{
|
|
|
|
"title": "${ETHERPAD_TITLE}",
|
|
|
|
"ip": "0.0.0.0",
|
|
|
|
"port" :${ETHERPAD_PORT},
|
|
|
|
"sessionKey" : "${ETHERPAD_SESSION_KEY}",
|
|
|
|
"dbType" : "mysql",
|
|
|
|
"dbSettings" : {
|
2017-07-18 11:55:37 +00:00
|
|
|
"user" : "${ETHERPAD_DB_USERNAME}",
|
2017-07-07 13:02:43 +00:00
|
|
|
"host" : "${ETHERPAD_DB_HOST}",
|
|
|
|
"password": "${ETHERPAD_DB_PASSWORD}",
|
|
|
|
"database": "${ETHERPAD_DB_NAME}"
|
|
|
|
},
|
|
|
|
EOF
|
|
|
|
|
|
|
|
if [ $ETHERPAD_ADMIN_PASSWORD ]; then
|
|
|
|
|
|
|
|
: ${ETHERPAD_ADMIN_USER:=admin}
|
|
|
|
|
|
|
|
cat <<- EOF >> settings.json
|
|
|
|
"users": {
|
|
|
|
"${ETHERPAD_ADMIN_USER}": {
|
|
|
|
"password": "${ETHERPAD_ADMIN_PASSWORD}",
|
|
|
|
"is_admin": true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
EOF
|
|
|
|
fi
|
|
|
|
|
|
|
|
cat <<- EOF >> settings.json
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
fi
|
|
|
|
|
|
|
|
exec "$@"
|