summaryrefslogtreecommitdiffstats
path: root/scripts/ndmp-fs-info.nse
blob: 8ff6a91421375253d5813db62ec184457ab002ee (plain)
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
local ndmp = require "ndmp"
local shortport = require "shortport"
local tab = require "tab"
local stdnse = require "stdnse"

description = [[
Lists remote file systems by querying the remote device using the Network
Data Management Protocol (ndmp). NDMP is a protocol intended to transport
data between a NAS device and the backup device, removing the need for the
data to pass through the backup server. The following products are known
to support the protocol:
* Amanda
* Bacula
* CA Arcserve
* CommVault Simpana
* EMC Networker
* Hitachi Data Systems
* IBM Tivoli
* Quest Software Netvault Backup
* Symantec Netbackup
* Symantec Backup Exec
]]

---
-- @usage
-- nmap -p 10000 --script ndmp-fs-info <ip>
--
-- @output
-- PORT      STATE SERVICE REASON  VERSION
-- 10000/tcp open  ndmp    syn-ack Symantec/Veritas Backup Exec ndmp
-- | ndmp-fs-info:
-- | FS       Logical device          Physical device
-- | NTFS     C:                      Device0000
-- | NTFS     E:                      Device0000
-- | UNKNOWN  Shadow Copy Components  Device0000
-- |_UNKNOWN  System State            Device0000
--
--

author = "Patrik Karlsson"
license = "Same as Nmap--See https://nmap.org/book/man-legal.html"
categories = {"discovery", "safe"}


portrule = shortport.port_or_service(10000, "ndmp", "tcp")

local function fail(err) return stdnse.format_output(false, err) end

action = function(host, port)

  local helper = ndmp.Helper:new(host, port)
  local status, msg = helper:connect()
  if ( not(status) ) then return fail("Failed to connect to server") end

  status, msg = helper:getFsInfo()
  if ( not(status) ) then return fail("Failed to get filesystem information from server") end
  if ( msg.header.error == ndmp.NDMP.ErrorType.NOT_AUTHORIZED_ERROR ) then return fail("Not authorized to get filesystem information from server") end
  helper:close()

  local result = tab.new(3)
  tab.addrow(result, "FS", "Logical device", "Physical device")

  for _, item in ipairs(msg.fsinfo) do
    if ( item.fs_logical_device and #item.fs_logical_device ~= 0 ) then
      if ( item and item.fs_type and item.fs_logical_device and item.fs_physical_device ) then
        tab.addrow(result, item.fs_type, item.fs_logical_device:gsub("?", " "), item.fs_physical_device)
      end
    end
  end

  return "\n" .. tab.dump(result)
end