From 4c82fb6599433024cb1574cdf625c7e6332d4ace Mon Sep 17 00:00:00 2001 From: James Tufarelli <8152401+Minituff@users.noreply.github.com> Date: Wed, 18 Oct 2023 12:30:28 -0700 Subject: [PATCH] Add more labels (#43) --- docs/arguments.md | 15 ++++++++++----- docs/labels.md | 38 ++++++++++++++++++++++++++++++++++++-- pkg/backup.sh | 15 +++++++++++++++ 3 files changed, 61 insertions(+), 7 deletions(-) diff --git a/docs/arguments.md b/docs/arguments.md index f66a9530..671770e8 100644 --- a/docs/arguments.md +++ b/docs/arguments.md @@ -191,16 +191,13 @@ Useful when using [Custom rsync Arugments](#custom-rsync-arguments) USE_DEFAULT_RSYNC_ARGS=false ``` +🔄 This is the same action as the [Use Default rsync Arguments](./labels.md#use-default-rsync-arguments) label, but applied globally. + ## Custom rsync Arguments Apply custom `rsync` args (in addition to the [default](#use-default-rsync-arguments) args) > **Default**: *empty* (no custom rsync args will be applied) -The `RSYNC_CUSTOM_ARGS` will be inserted after the `$DEFAULT_RSYNC_ARGS` as shown: -```bash -rsync $DEFAULT_RSYNC_ARGS $RSYNC_CUSTOM_ARGS $src_dir/ $dest_dir/ -``` - There are many `rsync` arguments and customizations that be be used here. === "Example 1" @@ -209,5 +206,13 @@ There are many `rsync` arguments and customizations that be be used here. RSYNC_CUSTOM_ARGS=--exclude='*.log' --exclude='*.txt' ``` +The `RSYNC_CUSTOM_ARGS` will be inserted after the `$DEFAULT_RSYNC_ARGS` as shown: +```bash +rsync $DEFAULT_RSYNC_ARGS $RSYNC_CUSTOM_ARGS $src_dir/ $dest_dir/ +``` + + + +🔄 This is the same action as the [Custom rsync Arguments](./labels.md#custom-rsync-arguments) label, but applied globally.

diff --git a/docs/labels.md b/docs/labels.md index c981789a..6747516d 100644 --- a/docs/labels.md +++ b/docs/labels.md @@ -128,7 +128,7 @@ nautical-backup.enable=true With this label set to `false`, the container will not be stopped before performing a backup. -> **Default If Missing**: true (container ==will== be stopped before backup). +> **Default If Missing**: true (container ^^will^^ be stopped before backup). ```properties nautical-backup.stop-before-backup=false @@ -173,4 +173,38 @@ By default, Nautical will create destination directory that is the same name as nautical-backup.override-destination-dir=new_folder_name ``` -🔄 This is the same action as the [Override Destination Directory](./arguments.md#override-destination-directory) variable, but applied only to this container. \ No newline at end of file +🔄 This is the same action as the [Override Destination Directory](./arguments.md#override-destination-directory) variable, but applied only to this container. + +## Use Default rsync Arguments +Use the default `rsync` arguemnts `-raq` (recursive, archive, quiet) + +Useful when using [Custom rsync Arugments](#custom-rsync-arguments) + +> **Default**: *none* (use global setting) + +```properties +nautical-backup.use-default-rsync-args=false +``` + +!!! note "This label will *override* the global setting applied through [Enviornment Variables](./arguments.md)" + * A value of `true` will use the default rsync arguments regardless of the global setting. + * A value of `false` will ^^**not**^^ use the default rsync arguments regardless of the global setting. + * Not setting the label value will use the [global setting](./arguments.md#custom-rsync-arguments) + +🔄 Not setting a label is the same action as the [Use Default rsync Arguments](./arguments.md#use-default-rsync-arguments) variable, but applied only to this container. + +## Custom rsync Arguments +Apply custom `rsync` args (in addition to the [default](#use-default-rsync-arguments) args) + +> **Default**: *empty* (use global setting) + +```properties +nautical-backup.rsync-custom-args=--exclude='*.log' --exclude='*.txt' +``` + +!!! note "This label will *override* the global setting applied through [Enviornment Variables](./arguments.md)" + * *Any value* will override the global rsync arguemnts configured through [global settings](./arguments.md#custom-rsync-arguments). + * A (empty) value of `"nautical-backup.rsync-custom-args="` will ^^cancel^^ any [global setting](./arguments.md#custom-rsync-arguments) for this container only. + * Not setting the label value will use the [global setting](./arguments.md#custom-rsync-arguments). + +🔄 Not setting a label is the same action as the [Custom rsync Arguments](./arguments.md#custom-rsync-arguments) variable, but applied only to this container. \ No newline at end of file diff --git a/pkg/backup.sh b/pkg/backup.sh index c10d1607..b3b49703 100644 --- a/pkg/backup.sh +++ b/pkg/backup.sh @@ -53,6 +53,7 @@ if [ "$REPORT_FILE" = "true" ]; then echo "Backup Report - $(date)" >"$DEST_LOCATION/$report_file" fi +DEFAULT_RSYNC_ARGS="-ahq" default_rsync_args="-ahq" if [ "$USE_DEFAULT_RSYNC_ARGS" = "false" ]; then default_rsync_args="" @@ -142,6 +143,20 @@ BackupContainer() { fi fi + if echo "$labels" | grep -q '"nautical-backup.use-default-rsync-args":"true"'; then + echo "Using default rsync args ($DEFAULT_RSYNC_ARGS) for $container" + default_rsync_args=$DEFAULT_RSYNC_ARGS + elif echo "$labels" | grep -q '"nautical-backup.use-default-rsync-args":"false"'; then + echo "Not using default rsync args ($DEFAULT_RSYNC_ARGS) for $container" + default_rsync_args="" + fi + + if echo "$labels" | grep -q '"nautical-backup.rsync-custom-args"'; then + new_custom_rsync_args=$(echo "$labels" | jq -r '.["nautical-backup.rsync-custom-args"]') + custom_args=$new_custom_rsync_args + echo "Using custom rsync args for $container" + fi + log_entry "Backing up $container data..." if [ "$LOG_RSYNC_COMMANDS" = "true" ]; then echo rsync $default_rsync_args $custom_args $src_dir/ $dest_dir/