]> git.sthu.org Git - shutils.git/commitdiff
nextcloud: Add nc-inotify-sync
authorStefan Huber <shuber@sthu.org>
Sun, 10 Feb 2019 12:00:13 +0000 (13:00 +0100)
committerStefan Huber <shuber@sthu.org>
Wed, 12 Jun 2019 07:55:48 +0000 (09:55 +0200)
nextcloud/nc-inotify-sync [new file with mode: 0755]
nextcloud/nextcloud-sync [new file with mode: 0644]

diff --git a/nextcloud/nc-inotify-sync b/nextcloud/nc-inotify-sync
new file mode 100755 (executable)
index 0000000..e310352
--- /dev/null
@@ -0,0 +1,101 @@
+#!/bin/sh
+
+NCC=/usr/bin/nextcloudcmd
+if ! [ -x ${NCC} ]; then
+       echo "There is no ${NCC}."
+       exit 2
+fi
+
+IWAIT=/usr/bin/inotifywait
+if ! [ -x ${IWAIT} ]; then
+       echo "There is no ${IWAIT}."
+       exit 2
+fi
+
+usage() {
+       cat << EOF
+
+Calls nextcloudcmd to sync a source directory and server url. The script
+triggers a synchronization when (i) the source directory was changed or (ii)
+after some period, whatever happens first. The nextcloudcmd is called with
+netrc for login.
+
+Usage:
+ $0 [OPTIONS] source_dir server_url
+ $0 -h
+
+OPTIONS:
+  -h        Show this text
+  -o        One-shot instead of looping
+  -s        Silent, be less verbose
+  -t SECS   Sync period if nothing changed locally.
+            Default: 180
+
+EXAMPLE
+    $0 ~/.vimwiki https://cloud.example.com/remote.php/webdav/vimwiki
+EOF
+}
+
+NCC_OPTS="-n"
+IWAIT_OPTS=""
+
+SILENT=0
+ONESHOT=0
+PERIOD=180
+
+while getopts "host:" OPTION; do
+       case "${OPTION}" in
+               h)
+                       usage
+                       exit
+                       ;;
+               o)
+                       ONESHOT=1
+                       ;;
+               s)
+                       SILENT=1
+                       NCC_OPTS="${NCC_OPTS} -s"
+                       IWAIT_OPTS="${IWAIT_OPTS} -q"
+                       ;;
+               t)
+                       PERIOD=${OPTARG}
+                       ;;
+               *)
+                       usage
+                       exit 1
+                       ;;
+       esac
+done
+shift $((OPTIND-1))
+
+SOURCE_DIR=$1
+SERVER_URL=$2
+
+if [ -z "${SOURCE_DIR}" ] ; then
+       echo "No source directory given."
+       usage
+       exit 1
+fi
+
+if [ -z "${SERVER_URL}" ] ; then
+       echo "No server URL given."
+       usage
+       exit 1
+fi
+
+NCC_OPTS="${NCC_OPTS} ${SOURCE_DIR} ${SERVER_URL}"
+
+while true; do
+       echo "About to sync..."
+       sleep 2
+       [ "$SILENT" = "1" ] || echo "[$(date '+%F %X')] Perform sync..."
+
+       ${NCC} ${NCC_OPTS}
+
+       [ "${ONESHOT}" = "1" ] && break
+
+       sleep 3
+       [ "$SILENT" = "1" ] || echo ""
+       [ "$SILENT" = "1" ] || echo "[$(date '+%F %X')] Wait for ${PERIOD} secs or source directory change."
+       ${IWAIT} ${IWAIT_OPTS} -t ${PERIOD} -r -e modify -e move -e create -e delete ${SOURCE_DIR}
+done
diff --git a/nextcloud/nextcloud-sync b/nextcloud/nextcloud-sync
new file mode 100644 (file)
index 0000000..84eacea
--- /dev/null
@@ -0,0 +1,6 @@
+#!/bin/sh
+
+# This script can be fired in crontab; it will launch a tmux sync session when none exists.
+
+ncc=~/.local/bin/nc-inotify-sync
+tmux has-session -t nc-vimwiki || tmux new-session -d -s nc-vimwiki "${ncc} ~/.vimwiki https://cloud.example.com/remote.php/webdav/vimwiki"