computer-playbook/roles/native-user-backup/templates/ssh-wrapper.sh.j2

36 lines
1022 B
Plaintext
Raw Normal View History

2021-01-11 14:14:36 +01:00
#!/bin/sh
2021-01-11 14:24:29 +01:00
# log command
2021-01-11 14:14:36 +01:00
if [ -n "$SSH_ORIGINAL_COMMAND" ]
then
2021-01-11 14:24:29 +01:00
echo "`/bin/date`: $SSH_ORIGINAL_COMMAND" | systemd-cat -t "ssh-wrapper.sh"
2021-01-11 14:14:36 +01:00
fi
2021-01-11 15:01:09 +01:00
# define executable commands
get_hashed_machine_id="sha256sum /etc/machine-id";
get_backup_types="find /Backups/{{hashed_machine_id.stdout}}/ -maxdepth 1 -type d -execdir basename {} ';'";
# @todo This configuration is not scalable yet. If other backup services then docker-volume-backup are integrated, this logic needs to be optimized
get_static_last_version_dir="readlink -f /Backups/{{hashed_machine_id.stdout}}/docker-volume-backup/latest/"
rsync_command="sudo rsync --server --sender -blogDtpre.iLsfxCIvu . $($get_static_last_version_dir)/"
2021-01-11 15:01:09 +01:00
2021-01-11 14:14:36 +01:00
# filter commands
case "$SSH_ORIGINAL_COMMAND" in
"$get_hashed_machine_id")
$get_hashed_machine_id
;;
"$get_static_last_version_dir")
$get_static_last_version_dir
2021-01-11 14:14:36 +01:00
;;
"$get_backup_types")
$get_backup_types
2021-01-11 14:14:36 +01:00
;;
2021-01-11 15:01:09 +01:00
"$rsync_command")
$rsync_command
2021-01-11 14:14:36 +01:00
;;
*)
echo "This command is not supported."
exit 1
;;
esac