2021-11-27 23:14:38 +00:00
|
|
|
#!/bin/bash
|
|
|
|
# license: gpl-3
|
|
|
|
|
|
|
|
show_help="conn: a quick and dirty server availability check
|
|
|
|
|
|
|
|
usage:
|
|
|
|
"$0" <args> [IP(s)/hostname(s)]
|
|
|
|
|
|
|
|
arguments:
|
|
|
|
-h / --help show help page (this)
|
|
|
|
-6 / --force-ipv6 force ipv6 portscanning (also forces portscanning)
|
|
|
|
-4 / --force-ipv4 force ipv4 portscanning (also forces portscanning)
|
|
|
|
-y / --yes portscan without asking
|
|
|
|
-n / --no dont portscan
|
|
|
|
-w / --wait wait for active connection
|
|
|
|
-u / --update update the script
|
|
|
|
-f / --fast disable os check
|
2021-11-28 00:26:31 +00:00
|
|
|
-s / --simple simplify output"
|
2021-11-27 23:14:38 +00:00
|
|
|
|
|
|
|
show_notfound="[error] argument not found
|
|
|
|
|
|
|
|
available arguments:
|
|
|
|
-h / --help show help page (this)
|
|
|
|
-6 / --force-ipv6 force ipv6 portscanning (also forces portscanning)
|
|
|
|
-4 / --force-ipv4 force ipv4 portscanning (also forces portscanning)
|
|
|
|
-y / --yes portscan without asking
|
|
|
|
-n / --no dont portscan
|
|
|
|
-w / --wait wait for active connection
|
|
|
|
-u / --update update the script
|
|
|
|
-f / --fast disable os check
|
|
|
|
-s / --simple simplify output"
|
|
|
|
|
2021-11-28 00:26:31 +00:00
|
|
|
function check_update {
|
|
|
|
if [[ $(curl -s https://raw.githubusercontent.com/byReqz/conn/main/hash) != $(md5sum $0 | cut -c -32) ]] && [[ -z $1 ]] || [[ $(curl -s https://raw.githubusercontent.com/byReqz/conn/main/hash) != $(md5sum $0 | cut -c -32) ]] && [[ $1 != "--update" ]] || [[ $(curl -s https://raw.githubusercontent.com/byReqz/conn/main/hash) != $(md5sum $0 | cut -c -32) ]] && [[ $1 != "-u" ]];then
|
|
|
|
echo "#############################################"
|
|
|
|
echo -e "\e[4mnote: newer version detected, use -u to update\e[0m"
|
|
|
|
echo "#############################################"
|
|
|
|
echo ""
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function run_update {
|
|
|
|
if [[ $(curl -s https://raw.githubusercontent.com/byReqz/conn/main/hash) != $(md5sum $0 | cut -c -32) ]];then
|
|
|
|
wget -O $0 --quiet "https://raw.githubusercontent.com/byReqz/conn/main/conn.sh"
|
|
|
|
echo "#############################################"
|
|
|
|
echo -e "\e[4mscript has been updated to the newest version\e[0m"
|
|
|
|
echo "#############################################"
|
|
|
|
exit
|
|
|
|
elif [[ $(curl -s https://raw.githubusercontent.com/byReqz/conn/main/hash) = $(md5sum $0 | cut -c -32) ]];then
|
|
|
|
echo "#############################################"
|
|
|
|
echo "no newer version found"
|
|
|
|
echo "#############################################"
|
|
|
|
exit
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2021-11-27 23:14:38 +00:00
|
|
|
function prepare {
|
2021-11-28 00:26:31 +00:00
|
|
|
#check_update
|
2021-11-28 16:03:11 +00:00
|
|
|
get_args "$@"
|
2021-11-28 00:26:31 +00:00
|
|
|
set_argvars $args
|
2021-11-28 14:40:45 +00:00
|
|
|
validate $input
|
2021-11-28 00:26:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function get_args {
|
2021-11-28 16:03:11 +00:00
|
|
|
input=$(echo " $@")
|
2021-11-28 00:26:31 +00:00
|
|
|
args=$(echo "$input" | grep -o -e "-h" -e "--help" -e "-6" -e "--force-ipv6" -e "-4" -e "--force-ipv4" -e "-y" -e "--yes" -e "-n" -e "--no" -e "-w" -e "--wait" -e "-u" -e "--update" -e "-f" -e "--fast" -e "-s" -e "--simple" | xargs)
|
|
|
|
for arg in $args; do
|
|
|
|
input=$(echo "$input" | sed "s/$arg//g")
|
|
|
|
done
|
|
|
|
|
|
|
|
# needs work
|
|
|
|
# argcheck=$(echo $input | grep -o -e " -* " | xargs)
|
|
|
|
# echo $argcheck
|
|
|
|
# if [[ -n "$argcheck" ]];then
|
|
|
|
# for arg in $argcheck; do
|
|
|
|
# echo "the given argument \""$arg"\" is not known"
|
|
|
|
# done
|
|
|
|
# fi
|
2021-11-28 18:19:39 +00:00
|
|
|
|
|
|
|
#quick fix to prevent nslookups interactive mode being triggered by wrong arguments
|
|
|
|
#some other places in the code have also gotten a leading space to prevent similar issues
|
|
|
|
input=$(echo "$input" | tr -d "-")
|
2021-11-28 00:26:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function set_argvars {
|
|
|
|
if [[ $@ =~ -6 ]] || [[ $@ =~ --force-ipv6 ]];then
|
2021-11-28 15:39:32 +00:00
|
|
|
only="-6"
|
2021-11-28 00:26:31 +00:00
|
|
|
fi
|
2021-11-28 14:40:45 +00:00
|
|
|
if [[ $@ =~ -4 ]] || [[ $@ =~ --force-ipv4 ]];then
|
2021-11-28 15:39:32 +00:00
|
|
|
only="-4"
|
2021-11-28 14:40:45 +00:00
|
|
|
fi
|
|
|
|
if [[ $@ =~ -y ]] || [[ $@ =~ --yes ]];then
|
|
|
|
doportscan=true
|
|
|
|
fi
|
|
|
|
if [[ $@ =~ -n ]] || [[ $@ =~ --no ]];then
|
|
|
|
doportscan=false
|
|
|
|
fi
|
|
|
|
if [[ $@ =~ -s ]] || [[ $@ =~ --simple ]];then
|
|
|
|
simpleoutput=true
|
|
|
|
fi
|
|
|
|
if [[ $@ =~ -w ]] || [[ $@ =~ --wait ]];then
|
|
|
|
waitcheck=true
|
|
|
|
fi
|
|
|
|
if [[ $@ =~ -f ]] || [[ $@ =~ --fast ]];then
|
|
|
|
oscheck=false
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function validate {
|
|
|
|
for arg in $@; do
|
2021-11-28 18:19:39 +00:00
|
|
|
if $(ip route show " $arg" 2&> /dev/null);then
|
2021-11-28 14:40:45 +00:00
|
|
|
hosts="$hosts $arg"
|
|
|
|
elif $(nslookup "$arg" > /dev/null);then
|
|
|
|
hosts="$hosts $arg"
|
|
|
|
else
|
|
|
|
echo "invalid input: $arg"
|
|
|
|
fi
|
|
|
|
done
|
2021-11-27 23:14:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function main {
|
2021-11-28 15:39:32 +00:00
|
|
|
if [[ $simpleoutput == true ]] && [[ -n $hosts ]];then
|
|
|
|
echo "-------------------Availability----------------------"
|
|
|
|
fping $only -e $@
|
|
|
|
quickport=$(nping $only -c1 -p22,222,3389,135 $@ | grep -e "completed")
|
|
|
|
if [[ -n $quickport ]];then
|
|
|
|
echo ""
|
|
|
|
echo "$quickport"
|
|
|
|
fi
|
|
|
|
echo "-----------------------------------------------------"
|
|
|
|
else
|
|
|
|
for host in $hosts;do
|
2021-11-28 16:24:21 +00:00
|
|
|
if [[ $waitcheck == true ]];then
|
|
|
|
echo "-w used, waiting for active connection"
|
|
|
|
echo "checking connection status for $host"
|
|
|
|
fping=$(fping $only -a $host)
|
2021-11-28 15:39:32 +00:00
|
|
|
if [[ ! $oscheck == false ]];then
|
2021-11-28 16:24:21 +00:00
|
|
|
p135=$(nping $only -q1 -c1 -p135 $host)
|
|
|
|
p3389=$(nping $only -q1 -c1 -p3389 $host)
|
|
|
|
fi
|
|
|
|
if [[ $fping != "$host" ]] && [[ -n $(echo $p135 | grep "Successful connections: 1") ]] || [[ $fping != "$host" ]] && [[ -n $(echo $p3389 | grep "Successful connections: 1") ]];then
|
|
|
|
echo "-------------------Availability----------------------"
|
|
|
|
echo "note: this seems to be a windows machine which does not respond to ICMP"
|
|
|
|
notify-send "$host is now reachable" "and seems to be a windows machine" -u normal -t 30000 -a conn
|
|
|
|
echo "-----------------------------------------------------"
|
|
|
|
elif [[ $fping = "$host" ]] && [[ -n $(echo $p135 | grep "Successful connections: 1") ]];then
|
|
|
|
echo "-------------------Availability----------------------"
|
|
|
|
echo "note: this seems to be a windows machine which does respond to ICMP"
|
|
|
|
fping -e $host
|
|
|
|
notify-send "$host is now reachable" "and seems to be a windows machine" -u normal -t 30000 -a conn
|
|
|
|
echo "-----------------------------------------------------"
|
|
|
|
else
|
|
|
|
while [[ "$(fping $only -m -q -u $host)" == "$host" ]]; do :
|
|
|
|
done
|
|
|
|
echo "-------------------Availability----------------------"
|
|
|
|
fping -e $host
|
|
|
|
if [[ ! $oscheck == false ]];then
|
|
|
|
rescue=$(nping $only -q1 -c1 -p22,222 $host)
|
|
|
|
fi
|
2021-11-28 15:39:32 +00:00
|
|
|
if [[ -n $(echo $rescue | grep "Successful connections: 1") ]];then
|
|
|
|
echo "note: this seems to be a linux machine"
|
2021-11-28 16:24:21 +00:00
|
|
|
notify-send "$host is now reachable" "and seems to be in a linux system" -u normal -t 30000 -a conn
|
2021-11-28 15:39:32 +00:00
|
|
|
elif [[ -n $(echo $rescue | grep "Successful connections: 2") ]];then
|
|
|
|
echo "note: this machine seems to be in the rescue system"
|
2021-11-28 16:24:21 +00:00
|
|
|
notify-send "$host is now reachable" "and seems to be in the rescue system" -u normal -t 30000 -a conn
|
2021-11-28 15:39:32 +00:00
|
|
|
elif [[ -n $(echo $p135 | grep "Successful connections: 1") ]] || [[ -n $(echo $p3389 | grep "Successful connections: 1") ]];then
|
|
|
|
echo "note: this machine seems to be booted into windows"
|
2021-11-28 16:24:21 +00:00
|
|
|
notify-send "$host is now reachable" "and seems to be booted into windows" -u normal -t 30000 -a conn
|
|
|
|
else
|
|
|
|
notify-send "$host is now reachable" -u normal -t 30000 -a conn
|
|
|
|
fi
|
|
|
|
echo "-----------------------------------------------------"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo "checking connection status for $host"
|
|
|
|
fping=$(fping $only -a $host)
|
|
|
|
if [[ ! $oscheck == false ]];then
|
|
|
|
p135=$(nping $only -q1 -c1 -p135 $host)
|
|
|
|
p3389=$(nping $only -q1 -c1 -p3389 $host)
|
|
|
|
fi
|
|
|
|
if [[ $fping != "$host" ]] && [[ -n $(echo $p135 | grep "Successful connections: 1") ]] || [[ $fping != "$host" ]] && [[ -n $(echo $p3389 | grep "Successful connections: 1") ]];then
|
|
|
|
echo "-------------------Availability----------------------"
|
|
|
|
echo "note: this seems to be a windows machine which does not respond to ICMP"
|
|
|
|
echo "-----------------------------------------------------"
|
|
|
|
elif [[ $fping != "$host" ]] && [[ -z $(echo $p135 | grep "Successful connections: 1") ]] || [[ $fping != "$host" ]] && [[ -z $(echo $p3389 | grep "Successful connections: 1") ]];then
|
|
|
|
echo "-------------------Availability----------------------"
|
|
|
|
echo "$host is not reachable"
|
|
|
|
echo "-----------------------------------------------------"
|
|
|
|
else
|
|
|
|
echo "-------------------Availability----------------------"
|
|
|
|
fping $only -e $host
|
|
|
|
if [[ ! $oscheck == false ]];then
|
|
|
|
rescue=$(nping $only -q1 -c1 -p22,222 $host)
|
|
|
|
if [[ -n $(echo $rescue | grep "Successful connections: 1") ]];then
|
|
|
|
echo "note: this seems to be a linux machine"
|
|
|
|
elif [[ -n $(echo $rescue | grep "Successful connections: 2") ]];then
|
|
|
|
echo "note: this machine seems to be in the rescue system"
|
|
|
|
elif [[ -n $(echo $p135 | grep "Successful connections: 1") ]] || [[ -n $(echo $p3389 | grep "Successful connections: 1") ]];then
|
|
|
|
echo "note: this machine seems to be booted into windows"
|
|
|
|
fi
|
2021-11-28 15:39:32 +00:00
|
|
|
fi
|
2021-11-28 16:24:21 +00:00
|
|
|
echo "-----------------------------------------------------"
|
2021-11-28 15:39:32 +00:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
if [[ ! $doportscan == false ]];then
|
|
|
|
if [[ $doportscan == true ]];then
|
|
|
|
portscan=y
|
|
|
|
else
|
|
|
|
echo "portscan? (y/n) (default: y)"
|
|
|
|
read portscan
|
|
|
|
fi
|
|
|
|
if [[ "$portscan" = "y" ]] || [[ -z "$portscan" ]]; then
|
|
|
|
echo "-------------------Portscan---------------------"
|
|
|
|
nmap $only --reason -Pn $host
|
|
|
|
echo ""
|
|
|
|
fping $only -c 4 $host
|
|
|
|
echo "------------------------------------------------"
|
2021-11-28 16:24:21 +00:00
|
|
|
echo ""
|
2021-11-28 15:39:32 +00:00
|
|
|
else
|
|
|
|
echo ""
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
2021-11-27 23:14:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if [[ -n $1 ]];then
|
2021-11-28 14:40:45 +00:00
|
|
|
prepare "$@"
|
|
|
|
main "$hosts"
|
2021-11-28 00:26:31 +00:00
|
|
|
elif [[ "$1" == "-u" ]];then
|
|
|
|
run_update
|
|
|
|
elif [[ "$1" == "-h" ]];then
|
|
|
|
check_update
|
|
|
|
echo "$show_help"
|
2021-11-27 23:14:38 +00:00
|
|
|
else
|
2021-11-28 00:26:31 +00:00
|
|
|
#check_update
|
2021-11-27 23:14:38 +00:00
|
|
|
echo "$show_help"
|
|
|
|
fi
|