X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=btrbk-run;h=2e1bc6352193f861031bd6e2cf4bbfeff81889a7;hb=103a2e153f844343c359882079936b2521c82f15;hp=5d020d773d0229cdbfbbeb75a5ead04af1b9f1c8;hpb=5c8530653c87af3757a2c649772e0405bcd143a0;p=distro-setup diff --git a/btrbk-run b/btrbk-run index 5d020d7..2e1bc63 100644 --- a/btrbk-run +++ b/btrbk-run @@ -63,7 +63,13 @@ conf_only=false dry_run=false # mostly for testing rate_limit=no verbose=true; verbose_arg=-v -progress_arg="--progress" +if [[ $INVOCATION_ID ]]; then + # INVOCATION_ID means running as a systemd service. we cant show progress in this case, + # but if we pass the arg, it will insert mbuffer into the command. + progress_arg= +else + progress_arg="--progress" +fi incremental_strict=false pull_reexec=false @@ -102,8 +108,8 @@ while true; do # Comma separated mountpoints to backup. This has defaults set below. -m) IFS=, mountpoints=($2); unset IFS; shift 2 ;; -n) dry_run=true; dry_run_arg=-n; shift ;; - # show progress - -p) progress_arg="--progress"; shift ;; + # hide progress + -p) progress_arg=; shift ;; # internal option for rerunning under newer SOURCE_HOST version. --pull-reexec) pull_reexec=true; shift ;; # quiet @@ -196,7 +202,8 @@ if [[ ! -v targets && ! $source ]]; then at_work=false - targets=(frodo.b8.nz) + # todo, fix this up once frodo is back + # targets=(frodo.b8.nz) case $HOSTNAME in x2|kw) at_work=true @@ -218,10 +225,13 @@ if [[ ! -v targets && ! $source ]]; then home=b8.nz fi ;;& + x2) + targets+=($home) + ;; kw) targets+=($home x2.office.fsf.org) ;; - x2|x3|sy|bo) + x3|sy|bo) targets+=($home) if $at_work; then targets+=(x2.office.fsf.org x2.b8.nz) @@ -230,12 +240,21 @@ if [[ ! -v targets && ! $source ]]; then fi ;; kd) - targets+=(x2wg.b8.nz x3.b8.nz) + if ping -q -c1 -w1 x2.office.fsf.org &>/dev/null; then + targets+=(x2.office.fsf.org) + else + targets+=(x2wg.b8.nz) + fi if ping -q -c1 -w1 sy.b8.nz &>/dev/null; then targets+=(sy.b8.nz) else targets+=(syw.b8.nz) fi + if ping -q -c1 -w1 x3.b8.nz &>/dev/null; then + targets+=(x3.b8.nz) + else + targets+=(x3w.b8.nz) + fi ;; frodo) # no targets @@ -279,19 +298,19 @@ else if [[ $source_host == "$MAIL_HOST" ]]; then prospective_mps+=(/o) fi + if [[ $source_host == "$HOST2" ]]; then + prospective_mps+=(/a /ar /qr /q) + fi else if [[ $HOSTNAME == "$MAIL_HOST" ]]; then - # HOST2 is really the mail host if it exists - if [[ $HOST2 && $HOST2 != "$HOSTNAME" ]]; then - echo "skipping /o because HOST2 is not us" - else - prospective_mps+=(/o) - fi + prospective_mps+=(/o) + fi + if [[ $HOSTNAME == "$HOST2" ]]; then + prospective_mps+=(/a /ar /qr /q) fi fi # note: put q last just in case its specific retention options were to # affect other config sections. I havent tested if that is the case. - prospective_mps+=(/a /ar /qr /q) ;; esac fi