]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - scripts/upgrade.sh
Don't import test tools in core
[github/Chocobozzz/PeerTube.git] / scripts / upgrade.sh
CommitLineData
0e4ffb4b 1#!/bin/sh
64586951 2
0e4ffb4b 3set -eu
64586951 4
b4e5942c
JJ
5PEERTUBE_PATH=${1:-/var/www/peertube/}
6
7if [ ! -e "$PEERTUBE_PATH" ]; then
8 echo "Error - path \"$PEERTUBE_PATH\" wasn't found"
9 echo ""
10 echo "If peertube was installed in another path, you can specify it with"
11 echo " ./upgrade.sh <PATH>"
12 exit 1
13fi
14
15if [ ! -e "$PEERTUBE_PATH/versions" -o ! -e "$PEERTUBE_PATH/config/production.yaml" ]; then
16 echo "Error - Couldn't find peertube installation in \"$PEERTUBE_PATH\""
17 echo ""
18 echo "If peertube was installed in another path, you can specify it with"
19 echo " ./upgrade.sh <PATH>"
20 exit 1
21fi
22
ee1219d8 23
64586951 24# Backup database
ee1219d8 25SQL_BACKUP_PATH="$PEERTUBE_PATH/backup/sql-peertube_prod-$(date +"%Y%m%d-%H%M").bak"
d9d1989b
LD
26DB_USER=$(node -e "console.log(require('js-yaml').safeLoad(fs.readFileSync('$PEERTUBE_PATH/config/production.yaml', 'utf8'))['database']['username'])")
27DB_PASS=$(node -e "console.log(require('js-yaml').safeLoad(fs.readFileSync('$PEERTUBE_PATH/config/production.yaml', 'utf8'))['database']['password'])")
28DB_HOST=$(node -e "console.log(require('js-yaml').safeLoad(fs.readFileSync('$PEERTUBE_PATH/config/production.yaml', 'utf8'))['database']['hostname'])")
29DB_SUFFIX=$(node -e "console.log(require('js-yaml').safeLoad(fs.readFileSync('$PEERTUBE_PATH/config/production.yaml', 'utf8'))['database']['suffix'])")
ee1219d8 30mkdir -p $PEERTUBE_PATH/backup
d9d1989b
LD
31
32PGPASSWORD=$DB_PASS pg_dump -U $DB_USER -h $DB_HOST -F c "peertube${DB_SUFFIX}" -f "$SQL_BACKUP_PATH"
64586951 33
4cd7a103
FA
34# If there is a pre-release, give the user a choice which one to install.
35RELEASE_VERSION=$(curl -s https://api.github.com/repos/chocobozzz/peertube/releases/latest | grep tag_name | cut -d '"' -f 4)
36PRE_RELEASE_VERSION=$(curl -s https://api.github.com/repos/chocobozzz/peertube/releases | grep tag_name | head -1 | cut -d '"' -f 4)
37
38if [ "$RELEASE_VERSION" != "$PRE_RELEASE_VERSION" ]; then
39 echo -e "Which version do you want to install?\n[1] $RELEASE_VERSION (stable) \n[2] $PRE_RELEASE_VERSION (pre-release)"
40 read choice
41 case $choice in
42 [1]* ) VERSION="$RELEASE_VERSION";;
43 [2]* ) VERSION="$PRE_RELEASE_VERSION";;
44 * ) exit;
45 esac
cee43cf1
FA
46else
47 VERSION="$RELEASE_VERSION"
4cd7a103
FA
48fi
49
50echo "Installing Peertube version $VERSION"
ee1219d8
JJ
51wget -q "https://github.com/Chocobozzz/PeerTube/releases/download/${VERSION}/peertube-${VERSION}.zip" -O "$PEERTUBE_PATH/versions/peertube-${VERSION}.zip"
52cd $PEERTUBE_PATH/versions
0e4ffb4b
LA
53unzip -o "peertube-${VERSION}.zip"
54rm -f "peertube-${VERSION}.zip"
64586951
SL
55
56# Upgrade Scripts
ee1219d8
JJ
57rm -rf $PEERTUBE_PATH/peertube-latest
58ln -s "$PEERTUBE_PATH/versions/peertube-${VERSION}" $PEERTUBE_PATH/peertube-latest
59cd $PEERTUBE_PATH/peertube-latest
64586951 60yarn install --production --pure-lockfile
ee1219d8 61cp $PEERTUBE_PATH/peertube-latest/config/default.yaml $PEERTUBE_PATH/config/default.yaml
64586951 62
34333925 63echo "Differences in configuration files..."
38d93700 64diff -u $PEERTUBE_PATH/config/production.yaml "$PEERTUBE_PATH/versions/peertube-${VERSION}/config/production.yaml.example"
34333925 65