mirror of
https://github.com/nmap/nmap.git
synced 2025-12-06 04:31:29 +00:00
o [NSE] Added two new scripts for the MongoDB database from Martin
Holst Swende. mongodb-info gets information like the version number, memory use, and operating system. mongodb-databases lists the databases and their size on disk.
This commit is contained in:
94
scripts/mongodb-info.nse
Normal file
94
scripts/mongodb-info.nse
Normal file
@@ -0,0 +1,94 @@
|
||||
description = [[
|
||||
Attempts to get build info and server status from a MongoDB
|
||||
]]
|
||||
|
||||
---
|
||||
-- @usage
|
||||
-- nmap -p 27017 --script mongodb-info <host>
|
||||
-- @output
|
||||
-- PORT STATE SERVICE REASON
|
||||
-- 27017/tcp open unknown syn-ack
|
||||
-- | mongodb-info:
|
||||
-- | MongoDB Build info
|
||||
-- | ok = 1
|
||||
-- | bits = 64
|
||||
-- | version = 1.3.1-
|
||||
-- | gitVersion = d1f0ffe23bcd667f4ed18a27b5fd31a0beab5535
|
||||
-- | sysInfo = Linux domU-12-31-39-06-79-A1 2.6.21.7-2.ec2.v1.2.fc8xen #1 SMP Fri Nov 20 17:48:28 EST 2009 x86_64 BOOST_LIB_VERSION=1_41
|
||||
-- | Server status
|
||||
-- | opcounters
|
||||
-- | delete = 0
|
||||
-- | insert = 3
|
||||
-- | getmore = 0
|
||||
-- | update = 0
|
||||
-- | query = 10
|
||||
-- | connections
|
||||
-- | available = 19999
|
||||
-- | current = 1
|
||||
-- | uptime = 747
|
||||
-- | mem
|
||||
-- | resident = 9
|
||||
-- | virtual = 210
|
||||
-- | supported = true
|
||||
-- | mapped = 80
|
||||
-- | ok = 1
|
||||
-- | globalLock
|
||||
-- | ratio = 0.010762343463949
|
||||
-- | lockTime = 8037112
|
||||
-- | totalTime = 746780850
|
||||
-- | extra_info
|
||||
-- | heap_usage_bytes = 117120
|
||||
-- | note = fields vary by platform
|
||||
-- |_ page_faults = 0
|
||||
--@version 0.2
|
||||
-- Created 01/12/2010 - v0.1 - created by Martin Holst Swende <martin@swende.se>
|
||||
|
||||
|
||||
author = "Martin Holst Swende"
|
||||
license = "Same as Nmap--See http://nmap.org/book/man-legal.html"
|
||||
categories = {"discovery", "safe"}
|
||||
|
||||
require "mongodb"
|
||||
require "shortport"
|
||||
|
||||
portrule = shortport.port_or_service({27017}, {"mongodb"})
|
||||
function action(host,port)
|
||||
|
||||
local socket = nmap.new_socket()
|
||||
|
||||
-- set a reasonable timeout value
|
||||
socket:set_timeout(10000)
|
||||
-- do some exception / cleanup
|
||||
local catch = function()
|
||||
socket:close()
|
||||
end
|
||||
|
||||
local try = nmap.new_try(catch)
|
||||
|
||||
try( socket:connect(host.ip, port.number, "tcp") )
|
||||
|
||||
local req, status, statusresponse, buildinfo, packet, err
|
||||
|
||||
status, packet = mongodb.serverStatusQuery()
|
||||
if not status then return packet end
|
||||
|
||||
status,statQResult = mongodb.query(socket, packet)
|
||||
|
||||
if not status then return statResult end
|
||||
|
||||
status, packet = mongodb.buildInfoQuery()
|
||||
if not status then return packet end
|
||||
|
||||
status, buildQResult = mongodb.query(socket,packet )
|
||||
|
||||
if not status then
|
||||
stdnse.log_error(buildQResult)
|
||||
return buildQResult
|
||||
end
|
||||
|
||||
local stat_out = mongodb.queryResultToTable(statQResult)
|
||||
local build_out = mongodb.queryResultToTable(buildQResult)
|
||||
local output = {"MongoDB Build info",build_out,"Server status",stat_out}
|
||||
|
||||
return stdnse.format_output(true, output )
|
||||
end
|
||||
Reference in New Issue
Block a user