Adds nmap automator
This commit is contained in:
parent
6caadcde51
commit
f3ce245a6e
1 changed files with 548 additions and 0 deletions
548
bin/.bin/nmap/nmapAutomator
Executable file
548
bin/.bin/nmap/nmapAutomator
Executable file
|
@ -0,0 +1,548 @@
|
|||
#!/bin/bash
|
||||
# Came from here: https://raw.githubusercontent.com/21y4d/nmapAutomator/master/nmapAutomator.sh
|
||||
#by 21y4d
|
||||
|
||||
RED='\033[0;31m'
|
||||
YELLOW='\033[0;33m'
|
||||
GREEN='\033[0;32m'
|
||||
NC='\033[0m'
|
||||
|
||||
SECONDS=0
|
||||
|
||||
usage(){
|
||||
echo -e ""
|
||||
echo -e "${RED}Usage: $0 <TARGET-IP> <TYPE>"
|
||||
echo -e "${YELLOW}"
|
||||
echo -e "Scan Types:"
|
||||
echo -e "\tQuick: Shows all open ports quickly (~15 seconds)"
|
||||
echo -e "\tBasic: Runs Quick Scan, then a runs more thorough scan on found ports (~5 minutes)"
|
||||
echo -e "\tUDP: Runs \"Basic\" on UDP ports (~5 minutes)"
|
||||
echo -e "\tFull: Runs a full range port scan, then runs a thorough scan on new ports (~5-10 minutes)"
|
||||
echo -e "\tVulns: Runs CVE scan and nmap Vulns scan on all found ports (~5-15 minutes)"
|
||||
echo -e "\tRecon: Suggests recon commands, then prompts to automatically run them"
|
||||
echo -e "\tAll: Runs all the scans (~20-30 minutes)"
|
||||
echo -e ""
|
||||
exit 1
|
||||
}
|
||||
|
||||
header(){
|
||||
echo -e ""
|
||||
|
||||
if [ "$2" == "All" ]; then
|
||||
echo -e "${YELLOW}Running all scans on $1"
|
||||
else
|
||||
echo -e "${YELLOW}Running a $2 scan on $1"
|
||||
fi
|
||||
|
||||
subnet=`echo "$1" | cut -d "." -f 1,2,3`".0"
|
||||
|
||||
checkPing=`checkPing $1`
|
||||
nmapType="nmap -Pn"
|
||||
|
||||
: '
|
||||
#nmapType=`echo "${checkPing}" | head -n 1`
|
||||
|
||||
if [ "$nmapType" != "nmap" ]; then
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}No ping detected.. Running with -Pn option!"
|
||||
echo -e "${NC}"
|
||||
fi
|
||||
'
|
||||
|
||||
ttl=`echo "${checkPing}" | tail -n 1`
|
||||
if [[ `echo "${ttl}"` != "nmap -Pn" ]]; then
|
||||
osType="$(checkOS $ttl)"
|
||||
echo -e "${NC}"
|
||||
echo -e "${GREEN}Host is likely running $osType"
|
||||
echo -e "${NC}"
|
||||
fi
|
||||
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
}
|
||||
|
||||
assignPorts(){
|
||||
if [ -f nmap/Quick_$1.nmap ]; then
|
||||
basicPorts=`cat nmap/Quick_$1.nmap | grep open | cut -d " " -f 1 | cut -d "/" -f 1 | tr "\n" "," | cut -c3- | head -c-2`
|
||||
fi
|
||||
|
||||
if [ -f nmap/Full_$1.nmap ]; then
|
||||
if [ -f nmap/Quick_$1.nmap ]; then
|
||||
allPorts=`cat nmap/Quick_$1.nmap nmap/Full_$1.nmap | grep open | cut -d " " -f 1 | cut -d "/" -f 1 | tr "\n" "," | cut -c3- | head -c-1`
|
||||
else
|
||||
allPorts=`cat nmap/Full_$1.nmap | grep open | cut -d " " -f 1 | cut -d "/" -f 1 | tr "\n" "," | head -c-1`
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ -f nmap/UDP_$1.nmap ]; then
|
||||
udpPorts=`cat nmap/UDP_$1.nmap | grep -w "open " | cut -d " " -f 1 | cut -d "/" -f 1 | tr "\n" "," | cut -c3- | head -c-2`
|
||||
if [[ "$udpPorts" == "Al" ]]; then
|
||||
udpPorts=""
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
checkPing(){
|
||||
pingTest=`ping -c 1 -W 3 $1 | grep ttl`
|
||||
if [[ -z $pingTest ]]; then
|
||||
echo "nmap -Pn"
|
||||
else
|
||||
echo "nmap"
|
||||
ttl=`echo "${pingTest}" | cut -d " " -f 6 | cut -d "=" -f 2`
|
||||
echo "${ttl}"
|
||||
fi
|
||||
}
|
||||
|
||||
checkOS(){
|
||||
if [ "$1" == 256 ] || [ "$1" == 255 ] || [ "$1" == 254 ]; then
|
||||
echo "OpenBSD/Cisco/Oracle"
|
||||
elif [ "$1" == 128 ] || [ "$1" == 127 ]; then
|
||||
echo "Windows"
|
||||
elif [ "$1" == 64 ] || [ "$1" == 63 ]; then
|
||||
echo "Linux"
|
||||
else
|
||||
echo "Unknown OS!"
|
||||
fi
|
||||
}
|
||||
|
||||
cmpPorts(){
|
||||
oldIFS=$IFS
|
||||
IFS=','
|
||||
touch nmap/cmpPorts_$1.txt
|
||||
|
||||
for i in `echo "${allPorts}"`
|
||||
do
|
||||
if [[ "$i" =~ ^($(echo "${basicPorts}" | sed 's/,/\|/g'))$ ]]; then
|
||||
:
|
||||
else
|
||||
echo -n "$i," >> nmap/cmpPorts_$1.txt
|
||||
fi
|
||||
done
|
||||
|
||||
extraPorts=`cat nmap/cmpPorts_$1.txt | tr "\n" "," | head -c-1`
|
||||
rm nmap/cmpPorts_$1.txt
|
||||
IFS=$oldIFS
|
||||
}
|
||||
|
||||
quickScan(){
|
||||
echo -e "${GREEN}---------------------Starting Nmap Quick Scan---------------------"
|
||||
echo -e "${NC}"
|
||||
|
||||
$nmapType -T4 --max-retries 1 --max-scan-delay 20 --defeat-rst-ratelimit --open -oN nmap/Quick_$1.nmap $1
|
||||
assignPorts $1
|
||||
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
}
|
||||
|
||||
basicScan(){
|
||||
echo -e "${GREEN}---------------------Starting Nmap Basic Scan---------------------"
|
||||
echo -e "${NC}"
|
||||
|
||||
if [ -z `echo "${basicPorts}"` ]; then
|
||||
echo -e "${YELLOW}No ports in quick scan.. Skipping!"
|
||||
else
|
||||
$nmapType -sCV -p`echo "${basicPorts}"` -oN nmap/Basic_$1.nmap $1
|
||||
fi
|
||||
|
||||
if [ -f nmap/Basic_$1.nmap ] && [[ ! -z `cat nmap/Basic_$1.nmap | grep -w "Service Info: OS:"` ]]; then
|
||||
serviceOS=`cat nmap/Basic_$1.nmap | grep -w "Service Info: OS:" | cut -d ":" -f 3 | cut -c2- | cut -d ";" -f 1 | head -c-1`
|
||||
if [[ "$osType" != "$serviceOS" ]]; then
|
||||
osType=`echo "${serviceOS}"`
|
||||
echo -e "${NC}"
|
||||
echo -e "${NC}"
|
||||
echo -e "${GREEN}OS Detection modified to: $osType"
|
||||
echo -e "${NC}"
|
||||
fi
|
||||
fi
|
||||
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
}
|
||||
|
||||
UDPScan(){
|
||||
echo -e "${GREEN}----------------------Starting Nmap UDP Scan----------------------"
|
||||
echo -e "${NC}"
|
||||
|
||||
$nmapType -sU --max-retries 1 --open -oN nmap/UDP_$1.nmap $1
|
||||
assignPorts $1
|
||||
|
||||
if [ ! -z `echo "${udpPorts}"` ]; then
|
||||
echo ""
|
||||
echo ""
|
||||
echo -e "${YELLOW}Making a script scan on UDP ports: `echo "${udpPorts}" | sed 's/,/, /g'`"
|
||||
echo -e "${NC}"
|
||||
if [ -f /usr/share/nmap/scripts/vulners.nse ]; then
|
||||
$nmapType -sCVU --script vulners --script-args mincvss=7.0 -p`echo "${udpPorts}"` -oN nmap/UDP_$1.nmap $1
|
||||
else
|
||||
$nmapType -sCVU -p`echo "${udpPorts}"` -oN nmap/UDP_$1.nmap $1
|
||||
fi
|
||||
fi
|
||||
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
}
|
||||
|
||||
fullScan(){
|
||||
echo -e "${GREEN}---------------------Starting Nmap Full Scan----------------------"
|
||||
echo -e "${NC}"
|
||||
|
||||
$nmapType -p- --max-retries 1 --max-rate 500 --max-scan-delay 20 -T4 -v -oN nmap/Full_$1.nmap $1
|
||||
assignPorts $1
|
||||
|
||||
if [ -z `echo "${basicPorts}"` ]; then
|
||||
echo ""
|
||||
echo ""
|
||||
echo -e "${YELLOW}Making a script scan on all ports"
|
||||
echo -e "${NC}"
|
||||
$nmapType -sCV -p`echo "${allPorts}"` -oN nmap/Full_$1.nmap $1
|
||||
assignPorts $1
|
||||
else
|
||||
cmpPorts $1
|
||||
if [ -z `echo "${extraPorts}"` ]; then
|
||||
echo ""
|
||||
echo ""
|
||||
allPorts=""
|
||||
echo -e "${YELLOW}No new ports"
|
||||
rm nmap/Full_$1.nmap
|
||||
echo -e "${NC}"
|
||||
else
|
||||
echo ""
|
||||
echo ""
|
||||
echo -e "${YELLOW}Making a script scan on extra ports: `echo "${extraPorts}" | sed 's/,/, /g'`"
|
||||
echo -e "${NC}"
|
||||
$nmapType -sCV -p`echo "${extraPorts}"` -oN nmap/Full_$1.nmap $1
|
||||
assignPorts $1
|
||||
fi
|
||||
fi
|
||||
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
}
|
||||
|
||||
vulnsScan(){
|
||||
echo -e "${GREEN}---------------------Starting Nmap Vulns Scan---------------------"
|
||||
echo -e "${NC}"
|
||||
|
||||
if [ -z `echo "${allPorts}"` ]; then
|
||||
portType="basic"
|
||||
ports=`echo "${basicPorts}"`
|
||||
else
|
||||
portType="all"
|
||||
ports=`echo "${allPorts}"`
|
||||
fi
|
||||
|
||||
|
||||
if [ ! -f /usr/share/nmap/scripts/vulners.nse ]; then
|
||||
echo -e "${RED}Please install 'vulners.nse' nmap script:"
|
||||
echo -e "${RED}https://github.com/vulnersCom/nmap-vulners"
|
||||
echo -e "${RED}"
|
||||
echo -e "${RED}Skipping CVE scan!"
|
||||
echo -e "${NC}"
|
||||
else
|
||||
echo -e "${YELLOW}Running CVE scan on $portType ports"
|
||||
echo -e "${NC}"
|
||||
$nmapType -sV --script vulners --script-args mincvss=7.0 -p`echo "${ports}"` -oN nmap/CVEs_$1.nmap $1
|
||||
echo ""
|
||||
fi
|
||||
|
||||
echo ""
|
||||
echo -e "${YELLOW}Running Vuln scan on $portType ports"
|
||||
echo -e "${NC}"
|
||||
$nmapType -sV --script vuln -p`echo "${ports}"` -oN nmap/Vulns_$1.nmap $1
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
}
|
||||
|
||||
recon(){
|
||||
|
||||
reconRecommend $1 | tee nmap/Recon_$1.nmap
|
||||
|
||||
availableRecon=`cat nmap/Recon_$1.nmap | grep $1 | cut -d " " -f 1 | sed 's/.\///g; s/.py//g; s/cd/odat/g;' | sort -u | tr "\n" "," | sed 's/,/,\ /g' | head -c-2`
|
||||
|
||||
secs=30
|
||||
count=0
|
||||
|
||||
reconCommand=""
|
||||
|
||||
if [ ! -z "$availableRecon" ]; then
|
||||
while [ ! `echo "${reconCommand}"` == "!" ]; do
|
||||
echo -e "${YELLOW}"
|
||||
echo -e "Which commands would you like to run?${NC}\nAll (Default), $availableRecon, Skip <!>\n"
|
||||
while [[ ${count} -lt ${secs} ]]; do
|
||||
tlimit=$(( $secs - $count ))
|
||||
echo -e "\rRunning Default in (${tlimit}) s: \c"
|
||||
read -t 1 reconCommand
|
||||
[ ! -z "$reconCommand" ] && { break ; }
|
||||
count=$((count+1))
|
||||
done
|
||||
if [ "$reconCommand" == "All" ] || [ -z `echo "${reconCommand}"` ]; then
|
||||
runRecon $1 "All"
|
||||
reconCommand="!"
|
||||
elif [[ "$reconCommand" =~ ^($(echo "${availableRecon}" | tr ", " "|"))$ ]]; then
|
||||
runRecon $1 $reconCommand
|
||||
reconCommand="!"
|
||||
elif [ "$reconCommand" == "Skip" ] || [ "$reconCommand" == "!" ]; then
|
||||
reconCommand="!"
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
else
|
||||
echo -e "${NC}"
|
||||
echo -e "${RED}Incorrect choice!"
|
||||
echo -e "${NC}"
|
||||
fi
|
||||
done
|
||||
fi
|
||||
|
||||
}
|
||||
|
||||
reconRecommend(){
|
||||
echo -e "${GREEN}---------------------Recon Recommendations----------------------"
|
||||
echo -e "${NC}"
|
||||
|
||||
oldIFS=$IFS
|
||||
IFS=$'\n'
|
||||
|
||||
if [ -f nmap/Full_$1.nmap ] && [ -f nmap/Basic_$1.nmap ]; then
|
||||
ports=`echo "${allPorts}"`
|
||||
file=`cat nmap/Basic_$1.nmap nmap/Full_$1.nmap | grep -w "open"`
|
||||
elif [ -f nmap/Full_$1.nmap ]; then
|
||||
ports=`echo "${allPorts}"`
|
||||
file=`cat nmap/Quick_$1.nmap nmap/Full_$1.nmap | grep -w "open"`
|
||||
elif [ -f nmap/Basic_$1.nmap ]; then
|
||||
ports=`echo "${basicPorts}"`
|
||||
file=`cat nmap/Basic_$1.nmap | grep -w "open"`
|
||||
else
|
||||
ports=`echo "${basicPorts}"`
|
||||
file=`cat nmap/Quick_$1.nmap | grep -w "open"`
|
||||
|
||||
fi
|
||||
|
||||
if [[ ! -z `echo "${file}" | grep -i http` ]]; then
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}Web Servers Recon:"
|
||||
echo -e "${NC}"
|
||||
fi
|
||||
|
||||
for line in $file; do
|
||||
if [[ ! -z `echo "${line}" | grep -i http` ]]; then
|
||||
port=`echo "${line}" | cut -d "/" -f 1`
|
||||
if [[ ! -z `echo "${line}" | grep -w "IIS"` ]]; then
|
||||
pages=".html,.asp,.php"
|
||||
else
|
||||
pages=".html,.php"
|
||||
fi
|
||||
if [[ ! -z `echo "${line}" | grep ssl/http` ]]; then
|
||||
#echo "sslyze --regular $1 | tee recon/sslyze_$1_$port.txt"
|
||||
echo "sslscan $1 | tee recon/sslscan_$1_$port.txt"
|
||||
echo "gobuster dir -w /usr/share/wordlists/dirb/common.txt -l -t 30 -e -k -x $pages -u https://$1:$port -o recon/gobuster_$1_$port.txt"
|
||||
echo "nikto -host https://$1:$port -ssl | tee recon/nikto_$1_$port.txt"
|
||||
else
|
||||
echo "gobuster dir -w /usr/share/wordlists/dirb/common.txt -l -t 30 -e -k -x $pages -u http://$1:$port -o recon/gobuster_$1_$port.txt"
|
||||
echo "nikto -host $1:$port | tee recon/nikto_$1_$port.txt"
|
||||
fi
|
||||
echo ""
|
||||
fi
|
||||
done
|
||||
|
||||
if [ -f nmap/Basic_$1.nmap ]; then
|
||||
cms=`cat nmap/Basic_$1.nmap | grep http-generator | cut -d " " -f 2`
|
||||
if [ ! -z `echo "${cms}"` ]; then
|
||||
for line in $cms; do
|
||||
port=`cat nmap/Basic_$1.nmap | grep $line -B1 | grep -w "open" | cut -d "/" -f 1`
|
||||
if [[ "$cms" =~ ^(Joomla|WordPress|Drupal)$ ]]; then
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}CMS Recon:"
|
||||
echo -e "${NC}"
|
||||
fi
|
||||
case "$cms" in
|
||||
Joomla!) echo "joomscan --url $1:$port | tee recon/joomscan_$1_$port.txt";;
|
||||
WordPress) echo "wpscan --url $1:$port --enumerate p | tee recon/wpscan_$1_$port.txt";;
|
||||
Drupal) echo "droopescan scan drupal -u $1:$port | tee recon/droopescan_$1_$port.txt";;
|
||||
esac
|
||||
done
|
||||
fi
|
||||
fi
|
||||
|
||||
if [[ ! -z `echo "${file}" | grep -w "445/tcp"` ]]; then
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}SMB Recon:"
|
||||
echo -e "${NC}"
|
||||
echo "smbmap -H $1 | tee recon/smbmap_$1.txt"
|
||||
echo "smbclient -L \"//$1/\" -U \"guest\"% | tee recon/smbclient_$1.txt"
|
||||
if [[ $osType == "Windows" ]]; then
|
||||
echo "nmap -Pn -p445 --script vuln -oN recon/SMB_vulns_$1.txt $1"
|
||||
fi
|
||||
if [[ $osType == "Linux" ]]; then
|
||||
echo "enum4linux -a $1 | tee recon/enum4linux_$1.txt"
|
||||
fi
|
||||
echo ""
|
||||
elif [[ ! -z `echo "${file}" | grep -w "139/tcp"` ]] && [[ $osType == "Linux" ]]; then
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}SMB Recon:"
|
||||
echo -e "${NC}"
|
||||
echo "enum4linux -a $1 | tee recon/enum4linux_$1.txt"
|
||||
echo ""
|
||||
fi
|
||||
|
||||
|
||||
if [ -f nmap/UDP_$1.nmap ] && [[ ! -z `cat nmap/UDP_$1.nmap | grep open | grep -w "161/udp"` ]]; then
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}SNMP Recon:"
|
||||
echo -e "${NC}"
|
||||
echo "snmp-check $1 -c public | tee recon/snmpcheck_$1.txt"
|
||||
echo "snmpwalk -Os -c public -v $1 | tee recon/snmpwalk_$1.txt"
|
||||
echo ""
|
||||
fi
|
||||
|
||||
if [[ ! -z `echo "${file}" | grep -w "53/tcp"` ]]; then
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}DNS Recon:"
|
||||
echo -e "${NC}"
|
||||
echo "host -l $1 $1 | tee recon/hostname_$1.txt"
|
||||
echo "dnsrecon -r $subnet/24 -n $1 | tee recon/dnsrecon_$1.txt"
|
||||
echo "dnsrecon -r 127.0.0.0/24 -n $1 | tee recon/dnsrecon-local_$1.txt"
|
||||
echo ""
|
||||
fi
|
||||
|
||||
if [[ ! -z `echo "${file}" | grep -w "1521/tcp"` ]]; then
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}Oracle Recon \"Exc. from Default\":"
|
||||
echo -e "${NC}"
|
||||
echo "cd /opt/odat/;#$1;"
|
||||
echo "./odat.py sidguesser -s $1 -p 1521"
|
||||
echo "./odat.py passwordguesser -s $1 -p 1521 -d XE --accounts-file accounts/accounts-multiple.txt"
|
||||
echo "cd -;#$1;"
|
||||
echo ""
|
||||
fi
|
||||
|
||||
IFS=$oldIFS
|
||||
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
}
|
||||
|
||||
runRecon(){
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
echo -e "${GREEN}---------------------Running Recon Commands----------------------"
|
||||
echo -e "${NC}"
|
||||
|
||||
oldIFS=$IFS
|
||||
IFS=$'\n'
|
||||
|
||||
if [[ ! -d recon/ ]]; then
|
||||
mkdir recon/
|
||||
fi
|
||||
|
||||
if [ "$2" == "All" ]; then
|
||||
reconCommands=`cat nmap/Recon_$1.nmap | grep $1 | grep -v odat`
|
||||
else
|
||||
reconCommands=`cat nmap/Recon_$1.nmap | grep $1 | grep $2`
|
||||
fi
|
||||
|
||||
for line in `echo "${reconCommands}"`; do
|
||||
currentScan=`echo $line | cut -d " " -f 1 | sed 's/.\///g; s/.py//g; s/cd/odat/g;' | sort -u | tr "\n" "," | sed 's/,/,\ /g' | head -c-2`
|
||||
fileName=`echo "${line}" | awk -F "recon/" '{print $2}' | head -c-1`
|
||||
if [ ! -z recon/`echo "${fileName}"` ] && [ ! -f recon/`echo "${fileName}"` ]; then
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}Starting $currentScan scan"
|
||||
echo -e "${NC}"
|
||||
echo $line | /bin/bash
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}Finished $currentScan scan"
|
||||
echo -e "${NC}"
|
||||
echo -e "${YELLOW}========================="
|
||||
fi
|
||||
done
|
||||
|
||||
IFS=$oldIFS
|
||||
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
echo -e ""
|
||||
}
|
||||
|
||||
footer(){
|
||||
|
||||
echo -e "${GREEN}---------------------Finished all Nmap scans---------------------"
|
||||
echo -e "${NC}"
|
||||
echo -e ""
|
||||
|
||||
if (( $SECONDS > 3600 )) ; then
|
||||
let "hours=SECONDS/3600"
|
||||
let "minutes=(SECONDS%3600)/60"
|
||||
let "seconds=(SECONDS%3600)%60"
|
||||
echo -e "${YELLOW}Completed in $hours hour(s), $minutes minute(s) and $seconds second(s)"
|
||||
elif (( $SECONDS > 60 )) ; then
|
||||
let "minutes=(SECONDS%3600)/60"
|
||||
let "seconds=(SECONDS%3600)%60"
|
||||
echo -e "${YELLOW}Completed in $minutes minute(s) and $seconds second(s)"
|
||||
else
|
||||
echo -e "${YELLOW}Completed in $SECONDS seconds"
|
||||
fi
|
||||
echo -e ""
|
||||
}
|
||||
|
||||
if (( "$#" != 2 )); then
|
||||
usage
|
||||
fi
|
||||
|
||||
if [[ $1 =~ ^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
|
||||
:
|
||||
else
|
||||
echo -e "${RED}"
|
||||
echo -e "${RED}Invalid IP!"
|
||||
echo -e "${RED}"
|
||||
usage
|
||||
fi
|
||||
|
||||
if [[ "$2" =~ ^(Quick|Basic|UDP|Full|Vulns|Recon|All)$ ]]; then
|
||||
if [[ ! -d $1 ]]; then
|
||||
mkdir $1
|
||||
fi
|
||||
|
||||
cd $1
|
||||
|
||||
if [[ ! -d nmap/ ]]; then
|
||||
mkdir nmap/
|
||||
fi
|
||||
|
||||
assignPorts $1
|
||||
|
||||
header $1 $2
|
||||
|
||||
case "$2" in
|
||||
Quick) quickScan $1;;
|
||||
Basic) if [ ! -f nmap/Quick_$1.nmap ]; then quickScan $1; fi
|
||||
basicScan $1;;
|
||||
UDP) UDPScan $1;;
|
||||
Full) fullScan $1;;
|
||||
Vulns) if [ ! -f nmap/Quick_$1.nmap ]; then quickScan $1; fi
|
||||
vulnsScan $1;;
|
||||
Recon) if [ ! -f nmap/Quick_$1.nmap ]; then quickScan $1; fi
|
||||
if [ ! -f nmap/Basic_$1.nmap ]; then basicScan $1; fi
|
||||
recon $1;;
|
||||
All) quickScan $1
|
||||
basicScan $1
|
||||
UDPScan $1
|
||||
fullScan $1
|
||||
vulnsScan $1
|
||||
recon $1;;
|
||||
esac
|
||||
|
||||
footer
|
||||
else
|
||||
echo -e "${RED}"
|
||||
echo -e "${RED}Invalid Type!"
|
||||
echo -e "${RED}"
|
||||
usage
|
||||
fi
|
Loading…
Add table
Add a link
Reference in a new issue