NMAP
HOST DISCOVERY: EXTERNAL
root@oco:~$ sudo nmap -sn -PE -PS 80,443 {targetIP} 
HOST DISCOVERY: INTERNAL RANGE
root@oco:~$ nmap -sn -T4 {networkAddress/CIDR} -sn -oA targetNet | grep for | cut -d" " -f5
 10.129.2.4
 10.129.2.10
 10.129.2.11
 10.129.2.18
 10.129.2.19
 10.129.2.20
 10.129.2.28
 
 * the -sn option only performs host discovery via ping scan w/o port scanning
    - by default, newer versions of Windows OS automatically block ping (ICMP Echo Requests)
    - for external networks, use ICMP Echo Requests (-PE) to check for live hosts 
      along with the -sn option (ping scan only) and -PS {port} which sends TCP SYN packets
      to specified ports (e.g., -PS80,443) to elicit a response
    - for local networks, Nmap uses ARP pings by default when -sn is used
       - these are faster and more reliable for discovering devices on the same 
         subnet, since ARP replies are guaranteed if the host is up and on the LAN.
          - This behavior can be confirmed and analyzed in detail using the --packet-trace option.
             - NOTE: arp is internal only
 * -oA targetNet stores the results in all formats starting with the name targetNet
 * this scanning method works only if the firewalls of the hosts allow it
HOST DISCOVERY: INTERNAL TARGET LIST (FILE)
root@oco:~$ cat hosts.lst
 10.129.2.4
 10.129.2.10
 10.129.2.11
 10.129.2.18
 10.129.2.19
 10.129.2.20
 10.129.2.28
root@oco:~$ sudo nmap -sn -oA targetNet -iL hosts.lst | grep for | cut -d" " -f5
 10.129.2.18
 10.129.2.19
 10.129.2.20
 
 * -iL Performs defined scans against targets in provided 'hosts.lst' list.HOST DISCOVERY: INTERNAL MULTI-TARGET LIST (CLI)
root@oco:~$ sudo nmap -sn -oA tnet 10.129.2.18 10.129.2.19 10.129.2.20 | grep for | cut -d" " -f5
 10.129.2.18
 10.129.2.19
 10.129.2.20
 
 * ALT: 
    - sudo nmap -sn -oA tnet 10.129.2.18-20| grep for | cut -d" " -f5
       - this alternate method only works when the defined ips are
         in the respective octet rangeHOST DISCOVERY: INTERNAL HOST STATUS
this method is used prior to scanning a single host for open ports and its services
root@oco:~$ sudo nmap 10.129.2.18 -sn -oA host 
 Starting Nmap 7.80 ( https://nmap.org ) at 2020-06-14 23:59 CEST
 Nmap scan report for 10.129.2.18
 Host is up (0.087s latency).
 MAC Address: DE:AD:00:00:BE:EF
 Nmap done: 1 IP address (1 host up) scanned in 0.11 seconds
 
 * this is similar to icmp scan via ping
 
 If we disable port scan (-sn), Nmap automatically ping scan with ICMP Echo Requests (-PE). Once such a request is sent, we usually expect an ICMP reply if the pinging host is alive. The more interesting fact is that our previous scans did not do that because before Nmap could send an ICMP echo request, it would send an ARP ping resulting in an ARP reply. We can confirm this with the "--packet-trace" option. To ensure that ICMP echo requests are sent, we also define the option (-PE) for this.SERVICE VERSION DETECTION
root@oco:~$ nmap -sV {ipAddress | networkAddress/CIDR} -p-
 * the -sV option enables version detectionBASIC CHECKS
root@oco:~$ nmap --script-help all
 * displays all available scripts
root@htb:~$ nmap -sV -sC -T4 {targetIP} -p 23
 * the -SC runs the default set of Nmap scripts (NSE scripts), which typically include
   scripts for service enumeration, version detection, and other basic checks.VULNERABILITY SCANNING
root@htb:~$ sudo nmap --script=vuln {targetIP} -p {port}
 * the --script=vuln will run scripts that focus specifically on detecting known 
   vulnerabilities in the service running on port 23
    - e.g., weak Telnet configurations, or known vulnerabilities in the Telnet 
      service
       - if no results are found then the service may be fully patched!SAVING SCAN RESULTS
root@oco:~$ sudo nmap {targetIP} -p- -oA target.targetIP.Results
 Starting Nmap 7.80 ( https://nmap.org ) at 2020-06-16 12:14 CEST
 Nmap scan report for 10.129.2.28
 Host is up (0.0091s latency).
 Not shown: 65525 closed ports
 PORT      STATE SERVICE
 22/tcp    open  ssh
 25/tcp    open  smtp
 80/tcp    open  http
 MAC Address: DE:AD:00:00:BE:EF (Intel Corporate)
 Nmap done: 1 IP address (1 host up) scanned in 10.22 seconds
 
root@oco:~$ ls
 target.targetIP.Results.gnmap target.targetIP.Results.xml  target.targetIP.Results.nmap
 
root@oco:~$ which xsltproc
root@oco:~$ xsltproc target.targetIP.Results.xml -o target.targetIP.Results.html
 ...
 
 * Nmap save results format
    - the -oN produces normal output and has the .nmap extension
	- the -oG produces a grepable output and has the .gnmap extension
	- the -oX produces an XML output with the .xml file extension
	   - this format can be converted to HTML to produce a report that is easy to read and digest
	     by non-technical people
		  - the xsltproc cmd is used in the conversion process
	- the -oA combines all three and save results in all formatLast updated
