2018-01-11 22:26:43 +00:00
#!{{ borgbackup_shell }}
2017-09-07 18:35:01 +00:00
if [ -z "$1" ] || [ ! -z "$2" ]
then
printf "Possible: info | init | list | backup | mount \n\n"
fi
# Sourcing the backup-passphrase
2018-01-28 17:01:15 +00:00
. ~{{ borgbackup_client_user }}/.borg.passphrase
2017-09-07 18:35:01 +00:00
# Small helper commands, like listing backups, will help us in the future :)
if [ "$1" = "info" ]
then
if [ -z "$2" ]; then printf "run $0 with list and use the backup-tag to request information\n"; exit 1; fi
2017-10-01 17:51:38 +00:00
{% for b in borgbackup_servers %}
2018-01-11 22:21:43 +00:00
REPOSITORY={% if b.type == 'hetzner' %}ssh://{% endif %}{{ b.user }}@{{ b.fqdn }}:{% if b.type == 'hetzner' %}23/./{% endif %}{{ b.home }}{{ b.pool }}/{{ inventory_hostname }}
2018-01-28 18:35:00 +00:00
/usr/local/bin/borg info {{ b.options }} $REPOSITORY::$2
2017-09-07 18:35:01 +00:00
{% endfor %}
exit 0
fi
if [ "$1" = "mount" ]
then
if [ -z "$2" ]; then printf "Select the backup-server\n"; exit 1; fi
if [ -z "$3" ]; then printf "Select the backup to mount\n"; exit 1; fi
if [ -z "$4" ]; then printf "Select the path to mount the backup on\n"; exit 1; fi
2017-10-01 17:51:38 +00:00
{% for b in borgbackup_servers %}
2018-01-11 22:21:43 +00:00
REPOSITORY={% if b.type == 'hetzner' %}ssh://{% endif %}{{ b.user }}@{{ b.fqdn }}:{% if b.type == 'hetzner' %}23/./{% endif %}{{ b.home }}{{ b.pool }}/{{ inventory_hostname }}
2018-01-28 18:35:00 +00:00
/usr/local/bin/borg mount {{ b.options }} $REPOSITORY::$3 $4
2017-09-07 18:35:01 +00:00
if [ "$?" = "0" ]; then printf "Backup mounted on $4, do not forget to unmount!\n"; fi
exit 0
{% endfor %}
fi
if [ "$1" = "list" ]
then
2017-10-01 17:51:38 +00:00
{% for b in borgbackup_servers %}
2018-01-11 22:21:43 +00:00
REPOSITORY={% if b.type == 'hetzner' %}ssh://{% endif %}{{ b.user }}@{{ b.fqdn }}:{% if b.type == 'hetzner' %}23/./{% endif %}{{ b.home }}{{ b.pool }}/{{ inventory_hostname }}
2017-09-07 18:35:01 +00:00
printf "Archives on {{ b.fqdn }} :\n"
2018-01-28 18:35:00 +00:00
/usr/local/bin/borg list {{ b.options }} -v $REPOSITORY
2017-09-07 18:35:01 +00:00
{% endfor %}
exit 0
fi
if [ "$1" = "init" ]
then
2017-10-01 17:51:38 +00:00
{% for b in borgbackup_servers %}
2018-01-11 22:21:43 +00:00
REPOSITORY={% if b.type == 'hetzner' %}ssh://{% endif %}{{ b.user }}@{{ b.fqdn }}:{% if b.type == 'hetzner' %}23/./{% endif %}{{ b.home }}{{ b.pool }}/{{ inventory_hostname }}
2018-01-28 18:35:00 +00:00
/usr/local/bin/borg init --encryption={{ borgbackup_encryption_mode }} {{ b.options }} $REPOSITORY
2017-09-07 18:35:01 +00:00
{% endfor %}
exit 0
fi
if [ "$1" = "backup" ]
then
date=`date +%Y%m%d-%H%M`
# Running some commands pre-backup
2017-10-01 11:05:59 +00:00
{% for precommand in borgbackup_pre_commands %}
2017-09-07 18:35:01 +00:00
{{ precommand }}
{% endfor %}
2017-10-01 17:51:38 +00:00
{% for b in borgbackup_servers %}
2017-09-07 18:35:01 +00:00
printf "Backing up to {{ b.fqdn }} :\n"
2018-01-11 22:21:43 +00:00
REPOSITORY={% if b.type == 'hetzner' %}ssh://{% endif %}{{ b.user }}@{{ b.fqdn }}:{% if b.type == 'hetzner' %}23/./{% endif %}{{ b.home }}{{ b.pool }}/{{ inventory_hostname }}
2017-09-07 18:35:01 +00:00
2018-01-29 19:34:41 +00:00
/usr/local/bin/borg create --progress --compression {{ borgbackup_compression }} --stats {{ b.options }} $REPOSITORY::$date {% for dir in borgbackup_include %}{{ dir }} {% endfor %}{% if automysql.stat.isdir is defined and automysql.stat.isdir == True %}/var/lib/automysqlbackup{% endif %} {% for dir in borgbackup_exclude %} --exclude '{{ dir }}'{% endfor %}
2017-09-07 18:35:01 +00:00
2018-01-11 22:21:43 +00:00
if [ "$?" -eq "0" ]; then printf "Backup succeeded on $date to {{ b.fqdn }}\n" >> /var/log/borg-backup.log; fi
2017-10-01 17:24:50 +00:00
{% if not borgbackup_appendonly %}
# prune old backups
2018-01-28 18:35:00 +00:00
/usr/local/bin/borg prune {{ b.options }} -v $REPOSITORY -H {{ borgbackup_retention.hourly }} -d {{ borgbackup_retention.daily }} -w {{ borgbackup_retention.weekly }} -m {{ borgbackup_retention.monthly }} -y {{ borgbackup_retention.yearly }}
2017-10-01 17:24:50 +00:00
{% endif %}
2017-09-07 18:35:01 +00:00
{% endfor %}
2018-01-11 22:24:11 +00:00
# Running some commands post-backup
{% for postcommand in borgbackup_post_commands %}
{{ postcommand }}
{% endfor %}
2017-09-07 18:35:01 +00:00
fi