librex 0.0.1

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 (370) hide show
  1. data/README +4 -0
  2. data/lib/rex.rb +101 -0
  3. data/lib/rex.rb.ts.rb +70 -0
  4. data/lib/rex/LICENSE +29 -0
  5. data/lib/rex/arch.rb +103 -0
  6. data/lib/rex/arch/sparc.rb +75 -0
  7. data/lib/rex/arch/sparc.rb.ut.rb +18 -0
  8. data/lib/rex/arch/x86.rb +513 -0
  9. data/lib/rex/arch/x86.rb.ut.rb +93 -0
  10. data/lib/rex/assembly/nasm.rb +100 -0
  11. data/lib/rex/assembly/nasm.rb.ut.rb +22 -0
  12. data/lib/rex/codepage.map +104 -0
  13. data/lib/rex/compat.rb +281 -0
  14. data/lib/rex/constants.rb +113 -0
  15. data/lib/rex/elfparsey.rb +11 -0
  16. data/lib/rex/elfparsey/elf.rb +123 -0
  17. data/lib/rex/elfparsey/elfbase.rb +260 -0
  18. data/lib/rex/elfparsey/exceptions.rb +27 -0
  19. data/lib/rex/elfscan.rb +12 -0
  20. data/lib/rex/elfscan/scanner.rb +207 -0
  21. data/lib/rex/elfscan/search.rb +46 -0
  22. data/lib/rex/encoder/alpha2.rb +31 -0
  23. data/lib/rex/encoder/alpha2/alpha_mixed.rb +68 -0
  24. data/lib/rex/encoder/alpha2/alpha_upper.rb +79 -0
  25. data/lib/rex/encoder/alpha2/generic.rb +113 -0
  26. data/lib/rex/encoder/alpha2/unicode_mixed.rb +117 -0
  27. data/lib/rex/encoder/alpha2/unicode_upper.rb +129 -0
  28. data/lib/rex/encoder/ndr.rb +89 -0
  29. data/lib/rex/encoder/ndr.rb.ut.rb +44 -0
  30. data/lib/rex/encoder/nonalpha.rb +61 -0
  31. data/lib/rex/encoder/nonupper.rb +64 -0
  32. data/lib/rex/encoder/xdr.rb +106 -0
  33. data/lib/rex/encoder/xdr.rb.ut.rb +29 -0
  34. data/lib/rex/encoder/xor.rb +69 -0
  35. data/lib/rex/encoder/xor/dword.rb +13 -0
  36. data/lib/rex/encoder/xor/dword_additive.rb +13 -0
  37. data/lib/rex/encoders/xor_dword.rb +35 -0
  38. data/lib/rex/encoders/xor_dword_additive.rb +53 -0
  39. data/lib/rex/encoders/xor_dword_additive.rb.ut.rb +12 -0
  40. data/lib/rex/encoding/xor.rb +20 -0
  41. data/lib/rex/encoding/xor.rb.ts.rb +14 -0
  42. data/lib/rex/encoding/xor/byte.rb +15 -0
  43. data/lib/rex/encoding/xor/byte.rb.ut.rb +21 -0
  44. data/lib/rex/encoding/xor/dword.rb +21 -0
  45. data/lib/rex/encoding/xor/dword.rb.ut.rb +15 -0
  46. data/lib/rex/encoding/xor/dword_additive.rb +92 -0
  47. data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +15 -0
  48. data/lib/rex/encoding/xor/exceptions.rb +17 -0
  49. data/lib/rex/encoding/xor/generic.rb +146 -0
  50. data/lib/rex/encoding/xor/generic.rb.ut.rb +120 -0
  51. data/lib/rex/encoding/xor/qword.rb +15 -0
  52. data/lib/rex/encoding/xor/word.rb +21 -0
  53. data/lib/rex/encoding/xor/word.rb.ut.rb +13 -0
  54. data/lib/rex/exceptions.rb +275 -0
  55. data/lib/rex/exceptions.rb.ut.rb +44 -0
  56. data/lib/rex/exploitation/cmdstager.rb +133 -0
  57. data/lib/rex/exploitation/egghunter.rb +143 -0
  58. data/lib/rex/exploitation/egghunter.rb.ut.rb +25 -0
  59. data/lib/rex/exploitation/encryptjs.rb +77 -0
  60. data/lib/rex/exploitation/heaplib.js.b64 +331 -0
  61. data/lib/rex/exploitation/heaplib.rb +94 -0
  62. data/lib/rex/exploitation/javascriptosdetect.rb +735 -0
  63. data/lib/rex/exploitation/obfuscatejs.rb +335 -0
  64. data/lib/rex/exploitation/opcodedb.rb +818 -0
  65. data/lib/rex/exploitation/opcodedb.rb.ut.rb +279 -0
  66. data/lib/rex/exploitation/seh.rb +92 -0
  67. data/lib/rex/exploitation/seh.rb.ut.rb +19 -0
  68. data/lib/rex/file.rb +84 -0
  69. data/lib/rex/file.rb.ut.rb +16 -0
  70. data/lib/rex/image_source.rb +12 -0
  71. data/lib/rex/image_source/disk.rb +60 -0
  72. data/lib/rex/image_source/image_source.rb +46 -0
  73. data/lib/rex/image_source/memory.rb +37 -0
  74. data/lib/rex/io/bidirectional_pipe.rb +157 -0
  75. data/lib/rex/io/datagram_abstraction.rb +35 -0
  76. data/lib/rex/io/stream.rb +313 -0
  77. data/lib/rex/io/stream_abstraction.rb +186 -0
  78. data/lib/rex/io/stream_server.rb +211 -0
  79. data/lib/rex/job_container.rb +202 -0
  80. data/lib/rex/logging.rb +4 -0
  81. data/lib/rex/logging/log_dispatcher.rb +179 -0
  82. data/lib/rex/logging/log_sink.rb +42 -0
  83. data/lib/rex/logging/sinks/flatfile.rb +55 -0
  84. data/lib/rex/logging/sinks/stderr.rb +43 -0
  85. data/lib/rex/machparsey.rb +9 -0
  86. data/lib/rex/machparsey/exceptions.rb +34 -0
  87. data/lib/rex/machparsey/mach.rb +209 -0
  88. data/lib/rex/machparsey/machbase.rb +408 -0
  89. data/lib/rex/machscan.rb +9 -0
  90. data/lib/rex/machscan/scanner.rb +217 -0
  91. data/lib/rex/mime.rb +9 -0
  92. data/lib/rex/mime/header.rb +75 -0
  93. data/lib/rex/mime/message.rb +112 -0
  94. data/lib/rex/mime/part.rb +20 -0
  95. data/lib/rex/nop/opty2.rb +108 -0
  96. data/lib/rex/nop/opty2.rb.ut.rb +23 -0
  97. data/lib/rex/nop/opty2_tables.rb +300 -0
  98. data/lib/rex/ole.rb +128 -0
  99. data/lib/rex/ole/clsid.rb +47 -0
  100. data/lib/rex/ole/difat.rb +141 -0
  101. data/lib/rex/ole/directory.rb +230 -0
  102. data/lib/rex/ole/direntry.rb +240 -0
  103. data/lib/rex/ole/fat.rb +99 -0
  104. data/lib/rex/ole/header.rb +204 -0
  105. data/lib/rex/ole/minifat.rb +77 -0
  106. data/lib/rex/ole/samples/create_ole.rb +27 -0
  107. data/lib/rex/ole/samples/dir.rb +35 -0
  108. data/lib/rex/ole/samples/dump_stream.rb +34 -0
  109. data/lib/rex/ole/samples/ole_info.rb +23 -0
  110. data/lib/rex/ole/storage.rb +395 -0
  111. data/lib/rex/ole/stream.rb +53 -0
  112. data/lib/rex/ole/substorage.rb +49 -0
  113. data/lib/rex/ole/util.rb +157 -0
  114. data/lib/rex/parser/arguments.rb +97 -0
  115. data/lib/rex/parser/arguments.rb.ut.rb +67 -0
  116. data/lib/rex/parser/ini.rb +185 -0
  117. data/lib/rex/parser/ini.rb.ut.rb +29 -0
  118. data/lib/rex/parser/nmap_xml.rb +111 -0
  119. data/lib/rex/payloads.rb +1 -0
  120. data/lib/rex/payloads/win32.rb +2 -0
  121. data/lib/rex/payloads/win32/common.rb +26 -0
  122. data/lib/rex/payloads/win32/kernel.rb +53 -0
  123. data/lib/rex/payloads/win32/kernel/common.rb +54 -0
  124. data/lib/rex/payloads/win32/kernel/migration.rb +12 -0
  125. data/lib/rex/payloads/win32/kernel/recovery.rb +50 -0
  126. data/lib/rex/payloads/win32/kernel/stager.rb +171 -0
  127. data/lib/rex/peparsey.rb +12 -0
  128. data/lib/rex/peparsey/exceptions.rb +32 -0
  129. data/lib/rex/peparsey/pe.rb +188 -0
  130. data/lib/rex/peparsey/pe_memdump.rb +63 -0
  131. data/lib/rex/peparsey/pebase.rb +1655 -0
  132. data/lib/rex/peparsey/section.rb +136 -0
  133. data/lib/rex/pescan.rb +13 -0
  134. data/lib/rex/pescan/analyze.rb +309 -0
  135. data/lib/rex/pescan/scanner.rb +206 -0
  136. data/lib/rex/pescan/search.rb +56 -0
  137. data/lib/rex/platforms.rb +1 -0
  138. data/lib/rex/platforms/windows.rb +51 -0
  139. data/lib/rex/poly.rb +132 -0
  140. data/lib/rex/poly/block.rb +468 -0
  141. data/lib/rex/poly/register.rb +100 -0
  142. data/lib/rex/poly/register/x86.rb +40 -0
  143. data/lib/rex/post.rb +8 -0
  144. data/lib/rex/post/dir.rb +51 -0
  145. data/lib/rex/post/file.rb +172 -0
  146. data/lib/rex/post/file_stat.rb +220 -0
  147. data/lib/rex/post/gen.pl +13 -0
  148. data/lib/rex/post/io.rb +182 -0
  149. data/lib/rex/post/meterpreter.rb +4 -0
  150. data/lib/rex/post/meterpreter/channel.rb +438 -0
  151. data/lib/rex/post/meterpreter/channel_container.rb +54 -0
  152. data/lib/rex/post/meterpreter/channels/pool.rb +160 -0
  153. data/lib/rex/post/meterpreter/channels/pools/file.rb +62 -0
  154. data/lib/rex/post/meterpreter/channels/pools/stream_pool.rb +103 -0
  155. data/lib/rex/post/meterpreter/channels/stream.rb +87 -0
  156. data/lib/rex/post/meterpreter/client.rb +335 -0
  157. data/lib/rex/post/meterpreter/client_core.rb +274 -0
  158. data/lib/rex/post/meterpreter/dependencies.rb +3 -0
  159. data/lib/rex/post/meterpreter/extension.rb +32 -0
  160. data/lib/rex/post/meterpreter/extensions/espia/espia.rb +58 -0
  161. data/lib/rex/post/meterpreter/extensions/espia/tlv.rb +16 -0
  162. data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +94 -0
  163. data/lib/rex/post/meterpreter/extensions/incognito/tlv.rb +21 -0
  164. data/lib/rex/post/meterpreter/extensions/priv/fs.rb +118 -0
  165. data/lib/rex/post/meterpreter/extensions/priv/passwd.rb +61 -0
  166. data/lib/rex/post/meterpreter/extensions/priv/priv.rb +104 -0
  167. data/lib/rex/post/meterpreter/extensions/priv/tlv.rb +28 -0
  168. data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +100 -0
  169. data/lib/rex/post/meterpreter/extensions/sniffer/tlv.rb +24 -0
  170. data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +333 -0
  171. data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +273 -0
  172. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +235 -0
  173. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +103 -0
  174. data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +48 -0
  175. data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +144 -0
  176. data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +73 -0
  177. data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +56 -0
  178. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +137 -0
  179. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +167 -0
  180. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +167 -0
  181. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +192 -0
  182. data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +139 -0
  183. data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +97 -0
  184. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +184 -0
  185. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log_subsystem/event_record.rb +41 -0
  186. data/lib/rex/post/meterpreter/extensions/stdapi/sys/power.rb +61 -0
  187. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +361 -0
  188. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/image.rb +129 -0
  189. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/io.rb +55 -0
  190. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/memory.rb +336 -0
  191. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/thread.rb +141 -0
  192. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb +279 -0
  193. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +182 -0
  194. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +102 -0
  195. data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +174 -0
  196. data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +185 -0
  197. data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +227 -0
  198. data/lib/rex/post/meterpreter/inbound_packet_handler.rb +30 -0
  199. data/lib/rex/post/meterpreter/object_aliases.rb +83 -0
  200. data/lib/rex/post/meterpreter/packet.rb +596 -0
  201. data/lib/rex/post/meterpreter/packet_dispatcher.rb +409 -0
  202. data/lib/rex/post/meterpreter/packet_parser.rb +94 -0
  203. data/lib/rex/post/meterpreter/packet_response_waiter.rb +83 -0
  204. data/lib/rex/post/meterpreter/ui/console.rb +135 -0
  205. data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +62 -0
  206. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +595 -0
  207. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +108 -0
  208. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +241 -0
  209. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +61 -0
  210. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +98 -0
  211. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +51 -0
  212. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +132 -0
  213. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +187 -0
  214. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +63 -0
  215. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +376 -0
  216. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +270 -0
  217. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +484 -0
  218. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +315 -0
  219. data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +95 -0
  220. data/lib/rex/post/permission.rb +26 -0
  221. data/lib/rex/post/process.rb +57 -0
  222. data/lib/rex/post/thread.rb +57 -0
  223. data/lib/rex/post/ui.rb +52 -0
  224. data/lib/rex/proto.rb +12 -0
  225. data/lib/rex/proto.rb.ts.rb +8 -0
  226. data/lib/rex/proto/dcerpc.rb +6 -0
  227. data/lib/rex/proto/dcerpc.rb.ts.rb +9 -0
  228. data/lib/rex/proto/dcerpc/client.rb +358 -0
  229. data/lib/rex/proto/dcerpc/client.rb.ut.rb +491 -0
  230. data/lib/rex/proto/dcerpc/exceptions.rb +150 -0
  231. data/lib/rex/proto/dcerpc/handle.rb +47 -0
  232. data/lib/rex/proto/dcerpc/handle.rb.ut.rb +85 -0
  233. data/lib/rex/proto/dcerpc/ndr.rb +72 -0
  234. data/lib/rex/proto/dcerpc/ndr.rb.ut.rb +41 -0
  235. data/lib/rex/proto/dcerpc/packet.rb +253 -0
  236. data/lib/rex/proto/dcerpc/packet.rb.ut.rb +56 -0
  237. data/lib/rex/proto/dcerpc/response.rb +186 -0
  238. data/lib/rex/proto/dcerpc/response.rb.ut.rb +15 -0
  239. data/lib/rex/proto/dcerpc/uuid.rb +84 -0
  240. data/lib/rex/proto/dcerpc/uuid.rb.ut.rb +46 -0
  241. data/lib/rex/proto/drda.rb +5 -0
  242. data/lib/rex/proto/drda.rb.ts.rb +17 -0
  243. data/lib/rex/proto/drda/constants.rb +49 -0
  244. data/lib/rex/proto/drda/constants.rb.ut.rb +23 -0
  245. data/lib/rex/proto/drda/packet.rb +252 -0
  246. data/lib/rex/proto/drda/packet.rb.ut.rb +109 -0
  247. data/lib/rex/proto/drda/utils.rb +123 -0
  248. data/lib/rex/proto/drda/utils.rb.ut.rb +84 -0
  249. data/lib/rex/proto/http.rb +5 -0
  250. data/lib/rex/proto/http.rb.ts.rb +12 -0
  251. data/lib/rex/proto/http/client.rb +817 -0
  252. data/lib/rex/proto/http/client.rb.ut.rb +93 -0
  253. data/lib/rex/proto/http/handler.rb +46 -0
  254. data/lib/rex/proto/http/handler/erb.rb +128 -0
  255. data/lib/rex/proto/http/handler/erb.rb.ut.rb +21 -0
  256. data/lib/rex/proto/http/handler/erb.rb.ut.rb.rhtml +1 -0
  257. data/lib/rex/proto/http/handler/proc.rb +54 -0
  258. data/lib/rex/proto/http/handler/proc.rb.ut.rb +24 -0
  259. data/lib/rex/proto/http/header.rb +161 -0
  260. data/lib/rex/proto/http/header.rb.ut.rb +46 -0
  261. data/lib/rex/proto/http/packet.rb +394 -0
  262. data/lib/rex/proto/http/packet.rb.ut.rb +165 -0
  263. data/lib/rex/proto/http/request.rb +356 -0
  264. data/lib/rex/proto/http/request.rb.ut.rb +214 -0
  265. data/lib/rex/proto/http/response.rb +85 -0
  266. data/lib/rex/proto/http/response.rb.ut.rb +149 -0
  267. data/lib/rex/proto/http/server.rb +367 -0
  268. data/lib/rex/proto/http/server.rb.ut.rb +79 -0
  269. data/lib/rex/proto/smb.rb +7 -0
  270. data/lib/rex/proto/smb.rb.ts.rb +8 -0
  271. data/lib/rex/proto/smb/client.rb +1733 -0
  272. data/lib/rex/proto/smb/client.rb.ut.rb +223 -0
  273. data/lib/rex/proto/smb/constants.rb +1062 -0
  274. data/lib/rex/proto/smb/constants.rb.ut.rb +18 -0
  275. data/lib/rex/proto/smb/crypt.rb +95 -0
  276. data/lib/rex/proto/smb/crypt.rb.ut.rb +20 -0
  277. data/lib/rex/proto/smb/evasions.rb +65 -0
  278. data/lib/rex/proto/smb/exceptions.rb +846 -0
  279. data/lib/rex/proto/smb/simpleclient.rb +292 -0
  280. data/lib/rex/proto/smb/simpleclient.rb.ut.rb +128 -0
  281. data/lib/rex/proto/smb/utils.rb +514 -0
  282. data/lib/rex/proto/smb/utils.rb.ut.rb +20 -0
  283. data/lib/rex/proto/sunrpc.rb +1 -0
  284. data/lib/rex/proto/sunrpc/client.rb +195 -0
  285. data/lib/rex/script.rb +42 -0
  286. data/lib/rex/script/base.rb +59 -0
  287. data/lib/rex/script/meterpreter.rb +9 -0
  288. data/lib/rex/script/shell.rb +9 -0
  289. data/lib/rex/service.rb +48 -0
  290. data/lib/rex/service_manager.rb +141 -0
  291. data/lib/rex/service_manager.rb.ut.rb +32 -0
  292. data/lib/rex/services/local_relay.rb +423 -0
  293. data/lib/rex/socket.rb +586 -0
  294. data/lib/rex/socket.rb.ut.rb +86 -0
  295. data/lib/rex/socket/comm.rb +119 -0
  296. data/lib/rex/socket/comm/local.rb +409 -0
  297. data/lib/rex/socket/comm/local.rb.ut.rb +75 -0
  298. data/lib/rex/socket/ip.rb +129 -0
  299. data/lib/rex/socket/parameters.rb +345 -0
  300. data/lib/rex/socket/parameters.rb.ut.rb +51 -0
  301. data/lib/rex/socket/range_walker.rb +295 -0
  302. data/lib/rex/socket/range_walker.rb.ut.rb +55 -0
  303. data/lib/rex/socket/ssl_tcp.rb +184 -0
  304. data/lib/rex/socket/ssl_tcp.rb.ut.rb +39 -0
  305. data/lib/rex/socket/ssl_tcp_server.rb +122 -0
  306. data/lib/rex/socket/ssl_tcp_server.rb.ut.rb +51 -0
  307. data/lib/rex/socket/subnet_walker.rb +75 -0
  308. data/lib/rex/socket/subnet_walker.rb.ut.rb +28 -0
  309. data/lib/rex/socket/switch_board.rb +272 -0
  310. data/lib/rex/socket/switch_board.rb.ut.rb +52 -0
  311. data/lib/rex/socket/tcp.rb +76 -0
  312. data/lib/rex/socket/tcp.rb.ut.rb +64 -0
  313. data/lib/rex/socket/tcp_server.rb +67 -0
  314. data/lib/rex/socket/tcp_server.rb.ut.rb +44 -0
  315. data/lib/rex/socket/udp.rb +157 -0
  316. data/lib/rex/socket/udp.rb.ut.rb +44 -0
  317. data/lib/rex/struct2.rb +5 -0
  318. data/lib/rex/struct2/c_struct.rb +181 -0
  319. data/lib/rex/struct2/c_struct_template.rb +39 -0
  320. data/lib/rex/struct2/constant.rb +26 -0
  321. data/lib/rex/struct2/element.rb +44 -0
  322. data/lib/rex/struct2/generic.rb +73 -0
  323. data/lib/rex/struct2/restraint.rb +54 -0
  324. data/lib/rex/struct2/s_string.rb +72 -0
  325. data/lib/rex/struct2/s_struct.rb +111 -0
  326. data/lib/rex/sync.rb +6 -0
  327. data/lib/rex/sync/event.rb +94 -0
  328. data/lib/rex/sync/read_write_lock.rb +176 -0
  329. data/lib/rex/sync/ref.rb +57 -0
  330. data/lib/rex/sync/thread_safe.rb +82 -0
  331. data/lib/rex/test.rb +35 -0
  332. data/lib/rex/text.rb +1029 -0
  333. data/lib/rex/text.rb.ut.rb +168 -0
  334. data/lib/rex/time.rb +65 -0
  335. data/lib/rex/transformer.rb +115 -0
  336. data/lib/rex/transformer.rb.ut.rb +38 -0
  337. data/lib/rex/ui.rb +21 -0
  338. data/lib/rex/ui/interactive.rb +252 -0
  339. data/lib/rex/ui/output.rb +80 -0
  340. data/lib/rex/ui/output/none.rb +18 -0
  341. data/lib/rex/ui/progress_tracker.rb +96 -0
  342. data/lib/rex/ui/subscriber.rb +149 -0
  343. data/lib/rex/ui/text/color.rb +97 -0
  344. data/lib/rex/ui/text/color.rb.ut.rb +18 -0
  345. data/lib/rex/ui/text/dispatcher_shell.rb +382 -0
  346. data/lib/rex/ui/text/input.rb +117 -0
  347. data/lib/rex/ui/text/input/buffer.rb +75 -0
  348. data/lib/rex/ui/text/input/readline.rb +129 -0
  349. data/lib/rex/ui/text/input/socket.rb +95 -0
  350. data/lib/rex/ui/text/input/stdio.rb +45 -0
  351. data/lib/rex/ui/text/irb_shell.rb +55 -0
  352. data/lib/rex/ui/text/output.rb +80 -0
  353. data/lib/rex/ui/text/output/buffer.rb +65 -0
  354. data/lib/rex/ui/text/output/file.rb +37 -0
  355. data/lib/rex/ui/text/output/socket.rb +43 -0
  356. data/lib/rex/ui/text/output/stdio.rb +40 -0
  357. data/lib/rex/ui/text/progress_tracker.rb +56 -0
  358. data/lib/rex/ui/text/progress_tracker.rb.ut.rb +34 -0
  359. data/lib/rex/ui/text/shell.rb +321 -0
  360. data/lib/rex/ui/text/table.rb +254 -0
  361. data/lib/rex/ui/text/table.rb.ut.rb +55 -0
  362. data/lib/rex/zip.rb +93 -0
  363. data/lib/rex/zip/archive.rb +91 -0
  364. data/lib/rex/zip/blocks.rb +182 -0
  365. data/lib/rex/zip/entry.rb +95 -0
  366. data/lib/rex/zip/samples/comment.rb +32 -0
  367. data/lib/rex/zip/samples/mkwar.rb +138 -0
  368. data/lib/rex/zip/samples/mkzip.rb +19 -0
  369. data/lib/rex/zip/samples/recursive.rb +58 -0
  370. metadata +435 -0
@@ -0,0 +1,273 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rex/post/dir'
4
+ require 'rex/post/meterpreter/extensions/stdapi/stdapi'
5
+
6
+ module Rex
7
+ module Post
8
+ module Meterpreter
9
+ module Extensions
10
+ module Stdapi
11
+ module Fs
12
+
13
+ ###
14
+ #
15
+ # This class implements directory operations against the remote endpoint. It
16
+ # implements the Rex::Post::Dir interface.
17
+ #
18
+ ###
19
+ class Dir < Rex::Post::Dir
20
+
21
+ class <<self
22
+ attr_accessor :client
23
+ end
24
+
25
+ ##
26
+ #
27
+ # Constructor
28
+ #
29
+ ##
30
+
31
+ #
32
+ # Initializes the directory instance.
33
+ #
34
+ def initialize(path)
35
+ self.path = path
36
+ self.client = self.class.client
37
+ end
38
+
39
+ ##
40
+ #
41
+ # Enumeration
42
+ #
43
+ ##
44
+
45
+ #
46
+ # Enumerates all of the contents of the directory.
47
+ #
48
+ def each(&block)
49
+ client.fs.dir.foreach(self.path, &block)
50
+ end
51
+
52
+ #
53
+ # Enumerates all of the files/folders in a given directory.
54
+ #
55
+ def Dir.entries(name = getwd)
56
+ request = Packet.create_request('stdapi_fs_ls')
57
+ files = []
58
+
59
+ request.add_tlv(TLV_TYPE_DIRECTORY_PATH, name)
60
+
61
+ response = client.send_request(request)
62
+
63
+ response.each(TLV_TYPE_FILE_NAME) { |file_name|
64
+ files << file_name.value
65
+ }
66
+
67
+ return files
68
+ end
69
+
70
+ #
71
+ # Enumerates files with a bit more information than the default entries.
72
+ #
73
+ def Dir.entries_with_info(name = getwd)
74
+ request = Packet.create_request('stdapi_fs_ls')
75
+ files = []
76
+
77
+ request.add_tlv(TLV_TYPE_DIRECTORY_PATH, name)
78
+
79
+ response = client.send_request(request)
80
+
81
+ fname = response.get_tlvs(TLV_TYPE_FILE_NAME)
82
+ fpath = response.get_tlvs(TLV_TYPE_FILE_PATH)
83
+ sbuf = response.get_tlvs(TLV_TYPE_STAT_BUF)
84
+
85
+ if (!fname or !sbuf)
86
+ return []
87
+ end
88
+
89
+ fname.each_with_index { |file_name, idx|
90
+ st = nil
91
+
92
+ if (sbuf[idx])
93
+ st = ::Rex::Post::FileStat.new
94
+ st.update(sbuf[idx].value)
95
+ end
96
+
97
+ files <<
98
+ {
99
+ 'FileName' => file_name.value,
100
+ 'FilePath' => fpath[idx].value,
101
+ 'StatBuf' => st,
102
+ }
103
+ }
104
+
105
+ return files
106
+ end
107
+
108
+ ##
109
+ #
110
+ # General directory operations
111
+ #
112
+ ##
113
+
114
+ #
115
+ # Changes the working directory of the remote process.
116
+ #
117
+ def Dir.chdir(path)
118
+ request = Packet.create_request('stdapi_fs_chdir')
119
+
120
+ request.add_tlv(TLV_TYPE_DIRECTORY_PATH, path)
121
+
122
+ response = client.send_request(request)
123
+
124
+ return 0
125
+ end
126
+
127
+ #
128
+ # Creates a directory.
129
+ #
130
+ def Dir.mkdir(path)
131
+ request = Packet.create_request('stdapi_fs_mkdir')
132
+
133
+ request.add_tlv(TLV_TYPE_DIRECTORY_PATH, path)
134
+
135
+ response = client.send_request(request)
136
+
137
+ return 0
138
+ end
139
+
140
+ #
141
+ # Returns the current working directory of the remote process.
142
+ #
143
+ def Dir.pwd
144
+ request = Packet.create_request('stdapi_fs_getwd')
145
+
146
+ response = client.send_request(request)
147
+
148
+ return response.get_tlv(TLV_TYPE_DIRECTORY_PATH).value
149
+ end
150
+
151
+ #
152
+ # Synonym for pwd.
153
+ #
154
+ def Dir.getwd
155
+ pwd
156
+ end
157
+
158
+ #
159
+ # Removes the supplied directory if it's empty.
160
+ #
161
+ def Dir.delete(path)
162
+ request = Packet.create_request('stdapi_fs_delete_dir')
163
+
164
+ request.add_tlv(TLV_TYPE_DIRECTORY_PATH, path)
165
+
166
+ response = client.send_request(request)
167
+
168
+ return 0
169
+ end
170
+
171
+ #
172
+ # Synonyms for delete.
173
+ #
174
+ def Dir.rmdir(path)
175
+ delete(path)
176
+ end
177
+
178
+ #
179
+ # Synonyms for delete.
180
+ #
181
+ def Dir.unlink(path)
182
+ delete(path)
183
+ end
184
+
185
+ ##
186
+ #
187
+ # Directory mirroring
188
+ #
189
+ ##
190
+
191
+ #
192
+ # Downloads the contents of a remote directory a
193
+ # local directory, optionally in a recursive fashion.
194
+ #
195
+ def Dir.download(dst, src, recursive = false, &stat)
196
+ self.entries(src).each { |src_sub|
197
+ dst_item = dst + ::File::SEPARATOR + src_sub
198
+ src_item = src + File::SEPARATOR + src_sub
199
+
200
+ if (src_sub == '.' or src_sub == '..')
201
+ next
202
+ end
203
+
204
+ src_stat = client.fs.filestat.new(src_item)
205
+
206
+ if (src_stat.file?)
207
+ stat.call('downloading', src_item, dst_item) if (stat)
208
+ client.fs.file.download(dst_item, src_item)
209
+ stat.call('downloaded', src_item, dst_item) if (stat)
210
+ elsif (src_stat.directory?)
211
+ if (recursive == false)
212
+ next
213
+ end
214
+
215
+ begin
216
+ ::Dir.mkdir(dst_item)
217
+ rescue
218
+ end
219
+
220
+ stat.call('mirroring', src_item, dst_item) if (stat)
221
+ download(dst_item, src_item, recursive, &stat)
222
+ stat.call('mirrored', src_item, dst_item) if (stat)
223
+ end
224
+ }
225
+ end
226
+
227
+ #
228
+ # Uploads the contents of a local directory to a remote
229
+ # directory, optionally in a recursive fashion.
230
+ #
231
+ def Dir.upload(dst, src, recursive = false, &stat)
232
+ ::Dir.entries(src).each { |src_sub|
233
+ dst_item = dst + File::SEPARATOR + src_sub
234
+ src_item = src + ::File::SEPARATOR + src_sub
235
+
236
+ if (src_sub == '.' or src_sub == '..')
237
+ next
238
+ end
239
+
240
+ src_stat = ::File.stat(src_item)
241
+
242
+ if (src_stat.file?)
243
+ stat.call('uploading', src_item, dst_item) if (stat)
244
+ client.fs.file.upload(dst_item, src_item)
245
+ stat.call('uploaded', src_item, dst_item) if (stat)
246
+ elsif (src_stat.directory?)
247
+ if (recursive == false)
248
+ next
249
+ end
250
+
251
+ begin
252
+ self.mkdir(dst_item)
253
+ rescue
254
+ end
255
+
256
+ stat.call('mirroring', src_item, dst_item) if (stat)
257
+ upload(dst_item, src_item, recursive, &stat)
258
+ stat.call('mirrored', src_item, dst_item) if (stat)
259
+ end
260
+ }
261
+ end
262
+
263
+ #
264
+ # The path of the directory that was opened.
265
+ #
266
+ attr_reader :path
267
+ protected
268
+ attr_accessor :client # :nodoc:
269
+ attr_writer :path # :nodoc:
270
+
271
+ end
272
+
273
+ end; end; end; end; end; end
@@ -0,0 +1,235 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rex/post/file'
4
+ require 'rex/post/meterpreter/channel'
5
+ require 'rex/post/meterpreter/channels/pools/file'
6
+ require 'rex/post/meterpreter/extensions/stdapi/stdapi'
7
+ require 'rex/post/meterpreter/extensions/stdapi/fs/io'
8
+ require 'rex/post/meterpreter/extensions/stdapi/fs/file_stat'
9
+ require 'fileutils'
10
+
11
+ module Rex
12
+ module Post
13
+ module Meterpreter
14
+ module Extensions
15
+ module Stdapi
16
+ module Fs
17
+
18
+ ###
19
+ #
20
+ # This class implements the Rex::Post::File interface and wraps interaction
21
+ # with files on the remote machine.
22
+ #
23
+ ###
24
+ class File < Rex::Post::Meterpreter::Extensions::Stdapi::Fs::IO
25
+
26
+ SEPARATOR = "\\"
27
+ Separator = "\\"
28
+
29
+ include Rex::Post::File
30
+
31
+ class <<self
32
+ attr_accessor :client
33
+ end
34
+
35
+ #
36
+ # Returns the base name of the supplied file path to the caller.
37
+ #
38
+ def File.basename(*a)
39
+ path = a[0]
40
+ sep = "\\" + File::SEPARATOR
41
+
42
+ # I suck at regex.
43
+ path =~ /(.*)#{sep}(.*)$/
44
+
45
+ return $2 || path
46
+ end
47
+
48
+ #
49
+ # Expands a file path, substituting all environment variables, such as
50
+ # %TEMP%.
51
+ #
52
+ def File.expand_path(path)
53
+ request = Packet.create_request('stdapi_fs_file_expand_path')
54
+
55
+ request.add_tlv(TLV_TYPE_FILE_PATH, path)
56
+
57
+ response = client.send_request(request)
58
+
59
+ return response.get_tlv_value(TLV_TYPE_FILE_PATH)
60
+ end
61
+
62
+ #
63
+ # Performs a stat on a file and returns a FileStat instance.
64
+ #
65
+ def File.stat(name)
66
+ return client.fs.filestat.new(name)
67
+ end
68
+
69
+ #
70
+ # Performs a delete on the specified file.
71
+ #
72
+ def File.rm(name)
73
+ request = Packet.create_request('stdapi_fs_delete_file')
74
+
75
+ request.add_tlv(TLV_TYPE_FILE_PATH,name)
76
+
77
+ response = client.send_request(request)
78
+
79
+ return response
80
+ end
81
+
82
+ #
83
+ # Performs a delete on the specified file.
84
+ #
85
+ def File.unlink(name)
86
+ return File.rm(name)
87
+ end
88
+
89
+ #
90
+ # Upload one or more files to the remote computer the remote
91
+ # directory supplied in destination.
92
+ #
93
+ def File.upload(destination, *src_files, &stat)
94
+ src_files.each { |src|
95
+ dest = destination
96
+
97
+ stat.call('uploading', src, dest) if (stat)
98
+ if (File.basename(destination) != ::File.basename(src))
99
+ dest += File::SEPARATOR + ::File.basename(src)
100
+ end
101
+
102
+ upload_file(dest, src)
103
+ stat.call('uploaded', src, dest) if (stat)
104
+ }
105
+ end
106
+
107
+ #
108
+ # Upload a single file.
109
+ #
110
+ def File.upload_file(dest_file, src_file)
111
+ # Open the file on the remote side for writing and read
112
+ # all of the contents of the local file
113
+ dest_fd = client.fs.file.new(dest_file, "wb")
114
+ src_buf = ''
115
+
116
+ ::File.open(src_file, 'rb') { |f|
117
+ src_buf = f.read(f.stat.size)
118
+ }
119
+
120
+ begin
121
+ dest_fd.write(src_buf)
122
+ ensure
123
+ dest_fd.close
124
+ end
125
+ end
126
+
127
+ #
128
+ # Download one or more files from the remote computer to the local
129
+ # directory supplied in destination.
130
+ #
131
+ def File.download(destination, *src_files, &stat)
132
+ src_files.each { |src|
133
+ dest = destination
134
+
135
+ stat.call('downloading', src, dest) if (stat)
136
+
137
+ if (::File.basename(destination) != File.basename(src))
138
+ dest += ::File::SEPARATOR + File.basename(src)
139
+ end
140
+
141
+ download_file(dest, src)
142
+
143
+ stat.call('downloaded', src, dest) if (stat)
144
+ }
145
+ end
146
+
147
+ #
148
+ # Download a single file.
149
+ #
150
+ def File.download_file(dest_file, src_file)
151
+ src_fd = client.fs.file.new(src_file, "rb")
152
+ ::FileUtils.mkdir_p(::File.dirname(dest_file))
153
+ dst_fd = ::File.new(dest_file, "wb")
154
+
155
+ # Keep transferring until EOF is reached...
156
+ begin
157
+ while ((data = src_fd.read) != nil)
158
+ dst_fd.write(data)
159
+ end
160
+ rescue EOFError
161
+ ensure
162
+ src_fd.close
163
+ dst_fd.close
164
+ end
165
+ end
166
+
167
+ ##
168
+ #
169
+ # Constructor
170
+ #
171
+ ##
172
+
173
+ #
174
+ # Initializes and opens the specified file with the specified permissions.
175
+ #
176
+ def initialize(name, mode = "r", perms = 0)
177
+ self.client = self.class.client
178
+ self.filed = _open(name, mode, perms)
179
+ end
180
+
181
+ ##
182
+ #
183
+ # IO implementators
184
+ #
185
+ ##
186
+
187
+ #
188
+ # Returns whether or not the file has reach EOF.
189
+ #
190
+ def eof
191
+ return self.filed.eof
192
+ end
193
+
194
+ #
195
+ # Returns the current position of the file pointer.
196
+ #
197
+ def pos
198
+ return self.filed.tell
199
+ end
200
+
201
+ #
202
+ # Synonym for sysseek.
203
+ #
204
+ def seek(offset, whence = SEEK_SET)
205
+ return self.sysseek(offset, whence)
206
+ end
207
+
208
+ #
209
+ # Seeks to the supplied offset based on the supplied relativity.
210
+ #
211
+ def sysseek(offset, whence = SEEK_SET)
212
+ return self.filed.seek(offset, whence)
213
+ end
214
+
215
+ protected
216
+
217
+ ##
218
+ #
219
+ # Internal methods
220
+ #
221
+ ##
222
+
223
+ #
224
+ # Creates a File channel using the supplied information.
225
+ #
226
+ def _open(name, mode = "r", perms = 0)
227
+ return Rex::Post::Meterpreter::Channels::Pools::File.open(
228
+ self.client, name, mode, perms)
229
+ end
230
+
231
+ attr_accessor :client # :nodoc:
232
+
233
+ end
234
+
235
+ end; end; end; end; end; end