mirror of
https://github.com/YunoHost-Apps/bookstack_ynh.git
synced 2024-09-03 18:16:02 +02:00
* 22.06
* Auto-update README
* Update manifest.json
* Fix
* 22.06.1
* Auto-update README
* Update upgrade
* 22.06.2
* Auto-update README
* Update app.src
* Update DESCRIPTION.md
* Auto-update README
* Update nginx.conf
* Update .env.example.complete
* Update .env.example.complete
* Update install
* Revert "Update install"
This reverts commit e43db7a0de
.
* 22.07.1 (#80)
* 22.07.1
* Auto-update README
Co-authored-by: yunohost-bot <yunohost@yunohost.org>
* Auto-update README
* Auto-update README
* 22.07.2 (#82)
* 22.07.2
* Auto-update README
Co-authored-by: yunohost-bot <yunohost@yunohost.org>
* 22.07.3 (#84)
* 22.07.3
* Auto-update README
* Update manifest.json
Co-authored-by: yunohost-bot <yunohost@yunohost.org>
* Update upgrade
* 22.09 (#88)
* 22.09
* Auto-update README
* Update app.src
Co-authored-by: yunohost-bot <yunohost@yunohost.org>
* 22.09.1
* Auto-update README
* upgrade composer
* upgrade config (#91)
* Update manifest.json
* Auto-update README
* Update upgrade
* 22.10
* Auto-update README
* 22.10.1
* 22.11
* Auto-update README
* 22.11.1
* Auto-update README
* Upgrade to version 22.11.1 (#100)
* Upgrade to v22.11.1
* Auto-update README
Co-authored-by: yunohost-bot <yunohost-bot@users.noreply.github.com>
Co-authored-by: yunohost-bot <yunohost@yunohost.org>
Co-authored-by: Éric Gaspar <46165813+ericgaspar@users.noreply.github.com>
* Fis php (#102)
* Update upgrade
* reorder script
* Update manifest.json
* Auto-update README
* Update restore
* Fix size
* Auto-update README
* Update DESCRIPTION_fr.md
* Auto-update README
* Fix
* 23.01
* Auto-update README
* PHP8.1
* 23.01.1
* Auto-update README
* Upgrade auto-updater (#108)
* [autopatch] Upgrade auto-updater
* Auto-update README
---------
Co-authored-by: tituspijean <titus@pijean.ovh>
* V2 (#107)
* Auto-update README
* v2
* Fix
* Update manifest.toml
* Update manifest.toml
* Fix
* Create post_install.md
* Fix
* Auto-update README
* Update install
* Update config_panel.toml
* Update manifest.toml
* Update _common.sh
* Update tests.toml
* Add post
* Update manifest.toml
* Update remove
* Update install
* Update _common.sh
* Fix
* Update change_url
* Update upgrade
* Auto-update README
* cleaning
* remove PHP version
* Update _common.sh
* Update manifest.toml
* Fix
* fix
* Update manifest.toml
* Update manifest.toml
* Update upgrade
* Update manifest.toml
* 23.02
* Auto-update README
* Update change_url
* Update change_url
* Update upgrade
---------
Co-authored-by: yunohost-bot <yunohost@yunohost.org>
---------
Co-authored-by: yunohost-bot <yunohost@yunohost.org>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: yunohost-bot <yunohost-bot@users.noreply.github.com>
Co-authored-by: tituspijean <titus@pijean.ovh>
109 lines
4.2 KiB
Bash
Executable file
109 lines
4.2 KiB
Bash
Executable file
#!/bin/bash
|
|
|
|
#=================================================
|
|
# PACKAGE UPDATING HELPER
|
|
#=================================================
|
|
|
|
# This script is meant to be run by GitHub Actions
|
|
# The YunoHost-Apps organisation offers a template Action to run this script periodically
|
|
# Since each app is different, maintainers can adapt its contents so as to perform
|
|
# automatic actions when a new upstream release is detected.
|
|
|
|
# Remove this exit command when you are ready to run this Action
|
|
#exit 1
|
|
|
|
#=================================================
|
|
# FETCHING LATEST RELEASE AND ITS ASSETS
|
|
#=================================================
|
|
|
|
# Fetching information
|
|
current_version=$(cat manifest.toml | tomlq -j '.version|split("~")[0]')
|
|
repo=$(cat manifest.toml | tomlq -j '.upstream.code|split("https://github.com/")[1]')
|
|
# Some jq magic is needed, because the latest upstream release is not always the latest version (e.g. security patches for older versions)
|
|
version=$(curl --silent "https://api.github.com/repos/$repo/releases" | jq -r '.[] | select( .prerelease != true ) | .tag_name' | sort -V | tail -1)
|
|
#assets=($(curl --silent "https://api.github.com/repos/$repo/releases" | jq -r '[ .[] | select(.tag_name=="'$version'").assets[].browser_download_url ] | join(" ") | @sh' | tr -d "'"))
|
|
asset_url=$(curl --silent "https://api.github.com/repos/$repo/releases" | jq -r '.[] | select(.tag_name=="'$version'").tarball_url')
|
|
|
|
# Later down the script, we assume the version has only digits and dots
|
|
# Sometimes the release name starts with a "v", so let's filter it out.
|
|
# You may need more tweaks here if the upstream repository has different naming conventions.
|
|
if [[ ${version:0:1} == "v" || ${version:0:1} == "V" ]]; then
|
|
version=${version:1}
|
|
fi
|
|
|
|
# Setting up the environment variables
|
|
echo "Current version: $current_version"
|
|
echo "Latest release from upstream: $version"
|
|
echo "VERSION=$version" >> $GITHUB_ENV
|
|
# For the time being, let's assume the script will fail
|
|
echo "PROCEED=false" >> $GITHUB_ENV
|
|
|
|
# Proceed only if the retrieved version is greater than the current one
|
|
if ! dpkg --compare-versions "$current_version" "lt" "$version" ; then
|
|
echo "::warning ::No new version available"
|
|
exit 0
|
|
# Proceed only if a PR for this new version does not already exist
|
|
elif git ls-remote -q --exit-code --heads https://github.com/$GITHUB_REPOSITORY.git ci-auto-update-v$version ; then
|
|
echo "::warning ::A branch already exists for this update"
|
|
exit 0
|
|
fi
|
|
|
|
# Each release can hold multiple assets (e.g. binaries for different architectures, source code, etc.)
|
|
#echo "${#assets[@]} available asset(s)"
|
|
|
|
#=================================================
|
|
# UPDATE SOURCE FILES
|
|
#=================================================
|
|
|
|
# Here we use the $assets variable to get the resources published in the upstream release.
|
|
# Here is an example for Grav, it has to be adapted in accordance with how the upstream releases look like.
|
|
|
|
# Let's loop over the array of assets URLs
|
|
#for asset_url in ${assets[@]}; do
|
|
|
|
echo "Handling asset at $asset_url"
|
|
|
|
src="app"
|
|
|
|
# Create the temporary directory
|
|
tempdir="$(mktemp -d)"
|
|
|
|
# Download sources and calculate checksum
|
|
filename="temp.tar.gz"
|
|
curl --silent -4 -L $asset_url -o "$tempdir/$filename"
|
|
checksum=$(sha256sum "$tempdir/$filename" | head -c 64)
|
|
|
|
# Delete temporary directory
|
|
rm -rf $tempdir
|
|
|
|
# Rewrite source file
|
|
cat <<EOT > conf/$src.src
|
|
SOURCE_URL=$asset_url
|
|
SOURCE_SUM=$checksum
|
|
SOURCE_SUM_PRG=sha256sum
|
|
SOURCE_FORMAT=$extension
|
|
SOURCE_IN_SUBDIR=true
|
|
SOURCE_EXTRACT=true
|
|
SOURCE_FILENAME=bookstack.tar.gz
|
|
EOT
|
|
echo "... conf/$src.src updated"
|
|
|
|
#=================================================
|
|
# SPECIFIC UPDATE STEPS
|
|
#=================================================
|
|
|
|
# Any action on the app's source code can be done.
|
|
# The GitHub Action workflow takes care of committing all changes after this script ends.
|
|
|
|
#=================================================
|
|
# GENERIC FINALIZATION
|
|
#=================================================
|
|
|
|
# Replace new version in manifest
|
|
echo "$(tomlq -s --indent 4 ".[] | .version = \"$version~ynh1\"" manifest.toml)" > manifest.toml
|
|
|
|
# No need to update the README, yunohost-bot takes care of it
|
|
|
|
# The Action will proceed only if the PROCEED environment variable is set to true
|
|
echo "PROCEED=true" >> $GITHUB_ENV
|
|
exit 0
|