diff options
author | Andreas Hubel | 2020-11-29 20:39:34 +0100 |
---|---|---|
committer | Andreas Hubel | 2020-11-29 21:13:40 +0100 |
commit | bbea394ffc0493f56dee7273bf0d56254673b7e7 (patch) | |
tree | 781b2f2d861145e351ffbe7c07a06d49efa9e6be /deploy-staging.sh | |
parent | 9cfd9517d52c3d8ff860de9b8247a7c58361bc98 (diff) |
add deployment script for streaming.test.c3voc.de
Diffstat (limited to 'deploy-staging.sh')
-rwxr-xr-x | deploy-staging.sh | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/deploy-staging.sh b/deploy-staging.sh new file mode 100755 index 0000000..d6a3cc2 --- /dev/null +++ b/deploy-staging.sh @@ -0,0 +1,69 @@ +#!/bin/bash + +for cmd in find xargs php git; do + command -v $cmd >/dev/null 2>&1 || { echo >&2 "I require $cmd but it's not installed. Aborting."; exit 1; } +done + + +find . -name "*.php" -print0 | xargs -0 -n1 php -l +if [ $? -ne 0 ]; then + echo "not deploying b0rken code ;)" + exit 1 +fi + +echo "" +DEPLOY_BRANCH=`git rev-parse --abbrev-ref HEAD` + +if [ `git rev-parse --verify origin/$DEPLOY_BRANCH` != `git rev-parse --verify $DEPLOY_BRANCH` ] && [ `git rev-parse --verify origin/staging` != `git rev-parse --verify $DEPLOY_BRANCH` ]; then + echo "You have commits on the $DEPLOY_BRANCH branch not pushed to origin yet. They would not be deployed." + echo "do you still which to deploy what's already in the repo? then type yes" + read -p "" input + if [ "x$input" != "xyes" ]; then + exit 2 + fi + echo "" +fi + +if ! (git diff --exit-code >/dev/null && git diff --cached --exit-code >/dev/null); then + echo "You have uncomitted changes. They would not be deployed." + echo "do you still which to deploy what's already in the repo? then type yes" + read -p "" input + if [ "x$input" != "xyes" ]; then + exit 2 + fi + echo "" +fi + +if [ "x$DEPLOY_BRANCH" != "xmaster" ] && [ "x$DEPLOY_BRANCH" != "xstaging" ]; then + echo "You're currently on branch $DEPLOY_BRANCH." + echo "Are you sure you want to deploy that branch (and not master)? then type yes" + read -p "" input + if [ "x$input" != "xyes" ]; then + exit 2 + fi + echo "" +fi + +for host in streaming.test.c3voc.de; do + echo "deploying to $host" + ssh -A voc@$host 'sudo sh' << EOT +cd /srv/nginx/streaming-website + +echo "updating code" +git fetch origin +git reset --hard HEAD +git checkout $DEPLOY_BRANCH +git reset --hard origin/$DEPLOY_BRANCH + +echo "fixing permissions" +chown -R voc:staff . +chown -R downloader configs + +echo "re-downloading schedules" +sudo -udownloader php index.php download + +echo "clearing cache" +./clear_cache +EOT + echo "deploying to $host done" +done
\ No newline at end of file |