gravity-sync/includes/gs-restore.sh

243 lines
7.2 KiB
Bash
Raw Normal View History

# GRAVITY SYNC BY VMSTAN #####################
# gs-restore.sh ##############################
# For documentation or downloading updates visit https://github.com/vmstan/gravity-sync
# This code is called from the main gravity-sync.sh file and should not execute directly!
## Restore Task
function task_restore {
TASKTYPE='RESTORE'
MESSAGE="${MESSAGE}: ${TASKTYPE} Requested"
echo_good
2020-12-31 02:49:54 +00:00
show_target
validate_gs_folders
validate_ph_folders
if [ "${INCLUDE_CNAME}" == "1" ]
then
validate_dns_folders
fi
validate_sqlite3
2020-12-31 02:49:54 +00:00
restore_gs
exit
}
## Restore Gravity
function restore_gs {
2020-12-31 02:45:47 +00:00
MESSAGE="This will restore your settings on $HOSTNAME with a previous version!"
echo_warn
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
MESSAGE="PREVIOUS BACKUPS AVAILABLE FOR RESTORATION"
echo_info
ls ${LOCAL_FOLDR}/${BACKUP_FOLD} | grep $(date +%Y) | grep ${GRAVITY_FI} | colrm 18
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
MESSAGE="Select backup date to restore ${GRAVITY_FI} from"
echo_need
read INPUT_BACKUP_DATE
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
if [ -f ${LOCAL_FOLDR}/${BACKUP_FOLD}/${INPUT_BACKUP_DATE}-${GRAVITY_FI}.backup ]
then
MESSAGE="Backup File Selected"
else
MESSAGE="Invalid Request"
echo_info
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
exit_nochange
fi
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
if [ "$SKIP_CUSTOM" != '1' ]
then
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
if [ -f ${PIHOLE_DIR}/${CUSTOM_DNS} ]
then
ls ${LOCAL_FOLDR}/${BACKUP_FOLD} | grep $(date +%Y) | grep ${CUSTOM_DNS} | colrm 18
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
MESSAGE="Select backup date to restore ${CUSTOM_DNS} from"
echo_need
read INPUT_DNSBACKUP_DATE
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
if [ -f ${LOCAL_FOLDR}/${BACKUP_FOLD}/${INPUT_DNSBACKUP_DATE}-${CUSTOM_DNS}.backup ]
then
MESSAGE="Backup File Selected"
else
MESSAGE="Invalid Request"
echo_info
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
exit_nochange
fi
fi
fi
2020-12-31 02:49:54 +00:00
if [ "$INCLUDE_CNAME" == '1' ]
then
if [ -f ${DNSMAQ_DIR}/${CNAME_CONF} ]
then
ls ${LOCAL_FOLDR}/${BACKUP_FOLD} | grep $(date +%Y) | grep ${CNAME_CONF} | colrm 18
MESSAGE="Select backup date to restore ${CNAME_CONF} from"
echo_need
read INPUT_CNAMEBACKUP_DATE
if [ -f ${LOCAL_FOLDR}/${BACKUP_FOLD}/${INPUT_CNAMEBACKUP_DATE}-${CNAME_CONF}.backup ]
then
MESSAGE="Backup File Selected"
else
MESSAGE="Invalid Request"
echo_info
exit_nochange
fi
fi
fi
2020-12-31 02:45:47 +00:00
MESSAGE="${GRAVITY_FI} from ${INPUT_BACKUP_DATE} Selected"
2020-12-31 02:49:54 +00:00
echo_info
2020-12-31 02:45:47 +00:00
MESSAGE="${CUSTOM_DNS} from ${INPUT_DNSBACKUP_DATE} Selected"
2020-12-31 02:49:54 +00:00
echo_info
MESSAGE="${CNAME_CONF} from ${INPUT_CNAMEBACKUP_DATE} Selected"
echo_info
2020-12-31 02:45:47 +00:00
intent_validate
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
MESSAGE="Making Time Warp Calculations"
echo_info
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
MESSAGE="Stopping Pi-hole Services"
echo_stat
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
sudo service pihole-FTL stop >/dev/null 2>&1
2020-12-31 02:49:54 +00:00
error_validate
2020-12-31 02:45:47 +00:00
MESSAGE="Restoring ${GRAVITY_FI} on $HOSTNAME"
2020-12-31 02:49:54 +00:00
echo_stat
sudo cp ${LOCAL_FOLDR}/${BACKUP_FOLD}/${INPUT_BACKUP_DATE}-${GRAVITY_FI}.backup ${PIHOLE_DIR}/${GRAVITY_FI} >/dev/null 2>&1
error_validate
2020-12-31 02:45:47 +00:00
MESSAGE="Validating Ownership on ${GRAVITY_FI}"
echo_stat
2020-12-31 02:49:54 +00:00
GRAVDB_OWN=$(ls -ld ${PIHOLE_DIR}/${GRAVITY_FI} | awk 'OFS=":" {print $3,$4}')
if [ "$GRAVDB_OWN" == "$FILE_OWNER" ]
then
echo_good
else
echo_fail
2020-12-31 02:45:47 +00:00
2020-12-31 02:49:54 +00:00
MESSAGE="Attempting to Compensate"
echo_warn
2020-12-31 02:45:47 +00:00
2020-12-31 02:49:54 +00:00
MESSAGE="Setting Ownership on ${GRAVITY_FI}"
echo_stat
sudo chown ${FILE_OWNER} ${PIHOLE_DIR}/${GRAVITY_FI} >/dev/null 2>&1
error_validate
fi
2020-12-31 02:45:47 +00:00
MESSAGE="Validating Permissions on ${GRAVITY_FI}"
echo_stat
2020-12-31 02:49:54 +00:00
GRAVDB_RWE=$(namei -m ${PIHOLE_DIR}/${GRAVITY_FI} | grep -v f: | grep ${GRAVITY_FI} | awk '{print $1}')
if [ "$GRAVDB_RWE" = "-rw-rw-r--" ]
then
echo_good
else
echo_fail
2020-12-31 02:45:47 +00:00
2020-12-31 02:49:54 +00:00
MESSAGE="Attempting to Compensate"
echo_warn
MESSAGE="Setting Ownership on ${GRAVITY_FI}"
echo_stat
sudo chmod 664 ${PIHOLE_DIR}/${GRAVITY_FI} >/dev/null 2>&1
error_validate
fi
2020-12-31 02:45:47 +00:00
if [ "$SKIP_CUSTOM" != '1' ]
2020-12-31 02:49:54 +00:00
then
2020-12-31 02:45:47 +00:00
if [ -f ${LOCAL_FOLDR}/${BACKUP_FOLD}/${INPUT_DNSBACKUP_DATE}-${CUSTOM_DNS}.backup ]
then
MESSAGE="Restoring ${CUSTOM_DNS} on $HOSTNAME"
echo_stat
2020-12-31 02:49:54 +00:00
sudo cp ${LOCAL_FOLDR}/${BACKUP_FOLD}/${INPUT_DNSBACKUP_DATE}-${CUSTOM_DNS}.backup ${PIHOLE_DIR}/${CUSTOM_DNS} >/dev/null 2>&1
error_validate
2020-12-31 02:45:47 +00:00
MESSAGE="Validating Ownership on ${CUSTOM_DNS}"
echo_stat
2020-12-31 02:49:54 +00:00
CUSTOMLS_OWN=$(ls -ld ${PIHOLE_DIR}/${CUSTOM_DNS} | awk '{print $3 $4}')
if [ "$CUSTOMLS_OWN" == "rootroot" ]
then
echo_good
else
echo_fail
2020-12-31 02:45:47 +00:00
2020-12-31 02:49:54 +00:00
MESSAGE="Attempting to Compensate"
echo_warn
2020-12-31 02:45:47 +00:00
2020-12-31 02:49:54 +00:00
MESSAGE="Setting Ownership on ${CUSTOM_DNS}"
echo_stat
sudo chown root:root ${PIHOLE_DIR}/${CUSTOM_DNS} >/dev/null 2>&1
error_validate
fi
2020-12-31 02:45:47 +00:00
MESSAGE="Validating Permissions on ${CUSTOM_DNS}"
echo_stat
2020-12-31 02:49:54 +00:00
CUSTOMLS_RWE=$(namei -m ${PIHOLE_DIR}/${CUSTOM_DNS} | grep -v f: | grep ${CUSTOM_DNS} | awk '{print $1}')
if [ "$CUSTOMLS_RWE" == "-rw-r--r--" ]
then
echo_good
else
echo_fail
MESSAGE="Attempting to Compensate"
echo_warn
2020-12-31 02:45:47 +00:00
2020-12-31 02:49:54 +00:00
MESSAGE="Setting Ownership on ${CUSTOM_DNS}"
echo_stat
sudo chmod 644 ${PIHOLE_DIR}/${CUSTOM_DNS} >/dev/null 2>&1
error_validate
fi
2020-12-31 02:45:47 +00:00
fi
fi
2020-12-31 02:49:54 +00:00
if [ "$INCLUDE_CNAME" == '1' ]
then
if [ -f ${LOCAL_FOLDR}/${BACKUP_FOLD}/${INPUT_CNAMEBACKUP_DATE}-${CNAME_CONF}.backup ]
then
MESSAGE="Restoring ${CNAME_CONF} on $HOSTNAME"
echo_stat
sudo cp ${LOCAL_FOLDR}/${BACKUP_FOLD}/${INPUT_CNAMEBACKUP_DATE}-${CNAME_CONF}.backup ${DNSMAQ_DIR}/${CNAME_CONF} >/dev/null 2>&1
error_validate
MESSAGE="Validating Ownership on ${CNAME_CONF}"
echo_stat
validate_cname_permissions
fi
fi
2020-12-31 02:45:47 +00:00
pull_gs_reload
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
MESSAGE="Do you want to push the restored configuration to the primary Pi-hole? (yes/no)"
echo_need
read PUSH_TO_PRIMARY
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
if [ "${PUSH_TO_PRIMARY}" == "Yes" ] || [ "${PUSH_TO_PRIMARY}" == "yes" ] || [ "${PUSH_TO_PRIMARY}" == "Y" ] || [ "${PUSH_TO_PRIMARY}" == "y" ]
then
push_gs
elif [ "${PUSH_TO_PRIMARY}" == "No" ] || [ "${PUSH_TO_PRIMARY}" == "no" ] || [ "${PUSH_TO_PRIMARY}" == "N" ] || [ "${PUSH_TO_PRIMARY}" == "n" ]
then
logs_export
exit_withchange
else
MESSAGE="Invalid Selection - Defaulting No"
echo_warn
2020-12-31 02:49:54 +00:00
2020-12-31 02:45:47 +00:00
logs_export
exit_withchange
fi
}