diff options
author | YISH <mokeyish@hotmail.com> | 2022-03-09 06:58:14 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-03-08 17:58:14 -0500 |
commit | ddf7f1319f70e124acfd1e8e86dff4ff87290f51 (patch) | |
tree | aeb76622d5ed404c2abb31588da91974c88b2e3c /contrib/upgrade.sh | |
parent | eceab9e26f671318d3b50e622736a514f384aee6 (diff) | |
download | gitea-ddf7f1319f70e124acfd1e8e86dff4ff87290f51.tar.gz gitea-ddf7f1319f70e124acfd1e8e86dff4ff87290f51.zip |
Fix script compatiable with OpenWrt (#19000)
* Fix compatibility of upgrade.sh in openwrt and add service init script for openwrt.
* Apply suggestions from code review
Co-authored-by: Gusted <williamzijl7@hotmail.com>
Co-authored-by: zeripath <art27@cantab.net>
* Update contrib/upgrade.sh
Co-authored-by: Norwin <noerw@users.noreply.github.com>
Co-authored-by: 6543 <6543@obermui.de>
Co-authored-by: Gusted <williamzijl7@hotmail.com>
Co-authored-by: zeripath <art27@cantab.net>
Co-authored-by: techknowlogick <matti@mdranta.net>
Co-authored-by: Norwin <noerw@users.noreply.github.com>
Co-authored-by: techknowlogick <techknowlogick@gitea.io>
Diffstat (limited to 'contrib/upgrade.sh')
-rwxr-xr-x | contrib/upgrade.sh | 92 |
1 files changed, 68 insertions, 24 deletions
diff --git a/contrib/upgrade.sh b/contrib/upgrade.sh index 2f4f32bfab..171d9617c1 100755 --- a/contrib/upgrade.sh +++ b/contrib/upgrade.sh @@ -1,6 +1,4 @@ #!/usr/bin/env bash -set -euo pipefail - # This is an update script for gitea installed via the binary distribution # from dl.gitea.io on linux as systemd service. It performs a backup and updates # Gitea in place. @@ -13,6 +11,42 @@ set -euo pipefail # upgrade.sh 1.15.10 # giteahome=/opt/gitea giteaconf=$giteahome/app.ini upgrade.sh +while true; do + case "$1" in + -v | --version ) ver="$2"; shift 2 ;; + -y | --yes ) no_confirm="yes"; shift ;; + --ignore-gpg) ignore_gpg="yes"; shift ;; + -- ) shift; break ;; + * ) break ;; + esac +done + +set -euo pipefail + + +function require { + for exe in "$@"; do + command -v "$exe" &>/dev/null || (echo "missing dependency '$exe'"; exit 1) + done +} + + +require curl xz sha256sum gpg + +if [[ -f /etc/os-release ]]; then + os_release=$(cat /etc/os-release) + + if [[ "$os_release" =~ "OpenWrt" ]]; then + sudocmd="su" + service_start="/etc/init.d/gitea start" + service_stop="/etc/init.d/gitea stop" + service_status="/etc/init.d/gitea status" + else + require systemctl + fi +fi + + # apply variables from environment : "${giteabin:="/usr/local/bin/gitea"}" : "${giteahome:="/var/lib/gitea"}" @@ -20,34 +54,40 @@ set -euo pipefail : "${giteauser:="git"}" : "${sudocmd:="sudo"}" : "${arch:="linux-amd64"}" +: "${service_start:="$sudocmd systemctl start gitea"}" +: "${service_stop:="$sudocmd systemctl stop gitea"}" +: "${service_status:="$sudocmd systemctl status gitea"}" : "${backupopts:=""}" # see `gitea dump --help` for available options -function giteacmd { - "$sudocmd" --user "$giteauser" "$giteabin" --config "$giteaconf" --work-path "$giteahome" "$@" -} -function require { - for exe in "$@"; do - command -v "$exe" &>/dev/null || (echo "missing dependency '$exe'"; exit 1) - done +function giteacmd { + if [[ $sudocmd = "su" ]]; then + "$sudocmd" - "$giteauser" -c "$giteabin" --config "$giteaconf" --work-path "$giteahome" "$@" + else + "$sudocmd" --user "$giteauser" "$giteabin" --config "$giteaconf" --work-path "$giteahome" "$@" + fi } -require systemctl curl xz sha256sum gpg "$sudocmd" # select version to install -if [[ -z "${1:-}" ]]; then +if [[ -z "${ver:-}" ]]; then require jq giteaversion=$(curl --connect-timeout 10 -sL https://dl.gitea.io/gitea/version.json | jq -r .latest.version) else - giteaversion="$1" + giteaversion="$ver" fi + # confirm update -current=$(giteacmd --version | cut --delimiter=' ' --fields=3) +current=$(giteacmd --version | cut -d ' ' -f 3) [[ "$current" == "$giteaversion" ]] && echo "$current is already installed, stopping." && exit 1 -echo "Make sure to read the changelog first: https://github.com/go-gitea/gitea/blob/main/CHANGELOG.md" -echo "Are you ready to update Gitea from ${current} to ${giteaversion}? (y/N)" -read -r confirm -[[ "$confirm" == "y" ]] || [[ "$confirm" == "Y" ]] || exit 1 +if [[ -z "${no_confirm:-}" ]]; then + echo "Make sure to read the changelog first: https://github.com/go-gitea/gitea/blob/main/CHANGELOG.md" + echo "Are you ready to update Gitea from ${current} to ${giteaversion}? (y/N)" + read -r confirm + [[ "$confirm" == "y" ]] || [[ "$confirm" == "Y" ]] || exit 1 +fi + +echo "Upgrading gitea from $current to $giteaversion ..." pushd "$(pwd)" &>/dev/null cd "$giteahome" # needed for gitea dump later @@ -59,9 +99,11 @@ echo "Downloading $binurl..." curl --connect-timeout 10 --silent --show-error --fail --location -O "$binurl{,.sha256,.asc}" # validate checksum & gpg signature (exit script if error) -sha256sum --check "${binname}.xz.sha256" -gpg --keyserver keys.openpgp.org --recv 7C9E68152594688862D62AF62D9AE806EC1592E2 -gpg --verify "${binname}.xz.asc" "${binname}.xz" || { echo 'Signature does not match'; exit 1; } +sha256sum -c "${binname}.xz.sha256" +if [[ -z "${ignore_gpg:-}" ]]; then + gpg --keyserver keys.openpgp.org --recv 7C9E68152594688862D62AF62D9AE806EC1592E2 + gpg --verify "${binname}.xz.asc" "${binname}.xz" || { echo 'Signature does not match'; exit 1; } +fi rm "${binname}".xz.{sha256,asc} # unpack binary + make executable @@ -72,12 +114,14 @@ chmod +x "$binname" # stop gitea, create backup, replace binary, restart gitea echo "Stopping gitea at $(date)" giteacmd manager flush-queues -$sudocmd systemctl stop gitea +$service_stop echo "Creating backup in $giteahome" giteacmd dump $backupopts echo "Updating binary at $giteabin" -mv --force --backup "$binname" "$giteabin" -$sudocmd systemctl start gitea -$sudocmd systemctl status gitea +cp -f "$giteabin" "$giteabin.bak" && mv -f "$binname" "$giteabin" +$service_start +$service_status + +echo "Upgrade to $giteaversion successful!" popd |