exit -1
fi
+maintainer_public_key=${MAINTAINER_GPG:-"583A612D890159BE"}
+
branch=$(git symbolic-ref --short -q HEAD)
-if [ "$branch" != "develop" ]; then
- echo "Need to be on develop branch."
+if [ "$branch" != "develop" ] && [[ "$branch" != release/* ]]; then
+ echo "Need to be on develop or release branch."
exit -1
fi
version="v$1"
+github_prerelease_option=""
+if [[ "$version" = *"-alpha."* ]] || [[ "$version" = *"-beta."* ]] || [[ "$version" = *"-rc."* ]]; then
+ echo -e "This is a pre-release.\n"
+ github_prerelease_option="--pre-release"
+fi
+
directory_name="peertube-$version"
zip_name="peertube-$version.zip"
tar_name="peertube-$version.tar.xz"
-changelog=$(awk -v version="$version" '/## v/ { printit = $2 == version }; printit;' CHANGELOG.md | grep -v "$version" | sed '1{/^$/d}')
+changelog=$(awk -v version="$version" '/## v/ { printit = $2 == version }; printit;' CHANGELOG.md | grep -v "## $version" | sed '1{/^$/d}')
-printf "Changelog will be:\\n%s\\n" "$changelog"
+printf "Changelog will be:\\n\\n%s\\n\\n" "$changelog"
read -p "Are you sure to release? " -n 1 -r
echo
-if [[ ! $REPLY =~ ^[Yy]$ ]]
-then
+if [[ ! $REPLY =~ ^[Yy]$ ]]; then
exit 0
fi
-(
+(
cd client
npm version --no-git-tag-version --no-commit-hooks "$1"
)
npm version -f --no-git-tag-version --no-commit-hooks "$1"
-git commit package.json client/package.json -m "Bumped to version $version"
+./scripts/openapi-peertube-version.sh
+
+git commit package.json client/package.json ./support/doc/api/openapi.yaml -m "Bumped to version $version"
git tag -s -a "$version" -m "$version"
npm run build
-rm "./client/dist/stats.json"
+rm -f "./client/dist/en_US/stats.json"
+rm -f "./client/dist/embed-stats.json"
# Creating the archives
(
# local variables
- directories_to_archive = ("$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")
- maintainer_pubkey = "583A612D890159BE"
+ directories_to_archive=("$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")
# temporary setup
cd ..
# archive creation + signing
zip -r "PeerTube/$zip_name" "${directories_to_archive[@]}"
- gpg --armor --detach-sign -u $maintainer_pubkey "PeerTube/$zip_name"
+ gpg --armor --detach-sign -u "$maintainer_public_key" "PeerTube/$zip_name"
XZ_OPT=-e9 tar cfJ "PeerTube/$tar_name" "${directories_to_archive[@]}"
- gpg --armor --detach-sign -u $maintainer_pubkey "PeerTube/$tar_name"
+ gpg --armor --detach-sign -u "$maintainer_public_key" "PeerTube/$tar_name"
# temporary setup destruction
rm "$directory_name"
# Creating the release on GitHub, with the created archives
(
- cd "PeerTube"
-
git push origin --tag
- github-release release --user chocobozzz --repo peertube --tag "$version" --name "$version" --description "$changelog"
+ if [ -z "$github_prerelease_option" ]; then
+ github-release release --user chocobozzz --repo peertube --tag "$version" --name "$version" --description "$changelog"
+ else
+ github-release release --user chocobozzz --repo peertube --tag "$version" --name "$version" --description "$changelog" "$github_prerelease_option"
+ fi
+
github-release upload --user chocobozzz --repo peertube --tag "$version" --name "$zip_name" --file "$zip_name"
github-release upload --user chocobozzz --repo peertube --tag "$version" --name "$zip_name.asc" --file "$zip_name.asc"
github-release upload --user chocobozzz --repo peertube --tag "$version" --name "$tar_name" --file "$tar_name"
github-release upload --user chocobozzz --repo peertube --tag "$version" --name "$tar_name.asc" --file "$tar_name.asc"
- git push origin develop
+ git push origin "$branch"
- # Update master branch
- git checkout master
- git rebase develop
- git push origin master
- git checkout develop
+ # Only update master if it is not a pre release
+ if [ -z "$github_prerelease_option" ]; then
+ # Update master branch
+ git checkout master
+ git merge "$branch"
+ git push origin master
+ git checkout "$branch"
+ fi
)