41 lines
882 B
Bash
41 lines
882 B
Bash
#!/bin/bash
|
|
|
|
# shellcheck source=actual_server-env
|
|
. "${HOME}"/"${USER}"-env
|
|
|
|
mkdir -p "${HOME}"/backup_logs
|
|
logFile=${HOME}/backup_logs/$(date +%y_%m).log
|
|
|
|
{
|
|
echo -e "\n[+] actual backup\n"
|
|
|
|
mkdir -p /tmp/"${USER}"-backup/{user,server}-files
|
|
|
|
sudo docker compose -f "${HOME}"/"${USER}"-compose.yaml stop
|
|
|
|
cp -pr "${VOLUME_PATH}"/* /tmp/"${USER}"-backup
|
|
|
|
sudo docker compose -f "${HOME}"/"${USER}"-compose.yaml start
|
|
|
|
rclone copy /tmp/"${USER}"-backup "${BUCKET_PATH}" -v
|
|
if [ $? -ne 0 ]; then
|
|
curl -Ss \
|
|
-H "Title: Actual Server" \
|
|
-H "Priority: 3" \
|
|
-H "Tags: warning,backup" \
|
|
-d "Backup not completed" \
|
|
"${NOTIF_URL}"
|
|
rm -r /tmp/"${USER}"-backup
|
|
exit 1
|
|
fi
|
|
|
|
curl -Ss \
|
|
-H "Title: Actual Server" \
|
|
-H "Priority: 2" \
|
|
-H "Tags: heavy_check_mark,backup" \
|
|
-d "Backup completed" \
|
|
"${NOTIF_URL}"
|
|
rm -r /tmp/"${USER}"-backup
|
|
|
|
} &>>"$logFile"
|