dstruct 0.0.1

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 (491) hide show
  1. checksums.yaml +15 -0
  2. data/README.markdown +23 -0
  3. data/examples/smb_example.rb +35 -0
  4. data/lib/rex.rb +108 -0
  5. data/lib/rex/LICENSE +29 -0
  6. data/lib/rex/arch.rb +104 -0
  7. data/lib/rex/arch/sparc.rb +75 -0
  8. data/lib/rex/arch/x86.rb +524 -0
  9. data/lib/rex/assembly/nasm.rb +104 -0
  10. data/lib/rex/codepage.map +104 -0
  11. data/lib/rex/compat.rb +389 -0
  12. data/lib/rex/constants.rb +124 -0
  13. data/lib/rex/elfparsey.rb +9 -0
  14. data/lib/rex/elfparsey/elf.rb +121 -0
  15. data/lib/rex/elfparsey/elfbase.rb +256 -0
  16. data/lib/rex/elfparsey/exceptions.rb +25 -0
  17. data/lib/rex/elfscan.rb +10 -0
  18. data/lib/rex/elfscan/scanner.rb +226 -0
  19. data/lib/rex/elfscan/search.rb +44 -0
  20. data/lib/rex/encoder/alpha2.rb +31 -0
  21. data/lib/rex/encoder/alpha2/alpha_mixed.rb +68 -0
  22. data/lib/rex/encoder/alpha2/alpha_upper.rb +79 -0
  23. data/lib/rex/encoder/alpha2/generic.rb +90 -0
  24. data/lib/rex/encoder/alpha2/unicode_mixed.rb +116 -0
  25. data/lib/rex/encoder/alpha2/unicode_upper.rb +123 -0
  26. data/lib/rex/encoder/bloxor/bloxor.rb +327 -0
  27. data/lib/rex/encoder/ndr.rb +90 -0
  28. data/lib/rex/encoder/nonalpha.rb +61 -0
  29. data/lib/rex/encoder/nonupper.rb +64 -0
  30. data/lib/rex/encoder/xdr.rb +107 -0
  31. data/lib/rex/encoder/xor.rb +69 -0
  32. data/lib/rex/encoder/xor/dword.rb +13 -0
  33. data/lib/rex/encoder/xor/dword_additive.rb +13 -0
  34. data/lib/rex/encoders/xor_dword.rb +35 -0
  35. data/lib/rex/encoders/xor_dword_additive.rb +53 -0
  36. data/lib/rex/encoding/xor.rb +20 -0
  37. data/lib/rex/encoding/xor/byte.rb +15 -0
  38. data/lib/rex/encoding/xor/dword.rb +21 -0
  39. data/lib/rex/encoding/xor/dword_additive.rb +92 -0
  40. data/lib/rex/encoding/xor/exceptions.rb +17 -0
  41. data/lib/rex/encoding/xor/generic.rb +146 -0
  42. data/lib/rex/encoding/xor/qword.rb +15 -0
  43. data/lib/rex/encoding/xor/word.rb +21 -0
  44. data/lib/rex/exceptions.rb +275 -0
  45. data/lib/rex/exploitation/cmdstager.rb +10 -0
  46. data/lib/rex/exploitation/cmdstager/base.rb +190 -0
  47. data/lib/rex/exploitation/cmdstager/bourne.rb +105 -0
  48. data/lib/rex/exploitation/cmdstager/debug_asm.rb +140 -0
  49. data/lib/rex/exploitation/cmdstager/debug_write.rb +134 -0
  50. data/lib/rex/exploitation/cmdstager/echo.rb +164 -0
  51. data/lib/rex/exploitation/cmdstager/printf.rb +122 -0
  52. data/lib/rex/exploitation/cmdstager/tftp.rb +71 -0
  53. data/lib/rex/exploitation/cmdstager/vbs.rb +126 -0
  54. data/lib/rex/exploitation/egghunter.rb +425 -0
  55. data/lib/rex/exploitation/encryptjs.rb +78 -0
  56. data/lib/rex/exploitation/heaplib.js.b64 +331 -0
  57. data/lib/rex/exploitation/heaplib.rb +107 -0
  58. data/lib/rex/exploitation/js.rb +6 -0
  59. data/lib/rex/exploitation/js/detect.rb +69 -0
  60. data/lib/rex/exploitation/js/memory.rb +81 -0
  61. data/lib/rex/exploitation/js/network.rb +84 -0
  62. data/lib/rex/exploitation/js/utils.rb +33 -0
  63. data/lib/rex/exploitation/jsobfu.rb +513 -0
  64. data/lib/rex/exploitation/obfuscatejs.rb +336 -0
  65. data/lib/rex/exploitation/omelet.rb +321 -0
  66. data/lib/rex/exploitation/opcodedb.rb +819 -0
  67. data/lib/rex/exploitation/powershell.rb +62 -0
  68. data/lib/rex/exploitation/powershell/function.rb +63 -0
  69. data/lib/rex/exploitation/powershell/obfu.rb +98 -0
  70. data/lib/rex/exploitation/powershell/output.rb +151 -0
  71. data/lib/rex/exploitation/powershell/param.rb +23 -0
  72. data/lib/rex/exploitation/powershell/parser.rb +183 -0
  73. data/lib/rex/exploitation/powershell/psh_methods.rb +70 -0
  74. data/lib/rex/exploitation/powershell/script.rb +99 -0
  75. data/lib/rex/exploitation/ropdb.rb +190 -0
  76. data/lib/rex/exploitation/seh.rb +93 -0
  77. data/lib/rex/file.rb +160 -0
  78. data/lib/rex/image_source.rb +10 -0
  79. data/lib/rex/image_source/disk.rb +58 -0
  80. data/lib/rex/image_source/image_source.rb +44 -0
  81. data/lib/rex/image_source/memory.rb +35 -0
  82. data/lib/rex/io/bidirectional_pipe.rb +161 -0
  83. data/lib/rex/io/datagram_abstraction.rb +35 -0
  84. data/lib/rex/io/ring_buffer.rb +369 -0
  85. data/lib/rex/io/stream.rb +312 -0
  86. data/lib/rex/io/stream_abstraction.rb +209 -0
  87. data/lib/rex/io/stream_server.rb +221 -0
  88. data/lib/rex/job_container.rb +200 -0
  89. data/lib/rex/logging.rb +4 -0
  90. data/lib/rex/logging/log_dispatcher.rb +180 -0
  91. data/lib/rex/logging/log_sink.rb +43 -0
  92. data/lib/rex/logging/sinks/flatfile.rb +56 -0
  93. data/lib/rex/logging/sinks/stderr.rb +44 -0
  94. data/lib/rex/mac_oui.rb +16581 -0
  95. data/lib/rex/machparsey.rb +9 -0
  96. data/lib/rex/machparsey/exceptions.rb +34 -0
  97. data/lib/rex/machparsey/mach.rb +209 -0
  98. data/lib/rex/machparsey/machbase.rb +408 -0
  99. data/lib/rex/machscan.rb +9 -0
  100. data/lib/rex/machscan/scanner.rb +217 -0
  101. data/lib/rex/mime.rb +10 -0
  102. data/lib/rex/mime/encoding.rb +17 -0
  103. data/lib/rex/mime/header.rb +78 -0
  104. data/lib/rex/mime/message.rb +150 -0
  105. data/lib/rex/mime/part.rb +50 -0
  106. data/lib/rex/nop/opty2.rb +109 -0
  107. data/lib/rex/nop/opty2_tables.rb +301 -0
  108. data/lib/rex/ole.rb +202 -0
  109. data/lib/rex/ole/clsid.rb +44 -0
  110. data/lib/rex/ole/difat.rb +138 -0
  111. data/lib/rex/ole/directory.rb +228 -0
  112. data/lib/rex/ole/direntry.rb +237 -0
  113. data/lib/rex/ole/docs/dependencies.txt +8 -0
  114. data/lib/rex/ole/docs/references.txt +1 -0
  115. data/lib/rex/ole/fat.rb +96 -0
  116. data/lib/rex/ole/header.rb +201 -0
  117. data/lib/rex/ole/minifat.rb +74 -0
  118. data/lib/rex/ole/propset.rb +141 -0
  119. data/lib/rex/ole/samples/create_ole.rb +27 -0
  120. data/lib/rex/ole/samples/dir.rb +35 -0
  121. data/lib/rex/ole/samples/dump_stream.rb +34 -0
  122. data/lib/rex/ole/samples/ole_info.rb +23 -0
  123. data/lib/rex/ole/storage.rb +392 -0
  124. data/lib/rex/ole/stream.rb +50 -0
  125. data/lib/rex/ole/substorage.rb +46 -0
  126. data/lib/rex/ole/util.rb +154 -0
  127. data/lib/rex/parser/acunetix_nokogiri.rb +406 -0
  128. data/lib/rex/parser/apple_backup_manifestdb.rb +132 -0
  129. data/lib/rex/parser/appscan_nokogiri.rb +367 -0
  130. data/lib/rex/parser/arguments.rb +108 -0
  131. data/lib/rex/parser/burp_session_nokogiri.rb +291 -0
  132. data/lib/rex/parser/ci_nokogiri.rb +193 -0
  133. data/lib/rex/parser/foundstone_nokogiri.rb +342 -0
  134. data/lib/rex/parser/fusionvm_nokogiri.rb +109 -0
  135. data/lib/rex/parser/group_policy_preferences.rb +185 -0
  136. data/lib/rex/parser/ini.rb +186 -0
  137. data/lib/rex/parser/ip360_aspl_xml.rb +103 -0
  138. data/lib/rex/parser/ip360_xml.rb +98 -0
  139. data/lib/rex/parser/mbsa_nokogiri.rb +256 -0
  140. data/lib/rex/parser/nessus_xml.rb +121 -0
  141. data/lib/rex/parser/netsparker_xml.rb +109 -0
  142. data/lib/rex/parser/nexpose_raw_nokogiri.rb +686 -0
  143. data/lib/rex/parser/nexpose_simple_nokogiri.rb +330 -0
  144. data/lib/rex/parser/nexpose_xml.rb +172 -0
  145. data/lib/rex/parser/nmap_nokogiri.rb +394 -0
  146. data/lib/rex/parser/nmap_xml.rb +166 -0
  147. data/lib/rex/parser/nokogiri_doc_mixin.rb +233 -0
  148. data/lib/rex/parser/openvas_nokogiri.rb +172 -0
  149. data/lib/rex/parser/outpost24_nokogiri.rb +240 -0
  150. data/lib/rex/parser/retina_xml.rb +110 -0
  151. data/lib/rex/parser/unattend.rb +171 -0
  152. data/lib/rex/parser/wapiti_nokogiri.rb +105 -0
  153. data/lib/rex/payloads.rb +2 -0
  154. data/lib/rex/payloads/win32.rb +3 -0
  155. data/lib/rex/payloads/win32/common.rb +27 -0
  156. data/lib/rex/payloads/win32/kernel.rb +54 -0
  157. data/lib/rex/payloads/win32/kernel/common.rb +55 -0
  158. data/lib/rex/payloads/win32/kernel/migration.rb +13 -0
  159. data/lib/rex/payloads/win32/kernel/recovery.rb +51 -0
  160. data/lib/rex/payloads/win32/kernel/stager.rb +195 -0
  161. data/lib/rex/peparsey.rb +10 -0
  162. data/lib/rex/peparsey/exceptions.rb +30 -0
  163. data/lib/rex/peparsey/pe.rb +210 -0
  164. data/lib/rex/peparsey/pe_memdump.rb +61 -0
  165. data/lib/rex/peparsey/pebase.rb +1662 -0
  166. data/lib/rex/peparsey/section.rb +128 -0
  167. data/lib/rex/pescan.rb +11 -0
  168. data/lib/rex/pescan/analyze.rb +366 -0
  169. data/lib/rex/pescan/scanner.rb +230 -0
  170. data/lib/rex/pescan/search.rb +68 -0
  171. data/lib/rex/platforms.rb +2 -0
  172. data/lib/rex/platforms/windows.rb +52 -0
  173. data/lib/rex/poly.rb +134 -0
  174. data/lib/rex/poly/block.rb +480 -0
  175. data/lib/rex/poly/machine.rb +13 -0
  176. data/lib/rex/poly/machine/machine.rb +830 -0
  177. data/lib/rex/poly/machine/x86.rb +509 -0
  178. data/lib/rex/poly/register.rb +101 -0
  179. data/lib/rex/poly/register/x86.rb +41 -0
  180. data/lib/rex/post.rb +7 -0
  181. data/lib/rex/post/dir.rb +51 -0
  182. data/lib/rex/post/file.rb +172 -0
  183. data/lib/rex/post/file_stat.rb +220 -0
  184. data/lib/rex/post/gen.pl +13 -0
  185. data/lib/rex/post/io.rb +182 -0
  186. data/lib/rex/post/meterpreter.rb +5 -0
  187. data/lib/rex/post/meterpreter/channel.rb +446 -0
  188. data/lib/rex/post/meterpreter/channel_container.rb +54 -0
  189. data/lib/rex/post/meterpreter/channels/pool.rb +160 -0
  190. data/lib/rex/post/meterpreter/channels/pools/file.rb +62 -0
  191. data/lib/rex/post/meterpreter/channels/pools/stream_pool.rb +103 -0
  192. data/lib/rex/post/meterpreter/channels/stream.rb +87 -0
  193. data/lib/rex/post/meterpreter/client.rb +483 -0
  194. data/lib/rex/post/meterpreter/client_core.rb +352 -0
  195. data/lib/rex/post/meterpreter/dependencies.rb +3 -0
  196. data/lib/rex/post/meterpreter/extension.rb +32 -0
  197. data/lib/rex/post/meterpreter/extensions/android/android.rb +128 -0
  198. data/lib/rex/post/meterpreter/extensions/android/tlv.rb +40 -0
  199. data/lib/rex/post/meterpreter/extensions/espia/espia.rb +58 -0
  200. data/lib/rex/post/meterpreter/extensions/espia/tlv.rb +17 -0
  201. data/lib/rex/post/meterpreter/extensions/extapi/adsi/adsi.rb +71 -0
  202. data/lib/rex/post/meterpreter/extensions/extapi/clipboard/clipboard.rb +169 -0
  203. data/lib/rex/post/meterpreter/extensions/extapi/extapi.rb +45 -0
  204. data/lib/rex/post/meterpreter/extensions/extapi/service/service.rb +104 -0
  205. data/lib/rex/post/meterpreter/extensions/extapi/tlv.rb +77 -0
  206. data/lib/rex/post/meterpreter/extensions/extapi/window/window.rb +56 -0
  207. data/lib/rex/post/meterpreter/extensions/extapi/wmi/wmi.rb +75 -0
  208. data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +94 -0
  209. data/lib/rex/post/meterpreter/extensions/incognito/tlv.rb +22 -0
  210. data/lib/rex/post/meterpreter/extensions/kiwi/kiwi.rb +361 -0
  211. data/lib/rex/post/meterpreter/extensions/kiwi/tlv.rb +76 -0
  212. data/lib/rex/post/meterpreter/extensions/lanattacks/dhcp/dhcp.rb +78 -0
  213. data/lib/rex/post/meterpreter/extensions/lanattacks/lanattacks.rb +43 -0
  214. data/lib/rex/post/meterpreter/extensions/lanattacks/tftp/tftp.rb +49 -0
  215. data/lib/rex/post/meterpreter/extensions/lanattacks/tlv.rb +17 -0
  216. data/lib/rex/post/meterpreter/extensions/mimikatz/mimikatz.rb +128 -0
  217. data/lib/rex/post/meterpreter/extensions/mimikatz/tlv.rb +16 -0
  218. data/lib/rex/post/meterpreter/extensions/networkpug/networkpug.rb +57 -0
  219. data/lib/rex/post/meterpreter/extensions/networkpug/tlv.rb +16 -0
  220. data/lib/rex/post/meterpreter/extensions/priv/fs.rb +118 -0
  221. data/lib/rex/post/meterpreter/extensions/priv/passwd.rb +61 -0
  222. data/lib/rex/post/meterpreter/extensions/priv/priv.rb +109 -0
  223. data/lib/rex/post/meterpreter/extensions/priv/tlv.rb +29 -0
  224. data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +117 -0
  225. data/lib/rex/post/meterpreter/extensions/sniffer/tlv.rb +27 -0
  226. data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +396 -0
  227. data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +284 -0
  228. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +399 -0
  229. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +104 -0
  230. data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +48 -0
  231. data/lib/rex/post/meterpreter/extensions/stdapi/net/arp.rb +59 -0
  232. data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +256 -0
  233. data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +129 -0
  234. data/lib/rex/post/meterpreter/extensions/stdapi/net/netstat.rb +97 -0
  235. data/lib/rex/post/meterpreter/extensions/stdapi/net/resolve.rb +106 -0
  236. data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +67 -0
  237. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +139 -0
  238. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +180 -0
  239. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +168 -0
  240. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +209 -0
  241. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb +38146 -0
  242. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb +48 -0
  243. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_advapi32.rb +2102 -0
  244. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_crypt32.rb +32 -0
  245. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_iphlpapi.rb +97 -0
  246. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_kernel32.rb +3852 -0
  247. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_netapi32.rb +100 -0
  248. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ntdll.rb +168 -0
  249. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_psapi.rb +32 -0
  250. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_shell32.rb +32 -0
  251. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_user32.rb +3170 -0
  252. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_version.rb +41 -0
  253. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_wlanapi.rb +87 -0
  254. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_wldap32.rb +128 -0
  255. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ws2_32.rb +613 -0
  256. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb +388 -0
  257. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb +111 -0
  258. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb +149 -0
  259. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_wrapper.rb +27 -0
  260. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/mock_magic.rb +515 -0
  261. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/multicall.rb +319 -0
  262. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/platform_util.rb +23 -0
  263. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb +301 -0
  264. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/tlv.rb +56 -0
  265. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/type/pointer_util.rb +106 -0
  266. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/util.rb +676 -0
  267. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb +96 -0
  268. data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +151 -0
  269. data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +128 -0
  270. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +192 -0
  271. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log_subsystem/event_record.rb +41 -0
  272. data/lib/rex/post/meterpreter/extensions/stdapi/sys/power.rb +60 -0
  273. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +408 -0
  274. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/image.rb +129 -0
  275. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/io.rb +55 -0
  276. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/memory.rb +336 -0
  277. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/thread.rb +141 -0
  278. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb +328 -0
  279. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +193 -0
  280. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +102 -0
  281. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/remote_registry_key.rb +188 -0
  282. data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +180 -0
  283. data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +236 -0
  284. data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +259 -0
  285. data/lib/rex/post/meterpreter/extensions/stdapi/webcam/webcam.rb +201 -0
  286. data/lib/rex/post/meterpreter/inbound_packet_handler.rb +30 -0
  287. data/lib/rex/post/meterpreter/object_aliases.rb +83 -0
  288. data/lib/rex/post/meterpreter/packet.rb +709 -0
  289. data/lib/rex/post/meterpreter/packet_dispatcher.rb +543 -0
  290. data/lib/rex/post/meterpreter/packet_parser.rb +94 -0
  291. data/lib/rex/post/meterpreter/packet_response_waiter.rb +83 -0
  292. data/lib/rex/post/meterpreter/ui/console.rb +142 -0
  293. data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +86 -0
  294. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/android.rb +383 -0
  295. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +939 -0
  296. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +109 -0
  297. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi.rb +65 -0
  298. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/adsi.rb +198 -0
  299. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/clipboard.rb +444 -0
  300. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/service.rb +199 -0
  301. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/window.rb +118 -0
  302. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/extapi/wmi.rb +108 -0
  303. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +242 -0
  304. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/kiwi.rb +509 -0
  305. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks.rb +60 -0
  306. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks/dhcp.rb +254 -0
  307. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/lanattacks/tftp.rb +159 -0
  308. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/mimikatz.rb +182 -0
  309. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/networkpug.rb +232 -0
  310. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +62 -0
  311. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +97 -0
  312. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +52 -0
  313. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +133 -0
  314. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +204 -0
  315. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +66 -0
  316. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +527 -0
  317. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +448 -0
  318. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +906 -0
  319. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +318 -0
  320. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/webcam.rb +343 -0
  321. data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +99 -0
  322. data/lib/rex/post/permission.rb +26 -0
  323. data/lib/rex/post/process.rb +57 -0
  324. data/lib/rex/post/thread.rb +57 -0
  325. data/lib/rex/post/ui.rb +52 -0
  326. data/lib/rex/proto.rb +15 -0
  327. data/lib/rex/proto/addp.rb +218 -0
  328. data/lib/rex/proto/dcerpc.rb +7 -0
  329. data/lib/rex/proto/dcerpc/client.rb +362 -0
  330. data/lib/rex/proto/dcerpc/exceptions.rb +151 -0
  331. data/lib/rex/proto/dcerpc/handle.rb +48 -0
  332. data/lib/rex/proto/dcerpc/ndr.rb +73 -0
  333. data/lib/rex/proto/dcerpc/packet.rb +264 -0
  334. data/lib/rex/proto/dcerpc/response.rb +188 -0
  335. data/lib/rex/proto/dcerpc/uuid.rb +85 -0
  336. data/lib/rex/proto/dcerpc/wdscp.rb +3 -0
  337. data/lib/rex/proto/dcerpc/wdscp/constants.rb +89 -0
  338. data/lib/rex/proto/dcerpc/wdscp/packet.rb +94 -0
  339. data/lib/rex/proto/dhcp.rb +7 -0
  340. data/lib/rex/proto/dhcp/constants.rb +34 -0
  341. data/lib/rex/proto/dhcp/server.rb +334 -0
  342. data/lib/rex/proto/drda.rb +6 -0
  343. data/lib/rex/proto/drda/constants.rb +50 -0
  344. data/lib/rex/proto/drda/packet.rb +253 -0
  345. data/lib/rex/proto/drda/utils.rb +124 -0
  346. data/lib/rex/proto/http.rb +7 -0
  347. data/lib/rex/proto/http/client.rb +722 -0
  348. data/lib/rex/proto/http/client_request.rb +472 -0
  349. data/lib/rex/proto/http/handler.rb +47 -0
  350. data/lib/rex/proto/http/handler/erb.rb +129 -0
  351. data/lib/rex/proto/http/handler/proc.rb +61 -0
  352. data/lib/rex/proto/http/header.rb +173 -0
  353. data/lib/rex/proto/http/packet.rb +414 -0
  354. data/lib/rex/proto/http/request.rb +354 -0
  355. data/lib/rex/proto/http/response.rb +151 -0
  356. data/lib/rex/proto/http/server.rb +385 -0
  357. data/lib/rex/proto/iax2.rb +2 -0
  358. data/lib/rex/proto/iax2/call.rb +326 -0
  359. data/lib/rex/proto/iax2/client.rb +218 -0
  360. data/lib/rex/proto/iax2/codecs.rb +5 -0
  361. data/lib/rex/proto/iax2/codecs/alaw.rb +16 -0
  362. data/lib/rex/proto/iax2/codecs/g711.rb +2176 -0
  363. data/lib/rex/proto/iax2/codecs/mulaw.rb +17 -0
  364. data/lib/rex/proto/iax2/constants.rb +262 -0
  365. data/lib/rex/proto/ipmi.rb +57 -0
  366. data/lib/rex/proto/ipmi/channel_auth_reply.rb +89 -0
  367. data/lib/rex/proto/ipmi/open_session_reply.rb +36 -0
  368. data/lib/rex/proto/ipmi/rakp2.rb +36 -0
  369. data/lib/rex/proto/ipmi/utils.rb +125 -0
  370. data/lib/rex/proto/natpmp.rb +7 -0
  371. data/lib/rex/proto/natpmp/constants.rb +19 -0
  372. data/lib/rex/proto/natpmp/packet.rb +45 -0
  373. data/lib/rex/proto/ntlm.rb +8 -0
  374. data/lib/rex/proto/ntlm/base.rb +327 -0
  375. data/lib/rex/proto/ntlm/constants.rb +75 -0
  376. data/lib/rex/proto/ntlm/crypt.rb +412 -0
  377. data/lib/rex/proto/ntlm/exceptions.rb +17 -0
  378. data/lib/rex/proto/ntlm/message.rb +534 -0
  379. data/lib/rex/proto/ntlm/utils.rb +765 -0
  380. data/lib/rex/proto/ntp.rb +3 -0
  381. data/lib/rex/proto/ntp/constants.rb +12 -0
  382. data/lib/rex/proto/ntp/modes.rb +130 -0
  383. data/lib/rex/proto/pjl.rb +31 -0
  384. data/lib/rex/proto/pjl/client.rb +163 -0
  385. data/lib/rex/proto/proxy/socks4a.rb +441 -0
  386. data/lib/rex/proto/rfb.rb +13 -0
  387. data/lib/rex/proto/rfb/cipher.rb +82 -0
  388. data/lib/rex/proto/rfb/client.rb +205 -0
  389. data/lib/rex/proto/rfb/constants.rb +50 -0
  390. data/lib/rex/proto/sip.rb +4 -0
  391. data/lib/rex/proto/sip/response.rb +61 -0
  392. data/lib/rex/proto/smb.rb +8 -0
  393. data/lib/rex/proto/smb/client.rb +2064 -0
  394. data/lib/rex/proto/smb/constants.rb +1064 -0
  395. data/lib/rex/proto/smb/crypt.rb +37 -0
  396. data/lib/rex/proto/smb/evasions.rb +67 -0
  397. data/lib/rex/proto/smb/exceptions.rb +867 -0
  398. data/lib/rex/proto/smb/simpleclient.rb +173 -0
  399. data/lib/rex/proto/smb/simpleclient/open_file.rb +106 -0
  400. data/lib/rex/proto/smb/simpleclient/open_pipe.rb +57 -0
  401. data/lib/rex/proto/smb/utils.rb +104 -0
  402. data/lib/rex/proto/sunrpc.rb +2 -0
  403. data/lib/rex/proto/sunrpc/client.rb +196 -0
  404. data/lib/rex/proto/tftp.rb +13 -0
  405. data/lib/rex/proto/tftp/client.rb +344 -0
  406. data/lib/rex/proto/tftp/constants.rb +39 -0
  407. data/lib/rex/proto/tftp/server.rb +497 -0
  408. data/lib/rex/random_identifier_generator.rb +177 -0
  409. data/lib/rex/registry.rb +14 -0
  410. data/lib/rex/registry/hive.rb +132 -0
  411. data/lib/rex/registry/lfkey.rb +51 -0
  412. data/lib/rex/registry/nodekey.rb +54 -0
  413. data/lib/rex/registry/regf.rb +25 -0
  414. data/lib/rex/registry/valuekey.rb +67 -0
  415. data/lib/rex/registry/valuelist.rb +29 -0
  416. data/lib/rex/ropbuilder.rb +8 -0
  417. data/lib/rex/ropbuilder/rop.rb +271 -0
  418. data/lib/rex/script.rb +42 -0
  419. data/lib/rex/script/base.rb +61 -0
  420. data/lib/rex/script/meterpreter.rb +16 -0
  421. data/lib/rex/script/shell.rb +10 -0
  422. data/lib/rex/service.rb +49 -0
  423. data/lib/rex/service_manager.rb +154 -0
  424. data/lib/rex/services/local_relay.rb +424 -0
  425. data/lib/rex/socket.rb +788 -0
  426. data/lib/rex/socket/comm.rb +120 -0
  427. data/lib/rex/socket/comm/local.rb +526 -0
  428. data/lib/rex/socket/ip.rb +132 -0
  429. data/lib/rex/socket/parameters.rb +363 -0
  430. data/lib/rex/socket/range_walker.rb +470 -0
  431. data/lib/rex/socket/ssl_tcp.rb +345 -0
  432. data/lib/rex/socket/ssl_tcp_server.rb +188 -0
  433. data/lib/rex/socket/subnet_walker.rb +76 -0
  434. data/lib/rex/socket/switch_board.rb +289 -0
  435. data/lib/rex/socket/tcp.rb +79 -0
  436. data/lib/rex/socket/tcp_server.rb +67 -0
  437. data/lib/rex/socket/udp.rb +165 -0
  438. data/lib/rex/sslscan/result.rb +201 -0
  439. data/lib/rex/sslscan/scanner.rb +206 -0
  440. data/lib/rex/struct2.rb +5 -0
  441. data/lib/rex/struct2/c_struct.rb +181 -0
  442. data/lib/rex/struct2/c_struct_template.rb +39 -0
  443. data/lib/rex/struct2/constant.rb +26 -0
  444. data/lib/rex/struct2/element.rb +44 -0
  445. data/lib/rex/struct2/generic.rb +73 -0
  446. data/lib/rex/struct2/restraint.rb +54 -0
  447. data/lib/rex/struct2/s_string.rb +72 -0
  448. data/lib/rex/struct2/s_struct.rb +111 -0
  449. data/lib/rex/sync.rb +6 -0
  450. data/lib/rex/sync/event.rb +85 -0
  451. data/lib/rex/sync/read_write_lock.rb +177 -0
  452. data/lib/rex/sync/ref.rb +58 -0
  453. data/lib/rex/sync/thread_safe.rb +83 -0
  454. data/lib/rex/text.rb +1813 -0
  455. data/lib/rex/thread_factory.rb +43 -0
  456. data/lib/rex/time.rb +66 -0
  457. data/lib/rex/transformer.rb +116 -0
  458. data/lib/rex/ui.rb +22 -0
  459. data/lib/rex/ui/interactive.rb +304 -0
  460. data/lib/rex/ui/output.rb +85 -0
  461. data/lib/rex/ui/output/none.rb +19 -0
  462. data/lib/rex/ui/progress_tracker.rb +97 -0
  463. data/lib/rex/ui/subscriber.rb +160 -0
  464. data/lib/rex/ui/text/color.rb +98 -0
  465. data/lib/rex/ui/text/dispatcher_shell.rb +538 -0
  466. data/lib/rex/ui/text/input.rb +119 -0
  467. data/lib/rex/ui/text/input/buffer.rb +79 -0
  468. data/lib/rex/ui/text/input/readline.rb +129 -0
  469. data/lib/rex/ui/text/input/socket.rb +96 -0
  470. data/lib/rex/ui/text/input/stdio.rb +46 -0
  471. data/lib/rex/ui/text/irb_shell.rb +62 -0
  472. data/lib/rex/ui/text/output.rb +86 -0
  473. data/lib/rex/ui/text/output/buffer.rb +62 -0
  474. data/lib/rex/ui/text/output/buffer/stdout.rb +26 -0
  475. data/lib/rex/ui/text/output/file.rb +44 -0
  476. data/lib/rex/ui/text/output/socket.rb +44 -0
  477. data/lib/rex/ui/text/output/stdio.rb +53 -0
  478. data/lib/rex/ui/text/output/tee.rb +56 -0
  479. data/lib/rex/ui/text/progress_tracker.rb +57 -0
  480. data/lib/rex/ui/text/shell.rb +403 -0
  481. data/lib/rex/ui/text/table.rb +346 -0
  482. data/lib/rex/zip.rb +96 -0
  483. data/lib/rex/zip/archive.rb +130 -0
  484. data/lib/rex/zip/blocks.rb +184 -0
  485. data/lib/rex/zip/entry.rb +122 -0
  486. data/lib/rex/zip/jar.rb +283 -0
  487. data/lib/rex/zip/samples/comment.rb +32 -0
  488. data/lib/rex/zip/samples/mkwar.rb +138 -0
  489. data/lib/rex/zip/samples/mkzip.rb +19 -0
  490. data/lib/rex/zip/samples/recursive.rb +58 -0
  491. metadata +536 -0
@@ -0,0 +1,17 @@
1
+ # -*- coding: binary -*-
2
+ module Rex
3
+ module Proto
4
+ module NTLM
5
+ module Exceptions
6
+
7
+ class NTLMMissingChallenge < ::RuntimeError
8
+ def to_s
9
+ "Unable to complete, no challenge key found"
10
+ end
11
+ end
12
+
13
+ end
14
+ end
15
+ end
16
+ end
17
+
@@ -0,0 +1,534 @@
1
+ # -*- coding: binary -*-
2
+ #
3
+ # An NTLM Authentication Library for Ruby
4
+ #
5
+ # This code is a derivative of "dbf2.rb" written by yrock
6
+ # and Minero Aoki. You can find original code here:
7
+ # http://jp.rubyist.net/magazine/?0013-CodeReview
8
+ # -------------------------------------------------------------
9
+ # Copyright (c) 2005,2006 yrock
10
+ #
11
+ # This program is free software.
12
+ # You can distribute/modify this program under the terms of the
13
+ # Ruby License.
14
+ #
15
+ # 2011-02-23 refactored by Alexandre Maloteaux for Metasploit Project
16
+ # -------------------------------------------------------------
17
+ #
18
+ # 2006-02-11 refactored by Minero Aoki
19
+ # -------------------------------------------------------------
20
+ #
21
+ # All protocol information used to write this code stems from
22
+ # "The NTLM Authentication Protocol" by Eric Glass. The author
23
+ # would thank to him for this tremendous work and making it
24
+ # available on the net.
25
+ # http://davenport.sourceforge.net/ntlm.html
26
+ # -------------------------------------------------------------
27
+ # Copyright (c) 2003 Eric Glass
28
+ #
29
+ # Permission to use, copy, modify, and distribute this document
30
+ # for any purpose and without any fee is hereby granted,
31
+ # provided that the above copyright notice and this list of
32
+ # conditions appear in all copies.
33
+ # -------------------------------------------------------------
34
+ #
35
+ # The author also looked Mozilla-Firefox-1.0.7 source code,
36
+ # namely, security/manager/ssl/src/nsNTLMAuthModule.cpp and
37
+ # Jonathan Bastien-Filiatrault's libntlm-ruby.
38
+ # "http://x2a.org/websvn/filedetails.php?
39
+ # repname=libntlm-ruby&path=%2Ftrunk%2Fntlm.rb&sc=1"
40
+ # The latter has a minor bug in its separate_keys function.
41
+ # The third key has to begin from the 14th character of the
42
+ # input string instead of 13th:)
43
+
44
+ #this module defines the message class , useful for easily handling type 1/2/3 ntlm messages
45
+
46
+ require 'rex/proto/ntlm/base'
47
+ require 'rex/proto/ntlm/constants'
48
+ require 'rex/proto/ntlm/crypt'
49
+
50
+
51
+ module Rex
52
+ module Proto
53
+ module NTLM
54
+ class Message < Rex::Proto::NTLM::Base::FieldSet
55
+
56
+ BASE = Rex::Proto::NTLM::Base
57
+ CONST = Rex::Proto::NTLM::Constants
58
+ CRYPT = Rex::Proto::NTLM::Crypt
59
+
60
+
61
+ class << Message
62
+ def parse(str)
63
+ m = Type0.new
64
+ m.parse(str)
65
+ case m.type
66
+ when 1
67
+ t = Type1.parse(str)
68
+ when 2
69
+ t = Type2.parse(str)
70
+ when 3
71
+ t = Type3.parse(str)
72
+ else
73
+ raise ArgumentError, "unknown type: #{m.type}"
74
+ end
75
+ t
76
+ end
77
+
78
+ def decode64(str)
79
+ parse(Rex::Text::decode_base64(str))
80
+ end
81
+ end#self
82
+
83
+ def has_flag?(flag)
84
+ (self[:flag].value & CONST::FLAGS[flag]) == CONST::FLAGS[flag]
85
+ end
86
+
87
+ def set_flag(flag)
88
+ self[:flag].value |= CONST::FLAGS[flag]
89
+ end
90
+
91
+ def dump_flags
92
+ CONST::FLAG_KEYS.each{ |k| print(k, "=", flag?(k), "\n") }
93
+ end
94
+
95
+ def serialize
96
+ deflag
97
+ super + security_buffers.map{|n, f| f.value}.join
98
+ end
99
+
100
+ def encode64
101
+ Rex::Text::encode_base64(serialize)
102
+ end
103
+
104
+ def decode64(str)
105
+ parse(Rex::Text::decode_base64(str))
106
+ end
107
+
108
+ alias head_size size
109
+
110
+ def data_size
111
+ security_buffers.inject(0){|sum, a| sum += a[1].data_size}
112
+ end
113
+
114
+ def size
115
+ head_size + data_size
116
+ end
117
+
118
+ private
119
+
120
+ def security_buffers
121
+ @alist.find_all{|n, f| f.instance_of?(BASE::SecurityBuffer)}
122
+ end
123
+
124
+ def deflag
125
+ security_buffers.inject(head_size){|cur, a|
126
+ a[1].offset = cur
127
+ cur += a[1].data_size
128
+ }
129
+ end
130
+
131
+ def data_edge
132
+ security_buffers.map{ |n, f| f.active ? f.offset : size}.min
133
+ end
134
+
135
+ # sub class definitions
136
+
137
+ Type0 = Message.define {
138
+ string :sign, {:size => 8, :value => CONST::SSP_SIGN}
139
+ int32LE :type, {:value => 0}
140
+ }
141
+
142
+ Type1 = Message.define {
143
+ string :sign, {:size => 8, :value => CONST::SSP_SIGN}
144
+ int32LE :type, {:value => 1}
145
+ int32LE :flag, {:value => CONST::DEFAULT_FLAGS[:TYPE1] }
146
+ security_buffer :domain, {:value => "", :active => false}
147
+ security_buffer :workstation, {:value => "", :active => false}
148
+ string :padding, {:size => 0, :value => "", :active => false }
149
+ }
150
+
151
+ class Type1
152
+ class << Type1
153
+ def parse(str)
154
+ t = new
155
+ t.parse(str)
156
+ t
157
+ end
158
+ end
159
+
160
+ def parse(str)
161
+ super(str)
162
+ enable(:domain) if has_flag?(:DOMAIN_SUPPLIED)
163
+ enable(:workstation) if has_flag?(:WORKSTATION_SUPPLIED)
164
+ super(str)
165
+ if ( (len = data_edge - head_size) > 0)
166
+ self.padding = "\0" * len
167
+ super(str)
168
+ end
169
+ end
170
+ end
171
+
172
+ Type2 = Message.define{
173
+ string :sign, {:size => 8, :value => CONST::SSP_SIGN}
174
+ int32LE :type, {:value => 2}
175
+ security_buffer :target_name, {:size => 0, :value => ""}
176
+ int32LE :flag, {:value => CONST::DEFAULT_FLAGS[:TYPE2]}
177
+ int64LE :challenge, {:value => 0}
178
+ int64LE :context, {:value => 0, :active => false}
179
+ security_buffer :target_info, {:value => "", :active => false}
180
+ string :padding, {:size => 0, :value => "", :active => false }
181
+ }
182
+
183
+ class Type2
184
+ class << Type2
185
+ def parse(str)
186
+ t = new
187
+ t.parse(str)
188
+ t
189
+ end
190
+ end
191
+
192
+ def parse(str)
193
+ super(str)
194
+ if has_flag?(:TARGET_INFO)
195
+ enable(:context)
196
+ enable(:target_info)
197
+ super(str)
198
+ end
199
+ if ( (len = data_edge - head_size) > 0)
200
+ self.padding = "\0" * len
201
+ super(str)
202
+ end
203
+ end
204
+ #create a type 3 response base on a type2
205
+ # This mehod is not compatible with windows 7 / 2008 r2
206
+ # to make it compatible avpair Time and SPN must be handle as in utils
207
+ def response(arg, opt = {})
208
+ usr = arg[:user]
209
+ pwd = arg[:password]
210
+ if usr.nil? or pwd.nil?
211
+ raise ArgumentError, "user and password have to be supplied"
212
+ end
213
+
214
+ if opt[:workstation]
215
+ ws = opt[:workstation]
216
+ else
217
+ ws = ""
218
+ end
219
+
220
+ if opt[:client_challenge]
221
+ cc = opt[:client_challenge]
222
+ else
223
+ cc = rand(CONST::MAX64)
224
+ end
225
+ cc = Rex::Text::pack_int64le(cc) if cc.is_a?(Integer)
226
+ opt[:client_challenge] = cc
227
+
228
+ if has_flag?(:OEM) and opt[:unicode]
229
+ usr = Rex::Text::to_ascii(usr,'utf-16le')
230
+ pwd = Rex::Text::to_ascii(pwd,'utf-16le')
231
+ ws = Rex::Text::to_ascii(ws,'utf-16le')
232
+ opt[:unicode] = false
233
+ end
234
+
235
+ if has_flag?(:UNICODE) and !opt[:unicode]
236
+ usr = Rex::Text::to_unicode(usr,'utf-16le')
237
+ pwd = Rex::Text::to_unicode(pwd,'utf-16le')
238
+ ws = Rex::Text::to_unicode(ws,'utf-16le')
239
+ opt[:unicode] = true
240
+ end
241
+
242
+ tgt = self.target_name
243
+ ti = self.target_info
244
+
245
+ chal = self[:challenge].serialize
246
+
247
+ if opt[:ntlmv2]
248
+ ar = { :ntlmv2_hash => CRYPT::ntlmv2_hash(usr, pwd, tgt, opt),
249
+ :challenge => chal, :target_info => ti}
250
+ lm_res = CRYPT::lmv2_response(ar, opt)
251
+ ntlm_res = CRYPT::ntlmv2_response(ar, opt)
252
+ elsif has_flag?(:NTLM2_KEY)
253
+ ar = {:ntlm_hash => CRYPT::ntlm_hash(pwd, opt), :challenge => chal}
254
+ lm_res, ntlm_res = CRYPT::ntlm2_session(ar, opt)
255
+ else
256
+ lm_res = CRYPT::lm_response(pwd, chal)
257
+ ntlm_res = CRYPT::ntlm_response(pwd, chal)
258
+ end
259
+
260
+ Type3.create({
261
+ :lm_response => lm_res,
262
+ :ntlm_response => ntlm_res,
263
+ :domain => tgt,
264
+ :user => usr,
265
+ :workstation => ws,
266
+ :flag => self.flag
267
+ })
268
+ end
269
+ end
270
+
271
+
272
+ Type3 = Message.define{
273
+ string :sign, {:size => 8, :value => CONST::SSP_SIGN}
274
+ int32LE :type, {:value => 3}
275
+ security_buffer :lm_response, {:value => ""}
276
+ security_buffer :ntlm_response, {:value => ""}
277
+ security_buffer :domain, {:value => ""}
278
+ security_buffer :user, {:value => ""}
279
+ security_buffer :workstation, {:value => ""}
280
+ security_buffer :session_key, {:value => "", :active => false }
281
+ int64LE :flag, {:value => 0, :active => false }
282
+ }
283
+
284
+ class Type3
285
+ class << Type3
286
+ def parse(str)
287
+ t = new
288
+ t.parse(str)
289
+ t
290
+ end
291
+
292
+ def create(arg, opt ={})
293
+ t = new
294
+ t.lm_response = arg[:lm_response]
295
+ t.ntlm_response = arg[:ntlm_response]
296
+ t.domain = arg[:domain]
297
+ t.user = arg[:user]
298
+ t.workstation = arg[:workstation]
299
+
300
+ if arg[:session_key]
301
+ t.enable(:session_key)
302
+ t.session_key = arg[session_key]
303
+ end
304
+ if arg[:flag]
305
+ t.enable(:session_key)
306
+ t.enable(:flag)
307
+ t.flag = arg[:flag]
308
+ end
309
+ t
310
+ end
311
+ end#self
312
+ end
313
+
314
+ public
315
+ #those class method have been merged from lib/rex/smb/utils
316
+
317
+ #
318
+ # Process Type 3 NTLM Message (in Base64)
319
+ #
320
+ # from http://www.innovation.ch/personal/ronald/ntlm.html
321
+ #
322
+ # struct {
323
+ # byte protocol[8]; // 'N', 'T', 'L', 'M', 'S', 'S', 'P', '\0'
324
+ # byte type; // 0x03
325
+ # byte zero[3];
326
+ #
327
+ # short lm_resp_len; // LanManager response length (always 0x18)
328
+ # short lm_resp_len; // LanManager response length (always 0x18)
329
+ # short lm_resp_off; // LanManager response offset
330
+ # byte zero[2];
331
+ #
332
+ # short nt_resp_len; // NT response length (always 0x18)
333
+ # short nt_resp_len; // NT response length (always 0x18)
334
+ # short nt_resp_off; // NT response offset
335
+ # byte zero[2];
336
+ #
337
+ # short dom_len; // domain string length
338
+ # short dom_len; // domain string length
339
+ # short dom_off; // domain string offset (always 0x40)
340
+ # byte zero[2];
341
+ #
342
+ # short user_len; // username string length
343
+ # short user_len; // username string length
344
+ # short user_off; // username string offset
345
+ # byte zero[2];
346
+ #
347
+ # short host_len; // host string length
348
+ # short host_len; // host string length
349
+ # short host_off; // host string offset
350
+ # byte zero[6];
351
+ #
352
+ # short msg_len; // message length
353
+ # byte zero[2];
354
+ #
355
+ # short flags; // 0x8201
356
+ # byte zero[2];
357
+ #
358
+ # byte dom[*]; // domain string (unicode UTF-16LE)
359
+ # byte user[*]; // username string (unicode UTF-16LE)
360
+ # byte host[*]; // host string (unicode UTF-16LE)
361
+ # byte lm_resp[*]; // LanManager response
362
+ # byte nt_resp[*]; // NT response
363
+ # } type_3_message
364
+ #
365
+ def self.process_type3_message(message)
366
+ decode = Rex::Text.decode_base64(message.strip)
367
+ type = decode[8,1].unpack("C").first
368
+ if (type == 3)
369
+ lm_len = decode[12,2].unpack("v").first
370
+ lm_offset = decode[16,2].unpack("v").first
371
+ lm = decode[lm_offset, lm_len].unpack("H*").first
372
+
373
+ nt_len = decode[20,2].unpack("v").first
374
+ nt_offset = decode[24,2].unpack("v").first
375
+ nt = decode[nt_offset, nt_len].unpack("H*").first
376
+
377
+ dom_len = decode[28,2].unpack("v").first
378
+ dom_offset = decode[32,2].unpack("v").first
379
+ domain = decode[dom_offset, dom_len]
380
+
381
+ user_len = decode[36,2].unpack("v").first
382
+ user_offset = decode[40,2].unpack("v").first
383
+ user = decode[user_offset, user_len]
384
+
385
+ host_len = decode[44,2].unpack("v").first
386
+ host_offset = decode[48,2].unpack("v").first
387
+ host = decode[host_offset, host_len]
388
+
389
+ return domain, user, host, lm, nt
390
+ else
391
+ return "", "", "", "", ""
392
+ end
393
+ end
394
+
395
+
396
+
397
+ #
398
+ # Process Type 1 NTLM Messages, return a Base64 Type 2 Message
399
+ #
400
+ def self.process_type1_message(message, nonce = "\x11\x22\x33\x44\x55\x66\x77\x88", win_domain = 'DOMAIN',
401
+ win_name = 'SERVER', dns_name = 'server', dns_domain = 'example.com', downgrade = true)
402
+
403
+ dns_name = Rex::Text.to_unicode(dns_name + "." + dns_domain)
404
+ win_domain = Rex::Text.to_unicode(win_domain)
405
+ dns_domain = Rex::Text.to_unicode(dns_domain)
406
+ win_name = Rex::Text.to_unicode(win_name)
407
+ decode = Rex::Text.decode_base64(message.strip)
408
+
409
+ type = decode[8,1].unpack("C").first
410
+
411
+ if (type == 1)
412
+ # A type 1 message has been received, lets build a type 2 message response
413
+
414
+ reqflags = decode[12,4]
415
+ reqflags = reqflags.unpack("V").first
416
+
417
+ if (reqflags & CONST::REQUEST_TARGET) == CONST::REQUEST_TARGET
418
+
419
+ if (downgrade)
420
+ # At this time NTLMv2 and signing requirements are not supported
421
+ if (reqflags & CONST::NEGOTIATE_NTLM2_KEY) == CONST::NEGOTIATE_NTLM2_KEY
422
+ reqflags = reqflags - CONST::NEGOTIATE_NTLM2_KEY
423
+ end
424
+ if (reqflags & CONST::NEGOTIATE_ALWAYS_SIGN) == CONST::NEGOTIATE_ALWAYS_SIGN
425
+ reqflags = reqflags - CONST::NEGOTIATE_ALWAYS_SIGN
426
+ end
427
+ end
428
+
429
+ flags = reqflags + CONST::TARGET_TYPE_DOMAIN + CONST::TARGET_TYPE_SERVER
430
+ tid = true
431
+
432
+ tidoffset = 48 + win_domain.length
433
+ tidbuff =
434
+ [2].pack('v') + # tid type, win domain
435
+ [win_domain.length].pack('v') +
436
+ win_domain +
437
+ [1].pack('v') + # tid type, server name
438
+ [win_name.length].pack('v') +
439
+ win_name +
440
+ [4].pack('v') + # tid type, domain name
441
+ [dns_domain.length].pack('v') +
442
+ dns_domain +
443
+ [3].pack('v') + # tid type, dns_name
444
+ [dns_name.length].pack('v') +
445
+ dns_name
446
+ else
447
+ flags = CONST::NEGOTIATE_UNICODE + CONST::NEGOTIATE_NTLM
448
+ tid = false
449
+ end
450
+
451
+ type2msg = "NTLMSSP\0" + # protocol, 8 bytes
452
+ "\x02\x00\x00\x00" # type, 4 bytes
453
+
454
+ if (tid)
455
+ type2msg += # Target security info, 8 bytes. Filled if REQUEST_TARGET
456
+ [win_domain.length].pack('v') + # Length, 2 bytes
457
+ [win_domain.length].pack('v') # Allocated space, 2 bytes
458
+ end
459
+
460
+ type2msg +="\x30\x00\x00\x00" + # Offset, 4 bytes
461
+ [flags].pack('V') + # flags, 4 bytes
462
+ nonce + # the nonce, 8 bytes
463
+ "\x00" * 8 # Context (all 0s), 8 bytes
464
+
465
+ if (tid)
466
+ type2msg += # Target information security buffer. Filled if REQUEST_TARGET
467
+ [tidbuff.length].pack('v') + # Length, 2 bytes
468
+ [tidbuff.length].pack('v') + # Allocated space, 2 bytes
469
+ [tidoffset].pack('V') + # Offset, 4 bytes (usually \x48 + length of win_domain)
470
+ win_domain + # Target name data (domain in unicode if REQUEST_UNICODE)
471
+ # Target information data
472
+ tidbuff + # Type, 2 bytes
473
+ # Length, 2 bytes
474
+ # Data (in unicode if REQUEST_UNICODE)
475
+ "\x00\x00\x00\x00" # Terminator, 4 bytes, all \x00
476
+ end
477
+
478
+ type2msg = Rex::Text.encode_base64(type2msg).delete("\n") # base64 encode and remove the returns
479
+ else
480
+ # This is not a Type2 message
481
+ type2msg = ""
482
+ end
483
+
484
+ return type2msg
485
+ end
486
+
487
+ #
488
+ # Downgrading Type messages to LMv1/NTLMv1 and removing signing
489
+ #
490
+ def self.downgrade_type_message(message)
491
+ decode = Rex::Text.decode_base64(message.strip)
492
+
493
+ type = decode[8,1].unpack("C").first
494
+
495
+ if (type > 0 and type < 4)
496
+ reqflags = decode[12..15] if (type == 1 or type == 3)
497
+ reqflags = decode[20..23] if (type == 2)
498
+ reqflags = reqflags.unpack("V")
499
+
500
+ # Remove NEGOTIATE_NTLMV2_KEY and NEGOTIATE_ALWAYS_SIGN, this lowers the negotiation
501
+ # down to LMv1/NTLMv1.
502
+ if (reqflags & CONST::NEGOTIATE_NTLM2_KEY) == CONST::NEGOTIATE_NTLM2_KEY
503
+ reqflags = reqflags - CONST::NEGOTIATE_NTLM2_KEY
504
+ end
505
+ if (reqflags & CONST::NEGOTIATE_ALWAYS_SIGN) == CONST::NEGOTIATE_ALWAYS_SIGN
506
+ reqflags = reqflags - CONST::NEGOTIATE_ALWAYS_SIGN
507
+ end
508
+
509
+ # Return the flags back to the decode so we can base64 it again
510
+ flags = reqflags.to_s(16)
511
+ 0.upto(8) do |idx|
512
+ if (idx > flags.length)
513
+ flags.insert(0, "0")
514
+ end
515
+ end
516
+
517
+ idx = 0
518
+ 0.upto(3) do |cnt|
519
+ if (type == 2)
520
+ decode[23-cnt] = [flags[idx,1]].pack("C")
521
+ else
522
+ decode[15-cnt] = [flags[idx,1]].pack("C")
523
+ end
524
+ idx += 2
525
+ end
526
+
527
+ end
528
+ return Rex::Text.encode_base64(decode).delete("\n") # base64 encode and remove the returns
529
+ end
530
+
531
+ end
532
+ end
533
+ end
534
+ end