mirror of
https://github.com/vmstan/gravity-sync.git
synced 2025-05-24 00:02:22 -04:00
* new first line of script * no requested * Abort! * Test silent folder validation * sameline * echo newline * echo_sameline * what happened? * sameline for ssh * sqlite sameline * Lower case * Reset line * clear line * Flip the line * version update * Backup lowercase * More lowercase * Remove file names from standard messages * Breakout backup message * Output backup folder size * Just H * Invalid replication settings * Compare updated * Colors and updates * Lower case for version output * For Pihole * Cron cleanup * Sudo, or no sudo. * Branch! * Silent error validate * Silent error validate * Clearing up status messages * Records * Primary and secondary * Gravity database * Domain Database * Backup output cleanup * Move file permission validation into new functions * Change restart * UI variables test * Breakout UI variables into new file * Unified validation functions * Replace text strings with variables * Replace text strings with variables * Replace logging with variables * Convert backup to UI variables * Switch restore to UI variables * Fix bug where gravity database did not restore * App validation checks * Rev to 3.4.0 * Convert Push functions to new strings * Completing push UI changes * remove added line * Move purge to UI strings * Move automation to UI strings * Move core strings into UI * Exit strings * First pass at hashing UI * Escape the remote system query (#179) * hashing committed Co-authored-by: Michael Stanclift <vmstan@mstanclift-a03.local> Co-authored-by: Veduco <59983694+Veduco@users.noreply.github.com>
188 lines
4.7 KiB
Bash
188 lines
4.7 KiB
Bash
# GRAVITY SYNC BY VMSTAN #####################
|
|
# gs-ssh.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!
|
|
|
|
## Determine SSH Pathways
|
|
function create_sshcmd {
|
|
# if hash ssh 2>/dev/null
|
|
# then
|
|
# if [ -z "$SSHPASSWORD" ]
|
|
# then
|
|
timeout --preserve-status ${CMD_TIMEOUT} ${SSH_CMD} -p ${SSH_PORT} -i $HOME/${SSH_PKIF} -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} "${CMD_REQUESTED}"
|
|
error_validate
|
|
# else
|
|
# timeout --preserve-status ${CMD_TIMEOUT} ${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} "${CMD_REQUESTED}"
|
|
# error_validate
|
|
# fi
|
|
# fi
|
|
}
|
|
|
|
## Determine SSH Pathways
|
|
function create_rsynccmd {
|
|
# if hash ssh 2>/dev/null
|
|
# then
|
|
# if [ -z "$SSHPASSWORD" ]
|
|
# then
|
|
rsync --rsync-path="${RSYNC_REPATH}" -e "${SSH_CMD} -p ${SSH_PORT} -i $HOME/${SSH_PKIF}" ${RSYNC_SOURCE} ${RSYNC_TARGET} >/dev/null 2>&1
|
|
error_validate
|
|
# else
|
|
# rsync --rsync-path="${RSYNC_REPATH}" -e "${SSHPASSWORD} ${SSH_CMD} -p ${SSH_PORT} -i $HOME/${SSH_PKIF}" ${RSYNC_SOURCE} ${RSYNC_TARGET} >/dev/null 2>&1
|
|
# error_validate
|
|
# fi
|
|
# fi
|
|
}
|
|
|
|
## Detect SSH-KEYGEN
|
|
function detect_sshkeygen {
|
|
MESSAGE="Validating SSH-KEYGEN install"
|
|
echo_stat
|
|
|
|
if hash ssh-keygen >/dev/null 2>&1
|
|
then
|
|
echo_sameline
|
|
else
|
|
echo_fail
|
|
MESSAGE="SSH-KEYGEN is required on $HOSTNAME"
|
|
echo_info
|
|
|
|
exit_nochange
|
|
fi
|
|
}
|
|
|
|
function generate_sshkey {
|
|
if [ -z $INPUT_REMOTE_PASS ]
|
|
then
|
|
if [ -f $HOME/${SSH_PKIF} ]
|
|
then
|
|
MESSAGE="Using existing ~/${SSH_PKIF} file"
|
|
echo_info
|
|
else
|
|
if hash ssh-keygen >/dev/null 2>&1
|
|
then
|
|
MESSAGE="Generating ~/${SSH_PKIF} file"
|
|
echo_stat
|
|
|
|
ssh-keygen -q -P "" -t rsa -f $HOME/${SSH_PKIF} >/dev/null 2>&1
|
|
error_validate
|
|
else
|
|
MESSAGE="No SSH-KEYGEN available"
|
|
echo_warn
|
|
exit_nochange
|
|
fi
|
|
fi
|
|
fi
|
|
}
|
|
|
|
function export_sshkey {
|
|
if [ -z $REMOTE_PASS ]
|
|
then
|
|
if [ -f $HOME/${SSH_PKIF} ]
|
|
then
|
|
MESSAGE="Registering key-pair to ${REMOTE_HOST}"
|
|
echo_info
|
|
|
|
ssh-copy-id -f -p ${SSH_PORT} -i $HOME/${SSH_PKIF}.pub ${REMOTE_USER}@${REMOTE_HOST}
|
|
else
|
|
MESSAGE="Error registering key-pair to ${REMOTE_HOST}"
|
|
echo_warn
|
|
fi
|
|
fi
|
|
}
|
|
|
|
## Detect SSH & RSYNC
|
|
function detect_ssh {
|
|
MESSAGE="Validating OpenSSH client"
|
|
echo_stat
|
|
|
|
if hash ssh 2>/dev/null
|
|
then
|
|
MESSAGE="${MESSAGE} (OpenSSH)"
|
|
echo_sameline
|
|
SSH_CMD='ssh'
|
|
elif hash dbclient 2>/dev/null
|
|
then
|
|
MESSAGE="${MESSAGE} (Dropbear)"
|
|
echo_fail
|
|
|
|
MESSAGE="Dropbear is not supported in ${PROGRAM} ${VERSION}"
|
|
echo_warn
|
|
exit_nochange
|
|
else
|
|
echo_fail
|
|
exit_nochange
|
|
|
|
# MESSAGE="Attempting to Compensate"
|
|
# echo_warn
|
|
# MESSAGE="Installing SSH Client with ${PKG_MANAGER}"
|
|
# echo_stat
|
|
|
|
# ${PKG_INSTALL} ssh-client >/dev/null 2>&1
|
|
# error_validate
|
|
fi
|
|
|
|
MESSAGE="Validating RSYNC client"
|
|
echo_stat
|
|
|
|
if hash rsync 2>/dev/null
|
|
then
|
|
echo_sameline
|
|
else
|
|
echo_fail
|
|
|
|
MESSAGE="RSYNC client install is required"
|
|
echo_warn
|
|
exit_nochange
|
|
|
|
# distro_check
|
|
|
|
# MESSAGE="Attempting to Compensate"
|
|
# echo_warn
|
|
|
|
# MESSAGE="Installing RSYNC with ${PKG_MANAGER}"
|
|
# echo_stat
|
|
# ${PKG_INSTALL} rsync >/dev/null 2>&1
|
|
# error_validate
|
|
fi
|
|
}
|
|
|
|
function detect_remotersync {
|
|
MESSAGE="Creating test file on ${REMOTE_HOST}"
|
|
echo_stat
|
|
|
|
CMD_TIMEOUT='15'
|
|
CMD_REQUESTED="touch ~/gs.test"
|
|
create_sshcmd
|
|
|
|
MESSAGE="If pull test fails ensure RSYNC is installed on ${REMOTE_HOST}"
|
|
echo_warn
|
|
|
|
MESSAGE="Pulling test file to $HOSTNAME"
|
|
echo_stat
|
|
|
|
RSYNC_REPATH="rsync"
|
|
RSYNC_SOURCE="${REMOTE_USER}@${REMOTE_HOST}:~/gs.test"
|
|
RSYNC_TARGET="${LOCAL_FOLDR}/gs.test"
|
|
create_rsynccmd
|
|
|
|
MESSAGE="Cleaning up local test file"
|
|
echo_stat
|
|
|
|
rm ${LOCAL_FOLDR}/gs.test
|
|
error_validate
|
|
|
|
MESSAGE="Cleaning up remote test file"
|
|
echo_stat
|
|
|
|
CMD_TIMEOUT='15'
|
|
CMD_REQUESTED="rm ~/gs.test"
|
|
create_sshcmd
|
|
}
|
|
|
|
function show_target {
|
|
MESSAGE="Remote Pi-hole: ${REMOTE_USER}@${REMOTE_HOST}"
|
|
echo_info
|
|
|
|
detect_ssh
|
|
} |