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
@@ -8,754 +8,754 @@ module Proto
8
8
  module NTLM
9
9
  class Utils
10
10
 
11
- CONST = Rex::Proto::NTLM::Constants
12
- CRYPT = Rex::Proto::NTLM::Crypt
13
- XCEPT = Rex::Proto::NTLM::Exceptions
11
+ CONST = Rex::Proto::NTLM::Constants
12
+ CRYPT = Rex::Proto::NTLM::Crypt
13
+ XCEPT = Rex::Proto::NTLM::Exceptions
14
14
 
15
15
  #duplicate from lib/rex/proto/smb/utils cause we only need this fonction from Rex::Proto::SMB::Utils
16
- # Convert a unix timestamp to a 64-bit signed server time
17
- def self.time_unix_to_smb(unix_time)
18
- t64 = (unix_time + 11644473600) * 10000000
19
- thi = (t64 & 0xffffffff00000000) >> 32
20
- tlo = (t64 & 0x00000000ffffffff)
21
- return [thi, tlo]
22
- end
23
-
24
- # Determine whether the password is a known hash format
25
- def self.is_pass_ntlm_hash?(str)
26
- str.downcase =~ /^[0-9a-f]{32}:[0-9a-f]{32}$/
27
- end
28
-
29
- #
30
- # Prepends an ASN1 formatted length field to a piece of data
31
- #
32
- def self.asn1encode(str = '')
33
- res = ''
34
-
35
- # If the high bit of the first byte is 1, it contains the number of
36
- # length bytes that follow
37
-
38
- case str.length
39
- when 0 .. 0x7F
40
- res = [str.length].pack('C') + str
41
- when 0x80 .. 0xFF
42
- res = [0x81, str.length].pack('CC') + str
43
- when 0x100 .. 0xFFFF
44
- res = [0x82, str.length].pack('Cn') + str
45
- when 0x10000 .. 0xffffff
46
- res = [0x83, str.length >> 16, str.length & 0xFFFF].pack('CCn') + str
47
- when 0x1000000 .. 0xffffffff
48
- res = [0x84, str.length].pack('CN') + str
49
- else
50
- raise "ASN1 str too long"
51
- end
52
- return res
53
- end
54
-
55
- # GSS functions
56
-
57
- # GSS BLOB usefull for SMB_NEGOCIATE_RESPONSE message
58
- # mechTypes: 2 items :
59
- # -MechType: 1.3.6.1.4.1.311.2.2.30 (SNMPv2-SMI::enterprises.311.2.2.30)
60
- # -MechType: 1.3.6.1.4.1.311.2.2.10 (NTLMSSP - Microsoft NTLM Security Support Provider)
61
- #
62
- # this is the default on Win7
63
- def self.make_simple_negotiate_secblob_resp
64
- blob =
65
- "\x60" + self.asn1encode(
66
- "\x06" + self.asn1encode(
67
- "\x2b\x06\x01\x05\x05\x02"
68
- ) +
69
- "\xa0" + self.asn1encode(
70
- "\x30" + self.asn1encode(
71
- "\xa0" + self.asn1encode(
72
- "\x30" + self.asn1encode(
73
- "\x06" + self.asn1encode(
74
- "\x2b\x06\x01\x04\x01\x82\x37\x02\x02\x0a"
75
- )
76
- )
77
- )
78
- )
79
- )
80
- )
81
-
82
- return blob
83
- end
84
-
85
- # GSS BLOB usefull for SMB_NEGOCIATE_RESPONSE message
86
- # mechTypes: 4 items :
87
- # MechType: 1.2.840.48018.1.2.2 (MS KRB5 - Microsoft Kerberos 5)
88
- # MechType: 1.2.840.113554.1.2.2 (KRB5 - Kerberos 5)
89
- # MechType: 1.2.840.113554.1.2.2.3 (KRB5 - Kerberos 5 - User to User)
90
- # MechType: 1.3.6.1.4.1.311.2.2.10 (NTLMSSP - Microsoft NTLM Security Support Provider)
91
- # mechListMIC:
92
- # principal: account@domain
93
- def self.make_negotiate_secblob_resp(account, domain)
94
- blob =
95
- "\x60" + self.asn1encode(
96
- "\x06" + self.asn1encode(
97
- "\x2b\x06\x01\x05\x05\x02"
98
- ) +
99
- "\xa0" + self.asn1encode(
100
- "\x30" + self.asn1encode(
101
- "\xa0" + self.asn1encode(
102
- "\x30" + self.asn1encode(
103
- "\x06" + self.asn1encode(
104
- "\x2a\x86\x48\x82\xf7\x12\x01\x02\x02"
105
- ) +
106
- "\x06" + self.asn1encode(
107
- "\x2a\x86\x48\x86\xf7\x12\x01\x02\x02"
108
- ) +
109
- "\x06" + self.asn1encode(
110
- "\x2a\x86\x48\x86\xf7\x12\x01\x02\x02\x03"
111
- ) +
112
- "\x06" + self.asn1encode(
113
- "\x2b\x06\x01\x04\x01\x82\x37\x02\x02\x0a"
114
- )
115
- )
116
- ) +
117
- "\xa3" + self.asn1encode(
118
- "\x30" + self.asn1encode(
119
- "\xa0" + self.asn1encode(
120
- "\x1b" + self.asn1encode(
121
- account + '@' + domain
122
- )
123
- )
124
- )
125
- )
126
- )
127
- )
128
- )
129
-
130
- return blob
131
- end
132
-
133
- # BLOB without GSS usefull for ntlmssp type 1 message
134
- def self.make_ntlmssp_blob_init(domain = 'WORKGROUP', name = 'WORKSTATION', flags=0x80201)
135
- blob = "NTLMSSP\x00" +
136
- [1, flags].pack('VV') +
137
-
138
- [
139
- domain.length, #length
140
- domain.length, #max length
141
- 32
142
- ].pack('vvV') +
143
-
144
- [
145
- name.length, #length
146
- name.length, #max length
147
- domain.length + 32
148
- ].pack('vvV') +
149
-
150
- domain + name
151
- return blob
152
- end
153
-
154
- # GSS BLOB usefull for ntlmssp type 1 message
155
- def self.make_ntlmssp_secblob_init(domain = 'WORKGROUP', name = 'WORKSTATION', flags=0x80201)
156
- blob =
157
- "\x60" + self.asn1encode(
158
- "\x06" + self.asn1encode(
159
- "\x2b\x06\x01\x05\x05\x02"
160
- ) +
161
- "\xa0" + self.asn1encode(
162
- "\x30" + self.asn1encode(
163
- "\xa0" + self.asn1encode(
164
- "\x30" + self.asn1encode(
165
- "\x06" + self.asn1encode(
166
- "\x2b\x06\x01\x04\x01\x82\x37\x02\x02\x0a"
167
- )
168
- )
169
- ) +
170
- "\xa2" + self.asn1encode(
171
- "\x04" + self.asn1encode(
172
- make_ntlmssp_blob_init(domain, name, flags)
173
- )
174
- )
175
- )
176
- )
177
- )
178
-
179
- return blob
180
- end
181
-
182
-
183
- # BLOB without GSS usefull for ntlm type 2 message
184
- def self.make_ntlmssp_blob_chall(win_domain, win_name, dns_domain, dns_name, chall, flags)
185
-
186
- addr_list = ''
187
- addr_list << [2, win_domain.length].pack('vv') + win_domain
188
- addr_list << [1, win_name.length].pack('vv') + win_name
189
- addr_list << [4, dns_domain.length].pack('vv') + dns_domain
190
- addr_list << [3, dns_name.length].pack('vv') + dns_name
191
- addr_list << [0, 0].pack('vv')
192
-
193
- ptr = 0
194
- blob = "NTLMSSP\x00" +
195
- [2].pack('V') +
196
- [
197
- win_domain.length, # length
198
- win_domain.length, # max length
199
- (ptr += 48) # offset
200
- ].pack('vvV') +
201
- [ flags ].pack('V') +
202
- chall +
203
- "\x00\x00\x00\x00\x00\x00\x00\x00" +
204
- [
205
- addr_list.length, # length
206
- addr_list.length, # max length
207
- (ptr += win_domain.length)
208
- ].pack('vvV') +
209
- win_domain +
210
- addr_list
211
- return blob
212
- end
213
-
214
- # GSS BLOB usefull for ntlmssp type 2 message
215
- def self.make_ntlmssp_secblob_chall(win_domain, win_name, dns_domain, dns_name, chall, flags)
216
-
217
- blob =
218
- "\xa1" + self.asn1encode(
219
- "\x30" + self.asn1encode(
220
- "\xa0" + self.asn1encode(
221
- "\x0a" + self.asn1encode(
222
- "\x01"
223
- )
224
- ) +
225
- "\xa1" + self.asn1encode(
226
- "\x06" + self.asn1encode(
227
- "\x2b\x06\x01\x04\x01\x82\x37\x02\x02\x0a"
228
- )
229
- ) +
230
- "\xa2" + self.asn1encode(
231
- "\x04" + self.asn1encode(
232
- make_ntlmssp_blob_chall(win_domain, win_name, dns_domain, dns_name, chall, flags)
233
- )
234
- )
235
- )
236
- )
237
-
238
- return blob
239
- end
240
-
241
- # BLOB without GSS Usefull for ntlmssp type 3 message
242
- def self.make_ntlmssp_blob_auth(domain, name, user, lm, ntlm, enc_session_key, flags = 0x080201)
243
- lm ||= "\x00" * 24
244
- ntlm ||= "\x00" * 24
245
-
246
- domain_uni = Rex::Text.to_unicode(domain)
247
- user_uni = Rex::Text.to_unicode(user)
248
- name_uni = Rex::Text.to_unicode(name)
249
- session = enc_session_key
250
-
251
- ptr = 64
252
-
253
- blob = "NTLMSSP\x00" +
254
- [ 3 ].pack('V') +
255
-
256
- [ # Lan Manager Response
257
- lm.length,
258
- lm.length,
259
- (ptr)
260
- ].pack('vvV') +
261
-
262
- [ # NTLM Manager Response
263
- ntlm.length,
264
- ntlm.length,
265
- (ptr += lm.length)
266
- ].pack('vvV') +
267
-
268
- [ # Domain Name
269
- domain_uni.length,
270
- domain_uni.length,
271
- (ptr += ntlm.length)
272
- ].pack('vvV') +
273
-
274
- [ # Username
275
- user_uni.length,
276
- user_uni.length,
277
- (ptr += domain_uni.length)
278
- ].pack('vvV') +
279
-
280
- [ # Hostname
281
- name_uni.length,
282
- name_uni.length,
283
- (ptr += user_uni.length)
284
- ].pack('vvV') +
285
-
286
- [ # Session Key (none)
287
- session.length,
288
- session.length,
289
- (ptr += name_uni.length)
290
- ].pack('vvV') +
291
-
292
- [ flags ].pack('V') +
293
-
294
- lm +
295
- ntlm +
296
- domain_uni +
297
- user_uni +
298
- name_uni +
299
- session + "\x00"
300
- return blob
301
-
302
- end
303
-
304
- # GSS BLOB Usefull for ntlmssp type 3 message
305
- def self.make_ntlmssp_secblob_auth(domain, name, user, lm, ntlm, enc_session_key, flags = 0x080201)
306
-
307
- blob =
308
- "\xa1" + self.asn1encode(
309
- "\x30" + self.asn1encode(
310
- "\xa2" + self.asn1encode(
311
- "\x04" + self.asn1encode(
312
- make_ntlmssp_blob_auth(domain, name, user, lm, ntlm, enc_session_key, flags )
313
- )
314
- )
315
- )
316
- )
317
- return blob
318
- end
319
-
320
-
321
- # GSS BLOB Usefull for SMB Success
322
- def self.make_ntlmv2_secblob_success
323
- blob =
324
- "\xa1" + self.asn1encode(
325
- "\x30" + self.asn1encode(
326
- "\xa0" + self.asn1encode(
327
- "\x0a" + self.asn1encode(
328
- "\x00"
329
- )
330
- )
331
- )
332
- )
333
- return blob
334
- end
335
-
336
- # Return the correct ntlmflags upon the configuration
337
- def self.make_ntlm_flags(opt = {})
338
-
339
- signing = opt[:signing] != nil ? opt[:signing] : false
340
- usentlm2_session = opt[:usentlm2_session] != nil ? opt[:usentlm2_session] : true
341
- use_ntlmv2 = opt[:use_ntlmv2] != nil ? opt[:use_ntlmv2] : false
342
- send_lm = opt[:send_lm] != nil ? opt[:send_lm] : true
343
- send_ntlm = opt[:send_ntlm] != nil ? opt[:send_ntlm] : true
344
- use_lanman_key = opt[:use_lanman_key] != nil ? opt[:use_lanman_key] : false
345
-
346
- if signing
347
- ntlmssp_flags = 0xe2088215
348
- else
349
-
350
- ntlmssp_flags = 0xa2080205
351
- end
352
-
353
- if usentlm2_session
354
- if use_ntlmv2
355
- #set Negotiate Target Info
356
- ntlmssp_flags |= CONST::NEGOTIATE_TARGET_INFO
357
- end
358
-
359
- else
360
- #remove the ntlm2_session flag
361
- ntlmssp_flags &= 0xfff7ffff
362
- #set lanmanflag only when lm and ntlm are sent
363
- if send_lm
364
- ntlmssp_flags |= CONST::NEGOTIATE_LMKEY if use_lanman_key
365
- end
366
- end
367
-
368
- #we can also downgrade ntlm2_session when we send only lmv1
369
- ntlmssp_flags &= 0xfff7ffff if usentlm2_session && (not use_ntlmv2) && (not send_ntlm)
370
-
371
- return ntlmssp_flags
372
- end
373
-
374
-
375
- # Parse an ntlm type 2 challenge blob and return usefull data
376
- def self.parse_ntlm_type_2_blob(blob)
377
- data = {}
378
- # Extract the NTLM challenge key the lazy way
379
- cidx = blob.index("NTLMSSP\x00\x02\x00\x00\x00")
380
-
381
- if not cidx
382
- raise XCEPT::NTLMMissingChallenge
383
- end
384
-
385
- data[:challenge_key] = blob[cidx + 24, 8]
386
-
387
- data[:server_ntlmssp_flags] = blob[cidx + 20, 4].unpack("V")[0]
388
-
389
- # Extract the address list from the blob
390
- alist_len,alist_mlen,alist_off = blob[cidx + 40, 8].unpack("vvV")
391
- alist_buf = blob[cidx + alist_off, alist_len]
392
-
393
- while(alist_buf.length > 0)
394
- atype, alen = alist_buf.slice!(0,4).unpack('vv')
395
- break if atype == 0x00
396
- addr = alist_buf.slice!(0, alen)
397
- case atype
398
- when 1
399
- #netbios name
400
- data[:default_name] = addr.gsub("\x00", '')
401
- when 2
402
- #netbios domain
403
- data[:default_domain] = addr.gsub("\x00", '')
404
- when 3
405
- #dns name
406
- data[:dns_host_name] = addr.gsub("\x00", '')
407
- when 4
408
- #dns domain
409
- data[:dns_domain_name] = addr.gsub("\x00", '')
410
- when 5
411
- #The FQDN of the forest.
412
- when 6
413
- #A 32-bit value indicating server or client configuration
414
- when 7
415
- #Client time
416
- data[:chall_MsvAvTimestamp] = addr
417
- when 8
418
- #A Restriction_Encoding structure
419
- when 9
420
- #The SPN of the target server.
421
- when 10
422
- #A channel bindings hash.
423
- end
424
- end
425
- return data
426
- end
427
-
428
- # This function return an ntlmv2 client challenge
429
- # This is a partial implementation, full description is in [MS-NLMP].pdf around 3.1.5.2.1 :-/
430
- def self.make_ntlmv2_clientchallenge(win_domain, win_name, dns_domain, dns_name,
431
- client_challenge = nil, chall_MsvAvTimestamp = nil, spnopt = {})
432
-
433
- client_challenge ||= Rex::Text.rand_text(8)
434
- # We have to set the timestamps here to the one in the challenge message from server if present
435
- # If we don't do that, recent server like Seven/2008 will send a STATUS_INVALID_PARAMETER error packet
436
- timestamp = chall_MsvAvTimestamp != '' ? chall_MsvAvTimestamp : self.time_unix_to_smb(Time.now.to_i).reverse.pack("VV")
437
- # Make those values unicode as requested
438
- win_domain = Rex::Text.to_unicode(win_domain)
439
- win_name = Rex::Text.to_unicode(win_name)
440
- dns_domain = Rex::Text.to_unicode(dns_domain)
441
- dns_name = Rex::Text.to_unicode(dns_name)
442
- # Make the AV_PAIRs
443
- addr_list = ''
444
- addr_list << [2, win_domain.length].pack('vv') + win_domain
445
- addr_list << [1, win_name.length].pack('vv') + win_name
446
- addr_list << [4, dns_domain.length].pack('vv') + dns_domain
447
- addr_list << [3, dns_name.length].pack('vv') + dns_name
448
- addr_list << [7, 8].pack('vv') + timestamp
449
-
450
- # Windows Seven / 2008r2 Request this type if in local security policies,
451
- # Microsoft network server : Server SPN target name validation level is set to <Required from client>
452
- # otherwise it send an STATUS_ACCESS_DENIED packet
453
- if spnopt[:use_spn]
454
- spn= Rex::Text.to_unicode("cifs/#{spnopt[:name] || 'unknow'}")
455
- addr_list << [9, spn.length].pack('vv') + spn
456
- end
457
-
458
- # MAY BE USEFUL FOR FUTURE
459
- # Seven (client) add at least one more av that is of type MsAvRestrictions (8)
460
- # maybe this will be usefull with future windows OSs but has no use at all for the moment afaik
461
- # restriction_encoding = [48,0,0,0].pack("VVV") + # Size, Z4, IntegrityLevel, SubjectIntegrityLevel
462
- # Rex::Text.rand_text(32) # MachineId generated on startup on win7 and above
463
- # addr_list << [8, restriction_encoding.length].pack('vv') + restriction_encoding
464
-
465
- # Seven (client) and maybe others versions also add an av of type MsvChannelBindings (10) but the hash is "\x00" * 16
466
- # addr_list << [10, 16].pack('vv') + "\x00" * 16
467
-
468
-
469
- addr_list << [0, 0].pack('vv')
470
- ntlm_clientchallenge = [1,1,0,0].pack("CCvV") + #RespType, HiRespType, Reserved1, Reserved2
471
- timestamp + #Timestamp
472
- client_challenge + #clientchallenge
473
- [0].pack("V") + #Reserved3
474
- addr_list + "\x00" * 4
475
-
476
- end
477
-
478
- # create lm/ntlm responses
479
- def self.create_lm_ntlm_responses(user, pass, challenge_key, domain = '', default_name = '', default_domain = '',
480
- dns_host_name = '', dns_domain_name = '', chall_MsvAvTimestamp = nil, spnopt = {}, opt = {} )
481
-
482
- usentlm2_session = opt[:usentlm2_session] != nil ? opt[:usentlm2_session] : true
483
- use_ntlmv2 = opt[:use_ntlmv2] != nil ? opt[:use_ntlmv2] : false
484
- send_lm = opt[:send_lm] != nil ? opt[:send_lm] : true
485
- send_ntlm = opt[:send_ntlm] != nil ? opt[:send_ntlm] : true
486
-
487
- #calculate the lm/ntlm response
488
- resp_lm = "\x00" * 24
489
- resp_ntlm = "\x00" * 24
490
-
491
- client_challenge = Rex::Text.rand_text(8)
492
- ntlm_cli_challenge = ''
493
- if send_ntlm #should be default
494
- if usentlm2_session
495
- if use_ntlmv2
496
- ntlm_cli_challenge = self.make_ntlmv2_clientchallenge(default_domain, default_name, dns_domain_name,
497
- dns_host_name,client_challenge ,
498
- chall_MsvAvTimestamp, spnopt)
499
- if self.is_pass_ntlm_hash?(pass)
500
- argntlm = {
501
- :ntlmv2_hash => CRYPT::ntlmv2_hash(
502
- user,
503
- [ pass.upcase()[33,65] ].pack('H32'),
504
- domain,{:pass_is_hash => true}
505
- ),
506
- :challenge => challenge_key
507
- }
508
- else
509
- argntlm = {
510
- :ntlmv2_hash => CRYPT::ntlmv2_hash(user, pass, domain),
511
- :challenge => challenge_key
512
- }
513
- end
514
-
515
- optntlm = { :nt_client_challenge => ntlm_cli_challenge}
516
- ntlmv2_response = CRYPT::ntlmv2_response(argntlm,optntlm)
517
- resp_ntlm = ntlmv2_response
518
-
519
- if send_lm
520
- if self.is_pass_ntlm_hash?(pass)
521
- arglm = {
522
- :ntlmv2_hash => CRYPT::ntlmv2_hash(
523
- user,
524
- [ pass.upcase()[33,65] ].pack('H32'),
525
- domain,{:pass_is_hash => true}
526
- ),
527
- :challenge => challenge_key
528
- }
529
- else
530
- arglm = {
531
- :ntlmv2_hash => CRYPT::ntlmv2_hash(user,pass, domain),
532
- :challenge => challenge_key
533
- }
534
- end
535
-
536
- optlm = { :client_challenge => client_challenge }
537
- resp_lm = CRYPT::lmv2_response(arglm, optlm)
538
- else
539
- resp_lm = "\x00" * 24
540
- end
541
-
542
- else # ntlm2_session
543
- if self.is_pass_ntlm_hash?(pass)
544
- argntlm = {
545
- :ntlm_hash => [ pass.upcase()[33,65] ].pack('H32'),
546
- :challenge => challenge_key
547
- }
548
- else
549
- argntlm = {
550
- :ntlm_hash => CRYPT::ntlm_hash(pass),
551
- :challenge => challenge_key
552
- }
553
- end
554
-
555
- optntlm = { :client_challenge => client_challenge}
556
- resp_ntlm = CRYPT::ntlm2_session(argntlm,optntlm).join[24,24]
557
-
558
- # Generate the fake LANMAN hash
559
- resp_lm = client_challenge + ("\x00" * 16)
560
- end
561
-
562
- else # we use lmv1/ntlmv1
563
- if self.is_pass_ntlm_hash?(pass)
564
- argntlm = {
565
- :ntlm_hash => [ pass.upcase()[33,65] ].pack('H32'),
566
- :challenge => challenge_key
567
- }
568
- else
569
- argntlm = {
570
- :ntlm_hash => CRYPT::ntlm_hash(pass),
571
- :challenge => challenge_key
572
- }
573
- end
574
-
575
- resp_ntlm = CRYPT::ntlm_response(argntlm)
576
- if send_lm
577
- if self.is_pass_ntlm_hash?(pass)
578
- arglm = {
579
- :lm_hash => [ pass.upcase()[0,32] ].pack('H32'),
580
- :challenge => challenge_key
581
- }
582
- else
583
- arglm = {
584
- :lm_hash => CRYPT::lm_hash(pass),
585
- :challenge => challenge_key
586
- }
587
- end
588
- resp_lm = CRYPT::lm_response(arglm)
589
- else
590
- #when windows does not send lm in ntlmv1 type response,
591
- # it gives lm response the same value as ntlm response
592
- resp_lm = resp_ntlm
593
- end
594
- end
595
- else #send_ntlm = false
596
- #lmv2
597
- if usentlm2_session && use_ntlmv2
598
- if self.is_pass_ntlm_hash?(pass)
599
- arglm = {
600
- :ntlmv2_hash => CRYPT::ntlmv2_hash(
601
- user,
602
- [ pass.upcase()[33,65] ].pack('H32'),
603
- domain,{:pass_is_hash => true}
604
- ),
605
- :challenge => challenge_key
606
- }
607
- else
608
- arglm = {
609
- :ntlmv2_hash => CRYPT::ntlmv2_hash(user,pass, domain),
610
- :challenge => challenge_key
611
- }
612
- end
613
- optlm = { :client_challenge => client_challenge }
614
- resp_lm = CRYPT::lmv2_response(arglm, optlm)
615
- else
616
- if self.is_pass_ntlm_hash?(pass)
617
- arglm = {
618
- :lm_hash => [ pass.upcase()[0,32] ].pack('H32'),
619
- :challenge => challenge_key
620
- }
621
- else
622
- arglm = {
623
- :lm_hash => CRYPT::lm_hash(pass),
624
- :challenge => challenge_key
625
- }
626
- end
627
- resp_lm = CRYPT::lm_response(arglm)
628
- end
629
- resp_ntlm = ""
630
- end
631
- return resp_lm, resp_ntlm, client_challenge, ntlm_cli_challenge
632
- end
633
-
634
- # create the session key
635
- def self.create_session_key(ntlmssp_flags, server_ntlmssp_flags, user, pass, domain, challenge_key,
636
- client_challenge = '', ntlm_cli_challenge = '' , opt = {} )
637
-
638
- usentlm2_session = opt[:usentlm2_session] != nil ? opt[:usentlm2_session] : true
639
- use_ntlmv2 = opt[:use_ntlmv2] != nil ? opt[:use_ntlmv2] : false
640
- send_lm = opt[:send_lm] != nil ? opt[:send_lm] : true
641
- send_ntlm = opt[:send_ntlm] != nil ? opt[:send_ntlm] : true
642
- use_lanman_key = opt[:use_lanman_key] != nil ? opt[:use_lanman_key] : false
643
-
644
- # Create the sessionkey (aka signing key, aka mackey) and encrypted session key
645
- # Server will decide for key_size and key_exchange
646
- enc_session_key = ''
647
- signing_key = ''
648
-
649
- # Set default key size and key exchange values
650
- key_size = 40
651
- key_exchange = false
652
- # Remove ntlmssp.negotiate56
653
- ntlmssp_flags &= 0x7fffffff
654
- # Remove ntlmssp.negotiatekeyexch
655
- ntlmssp_flags &= 0xbfffffff
656
- # Remove ntlmssp.negotiate128
657
- ntlmssp_flags &= 0xdfffffff
658
- # Check the keyexchange
659
- if server_ntlmssp_flags & CONST::NEGOTIATE_KEY_EXCH != 0 then
660
- key_exchange = true
661
- ntlmssp_flags |= CONST::NEGOTIATE_KEY_EXCH
662
- end
663
- # Check 128bits
664
- if server_ntlmssp_flags & CONST::NEGOTIATE_128 != 0 then
665
- key_size = 128
666
- ntlmssp_flags |= CONST::NEGOTIATE_128
667
- ntlmssp_flags |= CONST::NEGOTIATE_56
668
- # Check 56bits
669
- else
670
- if server_ntlmssp_flags & CONST::NEGOTIATE_56 != 0 then
671
- key_size = 56
672
- ntlmssp_flags |= CONST::NEGOTIATE_56
673
- end
674
- end
675
- # Generate the user session key
676
- lanman_weak = false
677
- if send_ntlm # Should be default
678
- if usentlm2_session
679
- if use_ntlmv2
680
- if self.is_pass_ntlm_hash?(pass)
681
- user_session_key = CRYPT::ntlmv2_user_session_key(user,
682
- [ pass.upcase()[33,65] ].pack('H32'),
683
- domain,
684
- challenge_key, ntlm_cli_challenge,
685
- {:pass_is_hash => true})
686
- else
687
- user_session_key = CRYPT::ntlmv2_user_session_key(user, pass, domain,
688
- challenge_key, ntlm_cli_challenge)
689
- end
690
- else
691
- if self.is_pass_ntlm_hash?(pass)
692
- user_session_key = CRYPT::ntlm2_session_user_session_key([ pass.upcase()[33,65] ].pack('H32'),
693
- challenge_key,
694
- client_challenge,
695
- {:pass_is_hash => true})
696
- else
697
- user_session_key = CRYPT::ntlm2_session_user_session_key(pass, challenge_key,
698
- client_challenge)
699
- end
700
- end
701
- else # lmv1/ntlmv1
702
- # lanman_key may also be used without ntlm response but it is not so much used
703
- # so we don't care about this feature
704
- if send_lm && use_lanman_key
705
- if self.is_pass_ntlm_hash?(pass)
706
- user_session_key = CRYPT::lanman_session_key([ pass.upcase()[0,32] ].pack('H32'),
707
- challenge_key,
708
- {:pass_is_hash => true})
709
- else
710
- user_session_key = CRYPT::lanman_session_key(pass, challenge_key)
711
- end
712
- lanman_weak = true
713
-
714
-
715
- else
716
- if self.is_pass_ntlm_hash?(pass)
717
- user_session_key = CRYPT::ntlmv1_user_session_key([ pass.upcase()[33,65] ].pack('H32'),
718
- {:pass_is_hash => true})
719
- else
720
- user_session_key = CRYPT::ntlmv1_user_session_key(pass)
721
- end
722
- end
723
- end
724
- else
725
- if usentlm2_session && use_ntlmv2
726
- if self.is_pass_ntlm_hash?(pass)
727
- user_session_key = CRYPT::lmv2_user_session_key(user, [ pass.upcase()[33,65] ].pack('H32'),
728
- domain,
729
- challenge_key, client_challenge,
730
- {:pass_is_hash => true})
731
- else
732
- user_session_key = CRYPT::lmv2_user_session_key(user, pass, domain,
733
- challenge_key, client_challenge)
734
- end
735
- else
736
- if self.is_pass_ntlm_hash?(pass)
737
- user_session_key = CRYPT::lmv1_user_session_key([ pass.upcase()[0,32] ].pack('H32'),
738
- {:pass_is_hash => true})
739
- else
740
- user_session_key = CRYPT::lmv1_user_session_key(pass)
741
- end
742
- end
743
- end
744
-
745
- user_session_key = CRYPT::make_weak_sessionkey(user_session_key,key_size, lanman_weak)
746
-
747
- # Sessionkey and encrypted session key
748
- if key_exchange
749
- signing_key = Rex::Text.rand_text(16)
750
- enc_session_key = CRYPT::encrypt_sessionkey(signing_key, user_session_key)
751
- else
752
- signing_key = user_session_key
753
- end
754
-
755
- return signing_key, enc_session_key, ntlmssp_flags
756
-
757
-
758
- end
16
+ # Convert a unix timestamp to a 64-bit signed server time
17
+ def self.time_unix_to_smb(unix_time)
18
+ t64 = (unix_time + 11644473600) * 10000000
19
+ thi = (t64 & 0xffffffff00000000) >> 32
20
+ tlo = (t64 & 0x00000000ffffffff)
21
+ return [thi, tlo]
22
+ end
23
+
24
+ # Determine whether the password is a known hash format
25
+ def self.is_pass_ntlm_hash?(str)
26
+ str.downcase =~ /^[0-9a-f]{32}:[0-9a-f]{32}$/
27
+ end
28
+
29
+ #
30
+ # Prepends an ASN1 formatted length field to a piece of data
31
+ #
32
+ def self.asn1encode(str = '')
33
+ res = ''
34
+
35
+ # If the high bit of the first byte is 1, it contains the number of
36
+ # length bytes that follow
37
+
38
+ case str.length
39
+ when 0 .. 0x7F
40
+ res = [str.length].pack('C') + str
41
+ when 0x80 .. 0xFF
42
+ res = [0x81, str.length].pack('CC') + str
43
+ when 0x100 .. 0xFFFF
44
+ res = [0x82, str.length].pack('Cn') + str
45
+ when 0x10000 .. 0xffffff
46
+ res = [0x83, str.length >> 16, str.length & 0xFFFF].pack('CCn') + str
47
+ when 0x1000000 .. 0xffffffff
48
+ res = [0x84, str.length].pack('CN') + str
49
+ else
50
+ raise "ASN1 str too long"
51
+ end
52
+ return res
53
+ end
54
+
55
+ # GSS functions
56
+
57
+ # GSS BLOB usefull for SMB_NEGOCIATE_RESPONSE message
58
+ # mechTypes: 2 items :
59
+ # -MechType: 1.3.6.1.4.1.311.2.2.30 (SNMPv2-SMI::enterprises.311.2.2.30)
60
+ # -MechType: 1.3.6.1.4.1.311.2.2.10 (NTLMSSP - Microsoft NTLM Security Support Provider)
61
+ #
62
+ # this is the default on Win7
63
+ def self.make_simple_negotiate_secblob_resp
64
+ blob =
65
+ "\x60" + self.asn1encode(
66
+ "\x06" + self.asn1encode(
67
+ "\x2b\x06\x01\x05\x05\x02"
68
+ ) +
69
+ "\xa0" + self.asn1encode(
70
+ "\x30" + self.asn1encode(
71
+ "\xa0" + self.asn1encode(
72
+ "\x30" + self.asn1encode(
73
+ "\x06" + self.asn1encode(
74
+ "\x2b\x06\x01\x04\x01\x82\x37\x02\x02\x0a"
75
+ )
76
+ )
77
+ )
78
+ )
79
+ )
80
+ )
81
+
82
+ return blob
83
+ end
84
+
85
+ # GSS BLOB usefull for SMB_NEGOCIATE_RESPONSE message
86
+ # mechTypes: 4 items :
87
+ # MechType: 1.2.840.48018.1.2.2 (MS KRB5 - Microsoft Kerberos 5)
88
+ # MechType: 1.2.840.113554.1.2.2 (KRB5 - Kerberos 5)
89
+ # MechType: 1.2.840.113554.1.2.2.3 (KRB5 - Kerberos 5 - User to User)
90
+ # MechType: 1.3.6.1.4.1.311.2.2.10 (NTLMSSP - Microsoft NTLM Security Support Provider)
91
+ # mechListMIC:
92
+ # principal: account@domain
93
+ def self.make_negotiate_secblob_resp(account, domain)
94
+ blob =
95
+ "\x60" + self.asn1encode(
96
+ "\x06" + self.asn1encode(
97
+ "\x2b\x06\x01\x05\x05\x02"
98
+ ) +
99
+ "\xa0" + self.asn1encode(
100
+ "\x30" + self.asn1encode(
101
+ "\xa0" + self.asn1encode(
102
+ "\x30" + self.asn1encode(
103
+ "\x06" + self.asn1encode(
104
+ "\x2a\x86\x48\x82\xf7\x12\x01\x02\x02"
105
+ ) +
106
+ "\x06" + self.asn1encode(
107
+ "\x2a\x86\x48\x86\xf7\x12\x01\x02\x02"
108
+ ) +
109
+ "\x06" + self.asn1encode(
110
+ "\x2a\x86\x48\x86\xf7\x12\x01\x02\x02\x03"
111
+ ) +
112
+ "\x06" + self.asn1encode(
113
+ "\x2b\x06\x01\x04\x01\x82\x37\x02\x02\x0a"
114
+ )
115
+ )
116
+ ) +
117
+ "\xa3" + self.asn1encode(
118
+ "\x30" + self.asn1encode(
119
+ "\xa0" + self.asn1encode(
120
+ "\x1b" + self.asn1encode(
121
+ account + '@' + domain
122
+ )
123
+ )
124
+ )
125
+ )
126
+ )
127
+ )
128
+ )
129
+
130
+ return blob
131
+ end
132
+
133
+ # BLOB without GSS usefull for ntlmssp type 1 message
134
+ def self.make_ntlmssp_blob_init(domain = 'WORKGROUP', name = 'WORKSTATION', flags=0x80201)
135
+ blob = "NTLMSSP\x00" +
136
+ [1, flags].pack('VV') +
137
+
138
+ [
139
+ domain.length, #length
140
+ domain.length, #max length
141
+ 32
142
+ ].pack('vvV') +
143
+
144
+ [
145
+ name.length, #length
146
+ name.length, #max length
147
+ domain.length + 32
148
+ ].pack('vvV') +
149
+
150
+ domain + name
151
+ return blob
152
+ end
153
+
154
+ # GSS BLOB usefull for ntlmssp type 1 message
155
+ def self.make_ntlmssp_secblob_init(domain = 'WORKGROUP', name = 'WORKSTATION', flags=0x80201)
156
+ blob =
157
+ "\x60" + self.asn1encode(
158
+ "\x06" + self.asn1encode(
159
+ "\x2b\x06\x01\x05\x05\x02"
160
+ ) +
161
+ "\xa0" + self.asn1encode(
162
+ "\x30" + self.asn1encode(
163
+ "\xa0" + self.asn1encode(
164
+ "\x30" + self.asn1encode(
165
+ "\x06" + self.asn1encode(
166
+ "\x2b\x06\x01\x04\x01\x82\x37\x02\x02\x0a"
167
+ )
168
+ )
169
+ ) +
170
+ "\xa2" + self.asn1encode(
171
+ "\x04" + self.asn1encode(
172
+ make_ntlmssp_blob_init(domain, name, flags)
173
+ )
174
+ )
175
+ )
176
+ )
177
+ )
178
+
179
+ return blob
180
+ end
181
+
182
+
183
+ # BLOB without GSS usefull for ntlm type 2 message
184
+ def self.make_ntlmssp_blob_chall(win_domain, win_name, dns_domain, dns_name, chall, flags)
185
+
186
+ addr_list = ''
187
+ addr_list << [2, win_domain.length].pack('vv') + win_domain
188
+ addr_list << [1, win_name.length].pack('vv') + win_name
189
+ addr_list << [4, dns_domain.length].pack('vv') + dns_domain
190
+ addr_list << [3, dns_name.length].pack('vv') + dns_name
191
+ addr_list << [0, 0].pack('vv')
192
+
193
+ ptr = 0
194
+ blob = "NTLMSSP\x00" +
195
+ [2].pack('V') +
196
+ [
197
+ win_domain.length, # length
198
+ win_domain.length, # max length
199
+ (ptr += 48) # offset
200
+ ].pack('vvV') +
201
+ [ flags ].pack('V') +
202
+ chall +
203
+ "\x00\x00\x00\x00\x00\x00\x00\x00" +
204
+ [
205
+ addr_list.length, # length
206
+ addr_list.length, # max length
207
+ (ptr += win_domain.length)
208
+ ].pack('vvV') +
209
+ win_domain +
210
+ addr_list
211
+ return blob
212
+ end
213
+
214
+ # GSS BLOB usefull for ntlmssp type 2 message
215
+ def self.make_ntlmssp_secblob_chall(win_domain, win_name, dns_domain, dns_name, chall, flags)
216
+
217
+ blob =
218
+ "\xa1" + self.asn1encode(
219
+ "\x30" + self.asn1encode(
220
+ "\xa0" + self.asn1encode(
221
+ "\x0a" + self.asn1encode(
222
+ "\x01"
223
+ )
224
+ ) +
225
+ "\xa1" + self.asn1encode(
226
+ "\x06" + self.asn1encode(
227
+ "\x2b\x06\x01\x04\x01\x82\x37\x02\x02\x0a"
228
+ )
229
+ ) +
230
+ "\xa2" + self.asn1encode(
231
+ "\x04" + self.asn1encode(
232
+ make_ntlmssp_blob_chall(win_domain, win_name, dns_domain, dns_name, chall, flags)
233
+ )
234
+ )
235
+ )
236
+ )
237
+
238
+ return blob
239
+ end
240
+
241
+ # BLOB without GSS Usefull for ntlmssp type 3 message
242
+ def self.make_ntlmssp_blob_auth(domain, name, user, lm, ntlm, enc_session_key, flags = 0x080201)
243
+ lm ||= "\x00" * 24
244
+ ntlm ||= "\x00" * 24
245
+
246
+ domain_uni = Rex::Text.to_unicode(domain)
247
+ user_uni = Rex::Text.to_unicode(user)
248
+ name_uni = Rex::Text.to_unicode(name)
249
+ session = enc_session_key
250
+
251
+ ptr = 64
252
+
253
+ blob = "NTLMSSP\x00" +
254
+ [ 3 ].pack('V') +
255
+
256
+ [ # Lan Manager Response
257
+ lm.length,
258
+ lm.length,
259
+ (ptr)
260
+ ].pack('vvV') +
261
+
262
+ [ # NTLM Manager Response
263
+ ntlm.length,
264
+ ntlm.length,
265
+ (ptr += lm.length)
266
+ ].pack('vvV') +
267
+
268
+ [ # Domain Name
269
+ domain_uni.length,
270
+ domain_uni.length,
271
+ (ptr += ntlm.length)
272
+ ].pack('vvV') +
273
+
274
+ [ # Username
275
+ user_uni.length,
276
+ user_uni.length,
277
+ (ptr += domain_uni.length)
278
+ ].pack('vvV') +
279
+
280
+ [ # Hostname
281
+ name_uni.length,
282
+ name_uni.length,
283
+ (ptr += user_uni.length)
284
+ ].pack('vvV') +
285
+
286
+ [ # Session Key (none)
287
+ session.length,
288
+ session.length,
289
+ (ptr += name_uni.length)
290
+ ].pack('vvV') +
291
+
292
+ [ flags ].pack('V') +
293
+
294
+ lm +
295
+ ntlm +
296
+ domain_uni +
297
+ user_uni +
298
+ name_uni +
299
+ session + "\x00"
300
+ return blob
301
+
302
+ end
303
+
304
+ # GSS BLOB Usefull for ntlmssp type 3 message
305
+ def self.make_ntlmssp_secblob_auth(domain, name, user, lm, ntlm, enc_session_key, flags = 0x080201)
306
+
307
+ blob =
308
+ "\xa1" + self.asn1encode(
309
+ "\x30" + self.asn1encode(
310
+ "\xa2" + self.asn1encode(
311
+ "\x04" + self.asn1encode(
312
+ make_ntlmssp_blob_auth(domain, name, user, lm, ntlm, enc_session_key, flags )
313
+ )
314
+ )
315
+ )
316
+ )
317
+ return blob
318
+ end
319
+
320
+
321
+ # GSS BLOB Usefull for SMB Success
322
+ def self.make_ntlmv2_secblob_success
323
+ blob =
324
+ "\xa1" + self.asn1encode(
325
+ "\x30" + self.asn1encode(
326
+ "\xa0" + self.asn1encode(
327
+ "\x0a" + self.asn1encode(
328
+ "\x00"
329
+ )
330
+ )
331
+ )
332
+ )
333
+ return blob
334
+ end
335
+
336
+ # Return the correct ntlmflags upon the configuration
337
+ def self.make_ntlm_flags(opt = {})
338
+
339
+ signing = opt[:signing] != nil ? opt[:signing] : false
340
+ usentlm2_session = opt[:usentlm2_session] != nil ? opt[:usentlm2_session] : true
341
+ use_ntlmv2 = opt[:use_ntlmv2] != nil ? opt[:use_ntlmv2] : false
342
+ send_lm = opt[:send_lm] != nil ? opt[:send_lm] : true
343
+ send_ntlm = opt[:send_ntlm] != nil ? opt[:send_ntlm] : true
344
+ use_lanman_key = opt[:use_lanman_key] != nil ? opt[:use_lanman_key] : false
345
+
346
+ if signing
347
+ ntlmssp_flags = 0xe2088215
348
+ else
349
+
350
+ ntlmssp_flags = 0xa2080205
351
+ end
352
+
353
+ if usentlm2_session
354
+ if use_ntlmv2
355
+ #set Negotiate Target Info
356
+ ntlmssp_flags |= CONST::NEGOTIATE_TARGET_INFO
357
+ end
358
+
359
+ else
360
+ #remove the ntlm2_session flag
361
+ ntlmssp_flags &= 0xfff7ffff
362
+ #set lanmanflag only when lm and ntlm are sent
363
+ if send_lm
364
+ ntlmssp_flags |= CONST::NEGOTIATE_LMKEY if use_lanman_key
365
+ end
366
+ end
367
+
368
+ #we can also downgrade ntlm2_session when we send only lmv1
369
+ ntlmssp_flags &= 0xfff7ffff if usentlm2_session && (not use_ntlmv2) && (not send_ntlm)
370
+
371
+ return ntlmssp_flags
372
+ end
373
+
374
+
375
+ # Parse an ntlm type 2 challenge blob and return usefull data
376
+ def self.parse_ntlm_type_2_blob(blob)
377
+ data = {}
378
+ # Extract the NTLM challenge key the lazy way
379
+ cidx = blob.index("NTLMSSP\x00\x02\x00\x00\x00")
380
+
381
+ if not cidx
382
+ raise XCEPT::NTLMMissingChallenge
383
+ end
384
+
385
+ data[:challenge_key] = blob[cidx + 24, 8]
386
+
387
+ data[:server_ntlmssp_flags] = blob[cidx + 20, 4].unpack("V")[0]
388
+
389
+ # Extract the address list from the blob
390
+ alist_len,alist_mlen,alist_off = blob[cidx + 40, 8].unpack("vvV")
391
+ alist_buf = blob[cidx + alist_off, alist_len]
392
+
393
+ while(alist_buf.length > 0)
394
+ atype, alen = alist_buf.slice!(0,4).unpack('vv')
395
+ break if atype == 0x00
396
+ addr = alist_buf.slice!(0, alen)
397
+ case atype
398
+ when 1
399
+ #netbios name
400
+ data[:default_name] = addr.gsub("\x00", '')
401
+ when 2
402
+ #netbios domain
403
+ data[:default_domain] = addr.gsub("\x00", '')
404
+ when 3
405
+ #dns name
406
+ data[:dns_host_name] = addr.gsub("\x00", '')
407
+ when 4
408
+ #dns domain
409
+ data[:dns_domain_name] = addr.gsub("\x00", '')
410
+ when 5
411
+ #The FQDN of the forest.
412
+ when 6
413
+ #A 32-bit value indicating server or client configuration
414
+ when 7
415
+ #Client time
416
+ data[:chall_MsvAvTimestamp] = addr
417
+ when 8
418
+ #A Restriction_Encoding structure
419
+ when 9
420
+ #The SPN of the target server.
421
+ when 10
422
+ #A channel bindings hash.
423
+ end
424
+ end
425
+ return data
426
+ end
427
+
428
+ # This function return an ntlmv2 client challenge
429
+ # This is a partial implementation, full description is in [MS-NLMP].pdf around 3.1.5.2.1 :-/
430
+ def self.make_ntlmv2_clientchallenge(win_domain, win_name, dns_domain, dns_name,
431
+ client_challenge = nil, chall_MsvAvTimestamp = nil, spnopt = {})
432
+
433
+ client_challenge ||= Rex::Text.rand_text(8)
434
+ # We have to set the timestamps here to the one in the challenge message from server if present
435
+ # If we don't do that, recent server like Seven/2008 will send a STATUS_INVALID_PARAMETER error packet
436
+ timestamp = chall_MsvAvTimestamp != '' ? chall_MsvAvTimestamp : self.time_unix_to_smb(Time.now.to_i).reverse.pack("VV")
437
+ # Make those values unicode as requested
438
+ win_domain = Rex::Text.to_unicode(win_domain)
439
+ win_name = Rex::Text.to_unicode(win_name)
440
+ dns_domain = Rex::Text.to_unicode(dns_domain)
441
+ dns_name = Rex::Text.to_unicode(dns_name)
442
+ # Make the AV_PAIRs
443
+ addr_list = ''
444
+ addr_list << [2, win_domain.length].pack('vv') + win_domain
445
+ addr_list << [1, win_name.length].pack('vv') + win_name
446
+ addr_list << [4, dns_domain.length].pack('vv') + dns_domain
447
+ addr_list << [3, dns_name.length].pack('vv') + dns_name
448
+ addr_list << [7, 8].pack('vv') + timestamp
449
+
450
+ # Windows Seven / 2008r2 Request this type if in local security policies,
451
+ # Microsoft network server : Server SPN target name validation level is set to <Required from client>
452
+ # otherwise it send an STATUS_ACCESS_DENIED packet
453
+ if spnopt[:use_spn]
454
+ spn= Rex::Text.to_unicode("cifs/#{spnopt[:name] || 'unknow'}")
455
+ addr_list << [9, spn.length].pack('vv') + spn
456
+ end
457
+
458
+ # MAY BE USEFUL FOR FUTURE
459
+ # Seven (client) add at least one more av that is of type MsAvRestrictions (8)
460
+ # maybe this will be usefull with future windows OSs but has no use at all for the moment afaik
461
+ # restriction_encoding = [48,0,0,0].pack("VVV") + # Size, Z4, IntegrityLevel, SubjectIntegrityLevel
462
+ # Rex::Text.rand_text(32) # MachineId generated on startup on win7 and above
463
+ # addr_list << [8, restriction_encoding.length].pack('vv') + restriction_encoding
464
+
465
+ # Seven (client) and maybe others versions also add an av of type MsvChannelBindings (10) but the hash is "\x00" * 16
466
+ # addr_list << [10, 16].pack('vv') + "\x00" * 16
467
+
468
+
469
+ addr_list << [0, 0].pack('vv')
470
+ ntlm_clientchallenge = [1,1,0,0].pack("CCvV") + #RespType, HiRespType, Reserved1, Reserved2
471
+ timestamp + #Timestamp
472
+ client_challenge + #clientchallenge
473
+ [0].pack("V") + #Reserved3
474
+ addr_list + "\x00" * 4
475
+
476
+ end
477
+
478
+ # create lm/ntlm responses
479
+ def self.create_lm_ntlm_responses(user, pass, challenge_key, domain = '', default_name = '', default_domain = '',
480
+ dns_host_name = '', dns_domain_name = '', chall_MsvAvTimestamp = nil, spnopt = {}, opt = {} )
481
+
482
+ usentlm2_session = opt[:usentlm2_session] != nil ? opt[:usentlm2_session] : true
483
+ use_ntlmv2 = opt[:use_ntlmv2] != nil ? opt[:use_ntlmv2] : false
484
+ send_lm = opt[:send_lm] != nil ? opt[:send_lm] : true
485
+ send_ntlm = opt[:send_ntlm] != nil ? opt[:send_ntlm] : true
486
+
487
+ #calculate the lm/ntlm response
488
+ resp_lm = "\x00" * 24
489
+ resp_ntlm = "\x00" * 24
490
+
491
+ client_challenge = Rex::Text.rand_text(8)
492
+ ntlm_cli_challenge = ''
493
+ if send_ntlm #should be default
494
+ if usentlm2_session
495
+ if use_ntlmv2
496
+ ntlm_cli_challenge = self.make_ntlmv2_clientchallenge(default_domain, default_name, dns_domain_name,
497
+ dns_host_name,client_challenge ,
498
+ chall_MsvAvTimestamp, spnopt)
499
+ if self.is_pass_ntlm_hash?(pass)
500
+ argntlm = {
501
+ :ntlmv2_hash => CRYPT::ntlmv2_hash(
502
+ user,
503
+ [ pass.upcase()[33,65] ].pack('H32'),
504
+ domain,{:pass_is_hash => true}
505
+ ),
506
+ :challenge => challenge_key
507
+ }
508
+ else
509
+ argntlm = {
510
+ :ntlmv2_hash => CRYPT::ntlmv2_hash(user, pass, domain),
511
+ :challenge => challenge_key
512
+ }
513
+ end
514
+
515
+ optntlm = { :nt_client_challenge => ntlm_cli_challenge}
516
+ ntlmv2_response = CRYPT::ntlmv2_response(argntlm,optntlm)
517
+ resp_ntlm = ntlmv2_response
518
+
519
+ if send_lm
520
+ if self.is_pass_ntlm_hash?(pass)
521
+ arglm = {
522
+ :ntlmv2_hash => CRYPT::ntlmv2_hash(
523
+ user,
524
+ [ pass.upcase()[33,65] ].pack('H32'),
525
+ domain,{:pass_is_hash => true}
526
+ ),
527
+ :challenge => challenge_key
528
+ }
529
+ else
530
+ arglm = {
531
+ :ntlmv2_hash => CRYPT::ntlmv2_hash(user,pass, domain),
532
+ :challenge => challenge_key
533
+ }
534
+ end
535
+
536
+ optlm = { :client_challenge => client_challenge }
537
+ resp_lm = CRYPT::lmv2_response(arglm, optlm)
538
+ else
539
+ resp_lm = "\x00" * 24
540
+ end
541
+
542
+ else # ntlm2_session
543
+ if self.is_pass_ntlm_hash?(pass)
544
+ argntlm = {
545
+ :ntlm_hash => [ pass.upcase()[33,65] ].pack('H32'),
546
+ :challenge => challenge_key
547
+ }
548
+ else
549
+ argntlm = {
550
+ :ntlm_hash => CRYPT::ntlm_hash(pass),
551
+ :challenge => challenge_key
552
+ }
553
+ end
554
+
555
+ optntlm = { :client_challenge => client_challenge}
556
+ resp_ntlm = CRYPT::ntlm2_session(argntlm,optntlm).join[24,24]
557
+
558
+ # Generate the fake LANMAN hash
559
+ resp_lm = client_challenge + ("\x00" * 16)
560
+ end
561
+
562
+ else # we use lmv1/ntlmv1
563
+ if self.is_pass_ntlm_hash?(pass)
564
+ argntlm = {
565
+ :ntlm_hash => [ pass.upcase()[33,65] ].pack('H32'),
566
+ :challenge => challenge_key
567
+ }
568
+ else
569
+ argntlm = {
570
+ :ntlm_hash => CRYPT::ntlm_hash(pass),
571
+ :challenge => challenge_key
572
+ }
573
+ end
574
+
575
+ resp_ntlm = CRYPT::ntlm_response(argntlm)
576
+ if send_lm
577
+ if self.is_pass_ntlm_hash?(pass)
578
+ arglm = {
579
+ :lm_hash => [ pass.upcase()[0,32] ].pack('H32'),
580
+ :challenge => challenge_key
581
+ }
582
+ else
583
+ arglm = {
584
+ :lm_hash => CRYPT::lm_hash(pass),
585
+ :challenge => challenge_key
586
+ }
587
+ end
588
+ resp_lm = CRYPT::lm_response(arglm)
589
+ else
590
+ #when windows does not send lm in ntlmv1 type response,
591
+ # it gives lm response the same value as ntlm response
592
+ resp_lm = resp_ntlm
593
+ end
594
+ end
595
+ else #send_ntlm = false
596
+ #lmv2
597
+ if usentlm2_session && use_ntlmv2
598
+ if self.is_pass_ntlm_hash?(pass)
599
+ arglm = {
600
+ :ntlmv2_hash => CRYPT::ntlmv2_hash(
601
+ user,
602
+ [ pass.upcase()[33,65] ].pack('H32'),
603
+ domain,{:pass_is_hash => true}
604
+ ),
605
+ :challenge => challenge_key
606
+ }
607
+ else
608
+ arglm = {
609
+ :ntlmv2_hash => CRYPT::ntlmv2_hash(user,pass, domain),
610
+ :challenge => challenge_key
611
+ }
612
+ end
613
+ optlm = { :client_challenge => client_challenge }
614
+ resp_lm = CRYPT::lmv2_response(arglm, optlm)
615
+ else
616
+ if self.is_pass_ntlm_hash?(pass)
617
+ arglm = {
618
+ :lm_hash => [ pass.upcase()[0,32] ].pack('H32'),
619
+ :challenge => challenge_key
620
+ }
621
+ else
622
+ arglm = {
623
+ :lm_hash => CRYPT::lm_hash(pass),
624
+ :challenge => challenge_key
625
+ }
626
+ end
627
+ resp_lm = CRYPT::lm_response(arglm)
628
+ end
629
+ resp_ntlm = ""
630
+ end
631
+ return resp_lm, resp_ntlm, client_challenge, ntlm_cli_challenge
632
+ end
633
+
634
+ # create the session key
635
+ def self.create_session_key(ntlmssp_flags, server_ntlmssp_flags, user, pass, domain, challenge_key,
636
+ client_challenge = '', ntlm_cli_challenge = '' , opt = {} )
637
+
638
+ usentlm2_session = opt[:usentlm2_session] != nil ? opt[:usentlm2_session] : true
639
+ use_ntlmv2 = opt[:use_ntlmv2] != nil ? opt[:use_ntlmv2] : false
640
+ send_lm = opt[:send_lm] != nil ? opt[:send_lm] : true
641
+ send_ntlm = opt[:send_ntlm] != nil ? opt[:send_ntlm] : true
642
+ use_lanman_key = opt[:use_lanman_key] != nil ? opt[:use_lanman_key] : false
643
+
644
+ # Create the sessionkey (aka signing key, aka mackey) and encrypted session key
645
+ # Server will decide for key_size and key_exchange
646
+ enc_session_key = ''
647
+ signing_key = ''
648
+
649
+ # Set default key size and key exchange values
650
+ key_size = 40
651
+ key_exchange = false
652
+ # Remove ntlmssp.negotiate56
653
+ ntlmssp_flags &= 0x7fffffff
654
+ # Remove ntlmssp.negotiatekeyexch
655
+ ntlmssp_flags &= 0xbfffffff
656
+ # Remove ntlmssp.negotiate128
657
+ ntlmssp_flags &= 0xdfffffff
658
+ # Check the keyexchange
659
+ if server_ntlmssp_flags & CONST::NEGOTIATE_KEY_EXCH != 0 then
660
+ key_exchange = true
661
+ ntlmssp_flags |= CONST::NEGOTIATE_KEY_EXCH
662
+ end
663
+ # Check 128bits
664
+ if server_ntlmssp_flags & CONST::NEGOTIATE_128 != 0 then
665
+ key_size = 128
666
+ ntlmssp_flags |= CONST::NEGOTIATE_128
667
+ ntlmssp_flags |= CONST::NEGOTIATE_56
668
+ # Check 56bits
669
+ else
670
+ if server_ntlmssp_flags & CONST::NEGOTIATE_56 != 0 then
671
+ key_size = 56
672
+ ntlmssp_flags |= CONST::NEGOTIATE_56
673
+ end
674
+ end
675
+ # Generate the user session key
676
+ lanman_weak = false
677
+ if send_ntlm # Should be default
678
+ if usentlm2_session
679
+ if use_ntlmv2
680
+ if self.is_pass_ntlm_hash?(pass)
681
+ user_session_key = CRYPT::ntlmv2_user_session_key(user,
682
+ [ pass.upcase()[33,65] ].pack('H32'),
683
+ domain,
684
+ challenge_key, ntlm_cli_challenge,
685
+ {:pass_is_hash => true})
686
+ else
687
+ user_session_key = CRYPT::ntlmv2_user_session_key(user, pass, domain,
688
+ challenge_key, ntlm_cli_challenge)
689
+ end
690
+ else
691
+ if self.is_pass_ntlm_hash?(pass)
692
+ user_session_key = CRYPT::ntlm2_session_user_session_key([ pass.upcase()[33,65] ].pack('H32'),
693
+ challenge_key,
694
+ client_challenge,
695
+ {:pass_is_hash => true})
696
+ else
697
+ user_session_key = CRYPT::ntlm2_session_user_session_key(pass, challenge_key,
698
+ client_challenge)
699
+ end
700
+ end
701
+ else # lmv1/ntlmv1
702
+ # lanman_key may also be used without ntlm response but it is not so much used
703
+ # so we don't care about this feature
704
+ if send_lm && use_lanman_key
705
+ if self.is_pass_ntlm_hash?(pass)
706
+ user_session_key = CRYPT::lanman_session_key([ pass.upcase()[0,32] ].pack('H32'),
707
+ challenge_key,
708
+ {:pass_is_hash => true})
709
+ else
710
+ user_session_key = CRYPT::lanman_session_key(pass, challenge_key)
711
+ end
712
+ lanman_weak = true
713
+
714
+
715
+ else
716
+ if self.is_pass_ntlm_hash?(pass)
717
+ user_session_key = CRYPT::ntlmv1_user_session_key([ pass.upcase()[33,65] ].pack('H32'),
718
+ {:pass_is_hash => true})
719
+ else
720
+ user_session_key = CRYPT::ntlmv1_user_session_key(pass)
721
+ end
722
+ end
723
+ end
724
+ else
725
+ if usentlm2_session && use_ntlmv2
726
+ if self.is_pass_ntlm_hash?(pass)
727
+ user_session_key = CRYPT::lmv2_user_session_key(user, [ pass.upcase()[33,65] ].pack('H32'),
728
+ domain,
729
+ challenge_key, client_challenge,
730
+ {:pass_is_hash => true})
731
+ else
732
+ user_session_key = CRYPT::lmv2_user_session_key(user, pass, domain,
733
+ challenge_key, client_challenge)
734
+ end
735
+ else
736
+ if self.is_pass_ntlm_hash?(pass)
737
+ user_session_key = CRYPT::lmv1_user_session_key([ pass.upcase()[0,32] ].pack('H32'),
738
+ {:pass_is_hash => true})
739
+ else
740
+ user_session_key = CRYPT::lmv1_user_session_key(pass)
741
+ end
742
+ end
743
+ end
744
+
745
+ user_session_key = CRYPT::make_weak_sessionkey(user_session_key,key_size, lanman_weak)
746
+
747
+ # Sessionkey and encrypted session key
748
+ if key_exchange
749
+ signing_key = Rex::Text.rand_text(16)
750
+ enc_session_key = CRYPT::encrypt_sessionkey(signing_key, user_session_key)
751
+ else
752
+ signing_key = user_session_key
753
+ end
754
+
755
+ return signing_key, enc_session_key, ntlmssp_flags
756
+
757
+
758
+ end
759
759
 
760
760
 
761
761