+npm run build
+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")
+
+ # temporary setup
+ cd ..
+ ln -s "PeerTube" "$directory_name"
+
+ # archive creation + signing
+ zip -r "PeerTube/$zip_name" "${directories_to_archive[@]}"
+ 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_public_key" "PeerTube/$tar_name"
+
+ # temporary setup destruction
+ rm "$directory_name"
+)
+
+# Creating the release on GitHub, with the created archives
+(
+ git push origin --tag
+
+ 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 "$branch"
+
+ # 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
+)