mirror of
https://github.com/deajan/obackup.git
synced 2025-01-12 15:13:53 +01:00
Some msys/cygwin compat fixes
This commit is contained in:
parent
78233a408e
commit
39de9cdfa5
@ -8,7 +8,7 @@ PROGRAM_VERSION=2.0-pre
|
|||||||
PROGRAM_BUILD=2016040603
|
PROGRAM_BUILD=2016040603
|
||||||
IS_STABLE=no
|
IS_STABLE=no
|
||||||
|
|
||||||
## FUNC_BUILD=2016040602
|
## FUNC_BUILD=2016040802
|
||||||
## BEGIN Generic functions for osync & obackup written in 2013-2016 by Orsiris de Jong - http://www.netpower.fr - ozy@netpower.fr
|
## BEGIN Generic functions for osync & obackup written in 2013-2016 by Orsiris de Jong - http://www.netpower.fr - ozy@netpower.fr
|
||||||
|
|
||||||
## type -p does not work on platforms other than linux (bash). If if does not work, always assume output is not a zero exitcode
|
## type -p does not work on platforms other than linux (bash). If if does not work, always assume output is not a zero exitcode
|
||||||
@ -553,17 +553,6 @@ function WaitForTaskCompletion {
|
|||||||
else
|
else
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
#kill -s SIGTERM $pid
|
|
||||||
#if [ $? == 0 ]; then
|
|
||||||
# Logger "Task stopped succesfully" "NOTICE"
|
|
||||||
#else
|
|
||||||
# Logger "Sending SIGTERM to proces failed. Trying the hard way." "ERROR"
|
|
||||||
# sleep 5 && kill -9 $pid
|
|
||||||
# if [ $? != 0 ]; then
|
|
||||||
# Logger "Could not stop task." "ERROR"
|
|
||||||
# fi
|
|
||||||
#fi
|
|
||||||
#return 1
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
sleep $SLEEP_TIME
|
sleep $SLEEP_TIME
|
||||||
@ -612,17 +601,6 @@ function WaitForCompletion {
|
|||||||
else
|
else
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
#kill -s SIGTERM $pid
|
|
||||||
#if [ $? == 0 ]; then
|
|
||||||
# Logger "Task stopped succesfully" "NOTICE"
|
|
||||||
#else
|
|
||||||
# Logger "Sending SIGTERM to proces failed. Trying the hard way." "ERROR"
|
|
||||||
# kill -9 $pid
|
|
||||||
# if [ $? != 0 ]; then
|
|
||||||
# Logger "Could not stop task." "ERROR"
|
|
||||||
# fi
|
|
||||||
#fi
|
|
||||||
#return 1
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
sleep $SLEEP_TIME
|
sleep $SLEEP_TIME
|
||||||
@ -1011,10 +989,10 @@ function InitLocalOSSettings {
|
|||||||
## Ping command is not the same
|
## Ping command is not the same
|
||||||
if [ "$LOCAL_OS" == "msys" ]; then
|
if [ "$LOCAL_OS" == "msys" ]; then
|
||||||
FIND_CMD=$(dirname $BASH)/find
|
FIND_CMD=$(dirname $BASH)/find
|
||||||
#TODO: The following command needs to be checked on msys. Does the $1 variable substitution work ?
|
|
||||||
# PROCESS_TEST_CMD assumes there is a variable $pid
|
# PROCESS_TEST_CMD assumes there is a variable $pid
|
||||||
|
# Tested on MSYS and cygwin
|
||||||
PROCESS_TEST_CMD='ps -a | awk "{\$1=\$1}\$1" | awk "{print \$1}" | grep $pid'
|
PROCESS_TEST_CMD='ps -a | awk "{\$1=\$1}\$1" | awk "{print \$1}" | grep $pid'
|
||||||
PING_CMD="ping -n 2"
|
PING_CMD='$SYSTEMROOT\system32\ping -n 2'
|
||||||
else
|
else
|
||||||
FIND_CMD=find
|
FIND_CMD=find
|
||||||
# PROCESS_TEST_CMD assumes there is a variable $pid
|
# PROCESS_TEST_CMD assumes there is a variable $pid
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
## FUNC_BUILD=2016040602
|
## FUNC_BUILD=2016040802
|
||||||
## BEGIN Generic functions for osync & obackup written in 2013-2016 by Orsiris de Jong - http://www.netpower.fr - ozy@netpower.fr
|
## BEGIN Generic functions for osync & obackup written in 2013-2016 by Orsiris de Jong - http://www.netpower.fr - ozy@netpower.fr
|
||||||
|
|
||||||
## type -p does not work on platforms other than linux (bash). If if does not work, always assume output is not a zero exitcode
|
## type -p does not work on platforms other than linux (bash). If if does not work, always assume output is not a zero exitcode
|
||||||
@ -543,17 +543,6 @@ function WaitForTaskCompletion {
|
|||||||
else
|
else
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
#kill -s SIGTERM $pid
|
|
||||||
#if [ $? == 0 ]; then
|
|
||||||
# Logger "Task stopped succesfully" "NOTICE"
|
|
||||||
#else
|
|
||||||
# Logger "Sending SIGTERM to proces failed. Trying the hard way." "ERROR"
|
|
||||||
# sleep 5 && kill -9 $pid
|
|
||||||
# if [ $? != 0 ]; then
|
|
||||||
# Logger "Could not stop task." "ERROR"
|
|
||||||
# fi
|
|
||||||
#fi
|
|
||||||
#return 1
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
sleep $SLEEP_TIME
|
sleep $SLEEP_TIME
|
||||||
@ -602,17 +591,6 @@ function WaitForCompletion {
|
|||||||
else
|
else
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
#kill -s SIGTERM $pid
|
|
||||||
#if [ $? == 0 ]; then
|
|
||||||
# Logger "Task stopped succesfully" "NOTICE"
|
|
||||||
#else
|
|
||||||
# Logger "Sending SIGTERM to proces failed. Trying the hard way." "ERROR"
|
|
||||||
# kill -9 $pid
|
|
||||||
# if [ $? != 0 ]; then
|
|
||||||
# Logger "Could not stop task." "ERROR"
|
|
||||||
# fi
|
|
||||||
#fi
|
|
||||||
#return 1
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
sleep $SLEEP_TIME
|
sleep $SLEEP_TIME
|
||||||
@ -1001,10 +979,10 @@ function InitLocalOSSettings {
|
|||||||
## Ping command is not the same
|
## Ping command is not the same
|
||||||
if [ "$LOCAL_OS" == "msys" ]; then
|
if [ "$LOCAL_OS" == "msys" ]; then
|
||||||
FIND_CMD=$(dirname $BASH)/find
|
FIND_CMD=$(dirname $BASH)/find
|
||||||
#TODO: The following command needs to be checked on msys. Does the $1 variable substitution work ?
|
|
||||||
# PROCESS_TEST_CMD assumes there is a variable $pid
|
# PROCESS_TEST_CMD assumes there is a variable $pid
|
||||||
|
# Tested on MSYS and cygwin
|
||||||
PROCESS_TEST_CMD='ps -a | awk "{\$1=\$1}\$1" | awk "{print \$1}" | grep $pid'
|
PROCESS_TEST_CMD='ps -a | awk "{\$1=\$1}\$1" | awk "{print \$1}" | grep $pid'
|
||||||
PING_CMD="ping -n 2"
|
PING_CMD='$SYSTEMROOT\system32\ping -n 2'
|
||||||
else
|
else
|
||||||
FIND_CMD=find
|
FIND_CMD=find
|
||||||
# PROCESS_TEST_CMD assumes there is a variable $pid
|
# PROCESS_TEST_CMD assumes there is a variable $pid
|
||||||
|
109
install.sh
109
install.sh
@ -4,15 +4,28 @@ PROGRAM=obackup
|
|||||||
PROGRAM_VERSION=2.0-pre
|
PROGRAM_VERSION=2.0-pre
|
||||||
PROGRAM_BINARY=$PROGRAM".sh"
|
PROGRAM_BINARY=$PROGRAM".sh"
|
||||||
PROGRAM_BATCH=$PROGRAM"-batch.sh"
|
PROGRAM_BATCH=$PROGRAM"-batch.sh"
|
||||||
SCRIPT_BUILD=2016032501
|
SCRIPT_BUILD=2016040801
|
||||||
|
|
||||||
## osync / obackup daemon install script
|
## osync / obackup / pmocr / zsnap install script
|
||||||
## Tested on RHEL / CentOS 6 & 7, Fedora 23, Debian 7 & 8, Mint 17 and FreeBSD 8 & 10
|
## Tested on RHEL / CentOS 6 & 7, Fedora 23, Debian 7 & 8, Mint 17 and FreeBSD 8 & 10
|
||||||
## Please adapt this to fit your distro needs
|
## Please adapt this to fit your distro needs
|
||||||
|
|
||||||
CONF_DIR=/etc/$PROGRAM
|
CONF_DIR=/etc/$PROGRAM
|
||||||
BIN_DIR=/usr/local/bin
|
BIN_DIR=/usr/local/bin
|
||||||
SERVICE_DIR=/etc/init.d
|
SERVICE_DIR_INIT=/etc/init.d
|
||||||
|
SERVICE_DIR_SYSTEMD_SYSTEM=/usr/lib/systemd/system
|
||||||
|
SERVICE_DIR_SYSTEMD_USER=/etc/systemd/user
|
||||||
|
|
||||||
|
## osync specific code
|
||||||
|
OSYNC_SERVICE_FILE_INIT="osync-srv"
|
||||||
|
OSYNC_SERVICE_FILE_SYSTEMD_SYSTEM="osync-srv@.service"
|
||||||
|
OSYNC_SERVICE_FILE_SYSTEMD_USER="osync-srv@.service.user"
|
||||||
|
|
||||||
|
## pmocr specfic code
|
||||||
|
PMOCR_SERVICE_FILE_INIT="pmocr-srv"
|
||||||
|
PMOCR_SERVICE_FILE_SYSTEMD_SYSTEM="pmocr-srv.service"
|
||||||
|
|
||||||
|
## Generic code
|
||||||
|
|
||||||
USER=root
|
USER=root
|
||||||
|
|
||||||
@ -31,13 +44,28 @@ case $local_os_var in
|
|||||||
*)
|
*)
|
||||||
GROUP=root
|
GROUP=root
|
||||||
;;
|
;;
|
||||||
|
*"MINGW32"*|*"CYGWIN"*)
|
||||||
|
USER=""
|
||||||
|
GROUP=""
|
||||||
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
if [ "$(whoami)" != "$USER" ]; then
|
if ([ "$USER" != "" ] && [ "$(whoami)" != "$USER" ]); then
|
||||||
echo "Must be run as $USER."
|
echo "Must be run as $USER."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ -f /sbin/init ]; then
|
||||||
|
if file /sbin/init | grep systemd > /dev/null; then
|
||||||
|
init=systemd
|
||||||
|
else
|
||||||
|
init=init
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Can't detect init system."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
if [ ! -d "$CONF_DIR" ]; then
|
if [ ! -d "$CONF_DIR" ]; then
|
||||||
mkdir "$CONF_DIR"
|
mkdir "$CONF_DIR"
|
||||||
if [ $? == 0 ]; then
|
if [ $? == 0 ]; then
|
||||||
@ -90,31 +118,77 @@ if [ -f "./ssh_filter.sh" ]; then
|
|||||||
echo "Cannot copy ssh_filter.sh to [$BIN_DIR]."
|
echo "Cannot copy ssh_filter.sh to [$BIN_DIR]."
|
||||||
else
|
else
|
||||||
chmod 755 "$BIN_DIR/ssh_filter.sh"
|
chmod 755 "$BIN_DIR/ssh_filter.sh"
|
||||||
chown $USER:$GROUP "$BIN_DIR/ssh_filter.sh"
|
if ([ "$USER" != "" ] && [ "$GROUP" != "" ]); then
|
||||||
|
chown $USER:$GROUP "$BIN_DIR/ssh_filter.sh"
|
||||||
|
fi
|
||||||
echo "Copied ssh_filter.sh to [$BIN_DIR]."
|
echo "Copied ssh_filter.sh to [$BIN_DIR]."
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -f "./osync-srv" ]; then
|
# OSYNC SPECIFIC
|
||||||
cp "./osync-srv" "$SERVICE_DIR"
|
if ([ "$init" == "systemd" ] && [ -f "./$OSYNC_SERVICE_FILE_SYSTEMD_SYSTEM" ]); then
|
||||||
|
cp "./$OSYNC_SERVICE_FILE_SYSTEMD_SYSTEM" "$SERVICE_DIR_SYSTEMD_SYSTEM" && cp "./$OSYNC_SERVICE_FILE_SYSTEMD_USER" "$SERVICE_DIR_SYSTEMD_USER/$SERVICE_FILE_SYSTEMD_SYSTEM"
|
||||||
if [ $? != 0 ]; then
|
if [ $? != 0 ]; then
|
||||||
echo "Cannot copy osync-srv to [$SERVICE_DIR]."
|
echo "Cannot copy the systemd file to [$SERVICE_DIR_SYSTEMD_SYSTEM] or [$SERVICE_DIR_SYSTEMD_USER]."
|
||||||
else
|
else
|
||||||
chmod 755 "$SERVICE_DIR/osync-srv"
|
echo "Created osync-srv service in [$SERVICE_DIR_SYSTEMD_SYSTEM] and [$SERVICE_DIR_SYSTEMD_USER]."
|
||||||
echo "Created osync-srv service in [$SERVICE_DIR]."
|
echo "Can be activated with [systemctl start osync-srv@instance.conf] where instance.conf is the name of the config file in /etc/osync."
|
||||||
|
echo "Can be enabled on boot with [systemctl enable osync-srv@instance.conf]."
|
||||||
|
echo "In userland, active with [systemctl --user start osync-srv@instance.conf]."
|
||||||
|
fi
|
||||||
|
elif [ -f "./$OSYNC_SERVICE_FILE_INIT" ]; then
|
||||||
|
cp "./$OSYNC_SERVICE_FILE_INIT" "$SERVICE_DIR_INIT"
|
||||||
|
if [ $? != 0 ]; then
|
||||||
|
echo "Cannot copy osync-srv to [$SERVICE_DIR_INIT]."
|
||||||
|
else
|
||||||
|
chmod 755 "$SERVICE_DIR_INIT/$OSYNC_SERVICE_FILE_INIT"
|
||||||
|
echo "Created osync-srv service in [$SERVICE_DIR_INIT]."
|
||||||
|
echo "Can be activated with [service $OSYNC_SERVICE_FILE_INIT start]."
|
||||||
|
echo "Can be enabled on boot with [chkconfig $OSYNC_SERVICE_FILE_INIT on]."
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# PMOCR SPECIFIC
|
||||||
|
if ([ "$init" == "systemd" ] && [ -f "./$PMOCR_SERVICE_FILE_SYSTEMD_SYSTEM" ]); then
|
||||||
|
cp "./$PMOCR_SERVICE_FILE_SYSTEMD_SYSTEM" "$SERVICE_DIR_SYSTEMD_SYSTEM"
|
||||||
|
if [ $? != 0 ]; then
|
||||||
|
echo "Cannot copy the systemd file to [$SERVICE_DIR_SYSTEMD_SYSTEM] or [$SERVICE_DIR_SYSTEMD_USER]."
|
||||||
|
else
|
||||||
|
echo "Created pmocr-srv service in [$SERVICE_DIR_SYSTEMD_SYSTEM] and [$SERVICE_DIR_SYSTEMD_USER]."
|
||||||
|
echo "Can be activated with [systemctl start pmocr-srv] after configuring file options in [$BIN_DIR/$PROGRAM]."
|
||||||
|
echo "Can be enabled on boot with [systemctl enable pmocr-srv]."
|
||||||
|
fi
|
||||||
|
elif [ -f "./$PMOCR_SERVICE_FILE_INIT" ]; then
|
||||||
|
cp "./$PMOCR_SERVICE_FILE_INIT" "$SERVICE_DIR_INIT"
|
||||||
|
if [ $? != 0 ]; then
|
||||||
|
echo "Cannot copy pmoct-srv to [$SERVICE_DIR_INIT]."
|
||||||
|
else
|
||||||
|
chmod 755 "$SERVICE_DIR_INIT/$PMOCR_SERVICE_FILE_INIT"
|
||||||
|
echo "Created osync-srv service in [$SERVICE_DIR_INIT]."
|
||||||
|
echo "Can be activated with [service $PMOCR_SERVICE_FILE_INIT start]."
|
||||||
|
echo "Can be enabled on boot with [chkconfig $PMOCR_SERVICE_FILE_INIT on]."
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
function Statistics {
|
function Statistics {
|
||||||
|
|
||||||
local link="http://instcount.netpower.fr?program=$PROGRAM&version=$PROGRAM_VERSION"
|
local link="http://instcount.netpower.fr?program=$PROGRAM&version=$PROGRAM_VERSION"
|
||||||
if type wget > /dev/null; then
|
if type wget > /dev/null; then
|
||||||
wget $link > /dev/null 2>&1
|
wget -qO- $link > /dev/null 2>&1
|
||||||
elif type curl > /dev/null; then
|
if [ $? == 0 ]; then
|
||||||
curl $link > /dev/null 2>&1
|
return 0
|
||||||
else
|
fi
|
||||||
echo "Neiter wget nor curl installed. Cannot run statistics. Use link below please."
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if type curl > /dev/null; then
|
||||||
|
curl $link > /dev/null 2>&1
|
||||||
|
if [ $? == 0 ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Neiter wget nor curl could be used for. Cannot run statistics. Use the provided link please."
|
||||||
|
retun 1
|
||||||
}
|
}
|
||||||
|
|
||||||
echo "$PROGRAM installed. Use with $BIN_DIR/$PROGRAM"
|
echo "$PROGRAM installed. Use with $BIN_DIR/$PROGRAM"
|
||||||
@ -127,5 +201,6 @@ case $response in
|
|||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
Statistics
|
Statistics
|
||||||
|
exit $?
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
28
obackup.sh
28
obackup.sh
@ -8,7 +8,7 @@ PROGRAM_VERSION=2.0-pre
|
|||||||
PROGRAM_BUILD=2016040603
|
PROGRAM_BUILD=2016040603
|
||||||
IS_STABLE=no
|
IS_STABLE=no
|
||||||
|
|
||||||
## FUNC_BUILD=2016040602
|
## FUNC_BUILD=2016040802
|
||||||
## BEGIN Generic functions for osync & obackup written in 2013-2016 by Orsiris de Jong - http://www.netpower.fr - ozy@netpower.fr
|
## BEGIN Generic functions for osync & obackup written in 2013-2016 by Orsiris de Jong - http://www.netpower.fr - ozy@netpower.fr
|
||||||
|
|
||||||
## type -p does not work on platforms other than linux (bash). If if does not work, always assume output is not a zero exitcode
|
## type -p does not work on platforms other than linux (bash). If if does not work, always assume output is not a zero exitcode
|
||||||
@ -536,17 +536,6 @@ function WaitForTaskCompletion {
|
|||||||
else
|
else
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
#kill -s SIGTERM $pid
|
|
||||||
#if [ $? == 0 ]; then
|
|
||||||
# Logger "Task stopped succesfully" "NOTICE"
|
|
||||||
#else
|
|
||||||
# Logger "Sending SIGTERM to proces failed. Trying the hard way." "ERROR"
|
|
||||||
# sleep 5 && kill -9 $pid
|
|
||||||
# if [ $? != 0 ]; then
|
|
||||||
# Logger "Could not stop task." "ERROR"
|
|
||||||
# fi
|
|
||||||
#fi
|
|
||||||
#return 1
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
sleep $SLEEP_TIME
|
sleep $SLEEP_TIME
|
||||||
@ -592,17 +581,6 @@ function WaitForCompletion {
|
|||||||
else
|
else
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
#kill -s SIGTERM $pid
|
|
||||||
#if [ $? == 0 ]; then
|
|
||||||
# Logger "Task stopped succesfully" "NOTICE"
|
|
||||||
#else
|
|
||||||
# Logger "Sending SIGTERM to proces failed. Trying the hard way." "ERROR"
|
|
||||||
# kill -9 $pid
|
|
||||||
# if [ $? != 0 ]; then
|
|
||||||
# Logger "Could not stop task." "ERROR"
|
|
||||||
# fi
|
|
||||||
#fi
|
|
||||||
#return 1
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
sleep $SLEEP_TIME
|
sleep $SLEEP_TIME
|
||||||
@ -940,10 +918,10 @@ function InitLocalOSSettings {
|
|||||||
## Ping command is not the same
|
## Ping command is not the same
|
||||||
if [ "$LOCAL_OS" == "msys" ]; then
|
if [ "$LOCAL_OS" == "msys" ]; then
|
||||||
FIND_CMD=$(dirname $BASH)/find
|
FIND_CMD=$(dirname $BASH)/find
|
||||||
#TODO: The following command needs to be checked on msys. Does the $1 variable substitution work ?
|
|
||||||
# PROCESS_TEST_CMD assumes there is a variable $pid
|
# PROCESS_TEST_CMD assumes there is a variable $pid
|
||||||
|
# Tested on MSYS and cygwin
|
||||||
PROCESS_TEST_CMD='ps -a | awk "{\$1=\$1}\$1" | awk "{print \$1}" | grep $pid'
|
PROCESS_TEST_CMD='ps -a | awk "{\$1=\$1}\$1" | awk "{print \$1}" | grep $pid'
|
||||||
PING_CMD="ping -n 2"
|
PING_CMD='$SYSTEMROOT\system32\ping -n 2'
|
||||||
else
|
else
|
||||||
FIND_CMD=find
|
FIND_CMD=find
|
||||||
# PROCESS_TEST_CMD assumes there is a variable $pid
|
# PROCESS_TEST_CMD assumes there is a variable $pid
|
||||||
|
Loading…
Reference in New Issue
Block a user