#!/bin/bash
-npm run build
-npm test
+shutdown() {
+ # Get our process group id
+ PGID=$(ps -o pgid= $$ | grep -o [0-9]*)
+
+ # Kill it in a new new process group
+ setsid kill -- -$PGID
+ exit 0
+}
+
+trap "shutdown" SIGINT SIGTERM
+
+if [ -z "$1" ]; then
+ echo "Need version as argument"
+ exit -1
+fi
+
+if [ -z $GITHUB_TOKEN ]; then
+ echo "Need GITHUB_TOKEN env set."
+ exit -1
+fi
+
+branch=$(git symbolic-ref --short -q HEAD)
+if [ "$branch" != "develop" ]; then
+ echo "Need to be on develop branch."
+ exit -1
+fi
+
+version="v$1"
+directory_name="peertube-$version"
+zip_name="peertube-$version.zip"
+
+cd ./client || exit -1
+npm version --no-git-tag-version --no-commit-hooks $1 || exit -1
+
+cd ../ || exit -1
+npm version -f --no-git-tag-version --no-commit-hooks $1 || exit -1
+
+git commit package.json client/package.json -m "Bumped to version $version" || exit -1
+git tag -s -a "$version" -m "$version"
+
+npm run build || exit -1
+rm "./client/dist/stats.json" || exit -1
cd ../ || exit -1
-zip -r PeerTube/peertube.zip PeerTube/{CREDITS.md,node_modules,FAQ.md,LICENSE,README.md,client/dist/,client/yarn.lock,client/package.json,config,dist,package.json,scripts,support,tsconfig.json,yarn.lock}
+
+ln -s "PeerTube" "$directory_name" || exit -1
+zip -r "PeerTube/$zip_name" "$directory_name/CREDITS.md" "$directory_name/FAQ.md" \
+ "$directory_name/LICENSE" "$directory_name/README.md" \
+ "$directory_name/client/dist/" "$directory_name/client/yarn.lock" \
+ "$directory_name/client/package.json" "$directory_name/config" \
+ "$directory_name/dist" "$directory_name/package.json" \
+ "$directory_name/scripts" "$directory_name/support" \
+ "$directory_name/tsconfig.json" "$directory_name/yarn.lock" \
+ || exit -1
+rm "$directory_name" || exit -1
+
+cd "PeerTube" || exit -1
+
+git push origin --tag
+
+github-release release --user chocobozzz --repo peertube --tag "$version" --name "$version"
+github-release upload --user chocobozzz --repo peertube --tag "$version" --name "$zip_name" --file "$zip_name"
+
+git push origin develop
+
+# Update master branch
+git checkout master
+git rebase develop
+git push origin master
+git checkout develop
+