82 lines
2.1 KiB
Bash
82 lines
2.1 KiB
Bash
|
#!/bin/bash
|
||
|
set -e
|
||
|
|
||
|
chmod +x parseurl.py
|
||
|
eval $(./parseurl.py)
|
||
|
|
||
|
: ${ETHERPAD_DB_HOST:=mysql}
|
||
|
: ${ETHERPAD_DB_USER:=root}
|
||
|
: ${ETHERPAD_DB_NAME:=etherpad}
|
||
|
ETHERPAD_DB_NAME=$( echo $ETHERPAD_DB_NAME | sed 's/\./_/g' )
|
||
|
|
||
|
# 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
|
||
|
if [ "$ETHERPAD_DB_USER" = 'root' ]; then
|
||
|
: ${ETHERPAD_DB_PASSWORD:=$MYSQL_ENV_MYSQL_ROOT_PASSWORD}
|
||
|
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=... ?'
|
||
|
echo >&2
|
||
|
echo >&2 ' (Also of interest might be ETHERPAD_DB_USER and ETHERPAD_DB_NAME.)'
|
||
|
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
|
||
|
RESULT=`mysql -u${ETHERPAD_DB_USER} -p${ETHERPAD_DB_PASSWORD} \
|
||
|
-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}"
|
||
|
|
||
|
mysql -u${ETHERPAD_DB_USER} -p${ETHERPAD_DB_PASSWORD} -h${ETHERPAD_DB_HOST} \
|
||
|
-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" : {
|
||
|
"user" : "${ETHERPAD_DB_USER}",
|
||
|
"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 "$@"
|