123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- #!/bin/bash
- set -e
- cd /app
- source /app/.env.example
- if [ -n "${MYSQL_PORT_3306_TCP_ADDR}" ]; then
- HUGINN_DATABASE_ADAPTER=${HUGINN_DATABASE_ADAPTER:-mysql2}
- HUGINN_DATABASE_HOST=${HUGINN_DATABASE_HOST:-${MYSQL_PORT_3306_TCP_ADDR}}
- HUGINN_DATABASE_PORT=${HUGINN_DATABASE_PORT:-${MYSQL_PORT_3306_TCP_PORT}}
- elif [ -n "${POSTGRESQL_PORT_5432_TCP_ADDR}" ]; then
- HUGINN_DATABASE_ADAPTER=${HUGINN_DATABASE_ADAPTER:-postgres}
- HUGINN_DATABASE_HOST=${HUGINN_DATABASE_HOST:-${POSTGRESQL_PORT_5432_TCP_ADDR}}
- HUGINN_DATABASE_PORT=${HUGINN_DATABASE_PORT:-${POSTGRESQL_PORT_5432_TCP_PORT}}
- fi
- grep = /app/.env.example | sed -e 's/^#[^ ]//' | grep -v -e '^#' | cut -d= -f1 | \
- while read var ; do
- eval "echo \"$var=\\\"\${HUGINN_$var:-\$$var}\\\"\""
- done | grep -v -e ^= > /app/.env
- chmod ugo+r /app/.env
- source /app/.env
- DATABASE_HOST=${HUGINN_DATABASE_HOST:-${DATABASE_HOST:-localhost}}
- DATABASE_ENCODING=${HUGINN_DATABASE_ENCODING:-${DATABASE_ENCODING}}
- USE_GRAPHVIZ_DOT=${HUGINN_USE_GRAPHVIZ_DOT:-${USE_GRAPHVIZ_DOT}}
- case "${DATABASE_ADAPTER}" in
- mysql2) DATABASE_PORT=${DATABASE_PORT:-3306} ;;
- postgres) DATABASE_PORT=${DATABASE_PORT:-5432} ;;
- *) echo "Unsupported database adapter. Available adapters are mysql2, and postgres." && exit 1 ;;
- esac
- /usr/bin/supervisord -c /etc/supervisor/supervisord.conf
- if [ "${DATABASE_HOST}" == "localhost" ]; then
- if [ "${DATABASE_ADAPTER}" == "postgres" ]; then
- echo "DATABASE_ADAPTER 'postgres' is not supported internally. Please provide DATABASE_HOST."
- exit 1
- fi
-
- cat > /etc/supervisor/conf.d/mysqld.conf <<EOF
- [program:mysqld]
- priority=20
- directory=/tmp
- command=/usr/bin/mysqld_safe
- user=root
- autostart=false
- autorestart=true
- stdout_logfile=/var/log/supervisor/%(program_name)s.log
- stderr_logfile=/var/log/supervisor/%(program_name)s.log
- EOF
- supervisorctl reload
-
- chown -R mysql:mysql /var/lib/mysql
- chmod 700 /var/lib/mysql
-
- if [ ! -d /var/lib/mysql/mysql ]; then
- mysql_install_db --user=mysql
- fi
- echo "Starting mysql server..."
- supervisorctl start mysqld >/dev/null
-
- timeout=120
- while ! mysqladmin -uroot ${DATABASE_PASSWORD:+-p$DATABASE_PASSWORD} status >/dev/null 2>&1
- do
- timeout=$(expr $timeout - 1)
- if [ $timeout -eq 0 ]; then
- echo "Failed to start mysql server"
- exit 1
- fi
- sleep 1
- done
- if ! echo "USE ${DATABASE_NAME}" | mysql -uroot ${DATABASE_PASSWORD:+-p$DATABASE_PASSWORD} >/dev/null 2>&1; then
- DB_INIT="yes"
- echo "CREATE DATABASE IF NOT EXISTS \`${DATABASE_NAME}\` DEFAULT CHARACTER SET \`utf8\` COLLATE \`utf8_unicode_ci\`;" | mysql -uroot ${DATABASE_PASSWORD:+-p$DATABASE_PASSWORD}
- echo "GRANT SELECT, LOCK TABLES, INSERT, UPDATE, DELETE, CREATE, DROP, INDEX, ALTER ON \`${DATABASE_NAME}\`.* TO 'root'@'localhost';" | mysql -uroot ${DATABASE_PASSWORD:+-p$DATABASE_PASSWORD}
- fi
- fi
- [ -z "${DO_NOT_MIGRATE}" ] && sudo -u huginn -EH bundle exec rake db:migrate
- [ -z "${DO_NOT_SEED}" ] && sudo -u huginn -EH bundle exec rake db:seed
- [ -n "$INTENTIONALLY_SLEEP" ] && sleep $INTENTIONALLY_SLEEP
- [ -z "${DO_NOT_RUN_JOBS}" ] && perl -pi -e 's/^jobs:/#jobs:/' /app/Procfile
- perl -pi -e 's/rails server$/rails server -p \$PORT/' /app/Procfile
- export PORT
- sudo -u huginn -EH bundle exec foreman start
- exit 0
|