#!/bin/bash # # packager.io postinstall script # PATH=/opt/zammad/bin:/opt/zammad/vendor/bundle/bin:/sbin:/bin:/usr/sbin:/usr/bin: DB="zammad_production" DB_USER="zammad" # get existing db pass DB_PASS="$(grep "password:" < /opt/zammad/config/database.yml | sed 's/.*password://')" # check if db pass exists if [ -z "${DB_PASS}" ]; then # create new db pass DB_PASS="$(tr -dc A-Za-z0-9 < /dev/urandom | head -c10)" # create database cd /tmp su - postgres -c "createdb -E UTF8 ${DB}" # create postgres user echo "CREATE USER \"${DB_USER}\" WITH PASSWORD '${DB_PASS}';" | su - postgres -c psql # grant privileges echo "GRANT ALL PRIVILEGES ON DATABASE \"${DB}\" TO \"${DB_USER}\";" | su - postgres -c psql # update configfile sed -e "s/ password:/ password: ${DB_PASS}/" < /opt/zammad/config/database.yml.pkgr > /opt/zammad/config/database.yml # zammad config set zammad config:set DATABASE_URL=postgres://${DB_USER}:${DB_PASS}@127.0.0.1/${DB} # fill database zammad run rake db:migrate zammad run rake db:seed fi # create init scripts zammad scale web=1 websocket=1 worker=1 # stop zammad systemctl stop zammad # db migration zammad run rake db:migrate # start zammad systemctl start zammad