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
@@ -4,70 +4,70 @@ module Proto
4
4
  module NTLM
5
5
  class Constants
6
6
 
7
- SSP_SIGN = "NTLMSSP\0"
8
- BLOB_SIGN = 0x00000101
9
- LM_MAGIC = "KGS!@\#$%"
10
- TIME_OFFSET = 11644473600
11
- MAX64 = 0xffffffffffffffff
12
-
13
- FLAGS = {
14
- :UNICODE => 0x00000001,
15
- :OEM => 0x00000002,
16
- :REQUEST_TARGET => 0x00000004,
17
- #:UNKNOWN => 0x00000008,
18
- :SIGN => 0x00000010,
19
- :SEAL => 0x00000020,
20
- #:UNKNOWN => 0x00000040,
21
- :NETWARE => 0x00000100,
22
- :NTLM => 0x00000200,
23
- #:UNKNOWN => 0x00000400,
24
- #:UNKNOWN => 0x00000800,
25
- :DOMAIN_SUPPLIED => 0x00001000,
26
- :WORKSTATION_SUPPLIED => 0x00002000,
27
- :LOCAL_CALL => 0x00004000,
28
- :ALWAYS_SIGN => 0x00008000,
29
- :TARGET_TYPE_DOMAIN => 0x00010000,
30
- :TARGET_INFO => 0x00800000,
31
- :NTLM2_KEY => 0x00080000,
32
- :KEY128 => 0x20000000,
33
- :KEY56 => 0x80000000
34
- }
35
-
36
- FLAG_KEYS = FLAGS.keys.sort{|a, b| FLAGS[a] <=> FLAGS[b] }
7
+ SSP_SIGN = "NTLMSSP\0"
8
+ BLOB_SIGN = 0x00000101
9
+ LM_MAGIC = "KGS!@\#$%"
10
+ TIME_OFFSET = 11644473600
11
+ MAX64 = 0xffffffffffffffff
37
12
 
38
- DEFAULT_FLAGS = {
39
- :TYPE1 => FLAGS[:UNICODE] | FLAGS[:OEM] | FLAGS[:REQUEST_TARGET] | FLAGS[:NTLM] | FLAGS[:ALWAYS_SIGN] | FLAGS[:NTLM2_KEY],
40
- :TYPE2 => FLAGS[:UNICODE],
41
- :TYPE3 => FLAGS[:UNICODE] | FLAGS[:REQUEST_TARGET] | FLAGS[:NTLM] | FLAGS[:ALWAYS_SIGN] | FLAGS[:NTLM2_KEY]
42
- }
13
+ FLAGS = {
14
+ :UNICODE => 0x00000001,
15
+ :OEM => 0x00000002,
16
+ :REQUEST_TARGET => 0x00000004,
17
+ #:UNKNOWN => 0x00000008,
18
+ :SIGN => 0x00000010,
19
+ :SEAL => 0x00000020,
20
+ #:UNKNOWN => 0x00000040,
21
+ :NETWARE => 0x00000100,
22
+ :NTLM => 0x00000200,
23
+ #:UNKNOWN => 0x00000400,
24
+ #:UNKNOWN => 0x00000800,
25
+ :DOMAIN_SUPPLIED => 0x00001000,
26
+ :WORKSTATION_SUPPLIED => 0x00002000,
27
+ :LOCAL_CALL => 0x00004000,
28
+ :ALWAYS_SIGN => 0x00008000,
29
+ :TARGET_TYPE_DOMAIN => 0x00010000,
30
+ :TARGET_INFO => 0x00800000,
31
+ :NTLM2_KEY => 0x00080000,
32
+ :KEY128 => 0x20000000,
33
+ :KEY56 => 0x80000000
34
+ }
43
35
 
44
- # NTLM Response Type
45
- NTLM_V1_RESPONSE = 1
46
- NTLM_V2_RESPONSE = 2
47
- NTLM_2_SESSION_RESPONSE = 3
36
+ FLAG_KEYS = FLAGS.keys.sort{|a, b| FLAGS[a] <=> FLAGS[b] }
48
37
 
49
- #the same flags but merged from lib/rex/proto/smb/constants and keeped for compatibility
50
- # NTLMSSP Message Flags
51
- NEGOTIATE_UNICODE = 0x00000001 # Only set if Type 1 contains it - this or oem, not both
52
- NEGOTIATE_OEM = 0x00000002 # Only set if Type 1 contains it - this or unicode, not both
53
- REQUEST_TARGET = 0x00000004 # If set in Type 1, must return domain or server
54
- NEGOTIATE_SIGN = 0x00000010 # Session signature required
55
- NEGOTIATE_SEAL = 0x00000020 # Session seal required
56
- NEGOTIATE_LMKEY = 0x00000080 # LM Session Key should be used for signing and sealing
57
- NEGOTIATE_NTLM = 0x00000200 # NTLM auth is supported
58
- NEGOTIATE_ANONYMOUS = 0x00000800 # Anonymous context used
59
- NEGOTIATE_DOMAIN = 0x00001000 # Sent in Type1, client gives domain info
60
- NEGOTIATE_WORKSTATION = 0x00002000 # Sent in Type1, client gives workstation info
61
- NEGOTIATE_LOCAL_CALL = 0x00004000 # Server and client are on same machine
62
- NEGOTIATE_ALWAYS_SIGN = 0x00008000 # Add signatures to packets
63
- TARGET_TYPE_DOMAIN = 0x00010000 # If REQUEST_TARGET, we're adding the domain name
64
- TARGET_TYPE_SERVER = 0x00020000 # If REQUEST_TARGET, we're adding the server name
65
- TARGET_TYPE_SHARE = 0x00040000 # Supposed to denote "a share" but for a webserver?
66
- NEGOTIATE_NTLM2_KEY = 0x00080000 # NTLMv2 Signature and Key exchanges
67
- NEGOTIATE_TARGET_INFO = 0x00800000 # Server set when sending Target Information Block
68
- NEGOTIATE_128 = 0x20000000 # 128-bit encryption supported
69
- NEGOTIATE_KEY_EXCH = 0x40000000 # Client will supply encrypted master key in Session Key field of Type3 msg
70
- NEGOTIATE_56 = 0x80000000 # 56-bit encryption supported
38
+ DEFAULT_FLAGS = {
39
+ :TYPE1 => FLAGS[:UNICODE] | FLAGS[:OEM] | FLAGS[:REQUEST_TARGET] | FLAGS[:NTLM] | FLAGS[:ALWAYS_SIGN] | FLAGS[:NTLM2_KEY],
40
+ :TYPE2 => FLAGS[:UNICODE],
41
+ :TYPE3 => FLAGS[:UNICODE] | FLAGS[:REQUEST_TARGET] | FLAGS[:NTLM] | FLAGS[:ALWAYS_SIGN] | FLAGS[:NTLM2_KEY]
42
+ }
43
+
44
+ # NTLM Response Type
45
+ NTLM_V1_RESPONSE = 1
46
+ NTLM_V2_RESPONSE = 2
47
+ NTLM_2_SESSION_RESPONSE = 3
48
+
49
+ #the same flags but merged from lib/rex/proto/smb/constants and keeped for compatibility
50
+ # NTLMSSP Message Flags
51
+ NEGOTIATE_UNICODE = 0x00000001 # Only set if Type 1 contains it - this or oem, not both
52
+ NEGOTIATE_OEM = 0x00000002 # Only set if Type 1 contains it - this or unicode, not both
53
+ REQUEST_TARGET = 0x00000004 # If set in Type 1, must return domain or server
54
+ NEGOTIATE_SIGN = 0x00000010 # Session signature required
55
+ NEGOTIATE_SEAL = 0x00000020 # Session seal required
56
+ NEGOTIATE_LMKEY = 0x00000080 # LM Session Key should be used for signing and sealing
57
+ NEGOTIATE_NTLM = 0x00000200 # NTLM auth is supported
58
+ NEGOTIATE_ANONYMOUS = 0x00000800 # Anonymous context used
59
+ NEGOTIATE_DOMAIN = 0x00001000 # Sent in Type1, client gives domain info
60
+ NEGOTIATE_WORKSTATION = 0x00002000 # Sent in Type1, client gives workstation info
61
+ NEGOTIATE_LOCAL_CALL = 0x00004000 # Server and client are on same machine
62
+ NEGOTIATE_ALWAYS_SIGN = 0x00008000 # Add signatures to packets
63
+ TARGET_TYPE_DOMAIN = 0x00010000 # If REQUEST_TARGET, we're adding the domain name
64
+ TARGET_TYPE_SERVER = 0x00020000 # If REQUEST_TARGET, we're adding the server name
65
+ TARGET_TYPE_SHARE = 0x00040000 # Supposed to denote "a share" but for a webserver?
66
+ NEGOTIATE_NTLM2_KEY = 0x00080000 # NTLMv2 Signature and Key exchanges
67
+ NEGOTIATE_TARGET_INFO = 0x00800000 # Server set when sending Target Information Block
68
+ NEGOTIATE_128 = 0x20000000 # 128-bit encryption supported
69
+ NEGOTIATE_KEY_EXCH = 0x40000000 # Client will supply encrypted master key in Session Key field of Type3 msg
70
+ NEGOTIATE_56 = 0x80000000 # 56-bit encryption supported
71
71
 
72
72
  end
73
73
  end
@@ -43,10 +43,6 @@
43
43
  # The latter has a minor bug in its separate_keys function.
44
44
  # The third key has to begin from the 14th character of the
45
45
  # input string instead of 13th:)
46
- #--
47
- # $Id: ntlm.rb 11678 2011-01-30 19:26:35Z hdm $
48
- #++
49
-
50
46
 
51
47
  require 'rex/proto/ntlm/constants'
52
48
  require 'rex/proto/ntlm/base'
@@ -59,356 +55,356 @@ class Crypt
59
55
  CONST = Rex::Proto::NTLM::Constants
60
56
  BASE = Rex::Proto::NTLM::Base
61
57
 
62
- @@loaded_openssl = false
63
-
64
- begin
65
- require 'openssl'
66
- require 'openssl/digest'
67
- @@loaded_openssl = true
68
- rescue ::Exception
69
- end
70
-
71
- def self.gen_keys(str)
72
- str.scan(/.{7}/).map{ |key| des_56_to_64(key) }
73
- end
74
-
75
- def self.des_56_to_64(ckey56s)
76
- ckey64 = []
77
- ckey56 = ckey56s.unpack('C*')
78
- ckey64[0] = ckey56[0]
79
- ckey64[1] = ((ckey56[0] << 7) & 0xFF) | (ckey56[1] >> 1)
80
- ckey64[2] = ((ckey56[1] << 6) & 0xFF) | (ckey56[2] >> 2)
81
- ckey64[3] = ((ckey56[2] << 5) & 0xFF) | (ckey56[3] >> 3)
82
- ckey64[4] = ((ckey56[3] << 4) & 0xFF) | (ckey56[4] >> 4)
83
- ckey64[5] = ((ckey56[4] << 3) & 0xFF) | (ckey56[5] >> 5)
84
- ckey64[6] = ((ckey56[5] << 2) & 0xFF) | (ckey56[6] >> 6)
85
- ckey64[7] = (ckey56[6] << 1) & 0xFF
86
- ckey64.pack('C*')
87
- end
88
-
89
- def self.apply_des(plain, keys)
90
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
91
- dec = OpenSSL::Cipher::DES.new
92
- keys.map do |k|
93
- dec.key = k
94
- dec.encrypt.update(plain)
95
- end
96
- end
97
-
98
- def self.lm_hash(password, half = false)
99
- size = half ? 7 : 14
100
- keys = gen_keys(password.upcase.ljust(size, "\0"))
101
- apply_des(CONST::LM_MAGIC, keys).join
102
- end
103
-
104
- def self.ntlm_hash(password, opt = {})
105
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
106
- pwd = password.dup
107
- unless opt[:unicode]
108
- pwd = Rex::Text.to_unicode(pwd)
109
- end
110
- OpenSSL::Digest::MD4.digest(pwd)
111
- end
112
-
113
- # This hash is used for lmv2/ntlmv2 response calculation
114
- def self.ntlmv2_hash(user, password, domain, opt={})
115
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
116
-
117
- if opt[:pass_is_hash]
118
- ntlmhash = password
119
- else
120
- ntlmhash = ntlm_hash(password, opt)
121
- end
122
- # With Win 7 and maybe other OSs we sometimes get the domain not uppercased
123
- userdomain = user.upcase + domain
124
- unless opt[:unicode]
125
- userdomain = Rex::Text.to_unicode(userdomain)
126
- end
127
- OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, ntlmhash, userdomain)
128
- end
129
-
130
- # Create the LANMAN response
131
- def self.lm_response(arg, half = false)
132
- begin
133
- hash = arg[:lm_hash]
134
- chal = arg[:challenge]
135
- rescue
136
- raise ArgumentError
137
- end
138
- chal = BASE::pack_int64le(chal) if chal.is_a?(Integer)
139
- if half then size = 7 else size = 21 end
140
- keys = gen_keys hash.ljust(size, "\0")
141
- apply_des(chal, keys).join
142
- end
143
-
144
- # Synonym of lm_response for old compatibility with lib/rex/proto/smb/crypt
145
- def self.lanman_des(password, challenge)
146
- lm_response({
147
- :lm_hash => self.lm_hash(password),
148
- :challenge => challenge
149
- })
150
- end
151
-
152
- def self.ntlm_response(arg)
153
- hash = arg[:ntlm_hash]
154
- chal = arg[:challenge]
155
- chal = BASE::pack_int64le(chal) if chal.is_a?(::Integer)
156
- keys = gen_keys(hash.ljust(21, "\0"))
157
- apply_des(chal, keys).join
158
- end
159
-
160
- #synonym of ntlm_response for old compatibility with lib/rex/proto/smb/crypt
161
- def self.ntlm_md4(password, challenge)
162
- ntlm_response({
163
- :ntlm_hash => self.ntlm_hash(password),
164
- :challenge => challenge
165
- })
166
- end
167
-
168
- def self.ntlmv2_response(arg, opt = {})
169
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
170
-
171
- key, chal = arg[:ntlmv2_hash], arg[:challenge]
172
- if not (key and chal)
173
- raise ArgumentError , 'ntlmv2_hash and challenge are mandatory'
174
- end
175
-
176
- chal = BASE::pack_int64le(chal) if chal.is_a?(::Integer)
177
- bb = nil
178
-
179
- if opt[:nt_client_challenge]
180
- if opt[:nt_client_challenge].to_s.length <= 8
181
- raise ArgumentError,"nt_client_challenge is not in a correct format "
182
- end
183
- bb = opt[:nt_client_challenge]
184
- else
185
- if not arg[:target_info]
186
- raise ArgumentError, "target_info is mandatory in this case"
187
- end
188
-
189
- ti = arg[:target_info]
190
- cc = opt[:client_challenge] || rand(CONST::MAX64)
191
- cc = BASE::pack_int64le(cc) if cc.is_a?(::Integer)
192
-
193
- ts = opt[:timestamp] || Time.now.to_i
194
-
195
- # Convert the unix timestamp to windows format
196
- # epoch -> milsec from Jan 1, 1601
197
- ts = 10000000 * (ts + CONST::TIME_OFFSET)
198
-
199
- blob = BASE::Blob.new
200
- blob.timestamp = ts
201
- blob.challenge = cc
202
- blob.target_info = ti
203
-
204
- bb = blob.serialize
205
- end
206
-
207
- OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, key, chal + bb) + bb
208
- end
209
-
210
- def self.lmv2_response(arg, opt = {})
211
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
212
- key = arg[:ntlmv2_hash]
213
- chal = arg[:challenge]
214
-
215
- chal = BASE::pack_int64le(chal) if chal.is_a?(::Integer)
216
- cc = opt[:client_challenge] || rand(CONST::MAX64)
217
- cc = BASE::pack_int64le(cc) if cc.is_a?(::Integer)
218
-
219
- OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, key, chal + cc) + cc
220
- end
221
-
222
- def self.ntlm2_session(arg, opt = {})
223
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
224
- passwd_hash,chal = arg[:ntlm_hash],arg[:challenge]
225
- if not (passwd_hash and chal)
226
- raise RuntimeError, "ntlm_hash and challenge are required"
227
- end
228
-
229
- cc = opt[:client_challenge] || rand(CONST::MAX64)
230
- cc = BASE::pack_int64le(cc) if cc.is_a?(Integer)
231
-
232
- keys = gen_keys(passwd_hash.ljust(21, "\0"))
233
- session_hash = OpenSSL::Digest::MD5.digest(chal + cc)[0,8]
234
- response = apply_des(session_hash, keys).join
235
- [cc.ljust(24, "\0"), response]
236
- end
237
-
238
- #this function will check if the net lm response provided correspond to en empty password
239
- def self.is_hash_from_empty_pwd?(arg)
240
- hash_type = arg[:type]
241
- raise ArgumentError,"arg[:type] is mandatory" if not hash_type
242
- raise ArgumentError,"arg[:type] must be lm or ntlm" if not hash_type =~ /^((lm)|(ntlm))$/
243
-
244
- ntlm_ver = arg[:ntlm_ver]
245
- raise ArgumentError,"arg[:ntlm_ver] is mandatory" if not ntlm_ver
246
-
247
- hash = arg[:hash]
248
- raise ArgumentError,"arg[:hash] is mandatory" if not hash
249
-
250
- srv_chall = arg[:srv_challenge]
251
- raise ArgumentError,"arg[:srv_challenge] is mandatory" if not srv_chall
252
- raise ArgumentError,"Server challenge length must be exactly 8 bytes" if srv_chall.length != 8
253
-
254
- #calculate responses for empty pwd
255
- case ntlm_ver
256
- when CONST::NTLM_V1_RESPONSE
257
- if hash.length != 24
258
- raise ArgumentError,"hash length must be exactly 24 bytes "
259
- end
260
- case hash_type
261
- when 'lm'
262
- arglm = { :lm_hash => self.lm_hash(''),
263
- :challenge => srv_chall}
264
- calculatedhash = self.lm_response(arglm)
265
- when 'ntlm'
266
- argntlm = { :ntlm_hash => self.ntlm_hash(''),
267
- :challenge => srv_chall }
268
- calculatedhash = self.ntlm_response(argntlm)
269
- end
270
- when CONST::NTLM_V2_RESPONSE
271
- raise ArgumentError,"hash length must be exactly 16 bytes " if hash.length != 16
272
- cli_chall = arg[:cli_challenge]
273
- raise ArgumentError,"arg[:cli_challenge] is mandatory in this case" if not cli_chall
274
- user = arg[:user]
275
- raise ArgumentError,"arg[:user] is mandatory in this case" if not user
276
- domain = arg[:domain]
277
- raise ArgumentError,"arg[:domain] is mandatory in this case" if not domain
278
-
279
- case hash_type
280
- when 'lm'
281
- raise ArgumentError,"Client challenge length must be exactly 8 bytes " if cli_chall.length != 8
282
- arglm = { :ntlmv2_hash => self.ntlmv2_hash(user,'', domain),
283
- :challenge => srv_chall }
284
- optlm = { :client_challenge => cli_chall}
285
- calculatedhash = self.lmv2_response(arglm, optlm)[0,16]
286
- when 'ntlm'
287
- raise ArgumentError,"Client challenge length must be bigger then 8 bytes " if cli_chall.length <= 8
288
- argntlm = { :ntlmv2_hash => self.ntlmv2_hash(user, '', domain),
289
- :challenge => srv_chall }
290
- optntlm = { :nt_client_challenge => cli_chall}
291
- calculatedhash = self.ntlmv2_response(argntlm,optntlm)[0,16]
292
- end
293
- when CONST::NTLM_2_SESSION_RESPONSE
294
- raise ArgumentError,"hash length must be exactly 16 bytes " if hash.length != 24
295
- cli_chall = arg[:cli_challenge]
296
- raise ArgumentError,"arg[:cli_challenge] is mandatory in this case" if not cli_chall
297
- raise ArgumentError,"Client challenge length must be exactly 8 bytes " if cli_chall.length != 8
298
- case hash_type
299
- when 'lm'
300
- raise ArgumentError, "ntlm2_session is incompatible with lm"
301
- when 'ntlm'
302
- argntlm = { :ntlm_hash => self.ntlm_hash(''),
303
- :challenge => srv_chall }
304
- optntlm = { :client_challenge => cli_chall}
305
- end
306
- calculatedhash = self.ntlm2_session(argntlm,optntlm).join[24,24]
307
- else
308
- raise ArgumentError,"ntlm_ver is of unknow type"
309
- end
310
- hash == calculatedhash
311
- end
312
-
313
-
314
-
315
- #
316
- # Signing method added for metasploit project
317
- #
318
-
319
- # Used when only the LMv1 response is provided (i.e., with Win9x clients)
320
- def self.lmv1_user_session_key(pass, opt = {})
321
- if opt[:pass_is_hash]
322
- usk = pass[0,8]
323
- else
324
- usk = self.lm_hash(pass.upcase[0,7],true)
325
- end
326
- usk.ljust(16,"\x00")
327
- end
328
-
329
- # This variant is used when the client sends the NTLMv1 response
330
- def self.ntlmv1_user_session_key(pass, opt = {})
331
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
332
-
333
- if opt[:pass_is_hash]
334
- usk = pass
335
- else
336
- usk = self.ntlm_hash(pass)
337
- end
338
- OpenSSL::Digest::MD4.digest(usk)
339
- end
340
-
341
- # Used when NTLMv1 authentication is employed with NTLM2 session security
342
- def self.ntlm2_session_user_session_key(pass, srv_chall, cli_chall, opt = {})
343
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
344
-
345
- ntlm_key = self.ntlmv1_user_session_key(pass, opt )
346
- session_chal = srv_chall + cli_chall
347
- OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, ntlm_key, session_chal)
348
- end
349
-
350
- # Used when the LMv2 response is sent
351
- def self.lmv2_user_session_key(user, pass, domain, srv_chall, cli_chall, opt = {})
352
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
353
-
354
- ntlmv2_key = self.ntlmv2_hash(user, pass, domain, opt)
355
- hash1 = OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, ntlmv2_key, srv_chall + cli_chall)
356
- OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, ntlmv2_key, hash1)
357
- end
358
-
359
- # Used when the NTLMv2 response is sent
360
- class << self; alias_method :ntlmv2_user_session_key, :lmv2_user_session_key; end
361
-
362
- # Used when LanMan Key flag is set
363
- def self.lanman_session_key(pass, srvchall, opt = {})
364
- if opt[:pass_is_hash]
365
- halfhash = pass[0,8]
366
- else
367
- halfhash = lm_hash(pass.upcase[0,7],true)
368
- end
369
- plain = self.lm_response({
370
- :lm_hash => halfhash[0,7],
371
- :challenge => srvchall
372
- }, true )
373
- key = halfhash + ["bdbdbdbdbdbd"].pack("H*")
58
+ @@loaded_openssl = false
59
+
60
+ begin
61
+ require 'openssl'
62
+ require 'openssl/digest'
63
+ @@loaded_openssl = true
64
+ rescue ::Exception
65
+ end
66
+
67
+ def self.gen_keys(str)
68
+ str.scan(/.{7}/).map{ |key| des_56_to_64(key) }
69
+ end
70
+
71
+ def self.des_56_to_64(ckey56s)
72
+ ckey64 = []
73
+ ckey56 = ckey56s.unpack('C*')
74
+ ckey64[0] = ckey56[0]
75
+ ckey64[1] = ((ckey56[0] << 7) & 0xFF) | (ckey56[1] >> 1)
76
+ ckey64[2] = ((ckey56[1] << 6) & 0xFF) | (ckey56[2] >> 2)
77
+ ckey64[3] = ((ckey56[2] << 5) & 0xFF) | (ckey56[3] >> 3)
78
+ ckey64[4] = ((ckey56[3] << 4) & 0xFF) | (ckey56[4] >> 4)
79
+ ckey64[5] = ((ckey56[4] << 3) & 0xFF) | (ckey56[5] >> 5)
80
+ ckey64[6] = ((ckey56[5] << 2) & 0xFF) | (ckey56[6] >> 6)
81
+ ckey64[7] = (ckey56[6] << 1) & 0xFF
82
+ ckey64.pack('C*')
83
+ end
84
+
85
+ def self.apply_des(plain, keys)
86
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
87
+ dec = OpenSSL::Cipher::DES.new
88
+ keys.map do |k|
89
+ dec.key = k
90
+ dec.encrypt.update(plain)
91
+ end
92
+ end
93
+
94
+ def self.lm_hash(password, half = false)
95
+ size = half ? 7 : 14
96
+ keys = gen_keys(password.upcase.ljust(size, "\0"))
97
+ apply_des(CONST::LM_MAGIC, keys).join
98
+ end
99
+
100
+ def self.ntlm_hash(password, opt = {})
101
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
102
+ pwd = password.dup
103
+ unless opt[:unicode]
104
+ pwd = Rex::Text.to_unicode(pwd)
105
+ end
106
+ OpenSSL::Digest::MD4.digest(pwd)
107
+ end
108
+
109
+ # This hash is used for lmv2/ntlmv2 response calculation
110
+ def self.ntlmv2_hash(user, password, domain, opt={})
111
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
112
+
113
+ if opt[:pass_is_hash]
114
+ ntlmhash = password
115
+ else
116
+ ntlmhash = ntlm_hash(password, opt)
117
+ end
118
+ # With Win 7 and maybe other OSs we sometimes get the domain not uppercased
119
+ userdomain = user.upcase + domain
120
+ unless opt[:unicode]
121
+ userdomain = Rex::Text.to_unicode(userdomain)
122
+ end
123
+ OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, ntlmhash, userdomain)
124
+ end
125
+
126
+ # Create the LANMAN response
127
+ def self.lm_response(arg, half = false)
128
+ begin
129
+ hash = arg[:lm_hash]
130
+ chal = arg[:challenge]
131
+ rescue
132
+ raise ArgumentError
133
+ end
134
+ chal = BASE::pack_int64le(chal) if chal.is_a?(Integer)
135
+ if half then size = 7 else size = 21 end
136
+ keys = gen_keys hash.ljust(size, "\0")
137
+ apply_des(chal, keys).join
138
+ end
139
+
140
+ # Synonym of lm_response for old compatibility with lib/rex/proto/smb/crypt
141
+ def self.lanman_des(password, challenge)
142
+ lm_response({
143
+ :lm_hash => self.lm_hash(password),
144
+ :challenge => challenge
145
+ })
146
+ end
147
+
148
+ def self.ntlm_response(arg)
149
+ hash = arg[:ntlm_hash]
150
+ chal = arg[:challenge]
151
+ chal = BASE::pack_int64le(chal) if chal.is_a?(::Integer)
152
+ keys = gen_keys(hash.ljust(21, "\0"))
153
+ apply_des(chal, keys).join
154
+ end
155
+
156
+ #synonym of ntlm_response for old compatibility with lib/rex/proto/smb/crypt
157
+ def self.ntlm_md4(password, challenge)
158
+ ntlm_response({
159
+ :ntlm_hash => self.ntlm_hash(password),
160
+ :challenge => challenge
161
+ })
162
+ end
163
+
164
+ def self.ntlmv2_response(arg, opt = {})
165
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
166
+
167
+ key, chal = arg[:ntlmv2_hash], arg[:challenge]
168
+ if not (key and chal)
169
+ raise ArgumentError , 'ntlmv2_hash and challenge are mandatory'
170
+ end
171
+
172
+ chal = BASE::pack_int64le(chal) if chal.is_a?(::Integer)
173
+ bb = nil
174
+
175
+ if opt[:nt_client_challenge]
176
+ if opt[:nt_client_challenge].to_s.length <= 8
177
+ raise ArgumentError,"nt_client_challenge is not in a correct format "
178
+ end
179
+ bb = opt[:nt_client_challenge]
180
+ else
181
+ if not arg[:target_info]
182
+ raise ArgumentError, "target_info is mandatory in this case"
183
+ end
184
+
185
+ ti = arg[:target_info]
186
+ cc = opt[:client_challenge] || rand(CONST::MAX64)
187
+ cc = BASE::pack_int64le(cc) if cc.is_a?(::Integer)
188
+
189
+ ts = opt[:timestamp] || Time.now.to_i
190
+
191
+ # Convert the unix timestamp to windows format
192
+ # epoch -> milsec from Jan 1, 1601
193
+ ts = 10000000 * (ts + CONST::TIME_OFFSET)
194
+
195
+ blob = BASE::Blob.new
196
+ blob.timestamp = ts
197
+ blob.challenge = cc
198
+ blob.target_info = ti
199
+
200
+ bb = blob.serialize
201
+ end
202
+
203
+ OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, key, chal + bb) + bb
204
+ end
205
+
206
+ def self.lmv2_response(arg, opt = {})
207
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
208
+ key = arg[:ntlmv2_hash]
209
+ chal = arg[:challenge]
210
+
211
+ chal = BASE::pack_int64le(chal) if chal.is_a?(::Integer)
212
+ cc = opt[:client_challenge] || rand(CONST::MAX64)
213
+ cc = BASE::pack_int64le(cc) if cc.is_a?(::Integer)
214
+
215
+ OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, key, chal + cc) + cc
216
+ end
217
+
218
+ def self.ntlm2_session(arg, opt = {})
219
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
220
+ passwd_hash,chal = arg[:ntlm_hash],arg[:challenge]
221
+ if not (passwd_hash and chal)
222
+ raise RuntimeError, "ntlm_hash and challenge are required"
223
+ end
224
+
225
+ cc = opt[:client_challenge] || rand(CONST::MAX64)
226
+ cc = BASE::pack_int64le(cc) if cc.is_a?(Integer)
227
+
228
+ keys = gen_keys(passwd_hash.ljust(21, "\0"))
229
+ session_hash = OpenSSL::Digest::MD5.digest(chal + cc)[0,8]
230
+ response = apply_des(session_hash, keys).join
231
+ [cc.ljust(24, "\0"), response]
232
+ end
233
+
234
+ #this function will check if the net lm response provided correspond to en empty password
235
+ def self.is_hash_from_empty_pwd?(arg)
236
+ hash_type = arg[:type]
237
+ raise ArgumentError,"arg[:type] is mandatory" if not hash_type
238
+ raise ArgumentError,"arg[:type] must be lm or ntlm" if not hash_type =~ /^((lm)|(ntlm))$/
239
+
240
+ ntlm_ver = arg[:ntlm_ver]
241
+ raise ArgumentError,"arg[:ntlm_ver] is mandatory" if not ntlm_ver
242
+
243
+ hash = arg[:hash]
244
+ raise ArgumentError,"arg[:hash] is mandatory" if not hash
245
+
246
+ srv_chall = arg[:srv_challenge]
247
+ raise ArgumentError,"arg[:srv_challenge] is mandatory" if not srv_chall
248
+ raise ArgumentError,"Server challenge length must be exactly 8 bytes" if srv_chall.length != 8
249
+
250
+ #calculate responses for empty pwd
251
+ case ntlm_ver
252
+ when CONST::NTLM_V1_RESPONSE
253
+ if hash.length != 24
254
+ raise ArgumentError,"hash length must be exactly 24 bytes "
255
+ end
256
+ case hash_type
257
+ when 'lm'
258
+ arglm = { :lm_hash => self.lm_hash(''),
259
+ :challenge => srv_chall}
260
+ calculatedhash = self.lm_response(arglm)
261
+ when 'ntlm'
262
+ argntlm = { :ntlm_hash => self.ntlm_hash(''),
263
+ :challenge => srv_chall }
264
+ calculatedhash = self.ntlm_response(argntlm)
265
+ end
266
+ when CONST::NTLM_V2_RESPONSE
267
+ raise ArgumentError,"hash length must be exactly 16 bytes " if hash.length != 16
268
+ cli_chall = arg[:cli_challenge]
269
+ raise ArgumentError,"arg[:cli_challenge] is mandatory in this case" if not cli_chall
270
+ user = arg[:user]
271
+ raise ArgumentError,"arg[:user] is mandatory in this case" if not user
272
+ domain = arg[:domain]
273
+ raise ArgumentError,"arg[:domain] is mandatory in this case" if not domain
274
+
275
+ case hash_type
276
+ when 'lm'
277
+ raise ArgumentError,"Client challenge length must be exactly 8 bytes " if cli_chall.length != 8
278
+ arglm = { :ntlmv2_hash => self.ntlmv2_hash(user,'', domain),
279
+ :challenge => srv_chall }
280
+ optlm = { :client_challenge => cli_chall}
281
+ calculatedhash = self.lmv2_response(arglm, optlm)[0,16]
282
+ when 'ntlm'
283
+ raise ArgumentError,"Client challenge length must be bigger then 8 bytes " if cli_chall.length <= 8
284
+ argntlm = { :ntlmv2_hash => self.ntlmv2_hash(user, '', domain),
285
+ :challenge => srv_chall }
286
+ optntlm = { :nt_client_challenge => cli_chall}
287
+ calculatedhash = self.ntlmv2_response(argntlm,optntlm)[0,16]
288
+ end
289
+ when CONST::NTLM_2_SESSION_RESPONSE
290
+ raise ArgumentError,"hash length must be exactly 16 bytes " if hash.length != 24
291
+ cli_chall = arg[:cli_challenge]
292
+ raise ArgumentError,"arg[:cli_challenge] is mandatory in this case" if not cli_chall
293
+ raise ArgumentError,"Client challenge length must be exactly 8 bytes " if cli_chall.length != 8
294
+ case hash_type
295
+ when 'lm'
296
+ raise ArgumentError, "ntlm2_session is incompatible with lm"
297
+ when 'ntlm'
298
+ argntlm = { :ntlm_hash => self.ntlm_hash(''),
299
+ :challenge => srv_chall }
300
+ optntlm = { :client_challenge => cli_chall}
301
+ end
302
+ calculatedhash = self.ntlm2_session(argntlm,optntlm).join[24,24]
303
+ else
304
+ raise ArgumentError,"ntlm_ver is of unknow type"
305
+ end
306
+ hash == calculatedhash
307
+ end
308
+
309
+
310
+
311
+ #
312
+ # Signing method added for metasploit project
313
+ #
314
+
315
+ # Used when only the LMv1 response is provided (i.e., with Win9x clients)
316
+ def self.lmv1_user_session_key(pass, opt = {})
317
+ if opt[:pass_is_hash]
318
+ usk = pass[0,8]
319
+ else
320
+ usk = self.lm_hash(pass.upcase[0,7],true)
321
+ end
322
+ usk.ljust(16,"\x00")
323
+ end
324
+
325
+ # This variant is used when the client sends the NTLMv1 response
326
+ def self.ntlmv1_user_session_key(pass, opt = {})
327
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
328
+
329
+ if opt[:pass_is_hash]
330
+ usk = pass
331
+ else
332
+ usk = self.ntlm_hash(pass)
333
+ end
334
+ OpenSSL::Digest::MD4.digest(usk)
335
+ end
336
+
337
+ # Used when NTLMv1 authentication is employed with NTLM2 session security
338
+ def self.ntlm2_session_user_session_key(pass, srv_chall, cli_chall, opt = {})
339
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
340
+
341
+ ntlm_key = self.ntlmv1_user_session_key(pass, opt )
342
+ session_chal = srv_chall + cli_chall
343
+ OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, ntlm_key, session_chal)
344
+ end
345
+
346
+ # Used when the LMv2 response is sent
347
+ def self.lmv2_user_session_key(user, pass, domain, srv_chall, cli_chall, opt = {})
348
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
349
+
350
+ ntlmv2_key = self.ntlmv2_hash(user, pass, domain, opt)
351
+ hash1 = OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, ntlmv2_key, srv_chall + cli_chall)
352
+ OpenSSL::HMAC.digest(OpenSSL::Digest::MD5.new, ntlmv2_key, hash1)
353
+ end
354
+
355
+ # Used when the NTLMv2 response is sent
356
+ class << self; alias_method :ntlmv2_user_session_key, :lmv2_user_session_key; end
357
+
358
+ # Used when LanMan Key flag is set
359
+ def self.lanman_session_key(pass, srvchall, opt = {})
360
+ if opt[:pass_is_hash]
361
+ halfhash = pass[0,8]
362
+ else
363
+ halfhash = lm_hash(pass.upcase[0,7],true)
364
+ end
365
+ plain = self.lm_response({
366
+ :lm_hash => halfhash[0,7],
367
+ :challenge => srvchall
368
+ }, true )
369
+ key = halfhash + ["bdbdbdbdbdbd"].pack("H*")
374
370
  keys = self.gen_keys(key)
375
371
  apply_des(plain, keys).join
376
- end
377
-
378
- def self.encrypt_sessionkey(session_key, user_session_key)
379
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
380
- cipher = OpenSSL::Cipher::Cipher.new('rc4')
381
- cipher.encrypt
382
- cipher.key = user_session_key
383
- cipher.update(session_key)
384
- end
385
-
386
- def self.decrypt_sessionkey(encrypted_session_key, user_session_key)
387
- raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
388
- cipher = OpenSSL::Cipher::Cipher.new('rc4')
389
- cipher.decrypt
390
- cipher.key = user_session_key
391
- cipher.update(encrypted_session_key)
392
- end
393
-
394
- def self.make_weak_sessionkey(session_key,key_size,lanman_key = false)
395
- case key_size
396
- when 40
397
- if lanman_key
398
- return session_key[0,5] + "\xe5\x38\xb0"
399
- else
400
- return session_key[0,5]
401
- end
402
- when 56
403
- if lanman_key
404
- return session_key[0,7] + "\xa0"
405
- else
406
- return session_key[0,7]
407
- end
408
- else #128
409
- return session_key[0,16]
410
- end
411
- end
372
+ end
373
+
374
+ def self.encrypt_sessionkey(session_key, user_session_key)
375
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
376
+ cipher = OpenSSL::Cipher::Cipher.new('rc4')
377
+ cipher.encrypt
378
+ cipher.key = user_session_key
379
+ cipher.update(session_key)
380
+ end
381
+
382
+ def self.decrypt_sessionkey(encrypted_session_key, user_session_key)
383
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
384
+ cipher = OpenSSL::Cipher::Cipher.new('rc4')
385
+ cipher.decrypt
386
+ cipher.key = user_session_key
387
+ cipher.update(encrypted_session_key)
388
+ end
389
+
390
+ def self.make_weak_sessionkey(session_key,key_size,lanman_key = false)
391
+ case key_size
392
+ when 40
393
+ if lanman_key
394
+ return session_key[0,5] + "\xe5\x38\xb0"
395
+ else
396
+ return session_key[0,5]
397
+ end
398
+ when 56
399
+ if lanman_key
400
+ return session_key[0,7] + "\xa0"
401
+ else
402
+ return session_key[0,7]
403
+ end
404
+ else #128
405
+ return session_key[0,16]
406
+ end
407
+ end
412
408
 
413
409
  end
414
410
  end