fixing db update in pkgr-postinstall.sh (#311)

fixing db update in pkgr-postinstall.sh
This commit is contained in:
André Bauer 2016-10-26 16:28:59 +02:00 committed by GitHub
parent c2f8339fde
commit 51683d9859

View file

@ -9,28 +9,26 @@ ZAMMAD_DIR="/opt/zammad"
DB="zammad_production" DB="zammad_production"
DB_USER="zammad" DB_USER="zammad"
echo -e "# (Re)Create init scripts" echo "# (Re)creating init scripts"
zammad scale web=1 websocket=1 worker=1 zammad scale web=1 websocket=1 worker=1
echo -e "# Stopping Zammad" echo "# Stopping Zammad"
systemctl stop zammad systemctl stop zammad
# check if database.yml exists # check if database.yml.bak exists
if [ -f ${ZAMMAD_DIR}/config/database.yml ]; then if [ -f ${ZAMMAD_DIR}/config/database.yml.bak ]; then
# get existing password # copy database.yml.bak to database.yml
DB_PASS="$(grep "password:" < ${ZAMMAD_DIR}/config/database.yml | sed 's/.*password: //')" cp ${ZAMMAD_DIR}/config/database.yml.bak ${ZAMMAD_DIR}/config/database.yml
#zammad config set
zammad config:set DATABASE_URL=postgres://${DB_USER}:${DB_PASS}@127.0.0.1/${DB}
# db migration # db migration
echo -e "# database.yml exists. Updating db..." echo "# database.yml.bak exists. Updating db..."
zammad run rake db:migrate zammad run rake db:migrate
else else
# create new password
DB_PASS="$(tr -dc A-Za-z0-9 < /dev/urandom | head -c10)" DB_PASS="$(tr -dc A-Za-z0-9 < /dev/urandom | head -c10)"
# create database # create database
echo -e "database.yml not found. Creating new db..." echo "# database.yml not found. Creating new db..."
su - postgres -c "createdb -E UTF8 ${DB}" su - postgres -c "createdb -E UTF8 ${DB}"
# create postgres user # create postgres user
@ -40,7 +38,10 @@ else
echo "GRANT ALL PRIVILEGES ON DATABASE \"${DB}\" TO \"${DB_USER}\";" | su - postgres -c psql echo "GRANT ALL PRIVILEGES ON DATABASE \"${DB}\" TO \"${DB_USER}\";" | su - postgres -c psql
# update configfile # update configfile
sed -e "s/ password:/ password: ${DB_PASS}/" < ${ZAMMAD_DIR}/config/database.yml.pkgr > ${ZAMMAD_DIR}/config/database.yml sed "s/.*password:.*/ password: ${DB_PASS}/" < ${ZAMMAD_DIR}/config/database.yml.pkgr > ${ZAMMAD_DIR}/config/database.yml
# save database config for updates
cp ${ZAMMAD_DIR}/config/database.yml ${ZAMMAD_DIR}/config/database.yml.bak
# zammad config set # zammad config set
zammad config:set DATABASE_URL=postgres://${DB_USER}:${DB_PASS}@127.0.0.1/${DB} zammad config:set DATABASE_URL=postgres://${DB_USER}:${DB_PASS}@127.0.0.1/${DB}
@ -50,7 +51,7 @@ else
zammad run rake db:seed zammad run rake db:seed
fi fi
echo -e "# Starting Zammad" echo "# Starting Zammad"
systemctl start zammad systemctl start zammad
# nginx config # nginx config
@ -65,10 +66,10 @@ if [ -d /etc/nginx/sites-enabled ]; then
echo -e "\nAdd your FQDN to servername directive in /etc/nginx/sites/enabled/zammad.conf anmd restart nginx if you're not testing localy!\n" echo -e "\nAdd your FQDN to servername directive in /etc/nginx/sites/enabled/zammad.conf anmd restart nginx if you're not testing localy!\n"
fi fi
echo -e "\nOpen http://localhost in your browser to start using Zammad!\n" echo "# Restarting Nginx"
# restart nginx
systemctl restart nginx systemctl restart nginx
echo -e "\nOpen http://localhost in your browser to start using Zammad!\n"
else else
echo -e "\nOpen http://localhost:3000 in your browser to start using Zammad!\n" echo -e "\nOpen http://localhost:3000 in your browser to start using Zammad!\n"
fi fi