diff options
Diffstat (limited to 'PKGBUILD')
-rw-r--r--[-rwxr-xr-x] | PKGBUILD | 67 |
1 files changed, 55 insertions, 12 deletions
diff --git a/PKGBUILD b/PKGBUILD index b1dd94145820..6755ba0ce742 100755..100644 --- a/PKGBUILD +++ b/PKGBUILD @@ -1,23 +1,66 @@ -# Maintainer: Jonas Heinrich <onny@project-insanity.org> +# Maintainer: +# Contributor: Lex Black <autumn-wind@web.de> +# Contributor: Felix Golatofski <contact@xdfr.de> # Contributor: Jonas Heinrich <onny@project-insanity.org> +_name=richdocuments pkgname=nextcloud-app-collabora-online -pkgver=1.1.25 -pkgrel=2 +pkgver=7.0.1 +pkgrel=1 pkgdesc="Integrate Collabora Online into NextCloud" arch=('any') url="https://github.com/nextcloud/richdocuments" license=('AGPL') -depends=('nextcloud' 'libreoffice-online-bin') -makedepends=() +depends=('libreoffice-online') +makedepends=('nextcloud' 'yq') options=('!strip') -source=("richdocuments-${pkgver}.tar.gz::https://github.com/nextcloud/richdocuments/releases/download/1.1.25/richdocuments.tar.gz") -sha512sums=("4d55f366ed9c39dcc04a5685c86e8099af472ff305bfba7bee0aaf2e80b571c3343638eec2051857911f63f3428b39509665b73b3b2f527b7380dc25a6795c29") +source=("${_name}-${pkgver}.tar.gz::${url}/releases/download/v${pkgver}/${_name}.tar.gz") +sha512sums=('c17443309dfc4dc588ac264ba583a30d5c4d81f56b1cc33f653093aca16578dceee08abdd45cf6d24deac2eb4ea9ebfc2be0d8a042e786c0329b29655d73854b') -package() { - install -d "${pkgdir}/usr/share/webapps/nextcloud/apps" - cp -a "${srcdir}/richdocuments" "${pkgdir}/usr/share/webapps/nextcloud/apps/richdocuments" + +# BEGIN boilerplate nextcloud app version clamping, see also other packages in group +# 1. Call respective function helpers in check() and package() *after* cd'ing to the source directory +# 2. Add makedepends+=(nextcloud yq) +_phps=(php7 php) +_get_supported_ranges() { + _app_min_nextcloud="$(< appinfo/info.xml xq -r '.info.dependencies.nextcloud["@min-version"] | values')" + _app_max_nextcloud="$(< appinfo/info.xml xq -r '.info.dependencies.nextcloud["@max-version"] | values | tonumber | .+1')" + _app_min_php="$(< appinfo/info.xml xq -r '.info.dependencies.php["@min-version"] | values')" + _app_max_php="$(< appinfo/info.xml xq -r '.info.dependencies.php["@max-version"] | values | tonumber | .+0.1')" +} +_unsupported_range() { + printf "%s requires %s %s, but %s %s is provided.\n" "$pkgname" "$1" "$2" "$1" "$3" + exit 1 +} +_nextcloud_app_check() { + _get_supported_ranges + for _php in "${_phps[@]}"; do command -v "$_php" > /dev/null && break; done + local _nextcloud_ver="$("$_php" <(cat /usr/share/webapps/nextcloud/version.php; echo 'print($OC_VersionString);'))" + local _php_ver="$("$_php" -r 'print(phpversion());')" + [[ "$(vercmp "${_app_min_nextcloud:-0}" "$_nextcloud_ver")" -le 0 ]] || \ + _unsupported_range nextcloud "=> $_app_min_nextcloud" "$_nextcloud_ver" + [[ "$(vercmp "${_app_max_nextcloud:-999}" "$_nextcloud_ver")" -gt 0 ]] || \ + _unsupported_range nextcloud "< $_app_max_nextcloud" "$_nextcloud_ver" + [[ "$(vercmp "${_app_min_php:-0}" "$_php_ver")" -le 0 ]] || \ + _unsupported_range php ">= $_app_min_php" "$_php_ver" + [[ "$(vercmp "${_app_max_php:-999}" "$_php_ver")" -gt 0 ]] || \ + _unsupported_range php "< $_app_max_php" "$_php_ver" +} +_nextcloud_app_package() { + _get_supported_ranges + depends+=("nextcloud>=${_app_min_nextcloud:-0}" "nextcloud<${_app_max_nextcloud:-999}") + depends+=("php-interpreter${_app_min_php:+>=$_app_min_php}" ${_app_max_php:+"php-interpreter<$_app_max_php"}) } +# END boilerplate nextcloud app version clamping -# Todo: -# - ArchWiki tutorial +check() { + cd $_name + _nextcloud_app_check +} + +package() { + install -vdm 755 "$pkgdir/usr/share/webapps/nextcloud/apps/" + cp -av $_name "$pkgdir/usr/share/webapps/nextcloud/apps/" + cd $_name + _nextcloud_app_package +} |