mb-backup-manager/scripts/imports/manage_backup_schedule.sh

78 lines
2.1 KiB
Bash
Raw Normal View History

2024-09-18 16:53:20 +00:00
#!/bin/bash
2024-11-12 18:15:11 +00:00
# Enable strict error handling
set -euo pipefail
trap 'handle_error $? $LINENO' ERR
2024-09-18 16:53:20 +00:00
# Configuration
BACKUP_SCRIPT="/home/litespeed/mb-backups/backup_all.sh"
LOG_DIR="/home/litespeed/mb-backups/logs/auto"
ACTION_LOG_FILE="${LOG_DIR}/schedule_actions.log"
BACKUP_LOG_PREFIX="${LOG_DIR}/backup_"
2024-11-12 18:15:11 +00:00
PASSWORD_FILE="/etc/restic-password"
LOCK_FILE="/tmp/backup_schedule.lock"
2024-11-12 18:58:17 +00:00
SCHEDULE="0 0 * * *" # Default to daily at midnight
2024-11-12 18:15:11 +00:00
# Error handling function
handle_error() {
local exit_code=$1
local line_no=$2
log_action "ERROR: Command failed at line ${line_no} with exit code ${exit_code}"
cleanup_and_exit 1
}
2024-09-18 16:53:20 +00:00
2024-11-12 18:15:11 +00:00
# Cleanup function
cleanup_and_exit() {
local exit_code=$1
[ -f "$LOCK_FILE" ] && rm -f "$LOCK_FILE"
exit "${exit_code}"
}
2024-09-18 16:53:20 +00:00
2024-11-12 18:15:11 +00:00
# Ensure single instance
ensure_single_instance() {
if [ -f "$LOCK_FILE" ]; then
if kill -0 "$(cat "$LOCK_FILE")" 2>/dev/null; then
log_action "ERROR: Another instance is running"
exit 1
fi
fi
echo $$ > "$LOCK_FILE"
}
2024-11-12 18:58:17 +00:00
# Logging function
2024-09-18 16:53:20 +00:00
log_action() {
2024-11-12 18:15:11 +00:00
local timestamp=$(date +'%Y-%m-%d %H:%M:%S')
2024-11-12 18:58:17 +00:00
echo "[$timestamp] $1" | tee -a "$ACTION_LOG_FILE"
2024-09-18 16:53:20 +00:00
}
2024-11-12 18:58:17 +00:00
# Function to configure the cron job
configure_cron_job() {
if [ ! -f "$PASSWORD_FILE" ]; then
log_action "ERROR: Restic password file not found"
2024-11-12 18:15:11 +00:00
return 1
2024-11-12 18:29:16 +00:00
fi
2024-09-18 16:53:20 +00:00
2024-11-12 18:58:17 +00:00
local restic_password
restic_password=$(cat "$PASSWORD_FILE")
local cmd="RESTIC_PASSWORD='$restic_password' LOG_FILE='${BACKUP_LOG_PREFIX}\$(date +\%Y-\%m-\%d_\%H-\%M-\%S).log' $BACKUP_SCRIPT > \"\$LOG_FILE\" 2>&1 || echo \"\$(date) Backup failed\" >> \"$ACTION_LOG_FILE\""
2024-09-18 16:53:20 +00:00
2024-11-12 19:15:30 +00:00
log_action "Adding cron job with schedule: $SCHEDULE and command: $cmd"
2024-11-12 18:58:17 +00:00
# Update the cron job
(crontab -l 2>/dev/null | grep -v "$BACKUP_SCRIPT"; echo "$SCHEDULE $cmd") | crontab -
2024-11-12 19:15:30 +00:00
2024-11-12 18:58:17 +00:00
log_action "Scheduled daily backup at midnight with command: $cmd"
2024-11-12 18:15:11 +00:00
}
# Main execution
main() {
2024-11-12 19:15:30 +00:00
log_action "Starting manage_backup_schedule.sh"
2024-11-12 18:15:11 +00:00
mkdir -p "$LOG_DIR"
chmod 750 "$LOG_DIR"
ensure_single_instance
2024-11-12 18:58:17 +00:00
configure_cron_job
2024-11-12 18:15:11 +00:00
cleanup_and_exit 0
}
# Execute main function with all arguments
2024-11-12 19:15:30 +00:00
main "$@"