mailcow/update.sh

40 lines
1.4 KiB
Bash
Raw Normal View History

2017-06-20 05:31:43 +08:00
#!/bin/bash
set -o pipefail
export LC_ALL=C
2017-06-20 06:02:03 +08:00
DATE=$(date +%Y-%m-%d_%H_%M_%S)
2017-06-20 05:31:43 +08:00
BRANCH=$(git rev-parse --abbrev-ref HEAD)
2017-06-20 06:02:03 +08:00
for image in "phpfpm" "dovecot" "postfix" "sogo" "unbound" "rspamd" "clamd"; do
if [[ ! -z $(docker images mailcow/${image} -q) ]]; then
2017-06-20 06:03:09 +08:00
echo -e "\e[32mSaving mailcow/${image} to mailcow/${image}:${DATE}...\e[90m"
docker tag mailcow/${image} mailcow/${image}:${DATE}
2017-06-20 06:02:03 +08:00
fi
done
2017-06-20 05:31:43 +08:00
# Silently fixing remote url from andryyy to mailcow
git remote set-url origin https://github.com/mailcow/mailcow-dockerized
echo -e "\e[32mCommitting current status...\e[90m"
git add -u
git commit -am "Before update on ${DATE}" > /dev/null
echo -e "\e[32mFetching updated code from remote...\e[90m"
2017-06-20 06:02:03 +08:00
git fetch origin master
2017-06-20 05:31:43 +08:00
echo -e "\e[32mMerging local with remote code...\e[90m"
git merge -Xtheirs -Xpatience -m "After update on ${DATE}"
if [[ $? == 1 ]]; then
2017-06-20 06:03:09 +08:00
echo -e "\e[31mRun into conflict, trying to fix...\e[90m"
git status --porcelain | grep -E "UD|DU" | awk '{print $2}' | xargs rm -v
git add -A
git commit -m "After update on ${DATE}" > /dev/null
git checkout .
echo -e "\e[32mRemoved and recreated files if necessary.\e[90m"
2017-06-20 05:31:43 +08:00
fi
echo -e "\e[32mDone!\e[0m"
2017-06-20 06:02:03 +08:00
echo
echo -e "\e[32mHashes to revert to:\e[0m"
git reflog --color=always | grep "Before update on "
2017-06-20 05:31:43 +08:00
2017-06-20 06:03:09 +08:00
# TODO: Menu, select hard reset, select reset to "before update" etc.
2017-06-20 05:31:43 +08:00
#git reset --hard origin/${BRANCH}