1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/bookstack_ynh.git synced 2024-09-03 18:16:02 +02:00
bookstack_ynh/.github/workflows/updater.sh
Éric Gaspar f47c560c2d
Testing (#69)
* Fix

* Update _common.sh

* Fix

* Update install

* Fix

* fix

* Fix

* fix

* Update README.md

* Update install

* Fix

* Fix

* Fix

* Fix

* Fix

* Update nginx.conf

* Update manifest.json

* Fix

* Fix

* Update .env.example

* Update .env.example

* Fix

* Fix

* Update php-fpm.conf

* Update .env.example

* Update README.md

* Update upgrade

* Update change_url

* Fix

* Update upgrade

* Fix

* Update upgrade

* Fix

* Fix

* Update upgrade

* Update check_process

* Fix

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Fix multi install

* Update php-fpm.conf

* Fix maintenance mail

* Update manifest.json

* upgrade to 0.31.5 (#10)

* 0.31.6 (#13)

* Upgrade to version 0.31.6

* Upgrade to version 0.31.7 (#15)

* Upgrade to 21.04 (#18)

* Upgrade to version 21.02

* Remove multi instance

* Update check_process

* 21.04.1 (#21)

* 21.04.2

* Upgrade to upstream (#24)

* Fix link

* upgrade to version 21.04.4 (#26)

* upgrade to version 21.04.4

* Upgrade requirements

* [autopatch] Update issue and PR templates (#28)

* Testing

* upgrade to version 21.04.4

* [autopatch] Update issue and PR templates

Co-authored-by: Éric Gaspar <46165813+ericgaspar@users.noreply.github.com>
Co-authored-by: Yunohost-Bot <>

* 21.04.5 (#29)

* Upgrade to version 21.4.6

* Add templates

* Auto-update README

* Update check_process

* Auto-update README

* 21.05 (#31)

* 21.05

* upgrade

* Auto-update README

* bump

* Auto-update README

* fix

* Update _common.sh

* Update install

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Update check_process

* Update upgrade (#33)

* 21.05.3 (#34)

* 21.05.3

* Patch (#37)

* PHP8

* 21.05.4

* Auto-update README

* Update restore

* 21.08 (#39)

* 21.08

* Fix

* Auto-update README

* 21.08.2

* Auto-update README

* Update manifest.json

* Update upgrade

* 21.11 (#41)

* 21.11.2

* Update _common.sh

* Update manifest.json

* Fix

* Fix

* Update _common.sh

* Update upgrade

* Update upgrade

* 21.11.2

* Auto-update README

* Update upgrade

* Update upgrade

* Fix

* Update _common.sh

* Update manifest.json

* Auto-update README

* Update app.src

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Update upgrade

* Update .env.example

* Update upgrade

* Update change_url

* Fix

* Update check_process

* Update check_process

* Update change_url

* Update change_url

* Update change_url

* Update change_url

* Update change_url

* Update _common.sh

* Update change_url

* Update change_url

* Update install

* Update install

* Update change_url

* Update change_url

* Update change_url

* Update change_url

* Update change_url

* Update change_url

* Update change_url

* Update change_url

* Update change_url

* Revert "Update change_url"

This reverts commit faec2bb235.

* Update change_url

* Update change_url

* Update change_url

* Update change_url

* Fix url (#45)

* Update change_url

* Update upgrade

* Fix url 2 (#46)

* fix

* Update change_url

* Update upgrade

* Update change_url

* Add timezone

* Fix url 2 (#47)

* Update change_url

* Update install

* Update change_url

* Admin ldap (#51)


    Define admin during install
    Add LDAP
    Add config panel

* Update check_process

* Update config_panel.toml

* Create updater.sh

* Remove password

* Auto-update README

* Fix

* Auto-update README

* Update manifest.json

* Auto-update README

* 21.12.5

* Auto-update README

* 22.02 (#55)

* 22.02

* Auto-update README

* Auto-update README

Co-authored-by: Yunohost-Bot <>

* 22.02.1

* Auto-update README

* Fix url (#48)

* Update change_url

* Add fr

* Auto-update README

* Update .env.example

* Upgrade composer

* Update upgrade

* Update upgrade

* Fix

* Update install

* 22.02.2

* Auto-update README

* Fix file size upload

* 22.02.3

* Auto-update README

* Auto-update README

* Update .env.example.complete

* Update .env.example

* Fix

* Auto-update README

* Multi instance (#61)

* multi_instance: true

* test multi_instance

* fix a typo? (weight)

* Update install

* Update upgrade

* Update manifest.json

* Auto-update README

* Update restore

* Update check_process

* 22.03

* Auto-update README

* Fix

* Auto-update README

* v22.04.1

* Auto-update README

* v22.04.2

* Auto-update README

* keep config

* Update _common.sh

* Update updater.sh

* Create updater.yml (#68)

* Update updater.sh

* Update manifest.json

* Auto-update README

* Update .env.example

* Auto-update README

* Queue worker process (#70)

* Add worker

* regenerate config file

* Set log_path to systemd

* Update change_url

Co-authored-by: tituspijean <tituspijean@outlook.com>
Co-authored-by: YunoHost Bot <yunohost-bot@users.noreply.github.com>
Co-authored-by: Yunohost-Bot <>
Co-authored-by: OniriCorpe <oniricorpe@disroot.org>
Co-authored-by: yunohost-bot <yunohost@yunohost.org>
2022-05-25 18:35:13 +02:00

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.json | jq -j '.version|split("~")[0]')
repo=$(cat manifest.json | jq -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 "$(jq -s --indent 4 ".[] | .version = \"$version~ynh1\"" manifest.json)" > manifest.json
# 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