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,13 @@
1
+ #!/usr/bin/perl
2
+ use strict;
3
+
4
+
5
+ foreach my $f ('atime', 'blockdev?', 'chardev?', 'ctime', 'directory?',
6
+ 'executable?', 'executable_real?', 'file?', 'ftype', 'grpowned?',
7
+ 'mtime', 'owned?', 'pipe?', 'readable?', 'readable_real?', 'setuid?',
8
+ 'setgid?', 'size', 'socket?', 'sticky?', 'symlink?', 'writeable?',
9
+ 'writeable_real?', 'zero?') {
10
+
11
+ my $t = "\t";
12
+ print "${t}def File.$f(name)\n\t${t}stat(name).$f\n${t}end\n";
13
+ }
@@ -0,0 +1,182 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ module Rex
4
+ module Post
5
+
6
+ ##
7
+ #
8
+ # Base IO class that is modeled after the ruby IO class.
9
+ #
10
+ ##
11
+ class IO
12
+ protected
13
+ attr_accessor :filed, :mode
14
+ public
15
+
16
+ ##
17
+ #
18
+ # Conditionals
19
+ #
20
+ ##
21
+
22
+ def eof?
23
+ return eof
24
+ end
25
+
26
+ def closed?
27
+ raise NotImplementedError
28
+ end
29
+
30
+ def tty?
31
+ return isatty
32
+ end
33
+
34
+ ##
35
+ #
36
+ # I/O operations
37
+ #
38
+ ##
39
+
40
+ def binmode
41
+ raise NotImplementedError
42
+ end
43
+
44
+ def close
45
+ raise NotImplementedError
46
+ end
47
+
48
+ def close_read
49
+ raise NotImplementedError
50
+ end
51
+
52
+ def close_write
53
+ raise NotImplementedError
54
+ end
55
+
56
+ def each(sep = $/, &block)
57
+ raise NotImplementedError
58
+ end
59
+
60
+ def each_line(sep = $/, &block)
61
+ raise NotImplementedError
62
+ end
63
+
64
+ def each_byte(&block)
65
+ raise NotImplementedError
66
+ end
67
+
68
+ def eof
69
+ raise NotImplementedError
70
+ end
71
+
72
+ def fcntl(cmd, arg)
73
+ raise NotImplementedError
74
+ end
75
+
76
+ def flush
77
+ raise NotImplementedError
78
+ end
79
+
80
+ def fsync
81
+ raise NotImplementedError
82
+ end
83
+
84
+ def getc
85
+ raise NotImplementedError
86
+ end
87
+
88
+ def gets(sep = $/)
89
+ raise NotImplementedError
90
+ end
91
+
92
+ def ioctl(cmd, arg)
93
+ raise NotImplementedError
94
+ end
95
+
96
+ def isatty
97
+ raise NotImplementedError
98
+ end
99
+
100
+ def lineno
101
+ raise NotImplementedError
102
+ end
103
+
104
+ def pos
105
+ raise NotImplementedError
106
+ end
107
+
108
+ def print
109
+ raise NotImplementedError
110
+ end
111
+
112
+ def printf(fmt, *args)
113
+ raise NotImplementedError
114
+ end
115
+
116
+ def putc(obj)
117
+ raise NotImplementedError
118
+ end
119
+
120
+ def puts(obj)
121
+ raise NotImplementedError
122
+ end
123
+
124
+ def read(length = nil, buffer = nil)
125
+ raise NotImplementedError
126
+ end
127
+
128
+ def readchar
129
+ raise NotImplementedError
130
+ end
131
+
132
+ def readline(sep = $/)
133
+ raise NotImplementedError
134
+ end
135
+
136
+ def readlines(sep = $/)
137
+ raise NotImplementedError
138
+ end
139
+
140
+ def rewind
141
+ raise NotImplementedError
142
+ end
143
+
144
+ def seek(offset, whence = SEEK_SET)
145
+ raise NotImplementedError
146
+ end
147
+
148
+ def stat
149
+ raise NotImplementedError
150
+ end
151
+
152
+ def sync
153
+ raise NotImplementedError
154
+ end
155
+
156
+ def sysread(length)
157
+ raise NotImplementedError
158
+ end
159
+
160
+ def sysseek(offset, whence = SEEK_SET)
161
+ raise NotImplementedError
162
+ end
163
+
164
+ def syswrite(buf)
165
+ raise NotImplementedError
166
+ end
167
+
168
+ def tell
169
+ return pos
170
+ end
171
+
172
+ def ungetc(val)
173
+ raise NotImplementedError
174
+ end
175
+
176
+ def write(buf)
177
+ raise NotImplementedError
178
+ end
179
+
180
+ end
181
+
182
+ end; end # Post/Rex
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rex/post/meterpreter/client'
4
+ require 'rex/post/meterpreter/ui/console'
@@ -0,0 +1,438 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rex/post/meterpreter/inbound_packet_handler'
4
+
5
+ module Rex
6
+ module Post
7
+ module Meterpreter
8
+
9
+ #
10
+ # The various types of channels
11
+ #
12
+ CHANNEL_CLASS_STREAM = 1
13
+ CHANNEL_CLASS_DATAGRAM = 2
14
+ CHANNEL_CLASS_POOL = 3
15
+
16
+ #
17
+ # The various flags that can affect how the channel operates
18
+ #
19
+ # CHANNEL_FLAG_SYNCHRONOUS
20
+ # Specifies that I/O requests on the channel are blocking.
21
+ #
22
+ # CHANNEL_FLAG_COMPRESS
23
+ # Specifies that I/O requests on the channel have their data zlib compressed.
24
+ #
25
+ CHANNEL_FLAG_SYNCHRONOUS = (1 << 0)
26
+ CHANNEL_FLAG_COMPRESS = (1 << 1)
27
+
28
+ #
29
+ # The core types of direct I/O requests
30
+ #
31
+ CHANNEL_DIO_READ = 'read'
32
+ CHANNEL_DIO_WRITE = 'write'
33
+ CHANNEL_DIO_CLOSE = 'close'
34
+
35
+ ###
36
+ #
37
+ # The channel class represents a logical data pipe that exists between the
38
+ # client and the server. The purpose and behavior of the channel depends on
39
+ # which type it is. The three basic types of channels are streams, datagrams,
40
+ # and pools. Streams are basically equivalent to a TCP connection.
41
+ # Bidirectional, connection-oriented streams. Datagrams are basically
42
+ # equivalent to a UDP session. Bidirectional, connectionless. Pools are
43
+ # basically equivalent to a uni-directional connection, like a file handle.
44
+ # Pools denote channels that only have requests flowing in one direction.
45
+ #
46
+ ###
47
+ class Channel
48
+
49
+ # Class modifications to support global channel message
50
+ # dispatching without having to register a per-instance handler
51
+ class << self
52
+ include Rex::Post::Meterpreter::InboundPacketHandler
53
+
54
+ # Class request handler for all channels that dispatches requests
55
+ # to the appropriate class instance's DIO handler
56
+ def request_handler(client, packet)
57
+ cid = packet.get_tlv_value(TLV_TYPE_CHANNEL_ID)
58
+
59
+ # No channel identifier, then drop it
60
+ if (cid == nil)
61
+ return false
62
+ end
63
+
64
+ channel = client.find_channel(cid)
65
+
66
+ # No valid channel context? The channel may not be registered yet
67
+ if (channel == nil)
68
+ return false
69
+ end
70
+
71
+
72
+ dio = channel.dio_map(packet.method)
73
+
74
+ # Supported DIO request? Dump it.
75
+ if (dio == nil)
76
+ return true
77
+ end
78
+
79
+
80
+ # Call the channel's dio handler and return success or fail
81
+ # based on what happens
82
+ channel.dio_handler(dio, packet)
83
+ end
84
+ end
85
+
86
+ ##
87
+ #
88
+ # Factory
89
+ #
90
+ ##
91
+
92
+ #
93
+ # Creates a logical channel between the client and the server
94
+ # based on a given type.
95
+ #
96
+ def Channel.create(client, type = nil, klass = nil,
97
+ flags = CHANNEL_FLAG_SYNCHRONOUS, addends = nil)
98
+ request = Packet.create_request('core_channel_open')
99
+
100
+ # Set the type of channel that we're allocating
101
+ if (type != nil)
102
+ request.add_tlv(TLV_TYPE_CHANNEL_TYPE, type)
103
+ end
104
+
105
+ # If no factory class was provided, use the default native class
106
+ if (klass == nil)
107
+ klass = self
108
+ end
109
+
110
+ request.add_tlv(TLV_TYPE_CHANNEL_CLASS, klass.cls)
111
+ request.add_tlv(TLV_TYPE_FLAGS, flags)
112
+ request.add_tlvs(addends);
113
+
114
+ # Transmit the request and wait for the response
115
+ response = client.send_request(request)
116
+ cid = response.get_tlv(TLV_TYPE_CHANNEL_ID).value
117
+
118
+ # Create the channel instance
119
+ channel = klass.new(client, cid, type, flags)
120
+
121
+ return channel
122
+ end
123
+
124
+ ##
125
+ #
126
+ # Constructor
127
+ #
128
+ ##
129
+
130
+ #
131
+ # Initializes the instance's attributes, such as client context,
132
+ # class identifier, type, and flags.
133
+ #
134
+ def initialize(client, cid, type, flags)
135
+ self.client = client
136
+ self.cid = cid
137
+ self.type = type
138
+ self.flags = flags
139
+
140
+ # Add this instance to the list
141
+ if (cid and client)
142
+ client.add_channel(self)
143
+ end
144
+ end
145
+
146
+ ##
147
+ #
148
+ # Channel interaction
149
+ #
150
+ ##
151
+
152
+ #
153
+ # Wrapper around the low-level channel read operation.
154
+ #
155
+ def read(length = nil, addends = nil)
156
+ return _read(length, addends)
157
+ end
158
+
159
+ #
160
+ # Reads data from the remote half of the channel.
161
+ #
162
+ def _read(length = nil, addends = nil)
163
+ if (self.cid == nil)
164
+ raise IOError, "Channel has been closed.", caller
165
+ end
166
+
167
+ request = Packet.create_request('core_channel_read')
168
+
169
+ if (length == nil)
170
+ length = 65536
171
+ end
172
+
173
+ request.add_tlv(TLV_TYPE_CHANNEL_ID, self.cid)
174
+ request.add_tlv(TLV_TYPE_LENGTH, length)
175
+ request.add_tlvs(addends)
176
+
177
+ begin
178
+ response = self.client.send_request(request)
179
+ rescue
180
+ return nil
181
+ end
182
+
183
+ # If the channel is in synchronous mode, the response should contain
184
+ # data that was read from the remote side of the channel
185
+ if (flag?(CHANNEL_FLAG_SYNCHRONOUS))
186
+ data = response.get_tlv(TLV_TYPE_CHANNEL_DATA);
187
+
188
+ if (data != nil)
189
+ return data.value
190
+ end
191
+ else
192
+ raise NotImplementedError, "Asynchronous channel mode is not implemented", caller
193
+ end
194
+
195
+ return nil
196
+ end
197
+
198
+ #
199
+ # Wrapper around the low-level write.
200
+ #
201
+ def write(buf, length = nil, addends = nil)
202
+ return _write(buf, length, addends)
203
+ end
204
+
205
+ #
206
+ # Writes data to the remote half of the channel.
207
+ #
208
+ def _write(buf, length = nil, addends = nil)
209
+
210
+ if (self.cid == nil)
211
+ raise IOError, "Channel has been closed.", caller
212
+ end
213
+
214
+ request = Packet.create_request('core_channel_write')
215
+
216
+ # Truncation and celebration
217
+ if ((length != nil) &&
218
+ (buf.length >= length))
219
+ buf = buf[0..length]
220
+ else
221
+ length = buf.length
222
+ end
223
+
224
+ # Populate the request
225
+ request.add_tlv(TLV_TYPE_CHANNEL_ID, self.cid)
226
+
227
+ cdata = request.add_tlv(TLV_TYPE_CHANNEL_DATA, buf)
228
+ if( ( self.flags & CHANNEL_FLAG_COMPRESS ) == CHANNEL_FLAG_COMPRESS )
229
+ cdata.compress = true
230
+ end
231
+
232
+ request.add_tlv(TLV_TYPE_LENGTH, length)
233
+ request.add_tlvs(addends)
234
+
235
+ response = self.client.send_request(request)
236
+ written = response.get_tlv(TLV_TYPE_LENGTH)
237
+
238
+ return (written == nil) ? 0 : written.value
239
+ end
240
+
241
+ #
242
+ # Wrapper around the low-level close.
243
+ #
244
+ def close(addends = nil)
245
+ return _close(addends)
246
+ end
247
+
248
+ #
249
+ # Close the channel for future writes.
250
+ #
251
+ def close_write
252
+ return _close
253
+ end
254
+
255
+ #
256
+ # Close the channel for future reads.
257
+ #
258
+ def close_read
259
+ return _close
260
+ end
261
+
262
+ #
263
+ # Closes the channel.
264
+ #
265
+ def _close(addends = nil)
266
+ if (self.cid == nil)
267
+ raise IOError, "Channel has been closed.", caller
268
+ end
269
+
270
+ request = Packet.create_request('core_channel_close')
271
+
272
+ # Populate the request
273
+ request.add_tlv(TLV_TYPE_CHANNEL_ID, self.cid)
274
+ request.add_tlvs(addends)
275
+
276
+ self.client.send_request(request)
277
+
278
+ # Disassociate this channel instance
279
+ self.client.remove_channel(self.cid)
280
+
281
+ self.cid = nil
282
+
283
+ return true
284
+ end
285
+
286
+ #
287
+ # Enables or disables interactive mode.
288
+ #
289
+ def interactive(tf = true, addends = nil)
290
+ if (self.cid == nil)
291
+ raise IOError, "Channel has been closed.", caller
292
+ end
293
+
294
+ request = Packet.create_request('core_channel_interact')
295
+
296
+ # Populate the request
297
+ request.add_tlv(TLV_TYPE_CHANNEL_ID, self.cid)
298
+ request.add_tlv(TLV_TYPE_BOOL, tf)
299
+ request.add_tlvs(addends)
300
+
301
+ self.client.send_request(request)
302
+
303
+ return true
304
+ end
305
+
306
+ ##
307
+ #
308
+ # Direct I/O
309
+ #
310
+ ##
311
+
312
+ #
313
+ # Handles dispatching I/O requests based on the request packet.
314
+ # The default implementation does nothing with direct I/O requests.
315
+ #
316
+ def dio_handler(dio, packet)
317
+ if (dio == CHANNEL_DIO_READ)
318
+ length = packet.get_tlv_value(TLV_TYPE_LENGTH)
319
+
320
+ return dio_read_handler(packet, length)
321
+ elsif (dio == CHANNEL_DIO_WRITE)
322
+ data = packet.get_tlv_value(TLV_TYPE_CHANNEL_DATA)
323
+
324
+ return dio_write_handler(packet, data)
325
+ elsif (dio == CHANNEL_DIO_CLOSE)
326
+ return dio_close_handler(packet)
327
+ end
328
+ return false;
329
+ end
330
+
331
+ #
332
+ # Stub read handler.
333
+ #
334
+ def dio_read_handler(packet, length)
335
+ return true
336
+ end
337
+
338
+ #
339
+ # Stub write handler.
340
+ #
341
+ def dio_write_handler(packet, data)
342
+ return true
343
+ end
344
+
345
+ #
346
+ # Stub close handler.
347
+ #
348
+ def dio_close_handler(packet)
349
+ client.remove_channel(self.cid)
350
+
351
+ # Trap IOErrors as parts of the channel may have already been closed
352
+ begin
353
+ self.cleanup
354
+ rescue IOError
355
+ end
356
+
357
+ # No more channel action, foo.
358
+ self.cid = nil
359
+
360
+ return true
361
+ end
362
+
363
+ #
364
+ # Maps packet request methods to DIO request identifiers on a
365
+ # per-instance basis as other instances may add custom dio
366
+ # handlers.
367
+ #
368
+ def dio_map(method)
369
+ if (method == 'core_channel_read')
370
+ return CHANNEL_DIO_READ
371
+ elsif (method == 'core_channel_write')
372
+ return CHANNEL_DIO_WRITE
373
+ elsif (method == 'core_channel_close')
374
+ return CHANNEL_DIO_CLOSE
375
+ end
376
+
377
+ return nil
378
+ end
379
+
380
+ ##
381
+ #
382
+ # Conditionals
383
+ #
384
+ ##
385
+
386
+ #
387
+ # Checks to see if a flag is set on the instance's flags attribute.
388
+ #
389
+ def flag?(flag)
390
+ return ((self.flags & flag) == flag)
391
+ end
392
+
393
+ #
394
+ # Returns whether or not the channel is operating synchronously.
395
+ #
396
+ def synchronous?
397
+ return (self.flags & CHANNEL_FLAG_SYNCHRONOUS)
398
+ end
399
+
400
+ #
401
+ # The unique channel identifier.
402
+ #
403
+ attr_reader :cid
404
+ #
405
+ # The type of channel.
406
+ #
407
+ attr_reader :type
408
+ #
409
+ # The class of channel (stream, datagram, pool).
410
+ #
411
+ attr_reader :cls
412
+ #
413
+ # Any channel-specific flag, like synchronous IO.
414
+ #
415
+ attr_reader :flags
416
+ #
417
+ # Any channel-specific parameters.
418
+ #
419
+ attr_accessor :params
420
+ #
421
+ # The associated meterpreter client instance
422
+ #
423
+ attr_accessor :client
424
+ protected
425
+
426
+
427
+ attr_writer :cid, :type, :cls, :flags # :nodoc:
428
+
429
+ #
430
+ # Cleans up any lingering resources
431
+ #
432
+ def cleanup
433
+ end
434
+
435
+ end
436
+
437
+ end; end; end
438
+