From 49e92cf705771c2a47fed50f95b42ab65a49e77a Mon Sep 17 00:00:00 2001 From: Gabriel Arakaki Giovanini Date: Mon, 26 Dec 2022 15:20:41 +0100 Subject: fix: Add jellyfin again --- apks/jellyfin-web/APKBUILD | 28 +++++++++++++ apks/jellyfin-web/jellyfin-web.post-install | 6 +++ apks/jellyfin/APKBUILD | 63 +++++++++++++++++++++++++++++ apks/jellyfin/jellyfin.confd | 5 +++ apks/jellyfin/jellyfin.initd | 20 +++++++++ apks/jellyfin/jellyfin.pre-install | 9 +++++ 6 files changed, 131 insertions(+) create mode 100644 apks/jellyfin-web/APKBUILD create mode 100644 apks/jellyfin-web/jellyfin-web.post-install create mode 100644 apks/jellyfin/APKBUILD create mode 100644 apks/jellyfin/jellyfin.confd create mode 100644 apks/jellyfin/jellyfin.initd create mode 100644 apks/jellyfin/jellyfin.pre-install (limited to 'apks') diff --git a/apks/jellyfin-web/APKBUILD b/apks/jellyfin-web/APKBUILD new file mode 100644 index 0000000..2786c42 --- /dev/null +++ b/apks/jellyfin-web/APKBUILD @@ -0,0 +1,28 @@ +# Maintainer: Simon Zeni +pkgname=jellyfin-web +pkgver=10.8.8 +pkgrel=0 +pkgdesc="Web Client for Jellyfin" +url="https://jellyfin.org/" +# armv7: oom +arch="x86_64 aarch64" +options="!check net" # no tests +license="GPL-2.0-only" +install="$pkgname.post-install" +depends="jellyfin" +makedepends="npm" +source="$pkgname-$pkgver.tar.gz::https://github.com/jellyfin/jellyfin-web/archive/refs/tags/v$pkgver.tar.gz" + +build() { + npm ci --no-audit +} + +package() { + mkdir -p "$pkgdir"/usr/lib/jellyfin/jellyfin-web + + cp -r "$builddir"/dist/* "$pkgdir"/usr/lib/jellyfin/jellyfin-web +} + +sha512sums=" +88a829248f1d2506509a3610cc67575899df4fcb371fdd766b4a91f2005f387055ac716047293882cc494e2894f4121049c9525f468a33c99a12ff5d0c87fb19 jellyfin-web-10.8.8.tar.gz +" diff --git a/apks/jellyfin-web/jellyfin-web.post-install b/apks/jellyfin-web/jellyfin-web.post-install new file mode 100644 index 0000000..a6e6942 --- /dev/null +++ b/apks/jellyfin-web/jellyfin-web.post-install @@ -0,0 +1,6 @@ +#!/bin/sh + +printf " *\n * The default jellyfin configuration does not enable the web ui.\n" +printf " * Remove the '--nowebclient' option from /etc/conf.d/jellyfin to enable it.\n *\n" + +exit 0 diff --git a/apks/jellyfin/APKBUILD b/apks/jellyfin/APKBUILD new file mode 100644 index 0000000..474faf3 --- /dev/null +++ b/apks/jellyfin/APKBUILD @@ -0,0 +1,63 @@ +# Maintainer: Simon Zeni +pkgname=jellyfin +pkgver=10.8.8 +pkgrel=0 +pkgdesc="The Free Software Media System" +pkgusers="$pkgname" +pkggroups="$pkgname" +install="$pkgname.pre-install" +url="https://jellyfin.org/" +arch="x86_64 armv7 aarch64" +license="GPL-2.0-only" +makedepends="dotnet6-sdk" +depends="aspnetcore6-runtime ffmpeg" +subpackages="$pkgname-openrc" +source="$pkgname-$pkgver.tar.gz::https://github.com/jellyfin/jellyfin/archive/refs/tags/v$pkgver.tar.gz + $pkgname.initd + $pkgname.confd" + +case $CARCH in + x86_64) _dotnet_arch=x64;; + aarch64) _dotnet_arch=arm64;; + armv7|armhf) _dotnet_arch=arm;; +esac + +# parses RID from /etc/os-release depending on if edge or production release +# to set _runtime_id +# shellcheck disable=SC2034 +. /etc/os-release +[ -n "${VERSION_ID//[^_]}" ] && _runtime_id="alpine.${VERSION_ID%_*}-$_dotnet_arch" || _runtime_id="alpine.${VERSION_ID%.*}-$_dotnet_arch" + +build() { + dotnet build --configuration Release Jellyfin.Server --no-self-contained --runtime $_runtime_id + dotnet publish --configuration Release Jellyfin.Server --no-self-contained --output publish --runtime $_runtime_id +} + +check() { + # check on aarch64 is broken for dotnet6-sdk v6.0.1xx due to + # https://github.com/microsoft/vstest/issues/2566 + if [ "$CARCH" = "aarch64" ]; then + return + fi + + dotnet test --runtime $_runtime_id +} + +package() { + mkdir -p "$pkgdir"/usr/lib + cp -dr publish "$pkgdir"/usr/lib/jellyfin + + mkdir -p "$pkgdir"/usr/bin + ln -s /usr/lib/jellyfin/jellyfin "$pkgdir"/usr/bin/jellyfin + + install -Dm755 "$srcdir"/$pkgname.initd \ + "$pkgdir"/etc/init.d/$pkgname + install -Dm644 "$srcdir"/$pkgname.confd \ + "$pkgdir"/etc/conf.d/$pkgname +} + +sha512sums=" +1866a8e6a730d2d2211a907aa9087c8bc7069ef53010ba652f1dbbe2c6c638a29259531e31ccf5bee797651999ec0963b2ff3588e791f3b523e43bf4a3556070 jellyfin-10.8.8.tar.gz +364a70a953d921048a249fd370642c1782e434c850334cd55e35bbb10d1bb93482d37faa1c11da5d7acba96a084d9832e5db212b65b0fa9907c7d3afe553aaf9 jellyfin.initd +d35eb07d11d711b8ad35c7726e151a8096609712fee3bfea00c9adeff8e56660e3cde3d9b0b2dc8a847514af4d2b32340e2b29b77facfab4f8921ba15ba671b0 jellyfin.confd +" diff --git a/apks/jellyfin/jellyfin.confd b/apks/jellyfin/jellyfin.confd new file mode 100644 index 0000000..6cd891c --- /dev/null +++ b/apks/jellyfin/jellyfin.confd @@ -0,0 +1,5 @@ +supervisor=supervise-daemon +datadir="/var/lib/jellyfin" +cachedir="/var/cache/jellyfin" +logdir="/var/log/jellyfin" +opts="--nowebclient" diff --git a/apks/jellyfin/jellyfin.initd b/apks/jellyfin/jellyfin.initd new file mode 100644 index 0000000..278d79d --- /dev/null +++ b/apks/jellyfin/jellyfin.initd @@ -0,0 +1,20 @@ +#!/sbin/openrc-run + +name=jellyfin +description="The Free Software Media System" + +command=/usr/bin/jellyfin +command_user=jellyfin:jellyfin +command_args="--datadir ${datadir} --cachedir ${cachedir} --logdir ${logdir} ${opts}" + +depend() { + use logger dns + need net + after firewall +} + +start_pre() { + checkpath -d -o $command_user "$datadir" + checkpath -d -o $command_user "$cachedir" + checkpath -d -o $command_user "$logdir" +} diff --git a/apks/jellyfin/jellyfin.pre-install b/apks/jellyfin/jellyfin.pre-install new file mode 100644 index 0000000..6e64716 --- /dev/null +++ b/apks/jellyfin/jellyfin.pre-install @@ -0,0 +1,9 @@ +#!/bin/sh + +user=jellyfin +group=jellyfin + +addgroup -S $group 2>/dev/null +adduser -S -D -h /var/lib/$user -s /sbin/nologin -G $group -g $user $user 2>/dev/null + +exit 0 -- cgit v1.2.3