2020-10-07 22:45:39 +00:00
|
|
|
# GRAVITY SYNC BY VMSTAN #####################
|
|
|
|
# gs-hasing.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!
|
|
|
|
|
|
|
|
## Validate Sync Required
|
|
|
|
function md5_compare {
|
2020-12-31 02:45:47 +00:00
|
|
|
HASHMARK='0'
|
2020-12-31 02:49:54 +00:00
|
|
|
|
2020-12-31 02:45:47 +00:00
|
|
|
MESSAGE="Analyzing ${GRAVITY_FI} on ${REMOTE_HOST}"
|
|
|
|
echo_stat
|
2020-12-31 02:49:54 +00:00
|
|
|
primaryDBMD5=$(${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} "md5sum ${RIHOLE_DIR}/${GRAVITY_FI}" | sed 's/\s.*$//')
|
|
|
|
error_validate
|
2020-12-31 02:45:47 +00:00
|
|
|
|
|
|
|
MESSAGE="Analyzing ${GRAVITY_FI} on $HOSTNAME"
|
|
|
|
echo_stat
|
|
|
|
secondDBMD5=$(md5sum ${PIHOLE_DIR}/${GRAVITY_FI} | sed 's/\s.*$//')
|
2020-12-31 02:49:54 +00:00
|
|
|
error_validate
|
2020-12-31 02:45:47 +00:00
|
|
|
|
|
|
|
if [ "$primaryDBMD5" == "$last_primaryDBMD5" ] && [ "$secondDBMD5" == "$last_secondDBMD5" ]
|
|
|
|
then
|
|
|
|
HASHMARK=$((HASHMARK+0))
|
|
|
|
else
|
|
|
|
MESSAGE="Differenced ${GRAVITY_FI} Detected"
|
|
|
|
echo_warn
|
|
|
|
HASHMARK=$((HASHMARK+1))
|
|
|
|
fi
|
2020-12-31 02:49:54 +00:00
|
|
|
|
2020-12-31 02:45:47 +00:00
|
|
|
if [ "$SKIP_CUSTOM" != '1' ]
|
|
|
|
then
|
|
|
|
if [ -f ${PIHOLE_DIR}/${CUSTOM_DNS} ]
|
|
|
|
then
|
|
|
|
if ${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} test -e ${RIHOLE_DIR}/${CUSTOM_DNS}
|
|
|
|
then
|
|
|
|
REMOTE_CUSTOM_DNS="1"
|
|
|
|
MESSAGE="Analyzing ${CUSTOM_DNS} on ${REMOTE_HOST}"
|
|
|
|
echo_stat
|
2020-12-31 02:49:54 +00:00
|
|
|
|
|
|
|
primaryCLMD5=$(${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} "md5sum ${RIHOLE_DIR}/${CUSTOM_DNS} | sed 's/\s.*$//'")
|
|
|
|
error_validate
|
2020-12-31 02:45:47 +00:00
|
|
|
|
|
|
|
MESSAGE="Analyzing ${CUSTOM_DNS} on $HOSTNAME"
|
|
|
|
echo_stat
|
|
|
|
secondCLMD5=$(md5sum ${PIHOLE_DIR}/${CUSTOM_DNS} | sed 's/\s.*$//')
|
2020-12-31 02:49:54 +00:00
|
|
|
error_validate
|
2020-12-31 02:45:47 +00:00
|
|
|
|
|
|
|
if [ "$primaryCLMD5" == "$last_primaryCLMD5" ] && [ "$secondCLMD5" == "$last_secondCLMD5" ]
|
|
|
|
then
|
|
|
|
HASHMARK=$((HASHMARK+0))
|
|
|
|
else
|
|
|
|
MESSAGE="Differenced ${CUSTOM_DNS} Detected"
|
|
|
|
echo_warn
|
|
|
|
HASHMARK=$((HASHMARK+1))
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
MESSAGE="No ${CUSTOM_DNS} Detected on ${REMOTE_HOST}"
|
|
|
|
echo_info
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
if ${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} test -e ${RIHOLE_DIR}/${CUSTOM_DNS}
|
|
|
|
then
|
|
|
|
REMOTE_CUSTOM_DNS="1"
|
|
|
|
MESSAGE="${REMOTE_HOST} has ${CUSTOM_DNS}"
|
|
|
|
HASHMARK=$((HASHMARK+1))
|
|
|
|
echo_info
|
2020-12-31 02:49:54 +00:00
|
|
|
fi
|
2020-12-31 02:45:47 +00:00
|
|
|
MESSAGE="No ${CUSTOM_DNS} Detected on $HOSTNAME"
|
|
|
|
echo_info
|
|
|
|
fi
|
|
|
|
fi
|
2020-12-31 02:49:54 +00:00
|
|
|
|
2021-01-04 20:37:35 +00:00
|
|
|
if [ "${SKIP_CUSTOM}" != '1' ]
|
|
|
|
then
|
|
|
|
if [ "${INCLUDE_CNAME}" == "1" ]
|
|
|
|
then
|
|
|
|
if [ -f ${DNSMAQ_DIR}/${CNAME_CONF} ]
|
|
|
|
then
|
|
|
|
if ${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} test -e ${RNSMAQ_DIR}/${CNAME_CONF}
|
|
|
|
then
|
|
|
|
REMOTE_CNAME_DNS="1"
|
|
|
|
MESSAGE="Analyzing ${CNAME_CONF} on ${REMOTE_HOST}"
|
|
|
|
echo_stat
|
|
|
|
|
|
|
|
primaryCNMD5=$(${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} "md5sum ${RNSMAQ_DIR}/${CNAME_CONF} | sed 's/\s.*$//'")
|
|
|
|
error_validate
|
|
|
|
|
|
|
|
MESSAGE="Analyzing ${CNAME_CONF} on $HOSTNAME"
|
|
|
|
echo_stat
|
|
|
|
secondCNMD5=$(md5sum ${DNSMAQ_DIR}/${CNAME_CONF} | sed 's/\s.*$//')
|
|
|
|
error_validate
|
|
|
|
|
|
|
|
if [ "$primaryCNMD5" == "$last_primaryCNMD5" ] && [ "$secondCNMD5" == "$last_secondCNMD5" ]
|
|
|
|
then
|
|
|
|
HASHMARK=$((HASHMARK+0))
|
|
|
|
else
|
|
|
|
MESSAGE="Differenced ${CNAME_CONF} Detected"
|
|
|
|
echo_warn
|
|
|
|
HASHMARK=$((HASHMARK+1))
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
MESSAGE="No ${CNAME_CONF} Detected on ${REMOTE_HOST}"
|
|
|
|
echo_info
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
if ${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} test -e ${RNSMAQ_DIR}/${CNAME_CONF}
|
|
|
|
then
|
|
|
|
REMOTE_CNAME_DNS="1"
|
|
|
|
MESSAGE="${REMOTE_HOST} has ${CNAME_CONF}"
|
|
|
|
HASHMARK=$((HASHMARK+1))
|
|
|
|
echo_info
|
|
|
|
fi
|
|
|
|
|
|
|
|
MESSAGE="No ${CNAME_CONF} Detected on $HOSTNAME"
|
|
|
|
echo_info
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-12-31 02:45:47 +00:00
|
|
|
if [ "$HASHMARK" != "0" ]
|
|
|
|
then
|
|
|
|
MESSAGE="Replication Required"
|
|
|
|
echo_warn
|
|
|
|
HASHMARK=$((HASHMARK+0))
|
|
|
|
else
|
|
|
|
MESSAGE="No Replication Required"
|
|
|
|
echo_info
|
2021-02-04 16:47:40 +00:00
|
|
|
backup_cleanup
|
2020-12-31 02:49:54 +00:00
|
|
|
exit_nochange
|
2020-12-31 02:45:47 +00:00
|
|
|
fi
|
2020-10-07 22:45:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function previous_md5 {
|
2020-12-31 02:45:47 +00:00
|
|
|
if [ -f "${LOG_PATH}/${HISTORY_MD5}" ]
|
|
|
|
then
|
|
|
|
last_primaryDBMD5=$(sed "1q;d" ${LOG_PATH}/${HISTORY_MD5})
|
|
|
|
last_secondDBMD5=$(sed "2q;d" ${LOG_PATH}/${HISTORY_MD5})
|
|
|
|
last_primaryCLMD5=$(sed "3q;d" ${LOG_PATH}/${HISTORY_MD5})
|
|
|
|
last_secondCLMD5=$(sed "4q;d" ${LOG_PATH}/${HISTORY_MD5})
|
2021-01-04 20:37:35 +00:00
|
|
|
last_primaryCNMD5=$(sed "5q;d" ${LOG_PATH}/${HISTORY_MD5})
|
|
|
|
last_secondCNMD5=$(sed "6q;d" ${LOG_PATH}/${HISTORY_MD5})
|
2020-12-31 02:45:47 +00:00
|
|
|
else
|
|
|
|
last_primaryDBMD5="0"
|
|
|
|
last_secondDBMD5="0"
|
|
|
|
last_primaryCLMD5="0"
|
|
|
|
last_secondCLMD5="0"
|
2021-01-04 20:37:35 +00:00
|
|
|
last_primaryCNMD5="0"
|
|
|
|
last_secondCNMD5="0"
|
2020-12-31 02:45:47 +00:00
|
|
|
fi
|
2020-10-07 22:45:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function md5_recheck {
|
2020-12-31 02:45:47 +00:00
|
|
|
MESSAGE="Performing Replicator Diagnostics"
|
|
|
|
echo_info
|
|
|
|
|
|
|
|
HASHMARK='0'
|
2020-12-31 02:49:54 +00:00
|
|
|
|
2020-12-31 02:45:47 +00:00
|
|
|
MESSAGE="Reanalyzing ${GRAVITY_FI} on ${REMOTE_HOST}"
|
|
|
|
echo_stat
|
2020-12-31 02:49:54 +00:00
|
|
|
primaryDBMD5=$(${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} "md5sum ${RIHOLE_DIR}/${GRAVITY_FI}" | sed 's/\s.*$//')
|
|
|
|
error_validate
|
2020-12-31 02:45:47 +00:00
|
|
|
|
|
|
|
MESSAGE="Reanalyzing ${GRAVITY_FI} on $HOSTNAME"
|
|
|
|
echo_stat
|
|
|
|
secondDBMD5=$(md5sum ${PIHOLE_DIR}/${GRAVITY_FI} | sed 's/\s.*$//')
|
2020-12-31 02:49:54 +00:00
|
|
|
error_validate
|
|
|
|
|
2020-12-31 02:45:47 +00:00
|
|
|
if [ "$SKIP_CUSTOM" != '1' ]
|
|
|
|
then
|
|
|
|
if [ -f ${PIHOLE_DIR}/${CUSTOM_DNS} ]
|
|
|
|
then
|
|
|
|
if ${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} test -e ${RIHOLE_DIR}/${CUSTOM_DNS}
|
|
|
|
then
|
|
|
|
REMOTE_CUSTOM_DNS="1"
|
|
|
|
MESSAGE="Reanalyzing ${CUSTOM_DNS} on ${REMOTE_HOST}"
|
|
|
|
echo_stat
|
2020-12-31 02:49:54 +00:00
|
|
|
|
|
|
|
primaryCLMD5=$(${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} "md5sum ${RIHOLE_DIR}/${CUSTOM_DNS} | sed 's/\s.*$//'")
|
|
|
|
error_validate
|
2020-12-31 02:45:47 +00:00
|
|
|
|
|
|
|
MESSAGE="Reanalyzing ${CUSTOM_DNS} on $HOSTNAME"
|
|
|
|
echo_stat
|
|
|
|
secondCLMD5=$(md5sum ${PIHOLE_DIR}/${CUSTOM_DNS} | sed 's/\s.*$//')
|
2020-12-31 02:49:54 +00:00
|
|
|
error_validate
|
2020-12-31 02:45:47 +00:00
|
|
|
else
|
|
|
|
MESSAGE="No ${CUSTOM_DNS} Detected on ${REMOTE_HOST}"
|
|
|
|
echo_info
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
if ${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} test -e ${RIHOLE_DIR}/${CUSTOM_DNS}
|
|
|
|
then
|
|
|
|
REMOTE_CUSTOM_DNS="1"
|
|
|
|
MESSAGE="${REMOTE_HOST} has ${CUSTOM_DNS}"
|
|
|
|
echo_info
|
2020-12-31 02:49:54 +00:00
|
|
|
fi
|
2020-12-31 02:45:47 +00:00
|
|
|
MESSAGE="No ${CUSTOM_DNS} Detected on $HOSTNAME"
|
|
|
|
echo_info
|
|
|
|
fi
|
|
|
|
fi
|
2021-01-04 20:37:35 +00:00
|
|
|
|
|
|
|
if [ "${SKIP_CUSTOM}" != '1' ]
|
|
|
|
then
|
|
|
|
if [ "${INCLUDE_CNAME}" == "1" ]
|
|
|
|
then
|
|
|
|
if [ -f ${DNSMAQ_DIR}/${CNAME_CONF} ]
|
|
|
|
then
|
|
|
|
if ${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} test -e ${RNSMAQ_DIR}/${CNAME_CONF}
|
|
|
|
then
|
|
|
|
REMOTE_CNAME_DNS="1"
|
|
|
|
MESSAGE="Reanalyzing ${CNAME_CONF} on ${REMOTE_HOST}"
|
|
|
|
echo_stat
|
|
|
|
|
|
|
|
primaryCNMD5=$(${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} "md5sum ${RNSMAQ_DIR}/${CNAME_CONF} | sed 's/\s.*$//'")
|
|
|
|
error_validate
|
|
|
|
|
|
|
|
MESSAGE="Reanalyzing ${CNAME_CONF} on $HOSTNAME"
|
|
|
|
echo_stat
|
|
|
|
secondCNMD5=$(md5sum ${DNSMAQ_DIR}/${CNAME_CONF} | sed 's/\s.*$//')
|
|
|
|
error_validate
|
|
|
|
else
|
|
|
|
MESSAGE="No ${CNAME_CONF} Detected on ${REMOTE_HOST}"
|
|
|
|
echo_info
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
if ${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" ${REMOTE_USER}@${REMOTE_HOST} test -e ${RNSMAQ_DIR}/${CNAME_CONF}
|
|
|
|
then
|
|
|
|
REMOTE_CNAME_DNS="1"
|
|
|
|
MESSAGE="${REMOTE_HOST} has ${CNAME_CONF}"
|
|
|
|
echo_info
|
|
|
|
fi
|
|
|
|
|
|
|
|
MESSAGE="No ${CNAME_CONF} Detected on $HOSTNAME"
|
|
|
|
echo_info
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
2020-10-07 22:45:39 +00:00
|
|
|
}
|