1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
|
local nmap = require "nmap"
local shortport = require "shortport"
local stdnse = require "stdnse"
description = [[
Extends version detection to detect NetBuster, a honeypot service
that mimes NetBus.
]]
---
-- @usage
-- nmap -sV -p 12345 --script netbus-version <target>
--
-- @output
-- 12345/tcp open netbus Netbuster (honeypot)
author = "Toni Ruottu"
license = "Same as Nmap--See https://nmap.org/book/man-legal.html"
categories = {"version"}
portrule = shortport.version_port_or_service ({}, "netbus", {"tcp"})
action = function( host, port )
local socket = nmap.new_socket()
socket:set_timeout(5000)
local status, err = socket:connect(host, port)
if not status then
return
end
local buffer, _ = stdnse.make_buffer(socket, "\r")
_ = buffer()
if not (_ and _:match("^NetBus")) then
stdnse.debug1("Not NetBus")
return nil
end
socket:send("Password;0;\r")
--NetBus answers to auth
if buffer() ~= nil then
return
end
--NetBuster does not
port.version.name = "netbus"
port.version.product = "NetBuster"
port.version.extrainfo = "honeypot"
port.version.version = nil
nmap.set_port_version(host, port)
return
end
|