mirror of
https://github.com/vmstan/gravity-sync.git
synced 2024-08-30 18:22:11 +00:00
@ -1 +1,2 @@
|
|||||||
Your backup files will be stored here. They will be ignored by any git updates.
|
Your backup files will be stored here.
|
||||||
|
They will be ignored by any git updates.
|
@ -6,7 +6,7 @@ REMOTE_HOST='192.168.1.10'
|
|||||||
# User account on primary with SUDO rights
|
# User account on primary with SUDO rights
|
||||||
REMOTE_USER='pi'
|
REMOTE_USER='pi'
|
||||||
|
|
||||||
# OPTIONAL SETTING #######################
|
# OPTIONAL SETTINGS ######################
|
||||||
|
|
||||||
# Password for REMOTE_USER account
|
# Password for REMOTE_USER account
|
||||||
# Requires 'SSHPASS' installed on server
|
# Requires 'SSHPASS' installed on server
|
||||||
@ -15,3 +15,14 @@ REMOTE_USER='pi'
|
|||||||
# Leave blank to use (preferred) key-pair
|
# Leave blank to use (preferred) key-pair
|
||||||
|
|
||||||
REMOTE_PASS=''
|
REMOTE_PASS=''
|
||||||
|
|
||||||
|
# ADVANCED SETTINGS ######################
|
||||||
|
|
||||||
|
# Uncomment and set for auxillary control
|
||||||
|
# Overrides gravity-sync.sh defaults
|
||||||
|
|
||||||
|
# SSH_PORT=''
|
||||||
|
# SSH_PKIF=''
|
||||||
|
# LOG_PATH=''
|
||||||
|
# SYNCING_LOG=''
|
||||||
|
# CRONJOB_LOG=''
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
# GRAVITY SYNC BY VMSTAN #####################
|
# GRAVITY SYNC BY VMSTAN #####################
|
||||||
PROGRAM='Gravity Sync'
|
PROGRAM='Gravity Sync'
|
||||||
VERSION='1.4.0'
|
VERSION='1.4.1'
|
||||||
|
|
||||||
# Execute from the home folder of the user who own's it (ex: 'cd ~/gravity-sync')
|
# Execute from the home folder of the user who own's it (ex: 'cd ~/gravity-sync')
|
||||||
# For documentation or download updates visit https://github.com/vmstan/gravity-sync
|
# For documentation or download updates visit https://github.com/vmstan/gravity-sync
|
||||||
@ -15,11 +15,14 @@ VERSION='1.4.0'
|
|||||||
|
|
||||||
# GS Folder/File Locations
|
# GS Folder/File Locations
|
||||||
LOCAL_FOLDR='gravity-sync' # must exist in running user home folder
|
LOCAL_FOLDR='gravity-sync' # must exist in running user home folder
|
||||||
CONFIG_FILE='gravity-sync.conf' # must exist as explained above
|
CONFIG_FILE='gravity-sync.conf' # must exist with primary host/user configured
|
||||||
SYNCING_LOG='gravity-sync.log' # will be created in above folder
|
|
||||||
CRONJOB_LOG='gravity-sync.cron' # only used if cron is configured to output to this file
|
|
||||||
BACKUP_FOLD='backup' # must exist as subdirectory in LOCAL_FOLDR
|
BACKUP_FOLD='backup' # must exist as subdirectory in LOCAL_FOLDR
|
||||||
|
|
||||||
|
# Logging Folder/File Locations
|
||||||
|
LOG_PATH="$HOME/${LOCAL_FOLDR}" # replace in gravity-sync.conf to overwrite
|
||||||
|
SYNCING_LOG='gravity-sync.log' # replace in gravity-sync.conf to overwrite
|
||||||
|
CRONJOB_LOG='gravity-sync.cron' # replace in gravity-sync.conf to overwrite
|
||||||
|
|
||||||
# PH Folder/File Locations
|
# PH Folder/File Locations
|
||||||
PIHOLE_DIR='/etc/pihole' # default PH data directory
|
PIHOLE_DIR='/etc/pihole' # default PH data directory
|
||||||
GRAVITY_FI='gravity.db' # default PH database file
|
GRAVITY_FI='gravity.db' # default PH database file
|
||||||
@ -249,19 +252,19 @@ function push_gs {
|
|||||||
### Write Logs Out
|
### Write Logs Out
|
||||||
function logs_export {
|
function logs_export {
|
||||||
echo -e "${INFO} Logging Timestamps to ${SYNCING_LOG}"
|
echo -e "${INFO} Logging Timestamps to ${SYNCING_LOG}"
|
||||||
# date >> $HOME/${LOCAL_FOLDR}/${SYNCING_LOG}
|
echo -e $(date) "[${TASKTYPE}]" >> ${LOG_PATH}/${SYNCING_LOG}
|
||||||
echo -e $(date) "[${TASKTYPE}]" >> $HOME/${LOCAL_FOLDR}/${SYNCING_LOG}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
### Output Sync Logs
|
### Output Sync Logs
|
||||||
function logs_gs {
|
function logs_gs {
|
||||||
|
import_gs
|
||||||
|
|
||||||
|
echo -e "${INFO} Tailing ${LOG_PATH}/${SYNCING_LOG}"
|
||||||
echo -e "========================================================"
|
echo -e "========================================================"
|
||||||
echo -e "Recent Complete ${YELLOW}PULL${NC} Executions"
|
echo -e "Recent Complete ${YELLOW}PULL${NC} Executions"
|
||||||
tail -n 10 ${SYNCING_LOG} | grep PULL
|
tail -n 7 "${LOG_PATH}/${SYNCING_LOG}" | grep PULL
|
||||||
#echo -e "Recent Complete ${YELLOW}UPDATE${NC} Executions"
|
|
||||||
# tail -n 10 ${SYNCING_LOG} | grep UPDATE
|
|
||||||
echo -e "Recent Complete ${YELLOW}PUSH${NC} Executions"
|
echo -e "Recent Complete ${YELLOW}PUSH${NC} Executions"
|
||||||
tail -n 10 ${SYNCING_LOG} | grep PUSH
|
tail -n 7 "${LOG_PATH}/${SYNCING_LOG}" | grep PUSH
|
||||||
echo -e "========================================================"
|
echo -e "========================================================"
|
||||||
exit_nochange
|
exit_nochange
|
||||||
}
|
}
|
||||||
@ -269,40 +272,34 @@ function logs_gs {
|
|||||||
## Crontab Logs
|
## Crontab Logs
|
||||||
### Core Crontab Logs
|
### Core Crontab Logs
|
||||||
function show_crontab {
|
function show_crontab {
|
||||||
CRONPATH="$HOME/${LOCAL_FOLDR}/${CRONJOB_LOG}"
|
import_gs
|
||||||
|
|
||||||
MESSAGE="Replaying Last Cronjob"
|
MESSAGE="Replaying Last Cronjob"
|
||||||
echo -en "${STAT} ${MESSAGE}"
|
echo -en "${STAT} ${MESSAGE}"
|
||||||
|
|
||||||
if [ -f ${CRONPATH} ]
|
if [ -f ${LOG_PATH}/${CRONJOB_LOG} ]
|
||||||
then
|
then
|
||||||
if [ -s ${CRONPATH} ]
|
if [ -s ${LOG_PATH}/${CRONJOB_LOG} ]
|
||||||
echo -e "\r${GOOD} ${MESSAGE}"
|
echo -e "\r${GOOD} ${MESSAGE}"
|
||||||
logs_crontab
|
|
||||||
|
echo -e "${INFO} Tailing ${LOG_PATH}/${CRONJOB_LOG}"
|
||||||
|
echo -e "========================================================"
|
||||||
|
date -r ${LOG_PATH}/${CRONJOB_LOG}
|
||||||
|
cat ${LOG_PATH}/${CRONJOB_LOG}
|
||||||
|
echo -e "========================================================"
|
||||||
exit_nochange
|
exit_nochange
|
||||||
then
|
then
|
||||||
echo -e "\r${FAIL} ${MESSAGE}"
|
echo -e "\r${FAIL} ${MESSAGE}"
|
||||||
echo -e "${INFO} ${CRONPATH} appears empty"
|
echo -e "${INFO} ${LOG_PATH}/${CRONJOB_LOG} appears empty"
|
||||||
exit_nochange
|
exit_nochange
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
echo -e "\r${FAIL} ${MESSAGE}"
|
echo -e "\r${FAIL} ${MESSAGE}"
|
||||||
echo -e "${INFO} ${CRONPATH} cannot be located"
|
echo -e "${INFO} ${LOG_PATH}/${CRONJOB_LOG} cannot be located"
|
||||||
exit_nochange
|
exit_nochange
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
### Output Crontab
|
|
||||||
function logs_crontab {
|
|
||||||
echo -e "========================================================"
|
|
||||||
echo -e "========================================================"
|
|
||||||
echo -e ""
|
|
||||||
cat ${CRONJOB_LOG}
|
|
||||||
echo -e ""
|
|
||||||
echo -e "========================================================"
|
|
||||||
echo -e "========================================================"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Validate Functions
|
# Validate Functions
|
||||||
## Validate GS Folders
|
## Validate GS Folders
|
||||||
function validate_gs_folders {
|
function validate_gs_folders {
|
||||||
|
Reference in New Issue
Block a user