From 1013c33728e2a49244d82f6e7bf924b257f402ed Mon Sep 17 00:00:00 2001 From: Timothy Werquin Date: Thu, 3 Aug 2023 21:22:32 +0200 Subject: [PATCH] Add support for rm-sync in xochitl package Recent xochitl versions renamed the sync service and binary to rm-sync. This updates the xochitl package to support both. --- ...nual-sync.service => manual-sync@.service} | 4 +-- package/xochitl/package | 25 ++++++++++++++----- package/xochitl/xochitl | 18 ++++++++++--- 3 files changed, 36 insertions(+), 11 deletions(-) rename package/xochitl/{manual-sync.service => manual-sync@.service} (89%) diff --git a/package/xochitl/manual-sync.service b/package/xochitl/manual-sync@.service similarity index 89% rename from package/xochitl/manual-sync.service rename to package/xochitl/manual-sync@.service index 359f84849..386011a02 100644 --- a/package/xochitl/manual-sync.service +++ b/package/xochitl/manual-sync@.service @@ -6,14 +6,14 @@ Description=reMarkable Document Sync without the xochitl.service dependency After=dbus.socket StartLimitIntervalSec=60 StartLimitBurst=4 -Conflicts=sync.service +Conflicts=%i.service [Service] # Do NOT make this dbus, systemd will kill the service when it should be # running otherwise. Type=simple BusName=no.remarkable.sync -ExecStart=/usr/bin/sync --service +ExecStart=/usr/bin/%i --service Restart=on-failure RestartForceExitStatus=SIGHUP SIGINT SIGTERM SIGPIPE diff --git a/package/xochitl/package b/package/xochitl/package index 1ebefec09..183873d49 100644 --- a/package/xochitl/package +++ b/package/xochitl/package @@ -5,7 +5,7 @@ pkgnames=(xochitl) pkgdesc="Read documents and take notes" url=https://remarkable.com -pkgver=0.0.0-14 +pkgver=0.0.0-15 timestamp=2022-11-07T20:19:57Z section="readers" maintainer="Mattéo Delabre " @@ -24,7 +24,7 @@ source=( toltec-after-launcher.conf toltec-wrapper.conf env-readme - manual-sync.service + manual-sync@.service ) sha256sums=( SKIP @@ -59,19 +59,29 @@ package() { install -D -m 644 -t "$pkgdir"/etc/systemd/system/remarkable-reboot.service.d \ "$srcdir"/toltec-after-launcher.conf install -D -m 644 -t "$pkgdir"/etc/systemd/system \ - "$srcdir"/manual-sync.service + "$srcdir"/manual-sync@.service } configure() { systemctl daemon-reload + # Newer firmwares renamed sync to rm-sync + USE_RMSYNC=$(test -f /usr/bin/rm-sync) + # sync.service interferes with launchers # we use manual-sync.service instead - if [[ "x$(systemctl is-enabled sync.service)" != "xmasked" ]]; then + if ! $USE_RMSYNC && [[ "x$(systemctl is-enabled sync.service)" != "xmasked" ]]; then systemctl mask sync.service fi - if ! is-active manual-sync.service; then - systemctl enable --now manual-sync.service + + if $USE_RMSYNC && [[ "x$(systemctl is-enabled rm-sync.service)" != "xmasked" ]]; then + systemctl mask rm-sync.service + fi + + if $USE_RMSYNC && ! is-active manual-sync@rm-sync.service; then + systemctl enable --now manual-sync@rm-sync.service + elif ! is-active manual-sync@sync.service; then + systemctl enable --now manual-sync@sync.service fi if is-enabled xochitl.service && ! is-enabled launcher.service; then @@ -94,6 +104,9 @@ postremove() { if [[ "x$(systemctl is-enabled sync.service)" == "xmasked" ]]; then systemctl unmask sync.service 2> /dev/null fi + if [[ "x$(systemctl is-enabled rm-sync.service)" == "xmasked" ]]; then + systemctl unmask rm-sync.service 2> /dev/null + fi if is-enabled xochitl.service && is-enabled launcher.service; then # If xochitl is currently the active launcher, make sure the diff --git a/package/xochitl/xochitl b/package/xochitl/xochitl index a745d8bea..8911c6e2c 100644 --- a/package/xochitl/xochitl +++ b/package/xochitl/xochitl @@ -9,13 +9,25 @@ for file in /opt/etc/xochitl.env.d/*.env; do source "$file" fi done + +# Newer firmwares renamed sync to rm-sync +USE_RMSYNC=$(test -f /usr/bin/rm-sync) + # If for some reason, sync.service is no longer masked, re-mask it # The package install should have handled this, but something may # have changed it. -if [[ "x$(systemctl is-enabled sync.service)" != "xmasked" ]]; then +if ! $USE_RMSYNC && [[ "x$(systemctl is-enabled sync.service)" != "xmasked" ]]; then systemctl mask sync.service fi -if ! systemctl is-active --quiet manual-sync.service; then - systemctl enable --now manual-sync.service + +if $USE_RMSYNC && [[ "x$(systemctl is-enabled rm-sync.service)" != "xmasked" ]]; then + systemctl mask rm-sync.service +fi + +if $USE_RMSYNC && ! is-active manual-sync@rm-sync.service; then + systemctl enable --now manual-sync@rm-sync.service +elif ! is-active manual-sync@sync.service; then + systemctl enable --now manual-sync@sync.service fi + exec /usr/bin/xochitl "$@"