librex 0.0.68 → 0.0.70

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (528) hide show
  1. checksums.yaml +15 -0
  2. data/README.markdown +1 -1
  3. data/Rakefile +18 -16
  4. data/lib/rex.rb +14 -10
  5. data/lib/rex/LICENSE +2 -2
  6. data/lib/rex/arch.rb +76 -76
  7. data/lib/rex/arch/sparc.rb +57 -58
  8. data/lib/rex/arch/x86.rb +506 -496
  9. data/lib/rex/assembly/nasm.rb +83 -84
  10. data/lib/rex/compat.rb +228 -173
  11. data/lib/rex/constants.rb +47 -37
  12. data/lib/rex/elfparsey.rb +0 -3
  13. data/lib/rex/elfparsey/elf.rb +107 -110
  14. data/lib/rex/elfparsey/elfbase.rb +244 -247
  15. data/lib/rex/elfparsey/exceptions.rb +0 -3
  16. data/lib/rex/elfscan.rb +0 -3
  17. data/lib/rex/elfscan/scanner.rb +184 -166
  18. data/lib/rex/elfscan/search.rb +35 -38
  19. data/lib/rex/encoder/alpha2.rb +1 -2
  20. data/lib/rex/encoder/alpha2/alpha_mixed.rb +52 -53
  21. data/lib/rex/encoder/alpha2/alpha_upper.rb +62 -63
  22. data/lib/rex/encoder/alpha2/generic.rb +77 -78
  23. data/lib/rex/encoder/alpha2/unicode_mixed.rb +101 -97
  24. data/lib/rex/encoder/alpha2/unicode_upper.rb +106 -107
  25. data/lib/rex/encoder/bloxor/bloxor.rb +326 -0
  26. data/lib/rex/encoder/ndr.rb +68 -68
  27. data/lib/rex/encoder/nonalpha.rb +50 -51
  28. data/lib/rex/encoder/nonupper.rb +50 -51
  29. data/lib/rex/encoder/xdr.rb +78 -78
  30. data/lib/rex/encoder/xor.rb +52 -53
  31. data/lib/rex/encoder/xor/dword.rb +1 -2
  32. data/lib/rex/encoder/xor/dword_additive.rb +1 -2
  33. data/lib/rex/encoders/xor_dword.rb +17 -18
  34. data/lib/rex/encoders/xor_dword_additive.rb +35 -36
  35. data/lib/rex/encoding/xor.rb +0 -1
  36. data/lib/rex/encoding/xor/byte.rb +3 -4
  37. data/lib/rex/encoding/xor/dword.rb +3 -4
  38. data/lib/rex/encoding/xor/dword_additive.rb +72 -73
  39. data/lib/rex/encoding/xor/exceptions.rb +2 -3
  40. data/lib/rex/encoding/xor/generic.rb +129 -130
  41. data/lib/rex/encoding/xor/qword.rb +3 -4
  42. data/lib/rex/encoding/xor/word.rb +3 -4
  43. data/lib/rex/exceptions.rb +100 -101
  44. data/lib/rex/exploitation/cmdstager.rb +3 -3
  45. data/lib/rex/exploitation/cmdstager/base.rb +170 -156
  46. data/lib/rex/exploitation/cmdstager/bourne.rb +105 -0
  47. data/lib/rex/exploitation/cmdstager/debug_asm.rb +110 -113
  48. data/lib/rex/exploitation/cmdstager/debug_write.rb +106 -109
  49. data/lib/rex/exploitation/cmdstager/echo.rb +164 -0
  50. data/lib/rex/exploitation/cmdstager/printf.rb +122 -0
  51. data/lib/rex/exploitation/cmdstager/tftp.rb +34 -27
  52. data/lib/rex/exploitation/cmdstager/vbs.rb +95 -98
  53. data/lib/rex/exploitation/egghunter.rb +359 -346
  54. data/lib/rex/exploitation/encryptjs.rb +60 -60
  55. data/lib/rex/exploitation/heaplib.rb +76 -76
  56. data/lib/rex/exploitation/js.rb +6 -0
  57. data/lib/rex/exploitation/js/detect.rb +69 -0
  58. data/lib/rex/exploitation/js/memory.rb +81 -0
  59. data/lib/rex/exploitation/js/network.rb +84 -0
  60. data/lib/rex/exploitation/js/utils.rb +33 -0
  61. data/lib/rex/exploitation/jsobfu.rb +448 -424
  62. data/lib/rex/exploitation/obfuscatejs.rb +301 -301
  63. data/lib/rex/exploitation/omelet.rb +257 -257
  64. data/lib/rex/exploitation/opcodedb.rb +699 -699
  65. data/lib/rex/exploitation/ropdb.rb +189 -0
  66. data/lib/rex/exploitation/seh.rb +68 -68
  67. data/lib/rex/file.rb +96 -49
  68. data/lib/rex/image_source.rb +0 -3
  69. data/lib/rex/image_source/disk.rb +45 -48
  70. data/lib/rex/image_source/image_source.rb +33 -36
  71. data/lib/rex/image_source/memory.rb +17 -20
  72. data/lib/rex/io/bidirectional_pipe.rb +118 -115
  73. data/lib/rex/io/datagram_abstraction.rb +13 -14
  74. data/lib/rex/io/ring_buffer.rb +273 -273
  75. data/lib/rex/io/stream.rb +284 -284
  76. data/lib/rex/io/stream_abstraction.rb +183 -181
  77. data/lib/rex/io/stream_server.rb +193 -193
  78. data/lib/rex/job_container.rb +167 -167
  79. data/lib/rex/logging.rb +0 -1
  80. data/lib/rex/logging/log_dispatcher.rb +113 -113
  81. data/lib/rex/logging/log_sink.rb +17 -17
  82. data/lib/rex/logging/sinks/flatfile.rb +36 -36
  83. data/lib/rex/logging/sinks/stderr.rb +27 -27
  84. data/lib/rex/mac_oui.rb +16572 -16571
  85. data/lib/rex/machparsey.rb +0 -1
  86. data/lib/rex/machparsey/exceptions.rb +0 -1
  87. data/lib/rex/machparsey/mach.rb +160 -161
  88. data/lib/rex/machparsey/machbase.rb +367 -368
  89. data/lib/rex/machscan.rb +0 -1
  90. data/lib/rex/machscan/scanner.rb +175 -176
  91. data/lib/rex/mime/encoding.rb +17 -0
  92. data/lib/rex/mime/header.rb +58 -58
  93. data/lib/rex/mime/message.rb +140 -137
  94. data/lib/rex/mime/part.rb +41 -12
  95. data/lib/rex/nop/opty2.rb +90 -90
  96. data/lib/rex/nop/opty2_tables.rb +273 -273
  97. data/lib/rex/ole.rb +0 -4
  98. data/lib/rex/ole/clsid.rb +26 -30
  99. data/lib/rex/ole/difat.rb +121 -125
  100. data/lib/rex/ole/directory.rb +205 -209
  101. data/lib/rex/ole/direntry.rb +217 -221
  102. data/lib/rex/ole/fat.rb +79 -83
  103. data/lib/rex/ole/header.rb +178 -182
  104. data/lib/rex/ole/minifat.rb +49 -53
  105. data/lib/rex/ole/propset.rb +113 -117
  106. data/lib/rex/ole/samples/create_ole.rb +8 -9
  107. data/lib/rex/ole/samples/dir.rb +10 -11
  108. data/lib/rex/ole/samples/dump_stream.rb +14 -15
  109. data/lib/rex/ole/samples/ole_info.rb +5 -6
  110. data/lib/rex/ole/storage.rb +372 -376
  111. data/lib/rex/ole/stream.rb +33 -37
  112. data/lib/rex/ole/substorage.rb +20 -24
  113. data/lib/rex/ole/util.rb +137 -141
  114. data/lib/rex/parser/acunetix_nokogiri.rb +398 -398
  115. data/lib/rex/parser/apple_backup_manifestdb.rb +116 -116
  116. data/lib/rex/parser/appscan_nokogiri.rb +359 -359
  117. data/lib/rex/parser/arguments.rb +88 -88
  118. data/lib/rex/parser/burp_session_nokogiri.rb +258 -258
  119. data/lib/rex/parser/ci_nokogiri.rb +184 -184
  120. data/lib/rex/parser/foundstone_nokogiri.rb +334 -333
  121. data/lib/rex/parser/fusionvm_nokogiri.rb +94 -94
  122. data/lib/rex/parser/ini.rb +167 -167
  123. data/lib/rex/parser/ip360_aspl_xml.rb +84 -84
  124. data/lib/rex/parser/ip360_xml.rb +77 -77
  125. data/lib/rex/parser/mbsa_nokogiri.rb +224 -224
  126. data/lib/rex/parser/nessus_xml.rb +100 -100
  127. data/lib/rex/parser/netsparker_xml.rb +89 -75
  128. data/lib/rex/parser/nexpose_raw_nokogiri.rb +677 -677
  129. data/lib/rex/parser/nexpose_simple_nokogiri.rb +322 -322
  130. data/lib/rex/parser/nexpose_xml.rb +105 -105
  131. data/lib/rex/parser/nmap_nokogiri.rb +386 -386
  132. data/lib/rex/parser/nmap_xml.rb +116 -116
  133. data/lib/rex/parser/nokogiri_doc_mixin.rb +223 -221
  134. data/lib/rex/parser/openvas_nokogiri.rb +162 -162
  135. data/lib/rex/parser/outpost24_nokogiri.rb +239 -0
  136. data/lib/rex/parser/retina_xml.rb +90 -90
  137. data/lib/rex/parser/unattend.rb +171 -0
  138. data/lib/rex/parser/wapiti_nokogiri.rb +89 -89
  139. data/lib/rex/payloads/win32/common.rb +14 -14
  140. data/lib/rex/payloads/win32/kernel.rb +36 -36
  141. data/lib/rex/payloads/win32/kernel/common.rb +32 -32
  142. data/lib/rex/payloads/win32/kernel/recovery.rb +27 -27
  143. data/lib/rex/payloads/win32/kernel/stager.rb +170 -170
  144. data/lib/rex/peparsey.rb +0 -3
  145. data/lib/rex/peparsey/exceptions.rb +0 -3
  146. data/lib/rex/peparsey/pe.rb +196 -199
  147. data/lib/rex/peparsey/pe_memdump.rb +35 -38
  148. data/lib/rex/peparsey/pebase.rb +1633 -1652
  149. data/lib/rex/peparsey/section.rb +115 -124
  150. data/lib/rex/pescan.rb +0 -3
  151. data/lib/rex/pescan/analyze.rb +351 -351
  152. data/lib/rex/pescan/scanner.rb +182 -182
  153. data/lib/rex/pescan/search.rb +59 -59
  154. data/lib/rex/platforms/windows.rb +37 -37
  155. data/lib/rex/poly.rb +111 -110
  156. data/lib/rex/poly/block.rb +419 -417
  157. data/lib/rex/poly/machine.rb +12 -0
  158. data/lib/rex/poly/machine/machine.rb +829 -0
  159. data/lib/rex/poly/machine/x86.rb +508 -0
  160. data/lib/rex/poly/register.rb +70 -70
  161. data/lib/rex/poly/register/x86.rb +22 -22
  162. data/lib/rex/post.rb +0 -1
  163. data/lib/rex/post/dir.rb +35 -36
  164. data/lib/rex/post/file.rb +140 -141
  165. data/lib/rex/post/file_stat.rb +198 -199
  166. data/lib/rex/post/io.rb +167 -168
  167. data/lib/rex/post/meterpreter.rb +1 -1
  168. data/lib/rex/post/meterpreter/channel.rb +389 -390
  169. data/lib/rex/post/meterpreter/channel_container.rb +33 -34
  170. data/lib/rex/post/meterpreter/channels/pool.rb +129 -130
  171. data/lib/rex/post/meterpreter/channels/pools/file.rb +35 -36
  172. data/lib/rex/post/meterpreter/channels/pools/stream_pool.rb +72 -73
  173. data/lib/rex/post/meterpreter/channels/stream.rb +62 -63
  174. data/lib/rex/post/meterpreter/client.rb +442 -436
  175. data/lib/rex/post/meterpreter/client_core.rb +326 -310
  176. data/lib/rex/post/meterpreter/dependencies.rb +0 -1
  177. data/lib/rex/post/meterpreter/extension.rb +12 -13
  178. data/lib/rex/post/meterpreter/extensions/espia/espia.rb +35 -36
  179. data/lib/rex/post/meterpreter/extensions/extapi/adsi/adsi.rb +71 -0
  180. data/lib/rex/post/meterpreter/extensions/extapi/clipboard/clipboard.rb +169 -0
  181. data/lib/rex/post/meterpreter/extensions/extapi/extapi.rb +45 -0
  182. data/lib/rex/post/meterpreter/extensions/extapi/service/service.rb +104 -0
  183. data/lib/rex/post/meterpreter/extensions/extapi/tlv.rb +77 -0
  184. data/lib/rex/post/meterpreter/extensions/extapi/window/window.rb +56 -0
  185. data/lib/rex/post/meterpreter/extensions/extapi/wmi/wmi.rb +75 -0
  186. data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +70 -71
  187. data/lib/rex/post/meterpreter/extensions/kiwi/kiwi.rb +361 -0
  188. data/lib/rex/post/meterpreter/extensions/kiwi/tlv.rb +76 -0
  189. data/lib/rex/post/meterpreter/extensions/lanattacks/dhcp/dhcp.rb +78 -0
  190. data/lib/rex/post/meterpreter/extensions/lanattacks/lanattacks.rb +22 -78
  191. data/lib/rex/post/meterpreter/extensions/lanattacks/tftp/tftp.rb +49 -0
  192. data/lib/rex/post/meterpreter/extensions/lanattacks/tlv.rb +4 -4
  193. data/lib/rex/post/meterpreter/extensions/mimikatz/mimikatz.rb +128 -0
  194. data/lib/rex/post/meterpreter/extensions/mimikatz/tlv.rb +16 -0
  195. data/lib/rex/post/meterpreter/extensions/networkpug/networkpug.rb +38 -39
  196. data/lib/rex/post/meterpreter/extensions/networkpug/tlv.rb +1 -1
  197. data/lib/rex/post/meterpreter/extensions/priv/fs.rb +95 -96
  198. data/lib/rex/post/meterpreter/extensions/priv/passwd.rb +39 -40
  199. data/lib/rex/post/meterpreter/extensions/priv/priv.rb +80 -85
  200. data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +94 -95
  201. data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +207 -147
  202. data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +258 -259
  203. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +366 -301
  204. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +72 -73
  205. data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +24 -25
  206. data/lib/rex/post/meterpreter/extensions/stdapi/net/arp.rb +59 -0
  207. data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +227 -149
  208. data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +107 -108
  209. data/lib/rex/post/meterpreter/extensions/stdapi/net/netstat.rb +97 -0
  210. data/lib/rex/post/meterpreter/extensions/stdapi/net/resolve.rb +106 -0
  211. data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +41 -42
  212. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +102 -101
  213. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +151 -152
  214. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +142 -142
  215. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +185 -185
  216. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb +38118 -38117
  217. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb +7 -7
  218. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_advapi32.rb +2086 -2084
  219. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_crypt32.rb +15 -15
  220. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_iphlpapi.rb +80 -80
  221. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_kernel32.rb +3835 -3833
  222. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_netapi32.rb +84 -28
  223. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ntdll.rb +151 -137
  224. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_shell32.rb +15 -6
  225. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_user32.rb +3155 -3155
  226. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_version.rb +41 -0
  227. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_wlanapi.rb +70 -70
  228. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_wldap32.rb +128 -0
  229. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ws2_32.rb +596 -596
  230. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb +310 -301
  231. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb +71 -61
  232. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb +100 -100
  233. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_wrapper.rb +14 -14
  234. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/mock_magic.rb +488 -488
  235. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/multicall.rb +273 -264
  236. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/platform_util.rb +5 -5
  237. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb +240 -238
  238. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/tlv.rb +17 -15
  239. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/type/pointer_util.rb +61 -61
  240. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/util.rb +654 -635
  241. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb +49 -49
  242. data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +103 -102
  243. data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +98 -68
  244. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +165 -166
  245. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log_subsystem/event_record.rb +16 -17
  246. data/lib/rex/post/meterpreter/extensions/stdapi/sys/power.rb +34 -36
  247. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +363 -364
  248. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/image.rb +102 -103
  249. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/io.rb +28 -29
  250. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/memory.rb +303 -304
  251. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/thread.rb +113 -114
  252. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb +260 -261
  253. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +165 -166
  254. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +69 -70
  255. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/remote_registry_key.rb +160 -161
  256. data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +143 -144
  257. data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +29 -12
  258. data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +230 -231
  259. data/lib/rex/post/meterpreter/extensions/stdapi/webcam/webcam.rb +181 -44
  260. data/lib/rex/post/meterpreter/inbound_packet_handler.rb +12 -13
  261. data/lib/rex/post/meterpreter/object_aliases.rb +56 -57
  262. data/lib/rex/post/meterpreter/packet.rb +591 -592
  263. data/lib/rex/post/meterpreter/packet_dispatcher.rb +506 -496
  264. data/lib/rex/post/meterpreter/packet_parser.rb +72 -73
  265. data/lib/rex/post/meterpreter/packet_response_waiter.rb +56 -57
  266. data/lib/rex/post/meterpreter/ui/console.rb +112 -112
  267. data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +53 -53
  268. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +911 -854
  269. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +86 -86
  270. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi.rb +65 -0
  271. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/adsi.rb +198 -0
  272. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/clipboard.rb +444 -0
  273. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/service.rb +199 -0
  274. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/window.rb +118 -0
  275. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/wmi.rb +108 -0
  276. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +220 -220
  277. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/kiwi.rb +509 -0
  278. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks.rb +60 -0
  279. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks/dhcp.rb +254 -0
  280. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks/tftp.rb +159 -0
  281. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/mimikatz.rb +182 -0
  282. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/networkpug.rb +173 -173
  283. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +40 -40
  284. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +75 -77
  285. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +30 -30
  286. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +105 -105
  287. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +182 -182
  288. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +37 -37
  289. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +504 -482
  290. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +401 -330
  291. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +883 -581
  292. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +296 -299
  293. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/webcam.rb +320 -153
  294. data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +78 -78
  295. data/lib/rex/post/permission.rb +0 -1
  296. data/lib/rex/post/process.rb +39 -40
  297. data/lib/rex/post/thread.rb +41 -42
  298. data/lib/rex/post/ui.rb +35 -36
  299. data/lib/rex/proto/addp.rb +218 -0
  300. data/lib/rex/proto/dcerpc/client.rb +344 -344
  301. data/lib/rex/proto/dcerpc/exceptions.rb +128 -128
  302. data/lib/rex/proto/dcerpc/handle.rb +32 -32
  303. data/lib/rex/proto/dcerpc/ndr.rb +56 -56
  304. data/lib/rex/proto/dcerpc/packet.rb +249 -245
  305. data/lib/rex/proto/dcerpc/response.rb +170 -170
  306. data/lib/rex/proto/dcerpc/uuid.rb +65 -65
  307. data/lib/rex/proto/dcerpc/wdscp.rb +3 -0
  308. data/lib/rex/proto/dcerpc/wdscp/constants.rb +89 -0
  309. data/lib/rex/proto/dcerpc/wdscp/packet.rb +94 -0
  310. data/lib/rex/proto/dhcp.rb +0 -1
  311. data/lib/rex/proto/dhcp/constants.rb +0 -1
  312. data/lib/rex/proto/dhcp/server.rb +303 -304
  313. data/lib/rex/proto/drda/constants.rb +1 -1
  314. data/lib/rex/proto/drda/packet.rb +186 -186
  315. data/lib/rex/proto/drda/utils.rb +104 -104
  316. data/lib/rex/proto/http.rb +1 -0
  317. data/lib/rex/proto/http/client.rb +692 -820
  318. data/lib/rex/proto/http/client_request.rb +472 -0
  319. data/lib/rex/proto/http/handler.rb +25 -25
  320. data/lib/rex/proto/http/handler/erb.rb +104 -104
  321. data/lib/rex/proto/http/handler/proc.rb +37 -37
  322. data/lib/rex/proto/http/header.rb +149 -149
  323. data/lib/rex/proto/http/packet.rb +388 -382
  324. data/lib/rex/proto/http/request.rb +332 -335
  325. data/lib/rex/proto/http/response.rb +132 -72
  326. data/lib/rex/proto/http/server.rb +348 -338
  327. data/lib/rex/proto/iax2/call.rb +310 -310
  328. data/lib/rex/proto/iax2/client.rb +197 -197
  329. data/lib/rex/proto/iax2/codecs/alaw.rb +4 -4
  330. data/lib/rex/proto/iax2/codecs/mulaw.rb +4 -4
  331. data/lib/rex/proto/ipmi.rb +57 -0
  332. data/lib/rex/proto/ipmi/channel_auth_reply.rb +88 -0
  333. data/lib/rex/proto/ipmi/open_session_reply.rb +35 -0
  334. data/lib/rex/proto/ipmi/rakp2.rb +35 -0
  335. data/lib/rex/proto/ipmi/utils.rb +125 -0
  336. data/lib/rex/proto/natpmp.rb +1 -5
  337. data/lib/rex/proto/natpmp/constants.rb +4 -4
  338. data/lib/rex/proto/natpmp/packet.rb +25 -25
  339. data/lib/rex/proto/ntlm/base.rb +271 -271
  340. data/lib/rex/proto/ntlm/constants.rb +61 -61
  341. data/lib/rex/proto/ntlm/crypt.rb +348 -352
  342. data/lib/rex/proto/ntlm/exceptions.rb +3 -3
  343. data/lib/rex/proto/ntlm/message.rb +468 -471
  344. data/lib/rex/proto/ntlm/utils.rb +746 -746
  345. data/lib/rex/proto/pjl.rb +30 -0
  346. data/lib/rex/proto/pjl/client.rb +162 -0
  347. data/lib/rex/proto/proxy/socks4a.rb +440 -440
  348. data/lib/rex/proto/rfb.rb +1 -8
  349. data/lib/rex/proto/rfb/cipher.rb +46 -49
  350. data/lib/rex/proto/rfb/client.rb +179 -182
  351. data/lib/rex/proto/rfb/constants.rb +18 -21
  352. data/lib/rex/proto/smb/client.rb +1954 -1843
  353. data/lib/rex/proto/smb/constants.rb +533 -516
  354. data/lib/rex/proto/smb/crypt.rb +21 -21
  355. data/lib/rex/proto/smb/evasions.rb +43 -43
  356. data/lib/rex/proto/smb/exceptions.rb +791 -791
  357. data/lib/rex/proto/smb/simpleclient.rb +142 -286
  358. data/lib/rex/proto/smb/simpleclient/open_file.rb +106 -0
  359. data/lib/rex/proto/smb/simpleclient/open_pipe.rb +57 -0
  360. data/lib/rex/proto/smb/utils.rb +81 -81
  361. data/lib/rex/proto/sunrpc/client.rb +158 -158
  362. data/lib/rex/proto/tftp.rb +0 -1
  363. data/lib/rex/proto/tftp/client.rb +289 -289
  364. data/lib/rex/proto/tftp/constants.rb +9 -10
  365. data/lib/rex/proto/tftp/server.rb +466 -467
  366. data/lib/rex/random_identifier_generator.rb +176 -0
  367. data/lib/rex/registry.rb +1 -1
  368. data/lib/rex/registry/hive.rb +88 -88
  369. data/lib/rex/registry/lfkey.rb +25 -25
  370. data/lib/rex/registry/nodekey.rb +30 -30
  371. data/lib/rex/registry/regf.rb +10 -10
  372. data/lib/rex/registry/valuekey.rb +43 -43
  373. data/lib/rex/registry/valuelist.rb +13 -13
  374. data/lib/rex/ropbuilder/rop.rb +254 -253
  375. data/lib/rex/script.rb +21 -22
  376. data/lib/rex/script/base.rb +51 -50
  377. data/lib/rex/script/meterpreter.rb +2 -2
  378. data/lib/rex/service.rb +24 -24
  379. data/lib/rex/service_manager.rb +132 -132
  380. data/lib/rex/services/local_relay.rb +398 -398
  381. data/lib/rex/socket.rb +758 -763
  382. data/lib/rex/socket/comm.rb +95 -95
  383. data/lib/rex/socket/comm/local.rb +507 -440
  384. data/lib/rex/socket/ip.rb +118 -118
  385. data/lib/rex/socket/parameters.rb +351 -350
  386. data/lib/rex/socket/range_walker.rb +445 -368
  387. data/lib/rex/socket/ssl_tcp.rb +323 -317
  388. data/lib/rex/socket/ssl_tcp_server.rb +173 -158
  389. data/lib/rex/socket/subnet_walker.rb +48 -48
  390. data/lib/rex/socket/switch_board.rb +259 -259
  391. data/lib/rex/socket/tcp.rb +58 -56
  392. data/lib/rex/socket/tcp_server.rb +42 -42
  393. data/lib/rex/socket/udp.rb +152 -152
  394. data/lib/rex/sslscan/result.rb +200 -0
  395. data/lib/rex/sslscan/scanner.rb +205 -0
  396. data/lib/rex/struct2.rb +0 -1
  397. data/lib/rex/struct2/c_struct.rb +162 -163
  398. data/lib/rex/struct2/c_struct_template.rb +21 -22
  399. data/lib/rex/struct2/constant.rb +6 -7
  400. data/lib/rex/struct2/element.rb +30 -31
  401. data/lib/rex/struct2/generic.rb +60 -61
  402. data/lib/rex/struct2/restraint.rb +40 -41
  403. data/lib/rex/struct2/s_string.rb +60 -61
  404. data/lib/rex/struct2/s_struct.rb +97 -98
  405. data/lib/rex/sync.rb +0 -1
  406. data/lib/rex/sync/event.rb +62 -72
  407. data/lib/rex/sync/read_write_lock.rb +149 -149
  408. data/lib/rex/sync/ref.rb +42 -42
  409. data/lib/rex/sync/thread_safe.rb +59 -59
  410. data/lib/rex/text.rb +1803 -1315
  411. data/lib/rex/thread_factory.rb +25 -25
  412. data/lib/rex/time.rb +44 -44
  413. data/lib/rex/transformer.rb +91 -91
  414. data/lib/rex/ui/interactive.rb +265 -265
  415. data/lib/rex/ui/output.rb +66 -60
  416. data/lib/rex/ui/progress_tracker.rb +79 -79
  417. data/lib/rex/ui/subscriber.rb +144 -134
  418. data/lib/rex/ui/text/color.rb +76 -76
  419. data/lib/rex/ui/text/dispatcher_shell.rb +512 -505
  420. data/lib/rex/ui/text/input.rb +96 -96
  421. data/lib/rex/ui/text/input/buffer.rb +58 -58
  422. data/lib/rex/ui/text/input/readline.rb +114 -114
  423. data/lib/rex/ui/text/input/socket.rb +77 -77
  424. data/lib/rex/ui/text/input/stdio.rb +24 -24
  425. data/lib/rex/ui/text/irb_shell.rb +45 -41
  426. data/lib/rex/ui/text/output.rb +64 -60
  427. data/lib/rex/ui/text/output/buffer.rb +42 -42
  428. data/lib/rex/ui/text/output/buffer/stdout.rb +25 -0
  429. data/lib/rex/ui/text/output/file.rb +24 -24
  430. data/lib/rex/ui/text/output/socket.rb +24 -24
  431. data/lib/rex/ui/text/output/stdio.rb +29 -29
  432. data/lib/rex/ui/text/output/tee.rb +36 -36
  433. data/lib/rex/ui/text/progress_tracker.rb +37 -37
  434. data/lib/rex/ui/text/shell.rb +371 -361
  435. data/lib/rex/ui/text/table.rb +320 -284
  436. data/lib/rex/zip.rb +0 -1
  437. data/lib/rex/zip/archive.rb +115 -94
  438. data/lib/rex/zip/blocks.rb +101 -100
  439. data/lib/rex/zip/entry.rb +108 -99
  440. data/lib/rex/zip/jar.rb +261 -206
  441. data/lib/rex/zip/samples/comment.rb +1 -2
  442. data/lib/rex/zip/samples/mkwar.rb +12 -13
  443. data/lib/rex/zip/samples/mkzip.rb +1 -2
  444. data/lib/rex/zip/samples/recursive.rb +29 -30
  445. metadata +424 -446
  446. data/lib/rex/arch/sparc.rb.ut.rb +0 -19
  447. data/lib/rex/arch/x86.rb.ut.rb +0 -94
  448. data/lib/rex/assembly/nasm.rb.ut.rb +0 -23
  449. data/lib/rex/encoder/ndr.rb.ut.rb +0 -45
  450. data/lib/rex/encoder/xdr.rb.ut.rb +0 -30
  451. data/lib/rex/encoders/xor_dword_additive.rb.ut.rb +0 -13
  452. data/lib/rex/encoding/xor.rb.ts.rb +0 -15
  453. data/lib/rex/encoding/xor/byte.rb.ut.rb +0 -22
  454. data/lib/rex/encoding/xor/dword.rb.ut.rb +0 -16
  455. data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +0 -16
  456. data/lib/rex/encoding/xor/generic.rb.ut.rb +0 -121
  457. data/lib/rex/encoding/xor/word.rb.ut.rb +0 -14
  458. data/lib/rex/exceptions.rb.ut.rb +0 -45
  459. data/lib/rex/exploitation/egghunter.rb.ut.rb +0 -28
  460. data/lib/rex/exploitation/javascriptosdetect.js +0 -1014
  461. data/lib/rex/exploitation/javascriptosdetect.rb +0 -43
  462. data/lib/rex/exploitation/omelet.rb.ut.rb +0 -27
  463. data/lib/rex/exploitation/opcodedb.rb.ut.rb +0 -280
  464. data/lib/rex/exploitation/seh.rb.ut.rb +0 -20
  465. data/lib/rex/file.rb.ut.rb +0 -17
  466. data/lib/rex/io/ring_buffer.rb.ut.rb +0 -135
  467. data/lib/rex/nop/opty2.rb.ut.rb +0 -24
  468. data/lib/rex/parser/arguments.rb.ut.rb +0 -68
  469. data/lib/rex/parser/ini.rb.ut.rb +0 -30
  470. data/lib/rex/post/meterpreter/extensions/stdapi/railgun.rb.ts.rb +0 -18
  471. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb.ut.rb +0 -39
  472. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb.ut.rb +0 -37
  473. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb.ut.rb +0 -52
  474. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb.ut.rb +0 -43
  475. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb.ut.rb +0 -128
  476. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_wrapper.rb.ut.rb +0 -64
  477. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/platform_util.rb.ut.rb +0 -29
  478. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb.ut.rb +0 -155
  479. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/type/pointer_util.rb.ut.rb +0 -128
  480. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb.ut.rb +0 -124
  481. data/lib/rex/proto.rb.ts.rb +0 -9
  482. data/lib/rex/proto/dcerpc.rb.ts.rb +0 -10
  483. data/lib/rex/proto/dcerpc/client.rb.ut.rb +0 -492
  484. data/lib/rex/proto/dcerpc/handle.rb.ut.rb +0 -86
  485. data/lib/rex/proto/dcerpc/ndr.rb.ut.rb +0 -42
  486. data/lib/rex/proto/dcerpc/packet.rb.ut.rb +0 -57
  487. data/lib/rex/proto/dcerpc/response.rb.ut.rb +0 -16
  488. data/lib/rex/proto/dcerpc/uuid.rb.ut.rb +0 -47
  489. data/lib/rex/proto/drda.rb.ts.rb +0 -18
  490. data/lib/rex/proto/drda/constants.rb.ut.rb +0 -24
  491. data/lib/rex/proto/drda/packet.rb.ut.rb +0 -110
  492. data/lib/rex/proto/drda/utils.rb.ut.rb +0 -85
  493. data/lib/rex/proto/http.rb.ts.rb +0 -13
  494. data/lib/rex/proto/http/client.rb.ut.rb +0 -96
  495. data/lib/rex/proto/http/handler/erb.rb.ut.rb +0 -22
  496. data/lib/rex/proto/http/handler/erb.rb.ut.rb.rhtml +0 -1
  497. data/lib/rex/proto/http/handler/proc.rb.ut.rb +0 -25
  498. data/lib/rex/proto/http/header.rb.ut.rb +0 -47
  499. data/lib/rex/proto/http/packet.rb.ut.rb +0 -166
  500. data/lib/rex/proto/http/request.rb.ut.rb +0 -215
  501. data/lib/rex/proto/http/response.rb.ut.rb +0 -150
  502. data/lib/rex/proto/http/server.rb.ut.rb +0 -80
  503. data/lib/rex/proto/ntlm.rb.ut.rb +0 -181
  504. data/lib/rex/proto/rfb.rb.ut.rb +0 -40
  505. data/lib/rex/proto/smb.rb.ts.rb +0 -9
  506. data/lib/rex/proto/smb/client.rb.ut.rb +0 -224
  507. data/lib/rex/proto/smb/constants.rb.ut.rb +0 -19
  508. data/lib/rex/proto/smb/simpleclient.rb.ut.rb +0 -129
  509. data/lib/rex/proto/smb/utils.rb.ut.rb +0 -21
  510. data/lib/rex/proto/tftp/server.rb.ut.rb +0 -29
  511. data/lib/rex/service_manager.rb.ut.rb +0 -33
  512. data/lib/rex/socket.rb.ut.rb +0 -108
  513. data/lib/rex/socket/comm/local.rb.ut.rb +0 -76
  514. data/lib/rex/socket/parameters.rb.ut.rb +0 -52
  515. data/lib/rex/socket/range_walker.rb.ut.rb +0 -56
  516. data/lib/rex/socket/ssl_tcp.rb.ut.rb +0 -40
  517. data/lib/rex/socket/ssl_tcp_server.rb.ut.rb +0 -62
  518. data/lib/rex/socket/subnet_walker.rb.ut.rb +0 -29
  519. data/lib/rex/socket/switch_board.rb.ut.rb +0 -53
  520. data/lib/rex/socket/tcp.rb.ut.rb +0 -65
  521. data/lib/rex/socket/tcp_server.rb.ut.rb +0 -45
  522. data/lib/rex/socket/udp.rb.ut.rb +0 -45
  523. data/lib/rex/test.rb +0 -36
  524. data/lib/rex/text.rb.ut.rb +0 -193
  525. data/lib/rex/transformer.rb.ut.rb +0 -39
  526. data/lib/rex/ui/text/color.rb.ut.rb +0 -19
  527. data/lib/rex/ui/text/progress_tracker.rb.ut.rb +0 -35
  528. data/lib/rex/ui/text/table.rb.ut.rb +0 -56
@@ -5,92 +5,92 @@ module Parser
5
5
  # XXX doesn't tie services to vulns
6
6
  class NexposeXMLStreamParser
7
7
 
8
- attr_accessor :callback
8
+ attr_accessor :callback
9
9
 
10
- def initialize(callback = nil)
11
- reset_state
12
- self.callback = callback if callback
13
- end
10
+ def initialize(callback = nil)
11
+ reset_state
12
+ self.callback = callback if callback
13
+ end
14
14
 
15
- def reset_state
16
- @state = :generic_state
17
- @only_vuln_states_needed = true
18
- @current_vuln_id = nil
19
- @vulnerable_markers = ['vulnerable-exploited', 'vulnerable-version', 'potential']
20
- @host = {"status" => nil, "endpoints" => [], "names" => [], "vulns" => {}}
21
- @vuln = {"refs" => [], "description" => [], "solution" => []}
22
- end
15
+ def reset_state
16
+ @state = :generic_state
17
+ @only_vuln_states_needed = true
18
+ @current_vuln_id = nil
19
+ @vulnerable_markers = ['vulnerable-exploited', 'vulnerable-version', 'potential']
20
+ @host = {"status" => nil, "endpoints" => [], "names" => [], "vulns" => {}}
21
+ @vuln = {"refs" => [], "description" => [], "solution" => []}
22
+ end
23
23
 
24
- # If all vuln states are required set this to false
25
- def parse_vulnerable_states_only only_vuln_states_needed
26
- @only_vuln_states_needed = only_vuln_states_needed
27
- end
24
+ # If all vuln states are required set this to false
25
+ def parse_vulnerable_states_only only_vuln_states_needed
26
+ @only_vuln_states_needed = only_vuln_states_needed
27
+ end
28
28
 
29
- def tag_start(name, attributes)
30
- case name
31
- when "node"
32
- @host["hardware-address"] = attributes["hardware-address"]
33
- @host["addr"] = attributes["address"]
34
- @host["status"] = attributes["status"]
35
- when "os"
36
- # Take only the highest certainty
37
- if not @host["os_certainty"] or (@host["os_certainty"].to_f < attributes["certainty"].to_f)
38
- @host["os_vendor"] = attributes["vendor"]
39
- @host["os_family"] = attributes["family"]
40
- @host["os_product"] = attributes["product"]
41
- @host["os_version"] = attributes["version"]
42
- @host["arch"] = attributes["arch"]
43
- @host["os_certainty"] = attributes["certainty"]
44
- end
45
- when "name"
46
- #@host["names"].push attributes["name"]
47
- @state = :in_name
48
- when "endpoint"
49
- # This is a port in NeXpose parlance
50
- @host["endpoints"].push(attributes)
51
- when "service"
52
- @state = :in_service
53
- # Store any service info with the associated port. There shouldn't
54
- # be any collisions on attribute names here, so just merge them.
55
- @host["endpoints"].last.merge!(attributes)
56
- when "fingerprint"
57
- if @state == :in_service
58
- @host["endpoints"].last.merge!(attributes)
59
- end
60
- when "test"
61
- if (not @only_vuln_states_needed) or (@vulnerable_markers.include? attributes["status"].to_s.chomp and @only_vuln_states_needed)
62
- @state = :in_test
63
- @current_vuln_id = attributes["id"]
64
- @host["vulns"][@current_vuln_id] = attributes.dup
65
- # Append the endpoint info for how the vuln was discovered
66
- unless @host["endpoints"].empty?
67
- @host["vulns"][@current_vuln_id].merge!("endpoint_data" => @host["endpoints"].last)
68
- end
69
- if attributes["key"]
70
- @host["notes"] ||= []
71
- @host["notes"] << [@current_vuln_id, attributes["key"]]
72
- end
73
- end
74
- when "vulnerability"
75
- @vuln.merge! attributes
76
- when "reference"
77
- @state = :in_reference
78
- @vuln["refs"].push attributes
79
- when "solution"
80
- @state = :in_solution
81
- when "description"
82
- @state = :in_description
83
- when "URLLink"
84
- @vuln["solution"] << attributes
85
- end
86
- end
29
+ def tag_start(name, attributes)
30
+ case name
31
+ when "node"
32
+ @host["hardware-address"] = attributes["hardware-address"]
33
+ @host["addr"] = attributes["address"]
34
+ @host["status"] = attributes["status"]
35
+ when "os"
36
+ # Take only the highest certainty
37
+ if not @host["os_certainty"] or (@host["os_certainty"].to_f < attributes["certainty"].to_f)
38
+ @host["os_vendor"] = attributes["vendor"]
39
+ @host["os_family"] = attributes["family"]
40
+ @host["os_product"] = attributes["product"]
41
+ @host["os_version"] = attributes["version"]
42
+ @host["arch"] = attributes["arch"]
43
+ @host["os_certainty"] = attributes["certainty"]
44
+ end
45
+ when "name"
46
+ #@host["names"].push attributes["name"]
47
+ @state = :in_name
48
+ when "endpoint"
49
+ # This is a port in NeXpose parlance
50
+ @host["endpoints"].push(attributes)
51
+ when "service"
52
+ @state = :in_service
53
+ # Store any service info with the associated port. There shouldn't
54
+ # be any collisions on attribute names here, so just merge them.
55
+ @host["endpoints"].last.merge!(attributes)
56
+ when "fingerprint"
57
+ if @state == :in_service
58
+ @host["endpoints"].last.merge!(attributes)
59
+ end
60
+ when "test"
61
+ if (not @only_vuln_states_needed) or (@vulnerable_markers.include? attributes["status"].to_s.chomp and @only_vuln_states_needed)
62
+ @state = :in_test
63
+ @current_vuln_id = attributes["id"]
64
+ @host["vulns"][@current_vuln_id] = attributes.dup
65
+ # Append the endpoint info for how the vuln was discovered
66
+ unless @host["endpoints"].empty?
67
+ @host["vulns"][@current_vuln_id].merge!("endpoint_data" => @host["endpoints"].last)
68
+ end
69
+ if attributes["key"]
70
+ @host["notes"] ||= []
71
+ @host["notes"] << [@current_vuln_id, attributes["key"]]
72
+ end
73
+ end
74
+ when "vulnerability"
75
+ @vuln.merge! attributes
76
+ when "reference"
77
+ @state = :in_reference
78
+ @vuln["refs"].push attributes
79
+ when "solution"
80
+ @state = :in_solution
81
+ when "description"
82
+ @state = :in_description
83
+ when "URLLink"
84
+ @vuln["solution"] << attributes
85
+ end
86
+ end
87
87
 
88
- def text(str)
89
- case @state
90
- when :in_name
91
- @host["names"].push str
92
- when :in_reference
93
- @vuln["refs"].last["value"] = str
88
+ def text(str)
89
+ case @state
90
+ when :in_name
91
+ @host["names"].push str
92
+ when :in_reference
93
+ @vuln["refs"].last["value"] = str
94
94
  when :in_solution
95
95
  @vuln["solution"] << str
96
96
  when :in_description
@@ -102,32 +102,32 @@ class NexposeXMLStreamParser
102
102
  @host["vulns"][@current_vuln_id]["proof"] = proof
103
103
  end
104
104
  end
105
- end
105
+ end
106
106
 
107
- def tag_end(name)
108
- case name
109
- when "node"
110
- callback.call(:host, @host) if callback
111
- reset_state
112
- when "vulnerability"
113
- callback.call(:vuln, @vuln) if callback
114
- reset_state
115
- when "service","reference","names"
116
- @state = :generic_state
117
- end
118
- end
107
+ def tag_end(name)
108
+ case name
109
+ when "node"
110
+ callback.call(:host, @host) if callback
111
+ reset_state
112
+ when "vulnerability"
113
+ callback.call(:vuln, @vuln) if callback
114
+ reset_state
115
+ when "service","reference","names"
116
+ @state = :generic_state
117
+ end
118
+ end
119
119
 
120
- # We don't need these methods, but they're necessary to keep REXML happy
121
- def xmldecl(version, encoding, standalone) # :nodoc:
122
- end
123
- def cdata # :nodoc:
124
- end
125
- def comment(str) # :nodoc:
126
- end
127
- def instruction(name, instruction) # :nodoc:
128
- end
129
- def attlist # :nodoc:
130
- end
120
+ # We don't need these methods, but they're necessary to keep REXML happy
121
+ def xmldecl(version, encoding, standalone) # :nodoc:
122
+ end
123
+ def cdata # :nodoc:
124
+ end
125
+ def comment(str) # :nodoc:
126
+ end
127
+ def instruction(name, instruction) # :nodoc:
128
+ end
129
+ def attlist # :nodoc:
130
+ end
131
131
  end
132
132
  end
133
133
  end
@@ -2,392 +2,392 @@
2
2
  require "rex/parser/nokogiri_doc_mixin"
3
3
 
4
4
  module Rex
5
- module Parser
6
-
7
- # If Nokogiri is available, define Nmap document class.
8
- load_nokogiri && class NmapDocument < Nokogiri::XML::SAX::Document
9
-
10
- include NokogiriDocMixin
11
-
12
- def determine_port_state(v)
13
- case v
14
- when "open"
15
- Msf::ServiceState::Open
16
- when "closed"
17
- Msf::ServiceState::Closed
18
- when "filtered"
19
- Msf::ServiceState::Filtered
20
- when "unknown"
21
- Msf::ServiceState::Unknown
22
- end
23
- end
24
-
25
- # Compare OS fingerprinting data
26
- def better_os_match(orig_hash,new_hash)
27
- return false unless new_hash.has_key? "accuracy"
28
- return true unless orig_hash.has_key? "accuracy"
29
- new_hash["accuracy"].to_i > orig_hash["accuracy"].to_i
30
- end
31
-
32
- # Triggered every time a new element is encountered. We keep state
33
- # ourselves with the @state variable, turning things on when we
34
- # get here (and turning things off when we exit in end_element()).
35
- def start_element(name=nil,attrs=[])
36
- attrs = normalize_attrs(attrs)
37
- block = @block
38
- @state[:current_tag][name] = true
39
- case name
40
- when "status"
41
- record_host_status(attrs)
42
- when "address"
43
- record_address(attrs)
44
- when "osclass"
45
- record_host_osclass(attrs)
46
- when "osmatch"
47
- record_host_osmatch(attrs)
48
- when "uptime"
49
- record_host_uptime(attrs)
50
- when "hostname"
51
- record_hostname(attrs)
52
- when "port"
53
- record_port(attrs)
54
- when "state"
55
- record_port_state(attrs)
56
- when "service"
57
- record_port_service(attrs)
58
- when "script" # Not actually used in import?
59
- record_port_script(attrs)
60
- record_host_script(attrs)
61
- # Ignoring post scripts completely
62
- when "trace"
63
- record_host_trace(attrs)
64
- when "hop"
65
- record_host_hop(attrs)
66
- end
67
- end
68
-
69
- # When we exit a tag, this is triggered.
70
- def end_element(name=nil)
71
- block = @block
72
- case name
73
- when "os"
74
- collect_os_data
75
- @state[:os] = {}
76
- when "port"
77
- collect_port_data
78
- @state[:port] = {}
79
- when "host" # Roll everything up now
80
- collect_host_data
81
- host_object = report_host &block
82
- if host_object
83
- db.report_import_note(@args[:wspace],host_object)
84
- report_services(host_object,&block)
85
- report_fingerprint(host_object)
86
- report_uptime(host_object)
87
- report_traceroute(host_object)
88
- end
89
- @state.delete_if {|k| k != :current_tag}
90
- @report_data = {:wspace => @args[:wspace]}
91
- end
92
- @state[:current_tag].delete name
93
- end
94
-
95
- # We can certainly get fancier with self.send() magic, but
96
- # leaving this pretty simple for now.
97
-
98
- def record_host_hop(attrs)
99
- return unless in_tag("host")
100
- return unless in_tag("trace")
101
- hops = attr_hash(attrs)
102
- hops["name"] = hops.delete "host"
103
- @state[:trace][:hops] << hops
104
- end
105
-
106
- def record_host_trace(attrs)
107
- return unless in_tag("host")
108
- @state[:trace] = attr_hash(attrs)
109
- @state[:trace][:hops] = []
110
- end
111
-
112
- def record_host_uptime(attrs)
113
- return unless in_tag("host")
114
- @state[:uptime] = attr_hash(attrs)
115
- end
116
-
117
- def record_host_osmatch(attrs)
118
- return unless in_tag("host")
119
- return unless in_tag("os")
120
- temp_hash = attr_hash(attrs)
121
- if temp_hash["accuracy"].to_i == 100
122
- @state[:os] ||= {}
123
- @state[:os]["osmatch"] = temp_hash["name"]
124
- end
125
- end
126
-
127
- def record_host_osclass(attrs)
128
- return unless in_tag("host")
129
- return unless in_tag("os")
130
- @state[:os] ||= {}
131
- temp_hash = attr_hash(attrs)
132
- if better_os_match(@state[:os],temp_hash)
133
- @state[:os] = temp_hash
134
- end
135
- end
136
-
137
- def record_hostname(attrs)
138
- return unless in_tag("host")
139
- if attr_hash(attrs)["type"] == "PTR"
140
- @state[:hostname] = attr_hash(attrs)["name"]
141
- end
142
- end
143
-
144
- def record_host_script(attrs)
145
- return unless in_tag("host")
146
- return if in_tag("port")
147
- temp_hash = attr_hash(attrs)
148
-
149
- if temp_hash["id"] and temp_hash["output"]
150
- @state[:scripts] ||= []
151
- @state[:scripts] << { temp_hash["id"] => temp_hash["output"] }
152
- end
153
- end
154
-
155
- def record_port_script(attrs)
156
- return unless in_tag("host")
157
- return unless in_tag("port")
158
- temp_hash = attr_hash(attrs)
159
- if temp_hash["id"] and temp_hash["output"]
160
- @state[:port][:scripts] ||= []
161
- @state[:port][:scripts] << { temp_hash["id"] => temp_hash["output"] }
162
- end
163
- end
164
-
165
- def record_port_service(attrs)
166
- return unless in_tag("host")
167
- return unless in_tag("port")
168
- svc = attr_hash(attrs)
169
- if svc["name"] && @args[:fix_services]
170
- svc["name"] = db.nmap_msf_service_map(svc["name"])
171
- end
172
- @state[:port] = @state[:port].merge(svc)
173
- end
174
-
175
- def record_port_state(attrs)
176
- return unless in_tag("host")
177
- return unless in_tag("port")
178
- temp_hash = attr_hash(attrs)
179
- @state[:port] = @state[:port].merge(temp_hash)
180
- end
181
-
182
- def record_port(attrs)
183
- return unless in_tag("host")
184
- @state[:port] ||= {}
185
- svc = attr_hash(attrs)
186
- @state[:port] = @state[:port].merge(svc)
187
- end
188
-
189
- def record_host_status(attrs)
190
- return unless in_tag("host")
191
- attrs.each do |k,v|
192
- next unless k == "state"
193
- @state[:host_alive] = (v == "up")
194
- end
195
- end
196
-
197
- def record_address(attrs)
198
- return unless in_tag("host")
199
- @state[:addresses] ||= {}
200
- address = nil
201
- type = nil
202
- attrs.each do |k,v|
203
- if k == "addr"
204
- address = v
205
- elsif k == "addrtype"
206
- type = v
207
- end
208
- end
209
- @state[:addresses][type] = address
210
- end
211
-
212
- def collect_os_data
213
- return unless in_tag("host")
214
- if @state[:os]
215
- @report_data[:os_fingerprint] = {
216
- :type => "host.os.nmap_fingerprint",
217
- :data => {
218
- :os_vendor => @state[:os]["vendor"],
219
- :os_family => @state[:os]["osfamily"],
220
- :os_version => @state[:os]["osgen"],
221
- :os_accuracy => @state[:os]["accuracy"].to_i
222
- }
223
- }
224
- if @state[:os].has_key? "osmatch"
225
- @report_data[:os_fingerprint][:data][:os_match] = @state[:os]["osmatch"]
226
- end
227
- end
228
- end
229
-
230
- def collect_host_data
231
- if @state[:host_alive]
232
- @report_data[:state] = Msf::HostState::Alive
233
- else
234
- @report_data[:state] = Msf::HostState::Dead
235
- end
236
- if @state[:addresses]
237
- if @state[:addresses].has_key? "ipv4"
238
- @report_data[:host] = @state[:addresses]["ipv4"]
239
- elsif @state[:addresses].has_key? "ipv6"
240
- @report_data[:host] = @state[:addresses]["ipv6"]
241
- end
242
- end
243
- if @state[:addresses] and @state[:addresses].has_key?("mac")
244
- @report_data[:mac] = @state[:addresses]["mac"]
245
- end
246
- if @state[:hostname]
247
- @report_data[:name] = @state[:hostname]
248
- end
249
- if @state[:uptime]
250
- @report_data[:last_boot] = @state[:uptime]["lastboot"]
251
- end
252
- if @state[:trace] and @state[:trace].has_key?(:hops)
253
- @report_data[:traceroute] = @state[:trace]
254
- end
255
- if @state[:scripts]
256
- @report_data[:scripts] = @state[:scripts]
257
- end
258
- end
259
-
260
- def collect_port_data
261
- return unless in_tag("host")
262
- if @args[:fix_services]
263
- if @state[:port]["state"] == "filtered"
264
- return
265
- end
266
- end
267
- @report_data[:ports] ||= []
268
- port_hash = {}
269
- extra = []
270
- @state[:port].each do |k,v|
271
- case k
272
- when "protocol"
273
- port_hash[:proto] = v
274
- when "portid"
275
- port_hash[:port] = v
276
- when "state"
277
- port_hash[:state] = determine_port_state(v)
278
- when "name"
279
- port_hash[:name] = v
280
- when "reason"
281
- port_hash[:reason] = v
282
- when "product"
283
- extra[0] = v
284
- when "version"
285
- extra[1] = v
286
- when "extrainfo"
287
- extra[2] = v
288
- when :scripts
289
- port_hash[:scripts] = v
290
- end
291
- end
292
- port_hash[:info] = extra.compact.join(" ") unless extra.empty?
293
- # Skip localhost port results when they're unknown
294
- if( port_hash[:reason] == "localhost-response" &&
295
- port_hash[:state] == Msf::ServiceState::Unknown )
296
- @report_data[:ports]
297
- else
298
- @report_data[:ports] << port_hash
299
- end
300
- end
301
-
302
- def report_traceroute(host_object)
303
- return unless host_object.kind_of? ::Mdm::Host
304
- return unless @report_data[:traceroute]
305
- tr_note = {
306
- :workspace => host_object.workspace,
307
- :host => host_object,
308
- :type => "host.nmap.traceroute",
309
- :data => { 'port' => @report_data[:traceroute]["port"].to_i,
310
- 'proto' => @report_data[:traceroute]["proto"].to_s,
311
- 'hops' => @report_data[:traceroute][:hops] }
312
- }
313
- db_report(:note, tr_note)
314
- end
315
-
316
- def report_uptime(host_object)
317
- return unless host_object.kind_of? ::Mdm::Host
318
- return unless @report_data[:last_boot]
319
- up_note = {
320
- :workspace => host_object.workspace,
321
- :host => host_object,
322
- :type => "host.last_boot",
323
- :data => { :time => @report_data[:last_boot] }
324
- }
325
- db_report(:note, up_note)
326
- end
327
-
328
- def report_fingerprint(host_object)
329
- return unless host_object.kind_of? ::Mdm::Host
330
- return unless @report_data[:os_fingerprint]
331
- fp_note = @report_data[:os_fingerprint].merge(
332
- {
333
- :workspace => host_object.workspace,
334
- :host => host_object
335
- })
336
- db_report(:note, fp_note)
337
- end
338
-
339
- def report_host(&block)
340
- if host_is_okay
341
- scripts = @report_data.delete(:scripts) || []
342
- host_object = db_report(:host, @report_data.merge( :workspace => @args[:wspace] ) )
343
- db.emit(:address,@report_data[:host],&block) if block
344
-
345
- scripts.each do |script|
346
- script.each_pair do |k,v|
347
- ntype =
348
- nse_note = {
349
- :workspace => host_object.workspace,
350
- :host => host_object,
351
- :type => "nmap.nse.#{k}.host",
352
- :data => { 'output' => v },
353
- :update => :unique_data
354
- }
355
- db_report(:note, nse_note)
356
- end
357
- end
358
-
359
- host_object
360
- end
361
- end
362
-
363
- def report_services(host_object,&block)
364
- return unless host_object.kind_of? ::Mdm::Host
365
- return unless @report_data[:ports]
366
- return if @report_data[:ports].empty?
367
- reported = []
368
- @report_data[:ports].each do |svc|
369
- scripts = svc.delete(:scripts) || []
370
- svc_obj = db_report(:service, svc.merge(:host => host_object))
371
- scripts.each do |script|
372
- script.each_pair do |k,v|
373
- ntype =
374
- nse_note = {
375
- :workspace => host_object.workspace,
376
- :host => host_object,
377
- :service => svc_obj,
378
- :type => "nmap.nse.#{k}." + (svc[:proto] || "tcp") +".#{svc[:port]}",
379
- :data => { 'output' => v },
380
- :update => :unique_data
381
- }
382
- db_report(:note, nse_note)
383
- end
384
- end
385
- reported << svc_obj
386
- end
387
- reported
388
- end
389
-
390
- end
5
+ module Parser
6
+
7
+ # If Nokogiri is available, define Nmap document class.
8
+ load_nokogiri && class NmapDocument < Nokogiri::XML::SAX::Document
9
+
10
+ include NokogiriDocMixin
11
+
12
+ def determine_port_state(v)
13
+ case v
14
+ when "open"
15
+ Msf::ServiceState::Open
16
+ when "closed"
17
+ Msf::ServiceState::Closed
18
+ when "filtered"
19
+ Msf::ServiceState::Filtered
20
+ when "unknown"
21
+ Msf::ServiceState::Unknown
22
+ end
23
+ end
24
+
25
+ # Compare OS fingerprinting data
26
+ def better_os_match(orig_hash,new_hash)
27
+ return false unless new_hash.has_key? "accuracy"
28
+ return true unless orig_hash.has_key? "accuracy"
29
+ new_hash["accuracy"].to_i > orig_hash["accuracy"].to_i
30
+ end
31
+
32
+ # Triggered every time a new element is encountered. We keep state
33
+ # ourselves with the @state variable, turning things on when we
34
+ # get here (and turning things off when we exit in end_element()).
35
+ def start_element(name=nil,attrs=[])
36
+ attrs = normalize_attrs(attrs)
37
+ block = @block
38
+ @state[:current_tag][name] = true
39
+ case name
40
+ when "status"
41
+ record_host_status(attrs)
42
+ when "address"
43
+ record_address(attrs)
44
+ when "osclass"
45
+ record_host_osclass(attrs)
46
+ when "osmatch"
47
+ record_host_osmatch(attrs)
48
+ when "uptime"
49
+ record_host_uptime(attrs)
50
+ when "hostname"
51
+ record_hostname(attrs)
52
+ when "port"
53
+ record_port(attrs)
54
+ when "state"
55
+ record_port_state(attrs)
56
+ when "service"
57
+ record_port_service(attrs)
58
+ when "script" # Not actually used in import?
59
+ record_port_script(attrs)
60
+ record_host_script(attrs)
61
+ # Ignoring post scripts completely
62
+ when "trace"
63
+ record_host_trace(attrs)
64
+ when "hop"
65
+ record_host_hop(attrs)
66
+ end
67
+ end
68
+
69
+ # When we exit a tag, this is triggered.
70
+ def end_element(name=nil)
71
+ block = @block
72
+ case name
73
+ when "os"
74
+ collect_os_data
75
+ @state[:os] = {}
76
+ when "port"
77
+ collect_port_data
78
+ @state[:port] = {}
79
+ when "host" # Roll everything up now
80
+ collect_host_data
81
+ host_object = report_host &block
82
+ if host_object
83
+ db.report_import_note(@args[:wspace],host_object)
84
+ report_services(host_object,&block)
85
+ report_fingerprint(host_object)
86
+ report_uptime(host_object)
87
+ report_traceroute(host_object)
88
+ end
89
+ @state.delete_if {|k| k != :current_tag}
90
+ @report_data = {:wspace => @args[:wspace]}
91
+ end
92
+ @state[:current_tag].delete name
93
+ end
94
+
95
+ # We can certainly get fancier with self.send() magic, but
96
+ # leaving this pretty simple for now.
97
+
98
+ def record_host_hop(attrs)
99
+ return unless in_tag("host")
100
+ return unless in_tag("trace")
101
+ hops = attr_hash(attrs)
102
+ hops["name"] = hops.delete "host"
103
+ @state[:trace][:hops] << hops
104
+ end
105
+
106
+ def record_host_trace(attrs)
107
+ return unless in_tag("host")
108
+ @state[:trace] = attr_hash(attrs)
109
+ @state[:trace][:hops] = []
110
+ end
111
+
112
+ def record_host_uptime(attrs)
113
+ return unless in_tag("host")
114
+ @state[:uptime] = attr_hash(attrs)
115
+ end
116
+
117
+ def record_host_osmatch(attrs)
118
+ return unless in_tag("host")
119
+ return unless in_tag("os")
120
+ temp_hash = attr_hash(attrs)
121
+ if temp_hash["accuracy"].to_i == 100
122
+ @state[:os] ||= {}
123
+ @state[:os]["osmatch"] = temp_hash["name"]
124
+ end
125
+ end
126
+
127
+ def record_host_osclass(attrs)
128
+ return unless in_tag("host")
129
+ return unless in_tag("os")
130
+ @state[:os] ||= {}
131
+ temp_hash = attr_hash(attrs)
132
+ if better_os_match(@state[:os],temp_hash)
133
+ @state[:os] = temp_hash
134
+ end
135
+ end
136
+
137
+ def record_hostname(attrs)
138
+ return unless in_tag("host")
139
+ if attr_hash(attrs)["type"] == "PTR"
140
+ @state[:hostname] = attr_hash(attrs)["name"]
141
+ end
142
+ end
143
+
144
+ def record_host_script(attrs)
145
+ return unless in_tag("host")
146
+ return if in_tag("port")
147
+ temp_hash = attr_hash(attrs)
148
+
149
+ if temp_hash["id"] and temp_hash["output"]
150
+ @state[:scripts] ||= []
151
+ @state[:scripts] << { temp_hash["id"] => temp_hash["output"] }
152
+ end
153
+ end
154
+
155
+ def record_port_script(attrs)
156
+ return unless in_tag("host")
157
+ return unless in_tag("port")
158
+ temp_hash = attr_hash(attrs)
159
+ if temp_hash["id"] and temp_hash["output"]
160
+ @state[:port][:scripts] ||= []
161
+ @state[:port][:scripts] << { temp_hash["id"] => temp_hash["output"] }
162
+ end
163
+ end
164
+
165
+ def record_port_service(attrs)
166
+ return unless in_tag("host")
167
+ return unless in_tag("port")
168
+ svc = attr_hash(attrs)
169
+ if svc["name"] && @args[:fix_services]
170
+ svc["name"] = db.nmap_msf_service_map(svc["name"])
171
+ end
172
+ @state[:port] = @state[:port].merge(svc)
173
+ end
174
+
175
+ def record_port_state(attrs)
176
+ return unless in_tag("host")
177
+ return unless in_tag("port")
178
+ temp_hash = attr_hash(attrs)
179
+ @state[:port] = @state[:port].merge(temp_hash)
180
+ end
181
+
182
+ def record_port(attrs)
183
+ return unless in_tag("host")
184
+ @state[:port] ||= {}
185
+ svc = attr_hash(attrs)
186
+ @state[:port] = @state[:port].merge(svc)
187
+ end
188
+
189
+ def record_host_status(attrs)
190
+ return unless in_tag("host")
191
+ attrs.each do |k,v|
192
+ next unless k == "state"
193
+ @state[:host_alive] = (v == "up")
194
+ end
195
+ end
196
+
197
+ def record_address(attrs)
198
+ return unless in_tag("host")
199
+ @state[:addresses] ||= {}
200
+ address = nil
201
+ type = nil
202
+ attrs.each do |k,v|
203
+ if k == "addr"
204
+ address = v
205
+ elsif k == "addrtype"
206
+ type = v
207
+ end
208
+ end
209
+ @state[:addresses][type] = address
210
+ end
211
+
212
+ def collect_os_data
213
+ return unless in_tag("host")
214
+ if @state[:os]
215
+ @report_data[:os_fingerprint] = {
216
+ :type => "host.os.nmap_fingerprint",
217
+ :data => {
218
+ :os_vendor => @state[:os]["vendor"],
219
+ :os_family => @state[:os]["osfamily"],
220
+ :os_version => @state[:os]["osgen"],
221
+ :os_accuracy => @state[:os]["accuracy"].to_i
222
+ }
223
+ }
224
+ if @state[:os].has_key? "osmatch"
225
+ @report_data[:os_fingerprint][:data][:os_match] = @state[:os]["osmatch"]
226
+ end
227
+ end
228
+ end
229
+
230
+ def collect_host_data
231
+ if @state[:host_alive]
232
+ @report_data[:state] = Msf::HostState::Alive
233
+ else
234
+ @report_data[:state] = Msf::HostState::Dead
235
+ end
236
+ if @state[:addresses]
237
+ if @state[:addresses].has_key? "ipv4"
238
+ @report_data[:host] = @state[:addresses]["ipv4"]
239
+ elsif @state[:addresses].has_key? "ipv6"
240
+ @report_data[:host] = @state[:addresses]["ipv6"]
241
+ end
242
+ end
243
+ if @state[:addresses] and @state[:addresses].has_key?("mac")
244
+ @report_data[:mac] = @state[:addresses]["mac"]
245
+ end
246
+ if @state[:hostname]
247
+ @report_data[:name] = @state[:hostname]
248
+ end
249
+ if @state[:uptime]
250
+ @report_data[:last_boot] = @state[:uptime]["lastboot"]
251
+ end
252
+ if @state[:trace] and @state[:trace].has_key?(:hops)
253
+ @report_data[:traceroute] = @state[:trace]
254
+ end
255
+ if @state[:scripts]
256
+ @report_data[:scripts] = @state[:scripts]
257
+ end
258
+ end
259
+
260
+ def collect_port_data
261
+ return unless in_tag("host")
262
+ if @args[:fix_services]
263
+ if @state[:port]["state"] == "filtered"
264
+ return
265
+ end
266
+ end
267
+ @report_data[:ports] ||= []
268
+ port_hash = {}
269
+ extra = []
270
+ @state[:port].each do |k,v|
271
+ case k
272
+ when "protocol"
273
+ port_hash[:proto] = v
274
+ when "portid"
275
+ port_hash[:port] = v
276
+ when "state"
277
+ port_hash[:state] = determine_port_state(v)
278
+ when "name"
279
+ port_hash[:name] = v
280
+ when "reason"
281
+ port_hash[:reason] = v
282
+ when "product"
283
+ extra[0] = v
284
+ when "version"
285
+ extra[1] = v
286
+ when "extrainfo"
287
+ extra[2] = v
288
+ when :scripts
289
+ port_hash[:scripts] = v
290
+ end
291
+ end
292
+ port_hash[:info] = extra.compact.join(" ") unless extra.empty?
293
+ # Skip localhost port results when they're unknown
294
+ if( port_hash[:reason] == "localhost-response" &&
295
+ port_hash[:state] == Msf::ServiceState::Unknown )
296
+ @report_data[:ports]
297
+ else
298
+ @report_data[:ports] << port_hash
299
+ end
300
+ end
301
+
302
+ def report_traceroute(host_object)
303
+ return unless host_object.kind_of? ::Mdm::Host
304
+ return unless @report_data[:traceroute]
305
+ tr_note = {
306
+ :workspace => host_object.workspace,
307
+ :host => host_object,
308
+ :type => "host.nmap.traceroute",
309
+ :data => { 'port' => @report_data[:traceroute]["port"].to_i,
310
+ 'proto' => @report_data[:traceroute]["proto"].to_s,
311
+ 'hops' => @report_data[:traceroute][:hops] }
312
+ }
313
+ db_report(:note, tr_note)
314
+ end
315
+
316
+ def report_uptime(host_object)
317
+ return unless host_object.kind_of? ::Mdm::Host
318
+ return unless @report_data[:last_boot]
319
+ up_note = {
320
+ :workspace => host_object.workspace,
321
+ :host => host_object,
322
+ :type => "host.last_boot",
323
+ :data => { :time => @report_data[:last_boot] }
324
+ }
325
+ db_report(:note, up_note)
326
+ end
327
+
328
+ def report_fingerprint(host_object)
329
+ return unless host_object.kind_of? ::Mdm::Host
330
+ return unless @report_data[:os_fingerprint]
331
+ fp_note = @report_data[:os_fingerprint].merge(
332
+ {
333
+ :workspace => host_object.workspace,
334
+ :host => host_object
335
+ })
336
+ db_report(:note, fp_note)
337
+ end
338
+
339
+ def report_host(&block)
340
+ if host_is_okay
341
+ scripts = @report_data.delete(:scripts) || []
342
+ host_object = db_report(:host, @report_data.merge( :workspace => @args[:wspace] ) )
343
+ db.emit(:address,@report_data[:host],&block) if block
344
+
345
+ scripts.each do |script|
346
+ script.each_pair do |k,v|
347
+ ntype =
348
+ nse_note = {
349
+ :workspace => host_object.workspace,
350
+ :host => host_object,
351
+ :type => "nmap.nse.#{k}.host",
352
+ :data => { 'output' => v },
353
+ :update => :unique_data
354
+ }
355
+ db_report(:note, nse_note)
356
+ end
357
+ end
358
+
359
+ host_object
360
+ end
361
+ end
362
+
363
+ def report_services(host_object,&block)
364
+ return unless host_object.kind_of? ::Mdm::Host
365
+ return unless @report_data[:ports]
366
+ return if @report_data[:ports].empty?
367
+ reported = []
368
+ @report_data[:ports].each do |svc|
369
+ scripts = svc.delete(:scripts) || []
370
+ svc_obj = db_report(:service, svc.merge(:host => host_object))
371
+ scripts.each do |script|
372
+ script.each_pair do |k,v|
373
+ ntype =
374
+ nse_note = {
375
+ :workspace => host_object.workspace,
376
+ :host => host_object,
377
+ :service => svc_obj,
378
+ :type => "nmap.nse.#{k}." + (svc[:proto] || "tcp") +".#{svc[:port]}",
379
+ :data => { 'output' => v },
380
+ :update => :unique_data
381
+ }
382
+ db_report(:note, nse_note)
383
+ end
384
+ end
385
+ reported << svc_obj
386
+ end
387
+ reported
388
+ end
389
+
390
+ end
391
391
 
392
392
  end
393
393
  end