librex 0.0.68 → 0.0.70

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