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,167 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'thread'
4
+ require 'rex/post/meterpreter/channel'
5
+ require 'rex/post/meterpreter/channels/stream'
6
+ require 'rex/post/meterpreter/extensions/stdapi/tlv'
7
+
8
+ module Rex
9
+ module Post
10
+ module Meterpreter
11
+ module Extensions
12
+ module Stdapi
13
+ module Net
14
+ module SocketSubsystem
15
+
16
+ ###
17
+ #
18
+ # This class represents a logical TCP client connection
19
+ # that is established from the remote machine and tunnelled
20
+ # through the established meterpreter connection, similar to an
21
+ # SSH port forward.
22
+ #
23
+ ###
24
+ class TcpClientChannel < Rex::Post::Meterpreter::Stream
25
+
26
+ class << self
27
+ def cls
28
+ return CHANNEL_CLASS_STREAM
29
+ end
30
+ end
31
+
32
+ module SocketInterface
33
+ def type?
34
+ 'tcp'
35
+ end
36
+
37
+ def getsockname
38
+ return super if not channel
39
+ # Find the first host in our chain (our address)
40
+ hops = 0
41
+ csock = channel.client.sock
42
+ while(csock.respond_to?('channel'))
43
+ csock = csock.channel.client.sock
44
+ hops += 1
45
+ end
46
+ tmp,caddr,cport = csock.getsockname
47
+ tmp,raddr,rport = csock.getpeername
48
+ maddr,mport = [ channel.params.localhost, channel.params.localport ]
49
+ [ tmp, "#{caddr}#{(hops > 0) ? "-_#{hops}_" : ""}-#{raddr}", "#{mport}" ]
50
+ end
51
+
52
+ def getpeername
53
+ return super if not channel
54
+ tmp,caddr,cport = channel.client.sock.getpeername
55
+ maddr,mport = [ channel.params.peerhost, channel.params.peerport ]
56
+ [ tmp, "#{maddr}", "#{mport}" ]
57
+ end
58
+
59
+ attr_accessor :channel
60
+ end
61
+
62
+ #
63
+ # Simple mixin for lsock in order to help avoid a ruby interpreter issue with ::Socket.pair
64
+ # Instead of writing to the lsock, reading from the rsock and then writing to the channel,
65
+ # we use this mixin to directly write to the channel.
66
+ #
67
+ # Note: This does not work with OpenSSL as OpenSSL is implemented nativly and requires a real
68
+ # socket to write to and we cant intercept the sockets syswrite at a native level.
69
+ #
70
+ # Note: The deadlock only seems to effect the Ruby build for cygwin.
71
+ #
72
+ module DirectChannelWrite
73
+
74
+ def syswrite( buf )
75
+ channel._write( buf )
76
+ end
77
+
78
+ attr_accessor :channel
79
+ end
80
+
81
+ ##
82
+ #
83
+ # Factory
84
+ #
85
+ ##
86
+
87
+ #
88
+ # Opens a TCP client channel using the supplied parameters.
89
+ #
90
+ def TcpClientChannel.open(client, params)
91
+ c = Channel.create(client, 'stdapi_net_tcp_client', self, CHANNEL_FLAG_SYNCHRONOUS,
92
+ [
93
+ {
94
+ 'type' => TLV_TYPE_PEER_HOST,
95
+ 'value' => params.peerhost
96
+ },
97
+ {
98
+ 'type' => TLV_TYPE_PEER_PORT,
99
+ 'value' => params.peerport
100
+ },
101
+ {
102
+ 'type' => TLV_TYPE_LOCAL_HOST,
103
+ 'value' => params.localhost
104
+ },
105
+ {
106
+ 'type' => TLV_TYPE_LOCAL_PORT,
107
+ 'value' => params.localport
108
+ },
109
+ {
110
+ 'type' => TLV_TYPE_CONNECT_RETRIES,
111
+ 'value' => params.retries
112
+ }
113
+ ])
114
+ c.params = params
115
+ c
116
+ end
117
+
118
+ ##
119
+ #
120
+ # Constructor
121
+ #
122
+ ##
123
+
124
+ #
125
+ # Passes the channel initialization information up to the base class.
126
+ #
127
+ def initialize( client, cid, type, flags )
128
+ super( client, cid, type, flags )
129
+
130
+ lsock.extend( SocketInterface )
131
+ lsock.extend( DirectChannelWrite )
132
+ lsock.channel = self
133
+
134
+ rsock.extend( SocketInterface )
135
+ rsock.channel = self
136
+
137
+ end
138
+
139
+ #
140
+ # Closes the write half of the connection.
141
+ #
142
+ def close_write
143
+ return shutdown(1)
144
+ end
145
+
146
+ #
147
+ # Shutdown the connection
148
+ #
149
+ # 0 -> future reads
150
+ # 1 -> future sends
151
+ # 2 -> both
152
+ #
153
+ def shutdown(how = 1)
154
+ request = Packet.create_request('stdapi_net_socket_tcp_shutdown')
155
+
156
+ request.add_tlv(TLV_TYPE_SHUTDOWN_HOW, how)
157
+ request.add_tlv(TLV_TYPE_CHANNEL_ID, self.cid)
158
+
159
+ response = client.send_request(request)
160
+
161
+ return true
162
+ end
163
+
164
+ end
165
+
166
+ end; end; end; end; end; end; end
167
+
@@ -0,0 +1,167 @@
1
+ require 'timeout'
2
+ require 'thread'
3
+ require 'rex/socket/parameters'
4
+ require 'rex/post/meterpreter/channels/stream'
5
+ require 'rex/post/meterpreter/extensions/stdapi/tlv'
6
+ require 'rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel'
7
+
8
+ module Rex
9
+ module Post
10
+ module Meterpreter
11
+ module Extensions
12
+ module Stdapi
13
+ module Net
14
+ module SocketSubsystem
15
+
16
+ class TcpServerChannel < Rex::Post::Meterpreter::Channel
17
+
18
+ #
19
+ # This is a class variable to store all pending client tcp connections which have not been passed
20
+ # off via a call to the respective server tcp channels accept method. The dictionary key is the
21
+ # tcp server channel instance and the values held are an array of pending tcp client channels
22
+ # connected to the tcp server channel.
23
+ #
24
+ @@server_channels = {}
25
+
26
+ class << self
27
+ include Rex::Post::Meterpreter::InboundPacketHandler
28
+
29
+ #
30
+ # This is the request handler which is registerd to the respective meterpreter instance via
31
+ # Rex::Post::Meterpreter::Extensions::Stdapi::Net::Socket. All incoming requests from the meterpreter
32
+ # for a 'tcp_channel_open' will be processed here. We create a new TcpClientChannel for each request
33
+ # received and store it in the respective tcp server channels list of new pending client channels.
34
+ # These new tcp client channels are passed off via a call the the tcp server channels accept() method.
35
+ #
36
+ def request_handler( client, packet )
37
+
38
+ if( packet.method == "tcp_channel_open" )
39
+
40
+ cid = packet.get_tlv_value( TLV_TYPE_CHANNEL_ID )
41
+ pid = packet.get_tlv_value( TLV_TYPE_CHANNEL_PARENTID )
42
+ localhost = packet.get_tlv_value( TLV_TYPE_LOCAL_HOST )
43
+ localport = packet.get_tlv_value( TLV_TYPE_LOCAL_PORT )
44
+ peerhost = packet.get_tlv_value( TLV_TYPE_PEER_HOST )
45
+ peerport = packet.get_tlv_value( TLV_TYPE_PEER_PORT )
46
+
47
+ if( cid == nil or pid == nil )
48
+ return false
49
+ end
50
+
51
+ server_channel = client.find_channel( pid )
52
+ if( server_channel == nil )
53
+ return false
54
+ end
55
+
56
+ params = Rex::Socket::Parameters.from_hash(
57
+ {
58
+ 'Proto' => 'tcp',
59
+ 'LocalHost' => localhost,
60
+ 'LocalPort' => localport,
61
+ 'PeerHost' => peerhost,
62
+ 'PeerPort' => peerport,
63
+ 'Comm' => server_channel.client
64
+ }
65
+ )
66
+
67
+ client_channel = TcpClientChannel.new( client, cid, TcpClientChannel, CHANNEL_FLAG_SYNCHRONOUS )
68
+
69
+ client_channel.params = params
70
+
71
+ if( @@server_channels[server_channel] == nil )
72
+ @@server_channels[server_channel] = []
73
+ end
74
+
75
+ @@server_channels[server_channel] << client_channel
76
+
77
+ return true
78
+ end
79
+
80
+ return false
81
+ end
82
+
83
+ def cls
84
+ return CHANNEL_CLASS_STREAM
85
+ end
86
+
87
+ end
88
+
89
+ #
90
+ # Open a new tcp server channel on the remote end.
91
+ #
92
+ def TcpServerChannel.open(client, params)
93
+ c = Channel.create(client, 'stdapi_net_tcp_server', self, CHANNEL_FLAG_SYNCHRONOUS,
94
+ [
95
+ {
96
+ 'type' => TLV_TYPE_LOCAL_HOST,
97
+ 'value' => params.localhost
98
+ },
99
+ {
100
+ 'type' => TLV_TYPE_LOCAL_PORT,
101
+ 'value' => params.localport
102
+ }
103
+ ] )
104
+ c.params = params
105
+ c
106
+ end
107
+
108
+ #
109
+ # Simply initilize this instance.
110
+ #
111
+ def initialize(client, cid, type, flags)
112
+ super(client, cid, type, flags)
113
+ # add this instance to the class variables dictionary of tcp server channels
114
+ @@server_channels[self] = []
115
+ end
116
+
117
+ #
118
+ # Accept a new tcp client connection form this tcp server channel. This method does not block
119
+ # and returns nil if no new client connection is available.
120
+ #
121
+ def accept_nonblock
122
+ result = nil
123
+ if( @@server_channels[self].length > 0 )
124
+ channel = @@server_channels[self].shift
125
+ result = channel.lsock
126
+ end
127
+ return result
128
+ end
129
+
130
+ #
131
+ # Accept a new tcp client connection form this tcp server channel. This method will block indefinatly
132
+ # if no timeout is specified.
133
+ #
134
+ def accept( opts={} )
135
+ timeout = opts['Timeout'] || -1
136
+ if( timeout == -1 )
137
+ result = _accept
138
+ else
139
+ begin
140
+ ::Timeout.timeout( timeout ) {
141
+ result = _accept
142
+ }
143
+ rescue Timeout::Error
144
+ result = nil
145
+ end
146
+ end
147
+ return result
148
+ end
149
+
150
+ protected
151
+
152
+ def _accept
153
+ while( true )
154
+ if( @@server_channels[self].empty? )
155
+ Rex::ThreadSafe.sleep( 0.2 )
156
+ next
157
+ end
158
+ result = accept_nonblock
159
+ break if result != nil
160
+ end
161
+ return result
162
+ end
163
+
164
+ end
165
+
166
+ end; end; end; end; end; end; end
167
+
@@ -0,0 +1,192 @@
1
+ require 'timeout'
2
+ require 'rex/sync/thread_safe'
3
+ require 'rex/socket/udp'
4
+ require 'rex/socket/parameters'
5
+ require 'rex/post/meterpreter/extensions/stdapi/tlv'
6
+ require 'rex/post/meterpreter/channel'
7
+
8
+ module Rex
9
+ module Post
10
+ module Meterpreter
11
+ module Extensions
12
+ module Stdapi
13
+ module Net
14
+ module SocketSubsystem
15
+
16
+ class UdpChannel < Rex::Post::Meterpreter::Channel
17
+
18
+ #
19
+ # We inclue Rex::Socket::Udp as this channel is effectivly a UDP socket.
20
+ #
21
+ include Rex::Socket::Udp
22
+
23
+ #
24
+ # We are a datagram channel.
25
+ #
26
+ class << self
27
+ def cls
28
+ return CHANNEL_CLASS_DATAGRAM
29
+ end
30
+ end
31
+
32
+ #
33
+ # Open a new UDP channel on the remote end. The local host/port are optional, if none are specified
34
+ # the remote end will bind to INADDR_ANY with a random port number. The peer host/port are also
35
+ # optional, if specified all default send(), write() call will sendto the specified peer. If no peer
36
+ # host/port is specified you must use sendto() and specify the remote peer you wish to send to. This
37
+ # effectivly lets us create bound/unbound and connected/unconnected UDP sockets with ease.
38
+ #
39
+ def UdpChannel.open(client, params)
40
+ c = Channel.create(client, 'stdapi_net_udp_client', self, CHANNEL_FLAG_SYNCHRONOUS,
41
+ [
42
+ {
43
+ 'type' => TLV_TYPE_LOCAL_HOST,
44
+ 'value' => params.localhost
45
+ },
46
+ {
47
+ 'type' => TLV_TYPE_LOCAL_PORT,
48
+ 'value' => params.localport
49
+ },
50
+ {
51
+ 'type' => TLV_TYPE_PEER_HOST,
52
+ 'value' => params.peerhost
53
+ },
54
+ {
55
+ 'type' => TLV_TYPE_PEER_PORT,
56
+ 'value' => params.peerport
57
+ }
58
+ ] )
59
+ c.params = params
60
+ c
61
+ end
62
+
63
+ #
64
+ # Simply initilize this instance.
65
+ #
66
+ def initialize(client, cid, type, flags)
67
+ super(client, cid, type, flags)
68
+ # the instance variable that holds all incoming datagrams.
69
+ @datagrams = []
70
+ end
71
+
72
+ #
73
+ # We overwrite Rex::Socket::Udp.timed_read in order to avoid the call to Kernel.select
74
+ # which wont be of use as we are not a natively backed ::Socket or ::IO instance.
75
+ #
76
+ def timed_read( length=65535, timeout=def_read_timeout )
77
+ result = ''
78
+
79
+ begin
80
+ Timeout.timeout( timeout ) {
81
+ while( true )
82
+ if( @datagrams.empty? )
83
+ Rex::ThreadSafe.sleep( 0.2 )
84
+ next
85
+ end
86
+ result = self.read( length )
87
+ break
88
+ end
89
+ }
90
+ rescue Timeout::Error
91
+ result = ''
92
+ end
93
+
94
+ return result
95
+ end
96
+
97
+ #
98
+ # We overwrite Rex::Socket::Udp.recvfrom in order to correctly hand out the
99
+ # datagrams which the remote end of this channel has received and are in the
100
+ # queue.
101
+ #
102
+ def recvfrom( length=65535, timeout=def_read_timeout )
103
+ result = nil
104
+ # force a timeout on the wait for an incoming datagram
105
+ begin
106
+ Timeout.timeout( timeout ) {
107
+ while( true )
108
+ # wait untill we have at least one datagram in the queue
109
+ if( @datagrams.empty? )
110
+ Rex::ThreadSafe.sleep( 0.2 )
111
+ next
112
+ end
113
+ # grab the oldest datagram we have received...
114
+ result = @datagrams.shift
115
+ # break as we have a result...
116
+ break
117
+ end
118
+ }
119
+ rescue Timeout::Error
120
+ result = nil
121
+ end
122
+ # if no result return nothing
123
+ if( result == nil )
124
+ return [ '', nil, nil ]
125
+ end
126
+ # get the data from this datagram
127
+ data = result[0]
128
+ # if its only a partial read of this datagram, slice it, loosing the remainder.
129
+ result[0] = data[0,length-1] if data.length > length
130
+ # return the result in the form [ data, host, port ]
131
+ return result
132
+ end
133
+
134
+ #
135
+ # Overwrite the low level sysread to read data off our datagram queue. Calls
136
+ # to read() will end up calling this.
137
+ #
138
+ def sysread( length )
139
+ result = self.recvfrom( length )
140
+ return result[0]
141
+ end
142
+
143
+ #
144
+ # Overwrite the low level syswrite to write data to the remote end of the channel.
145
+ # Calls to write() will end up calling this.
146
+ #
147
+ def syswrite( buf )
148
+ return _write( buf )
149
+ end
150
+
151
+ #
152
+ # This function is called by Rex::Socket::Udp.sendto and writes data to a specified
153
+ # remote peer host/port via the remote end of the channel.
154
+ #
155
+ def send( buf, flags, saddr )
156
+ af, peerhost, peerport = Rex::Socket.from_sockaddr( saddr )
157
+
158
+ addends = [
159
+ {
160
+ 'type' => TLV_TYPE_PEER_HOST,
161
+ 'value' => peerhost
162
+ },
163
+ {
164
+ 'type' => TLV_TYPE_PEER_PORT,
165
+ 'value' => peerport
166
+ }
167
+ ]
168
+
169
+ return _write( buf, buf.length, addends )
170
+ end
171
+
172
+ #
173
+ # The channels direct io write handler for any incoming data from the remote end
174
+ # of the channel. We extract the data and peer host/port, and save this to a queue
175
+ # of incoming datagrams which are passed out via calls to self.recvfrom()
176
+ #
177
+ def dio_write_handler( packet, data )
178
+
179
+ peerhost = packet.get_tlv_value( TLV_TYPE_PEER_HOST )
180
+ peerport = packet.get_tlv_value( TLV_TYPE_PEER_PORT )
181
+
182
+ if( peerhost and peerport )
183
+ @datagrams << [ data, peerhost, peerport ]
184
+ return true
185
+ end
186
+
187
+ return false
188
+ end
189
+
190
+ end
191
+
192
+ end; end; end; end; end; end; end