summaryrefslogtreecommitdiffstats
path: root/scripts/giop-info.nse
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/giop-info.nse')
-rw-r--r--scripts/giop-info.nse81
1 files changed, 81 insertions, 0 deletions
diff --git a/scripts/giop-info.nse b/scripts/giop-info.nse
new file mode 100644
index 0000000..c4aabd2
--- /dev/null
+++ b/scripts/giop-info.nse
@@ -0,0 +1,81 @@
+local giop = require "giop"
+local shortport = require "shortport"
+local stdnse = require "stdnse"
+
+description = [[
+Queries a CORBA naming server for a list of objects.
+]]
+
+author = "Patrik Karlsson"
+license = "Same as Nmap--See https://nmap.org/book/man-legal.html"
+categories = {"default", "discovery", "safe"}
+
+---
+-- @output
+-- PORT STATE SERVICE REASON
+-- 1050/tcp open java-or-OTGfileshare syn-ack
+-- | giop-info:
+-- | Object: Hello
+-- | Context: Test
+-- |_ Object: GoodBye
+--
+-- @xmloutput
+-- <table>
+-- <enum key="enum">0</enum>
+-- <enum key="id">Hello</enum>
+-- <enum key="kind">18</enum>
+-- </table>
+-- <table>
+-- <enum key="enum">1</enum>
+-- <enum key="id">Test</enum>
+-- <enum key="kind">0</enum>
+-- </table>
+-- <table>
+-- <enum key="enum">0</enum>
+-- <enum key="id">Goodbye</enum>
+-- <enum key="kind">18</enum>
+-- </table>
+
+
+-- Version 0.1
+
+-- Created 07/08/2010 - v0.1 - created by Patrik Karlsson <patrik@cqure.net>
+
+
+portrule = shortport.port_or_service( {2809,1050,1049} , "giop", "tcp", "open")
+
+local fmt_meta = {
+ __tostring = function (t)
+ local tmp = "Unknown"
+ if ( t.enum == 0 ) then
+ tmp = "Object"
+ elseif( t.enum == 1 ) then
+ tmp = "Context"
+ end
+
+ -- TODO: Handle t.kind? May require IDL.
+ return ("%s: %s"):format(tmp, t.id)
+ end
+}
+
+local function fail (err) return stdnse.format_output(false, err) end
+action = function(host, port)
+
+ local helper = giop.Helper:new( host, port )
+ local ctx, objs, status, err
+
+ status, err = helper:Connect()
+ if ( not(status) ) then return err end
+
+ status, ctx = helper:GetNamingContext()
+ if ( not(status) ) then return fail(ctx) end
+
+ status, objs = helper:ListObjects(ctx)
+ if ( not(status) ) then return fail(objs) end
+
+ for _, obj in ipairs( objs ) do
+ setmetatable(obj, fmt_meta)
+ end
+
+ return objs
+end