mirror of
https://github.com/vmstan/gravity-sync.git
synced 2024-08-30 18:22:11 +00:00
f32a0e2ab4
* 3.3.1 * Delete changelog files * No SVG * Ignore year. * A great many things. * Add CONTAIMAGE variable. * “ Co-authored-by: Michael Stanclift <vmstan@mstanclift-a03.local>
222 lines
5.6 KiB
Bash
222 lines
5.6 KiB
Bash
# GRAVITY SYNC BY VMSTAN #####################
|
|
# gs-validate.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 GS Folders
|
|
function validate_gs_folders {
|
|
MESSAGE="Validating ${PROGRAM} Folders on $HOSTNAME"
|
|
echo_stat
|
|
if [ ! -d ${LOCAL_FOLDR} ]
|
|
then
|
|
MESSAGE="Unable to Validate ${PROGRAM} Folders on $HOSTNAME"
|
|
echo_fail
|
|
exit_nochange
|
|
fi
|
|
|
|
if [ ! -d ${LOCAL_FOLDR}/${BACKUP_FOLD} ]
|
|
then
|
|
MESSAGE="Unable to Validate ${PROGRAM} Backup Folder on $HOSTNAME"
|
|
echo_fail
|
|
exit_nochange
|
|
fi
|
|
echo_good
|
|
}
|
|
|
|
## Validate Pi-hole Folders
|
|
function validate_ph_folders {
|
|
MESSAGE="Validating Pi-hole Configuration"
|
|
echo_stat
|
|
|
|
if [ "$PH_IN_TYPE" == "default" ]
|
|
then
|
|
if [ ! -f ${PIHOLE_BIN} ]
|
|
then
|
|
MESSAGE="Unable to Validate that Pi-Hole is Installed"
|
|
echo_fail
|
|
exit_nochange
|
|
fi
|
|
elif [ "$PH_IN_TYPE" == "docker" ]
|
|
then
|
|
FTLCHECK=$(sudo docker container ls | grep "${CONTAIMAGE}")
|
|
if [ "$FTLCHECK" == "" ]
|
|
then
|
|
MESSAGE="Unable to Validate that Pi-Hole is Installed"
|
|
echo_fail
|
|
exit_nochange
|
|
fi
|
|
elif [ "$PH_IN_TYPE" == "podman" ]
|
|
then
|
|
FTLCHECK=$(sudo podman container ls | grep "${CONTAIMAGE}")
|
|
if [ "$FTLCHECK" == "" ]
|
|
then
|
|
MESSAGE="Unable to Validate that Pi-Hole is Installed"
|
|
echo_fail
|
|
exit_nochange
|
|
fi
|
|
fi
|
|
|
|
if [ ! -d ${PIHOLE_DIR} ]
|
|
then
|
|
MESSAGE="Unable to Validate Pi-Hole Configuration Directory"
|
|
echo_fail
|
|
exit_nochange
|
|
fi
|
|
echo_good
|
|
}
|
|
|
|
## Validate DNSMASQ Folders
|
|
function validate_dns_folders {
|
|
MESSAGE="Validating DNSMASQ Configuration"
|
|
echo_stat
|
|
|
|
if [ ! -d ${DNSMAQ_DIR} ]
|
|
then
|
|
MESSAGE="Unable to Validate DNSMASQ Configuration Directory"
|
|
echo_fail
|
|
exit_nochange
|
|
fi
|
|
echo_good
|
|
}
|
|
|
|
## Validate SQLite3
|
|
function validate_sqlite3 {
|
|
MESSAGE="Validating SQLITE Installed on $HOSTNAME"
|
|
echo_stat
|
|
if hash sqlite3 2>/dev/null
|
|
then
|
|
# MESSAGE="SQLITE3 Utility Detected"
|
|
echo_good
|
|
else
|
|
MESSAGE="Unable to Validate SQLITE Install on $HOSTNAME"
|
|
echo_warn
|
|
|
|
MESSAGE="Installing SQLLITE3 with ${PKG_MANAGER}"
|
|
echo_stat
|
|
|
|
${PKG_INSTALL} sqllite3 >/dev/null 2>&1
|
|
error_validate
|
|
fi
|
|
}
|
|
|
|
## Validate SSHPASS
|
|
function validate_os_sshpass {
|
|
# SSHPASSWORD=''
|
|
|
|
# if hash sshpass 2>/dev/null
|
|
# then
|
|
# MESSAGE="SSHPASS Utility Detected"
|
|
# echo_warn
|
|
# if [ -z "$REMOTE_PASS" ]
|
|
# then
|
|
# MESSAGE="Using SSH Key-Pair Authentication"
|
|
# echo_info
|
|
# else
|
|
# MESSAGE="Testing Authentication Options"
|
|
# echo_stat
|
|
|
|
# timeout 5 ssh -p ${SSH_PORT} -i "$HOME/${SSH_PKIF}" -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} 'exit' >/dev/null 2>&1
|
|
# if [ "$?" != "0" ]
|
|
# then
|
|
# SSHPASSWORD="sshpass -p ${REMOTE_PASS}"
|
|
# MESSAGE="Using SSH Password Authentication"
|
|
# echo_warn
|
|
# else
|
|
# MESSAGE="Valid Key-Pair Detected ${NC}(${RED}Password Ignored${NC})"
|
|
# echo_info
|
|
# fi
|
|
# fi
|
|
# else
|
|
# SSHPASSWORD=''
|
|
# MESSAGE="Using SSH Key-Pair Authentication"
|
|
# echo_info
|
|
# fi
|
|
|
|
MESSAGE="Validating Connection to ${REMOTE_HOST}"
|
|
echo_stat
|
|
|
|
CMD_TIMEOUT='5'
|
|
CMD_REQUESTED="exit"
|
|
create_sshcmd
|
|
|
|
}
|
|
|
|
## Detect Package Manager
|
|
function distro_check {
|
|
if hash apt-get 2>/dev/null
|
|
then
|
|
PKG_MANAGER="apt-get"
|
|
PKG_INSTALL="sudo apt-get --yes --no-install-recommends --quiet install"
|
|
elif hash rpm 2>/dev/null
|
|
then
|
|
if hash dnf 2>/dev/null
|
|
then
|
|
PKG_MANAGER="dnf"
|
|
elif hash yum 2>/dev/null
|
|
then
|
|
PKG_MANAGER="yum"
|
|
else
|
|
MESSAGE="Unable to find OS Package Manager"
|
|
echo_info
|
|
exit_nochange
|
|
fi
|
|
PKG_INSTALL="sudo ${PKG_MANAGER} install -y"
|
|
else
|
|
MESSAGE="Unable to find OS Package Manager"
|
|
echo_info
|
|
exit_nochange
|
|
fi
|
|
}
|
|
|
|
## Dropbear Warning
|
|
function dbclient_warning {
|
|
if hash dbclient 2>/dev/null
|
|
then
|
|
if hash ssh 2>/dev/null
|
|
then
|
|
NOEMPTYBASHIF="1"
|
|
else
|
|
MESSAGE="Dropbear support has been deprecated - please convert to OpenSSH"
|
|
echo_warn
|
|
fi
|
|
fi
|
|
}
|
|
|
|
## Validate CNAME Permissions
|
|
function validate_cname_permissions {
|
|
CNAMELS_OWN=$(ls -ld ${DNSMAQ_DIR}/${CNAME_CONF} | awk '{print $3 $4}')
|
|
if [ "$CNAMELS_OWN" == "rootroot" ]
|
|
then
|
|
echo_good
|
|
else
|
|
echo_fail
|
|
|
|
MESSAGE="Attempting to Compensate"
|
|
echo_warn
|
|
|
|
MESSAGE="Setting Ownership on ${CNAME_CONF}"
|
|
echo_stat
|
|
sudo chown root:root ${DNSMAQ_DIR}/${CNAME_CONF} >/dev/null 2>&1
|
|
error_validate
|
|
fi
|
|
|
|
MESSAGE="Validating Permissions on ${CNAME_CONF}"
|
|
echo_stat
|
|
|
|
CNAMELS_RWE=$(namei -m ${DNSMAQ_DIR}/${CNAME_CONF} | grep -v f: | grep ${CNAME_CONF} | awk '{print $1}')
|
|
if [ "$CNAMELS_RWE" == "-rw-r--r--" ]
|
|
then
|
|
echo_good
|
|
else
|
|
echo_fail
|
|
|
|
MESSAGE="Attempting to Compensate"
|
|
echo_warn
|
|
|
|
MESSAGE="Setting Ownership on ${CNAME_CONF}"
|
|
echo_stat
|
|
sudo chmod 644 ${DNSMAQ_DIR}/${CNAME_CONF} >/dev/null 2>&1
|
|
error_validate
|
|
fi
|
|
} |