librex 0.0.19 → 0.0.20

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