summaryrefslogtreecommitdiffstats
path: root/scripts/smb-vuln-ms08-067.nse
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--scripts/smb-vuln-ms08-067.nse154
1 files changed, 154 insertions, 0 deletions
diff --git a/scripts/smb-vuln-ms08-067.nse b/scripts/smb-vuln-ms08-067.nse
new file mode 100644
index 0000000..74ab327
--- /dev/null
+++ b/scripts/smb-vuln-ms08-067.nse
@@ -0,0 +1,154 @@
+local msrpc = require "msrpc"
+local smb = require "smb"
+local string = require "string"
+local vulns = require "vulns"
+
+description = [[
+Detects Microsoft Windows systems vulnerable to the remote code execution vulnerability
+known as MS08-067. This check is dangerous and it may crash systems.
+
+On a fairly wide scan conducted by Brandon Enright, we determined
+that on average, a vulnerable system is more likely to crash than to survive
+the check. Out of 82 vulnerable systems, 52 crashed.
+Please consider this before running the script.
+
+This check was previously part of smb-check-vulns.nse.
+]]
+---
+--@usage
+-- nmap --script smb-vuln-ms08-067.nse -p445 <host>
+-- nmap -sU --script smb-vuln-ms08-067.nse -p U:137 <host>
+--
+--@output
+--| smb-vuln-ms08-067:
+--| VULNERABLE:
+--| Microsoft Windows system vulnerable to remote code execution (MS08-067)
+--| State: VULNERABLE
+--| IDs: CVE:CVE-2008-4250
+--| The Server service in Microsoft Windows 2000 SP4, XP SP2 and SP3, Server 2003 SP1 and SP2,
+--| Vista Gold and SP1, Server 2008, and 7 Pre-Beta allows remote attackers to execute arbitrary
+--| code via a crafted RPC request that triggers the overflow during path canonicalization.
+--|
+--| Disclosure date: 2008-10-23
+--| References:
+--| https://technet.microsoft.com/en-us/library/security/ms08-067.aspx
+--|_ https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2008-4250
+---
+
+author = {"Ron Bowes", "Jiayi Ye", "Paulino Calderon <calderon()websec.mx>"}
+copyright = "Ron Bowes"
+license = "Same as Nmap--See https://nmap.org/book/man-legal.html"
+categories = {"intrusive","exploit","dos","vuln"}
+-- run after all smb-* scripts (so if it DOES crash something, it doesn't kill
+-- other scans have had a chance to run)
+dependencies = {
+ "smb-brute", "smb-enum-sessions", "smb-security-mode",
+ "smb-enum-shares", "smb-server-stats",
+ "smb-enum-domains", "smb-enum-users", "smb-system-info",
+ "smb-enum-groups", "smb-os-discovery", "smb-enum-processes",
+ "smb-psexec",
+};
+
+hostrule = function(host)
+ return smb.get_port(host) ~= nil
+end
+
+local VULNERABLE = 1
+local PATCHED = 2
+local UNKNOWN = 3
+local NOTRUN = 4
+local INFECTED = 5
+
+---Check if the server is patched for MS08-067. This is done by calling NetPathCompare with an
+-- illegal string. If the string is accepted, then the server is vulnerable; if it's rejected, then
+-- you're safe (for now).
+--
+-- Based on a packet cap of this script, thanks go out to the author:
+-- http://labs.portcullis.co.uk/application/ms08-067-check/
+--
+-- NOTE: This CAN crash stuff (ie, crash svchost and force a reboot), so beware! In about 20
+-- tests I did, it crashed once. This is not a guarantee.
+--
+--@param host The host object.
+--@return (status, result) If status is false, result is an error code; otherwise, result is either
+-- <code>VULNERABLE</code> for vulnerable, <code>PATCHED</code> for not vulnerable,
+-- <code>UNKNOWN</code> if there was an error (likely vulnerable),
+-- and <code>INFECTED</code> if it was patched by Conficker.
+function check_ms08_067(host)
+ local status, smbstate
+ local bind_result, netpathcompare_result
+
+ -- Create the SMB session
+ status, smbstate = msrpc.start_smb(host, "\\\\BROWSER")
+ if(status == false) then
+ return false, smbstate
+ end
+
+ -- Bind to SRVSVC service
+ status, bind_result = msrpc.bind(smbstate, msrpc.SRVSVC_UUID, msrpc.SRVSVC_VERSION, nil)
+ if(status == false) then
+ msrpc.stop_smb(smbstate)
+ return false, bind_result
+ end
+
+ -- Call netpathcanonicalize
+ -- status, netpathcanonicalize_result = msrpc.srvsvc_netpathcanonicalize(smbstate, host.ip, "\\a", "\\test\\")
+
+ local path1 = "\\AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\\..\\n"
+ local path2 = "\\n"
+ status, netpathcompare_result = msrpc.srvsvc_netpathcompare(smbstate, host.ip, path1, path2, 1, 0)
+
+ -- Stop the SMB session
+ msrpc.stop_smb(smbstate)
+
+ if(status == false) then
+ if(string.find(netpathcompare_result, "WERR_INVALID_PARAMETER") ~= nil) then
+ return true, INFECTED
+ elseif(string.find(netpathcompare_result, "INVALID_NAME") ~= nil) then
+ return true, PATCHED
+ else
+ return true, UNKNOWN, netpathcompare_result
+ end
+ end
+
+ return true, VULNERABLE
+end
+
+action = function(host)
+ local status, result, message
+ local response = {}
+ local vuln_report = vulns.Report:new(SCRIPT_NAME, host)
+ local vuln_table = {
+ title = 'Microsoft Windows system vulnerable to remote code execution (MS08-067)',
+ state = vulns.STATE.NOT_VULN,
+ description = [[
+ The Server service in Microsoft Windows 2000 SP4, XP SP2 and SP3, Server 2003 SP1 and SP2,
+ Vista Gold and SP1, Server 2008, and 7 Pre-Beta allows remote attackers to execute arbitrary
+ code via a crafted RPC request that triggers the overflow during path canonicalization.
+ ]],
+ IDS = {CVE = 'CVE-2008-4250'},
+ references = {
+ 'https://technet.microsoft.com/en-us/library/security/ms08-067.aspx'
+ },
+ dates = {
+ disclosure = {year = '2008', month = '10', day = '23'},
+ }
+ }
+ -- Check for ms08-067
+ status, result, message = check_ms08_067(host)
+ if(status == false) then
+ vuln_table.state = vulns.STATE.NOT_VULN
+ else
+ if(result == VULNERABLE) then
+ vuln_table.state = vulns.STATE.VULN
+ elseif(result == UNKNOWN) then
+ vuln_table.state = vulns.STATE.LIKELY_VULN
+ elseif(result == INFECTED) then
+ vuln_table.exploit_results = "This system has been infected by the Conficker worm."
+ vuln_table.state = vulns.STATE.LIKELY_VULN
+ else
+ vuln_table.state = vulns.STATE.NOT_VULN
+ end
+ end
+ return vuln_report:make_output(vuln_table)
+end