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,39 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ $:.unshift(File.join(File.dirname(__FILE__), '..', '..'))
4
+
5
+ require 'test/unit'
6
+ require 'rex/socket/ssl_tcp'
7
+
8
+ class Rex::Socket::SslTcp::UnitTest < Test::Unit::TestCase
9
+
10
+ def test_ssltcp
11
+
12
+ # Create an SslTcp instance
13
+ t = nil
14
+ assert_nothing_raised {
15
+ t = Rex::Socket::SslTcp.create(
16
+ 'PeerHost' => 'www.google.com',
17
+ 'PeerPort' => 443)
18
+ }
19
+ assert_kind_of(Rex::Socket::SslTcp, t, "valid ssl tcp")
20
+
21
+ # Send a HEAD request and make sure we get some kind of response
22
+ head_request = "HEAD / HTTP/1.0\r\n\r\n"
23
+
24
+ assert_equal(19, t.put(head_request), "sending head request")
25
+
26
+ head_response = ""
27
+
28
+ assert_nothing_raised {
29
+ head_response = t.get(nil) || ""
30
+ }
31
+
32
+ assert_match(/^HTTP\/1./, head_response, "valid head response")
33
+
34
+ assert_nothing_raised {
35
+ t.close
36
+ }
37
+ end
38
+
39
+ end
@@ -0,0 +1,122 @@
1
+ require 'rex/socket'
2
+ require 'rex/socket/tcp_server'
3
+ require 'rex/io/stream_server'
4
+
5
+ ###
6
+ #
7
+ # This class provides methods for interacting with an SSL wrapped TCP server. It
8
+ # implements the StreamServer IO interface.
9
+ #
10
+ ###
11
+ module Rex::Socket::SslTcpServer
12
+
13
+ @@loaded_openssl = false
14
+
15
+ begin
16
+ require 'openssl'
17
+ @@loaded_openssl = true
18
+ rescue ::Exception
19
+ end
20
+
21
+
22
+ include Rex::Socket::TcpServer
23
+
24
+ ##
25
+ #
26
+ # Factory
27
+ #
28
+ ##
29
+
30
+ def self.create(hash = {})
31
+ hash['Proto'] = 'tcp'
32
+ hash['Server'] = true
33
+ hash['SSL'] = true
34
+ self.create_param(Rex::Socket::Parameters.from_hash(hash))
35
+ end
36
+
37
+ #
38
+ # Wrapper around the base class' creation method that automatically sets
39
+ # the parameter's protocol to TCP and sets the server flag to true.
40
+ #
41
+ def self.create_param(param)
42
+ param.proto = 'tcp'
43
+ param.server = true
44
+ param.ssl = true
45
+ Rex::Socket.create_param(param)
46
+ end
47
+
48
+ def initsock(params = nil)
49
+ raise RuntimeError, "No OpenSSL support" if not @@loaded_openssl
50
+ self.sslctx = makessl()
51
+ super
52
+ end
53
+
54
+ def accept(opts = {})
55
+ sock = super()
56
+ return if not sock
57
+
58
+ begin
59
+ ssl = OpenSSL::SSL::SSLSocket.new(sock, self.sslctx)
60
+ ssl.accept
61
+ sock.extend(Rex::Socket::SslTcp)
62
+ sock.sslsock = ssl
63
+ sock.sslctx = self.sslctx
64
+ return sock
65
+
66
+ rescue ::OpenSSL::SSL::SSLError
67
+ sock.close
68
+ nil
69
+ end
70
+ end
71
+
72
+
73
+ def makessl
74
+ key = OpenSSL::PKey::RSA.new(1024){ }
75
+
76
+ cert = OpenSSL::X509::Certificate.new
77
+ cert.version = 2
78
+ cert.serial = rand(0xFFFFFFFF)
79
+ # name = OpenSSL::X509::Name.new([["C","JP"],["O","TEST"],["CN","localhost"]])
80
+ subject = OpenSSL::X509::Name.new([
81
+ ["C","US"],
82
+ ['ST', Rex::Text.rand_state()],
83
+ ["L", Rex::Text.rand_text_alpha(rand(20) + 10)],
84
+ ["O", Rex::Text.rand_text_alpha(rand(20) + 10)],
85
+ ["CN", Rex::Text.rand_hostname],
86
+ ])
87
+ issuer = OpenSSL::X509::Name.new([
88
+ ["C","US"],
89
+ ['ST', Rex::Text.rand_state()],
90
+ ["L", Rex::Text.rand_text_alpha(rand(20) + 10)],
91
+ ["O", Rex::Text.rand_text_alpha(rand(20) + 10)],
92
+ ["CN", Rex::Text.rand_hostname],
93
+ ])
94
+
95
+ cert.subject = subject
96
+ cert.issuer = issuer
97
+ cert.not_before = Time.now - (3600 * 365)
98
+ cert.not_after = Time.now + (3600 * 365)
99
+ cert.public_key = key.public_key
100
+ ef = OpenSSL::X509::ExtensionFactory.new(nil,cert)
101
+ cert.extensions = [
102
+ ef.create_extension("basicConstraints","CA:FALSE"),
103
+ ef.create_extension("subjectKeyIdentifier","hash"),
104
+ ef.create_extension("extendedKeyUsage","serverAuth"),
105
+ ef.create_extension("keyUsage","keyEncipherment,dataEncipherment,digitalSignature")
106
+ ]
107
+ ef.issuer_certificate = cert
108
+ cert.add_extension ef.create_extension("authorityKeyIdentifier", "keyid:always,issuer:always")
109
+ cert.sign(key, OpenSSL::Digest::SHA1.new)
110
+
111
+ ctx = OpenSSL::SSL::SSLContext.new()
112
+ ctx.key = key
113
+ ctx.cert = cert
114
+
115
+ ctx.session_id_context = Rex::Text.rand_text(16)
116
+
117
+ return ctx
118
+ end
119
+
120
+ attr_accessor :sslctx
121
+ end
122
+
@@ -0,0 +1,51 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ $:.unshift(File.join(File.dirname(__FILE__), '..', '..'))
4
+
5
+ require 'test/unit'
6
+ require 'rex/socket/ssl_tcp_server'
7
+ require 'rex/socket/ssl_tcp'
8
+
9
+ class Rex::Socket::SslTcpServer::UnitTest < Test::Unit::TestCase
10
+
11
+ # XXX. The client data is sent & decrypted just fine. The server data is not. the client thread just spins. BAH.
12
+ def test_tcp_server
13
+ return;
14
+
15
+ serv_port = 65433
16
+ c = nil
17
+
18
+ threads = []
19
+ threads << Thread.new() {
20
+ serv = Rex::Socket.create_tcp_server('LocalPort' => serv_port, 'SSL' => true)
21
+ assert_kind_of(Rex::Socket::SslTcpServer, serv, "type => ssl")
22
+ assert_kind_of(Rex::Socket::TcpServer, serv, "type => tcp")
23
+ assert_kind_of(Rex::IO::StreamServer, serv, "type => stream")
24
+ s = serv.accept
25
+ assert_equal("client_data\n", s.get_once(), "s: get_once")
26
+ assert_equal(3, s.write("Yo\n"), "s: put Yo")
27
+ assert(s.methods.include?('<<'))
28
+ assert(s.methods.include?('>>'))
29
+ assert(s.methods.include?('has_read_data?'))
30
+ serv.close
31
+ }
32
+
33
+ threads << Thread.new() {
34
+ sleep(2)
35
+ assert_nothing_raised {
36
+ c = Rex::Socket::SslTcp.create(
37
+ 'PeerHost' => '127.0.0.1',
38
+ 'PeerPort' => serv_port
39
+ )
40
+ }
41
+ assert_kind_of(Rex::Socket::Tcp, c, "TCP")
42
+ assert_kind_of(Rex::Socket::SslTcp, c, "SSL")
43
+ assert_equal(12, c.write("client_data\n"), "c: write")
44
+ assert_equal("Yo\n", c.get_once(), "c: get_once")
45
+ c.close if (c)
46
+ }
47
+
48
+ threads.each { |aThread| aThread.join }
49
+ end
50
+
51
+ end
@@ -0,0 +1,75 @@
1
+ require 'rex/socket'
2
+
3
+ module Rex
4
+ module Socket
5
+
6
+ ###
7
+ #
8
+ # This class provides an interface to enumerating a subnet with a supplied
9
+ # netmask.
10
+ #
11
+ ###
12
+ class SubnetWalker
13
+
14
+ #
15
+ # Initializes a subnet walker instance using the supplied subnet
16
+ # information.
17
+ #
18
+ def initialize(subnet, netmask)
19
+ self.subnet = Socket.resolv_to_dotted(subnet)
20
+ self.netmask = Socket.resolv_to_dotted(netmask)
21
+
22
+ reset
23
+ end
24
+
25
+ #
26
+ # Resets the subnet walker back to its original state.
27
+ #
28
+ def reset
29
+ self.curr_ip = self.subnet.split('.')
30
+ self.num_ips = (1 << (32 - Socket.net2bitmask(self.netmask).to_i))
31
+ self.curr_ip_idx = 0
32
+ end
33
+
34
+ #
35
+ # Returns the next IP address.
36
+ #
37
+ def next_ip
38
+ if (curr_ip_idx >= num_ips)
39
+ return nil
40
+ end
41
+
42
+ if (curr_ip_idx > 0)
43
+ self.curr_ip[3] = (curr_ip[3].to_i + 1) % 256
44
+ self.curr_ip[2] = (curr_ip[2].to_i + 1) % 256 if (curr_ip[3] == 0)
45
+ self.curr_ip[1] = (curr_ip[1].to_i + 1) % 256 if (curr_ip[2] == 0)
46
+ self.curr_ip[0] = (curr_ip[0].to_i + 1) % 256 if (curr_ip[1] == 0)
47
+ end
48
+
49
+ self.curr_ip_idx += 1
50
+
51
+ self.curr_ip.join('.')
52
+ end
53
+
54
+ #
55
+ # The subnet that is being enumerated.
56
+ #
57
+ attr_reader :subnet
58
+ #
59
+ # The netmask of the subnet.
60
+ #
61
+ attr_reader :netmask
62
+ #
63
+ # The total number of IPs within the subnet.
64
+ #
65
+ attr_reader :num_ips
66
+
67
+ protected
68
+
69
+ attr_writer :subnet, :netmask, :num_ips # :nodoc:
70
+ attr_accessor :curr_ip, :curr_ip_idx # :nodoc:
71
+
72
+ end
73
+
74
+ end
75
+ end
@@ -0,0 +1,28 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ $:.unshift(File.join(File.dirname(__FILE__), '..', '..'))
4
+
5
+ require 'test/unit'
6
+ require 'rex/socket/subnet_walker'
7
+
8
+ class Rex::Socket::SubnetWalker::UnitTest < Test::Unit::TestCase
9
+
10
+ Klass = Rex::Socket::SubnetWalker
11
+
12
+ def test_walker
13
+ s = Klass.new('10.0.0.0', '255.255.255.0')
14
+
15
+ 0.upto(255) { |x|
16
+ assert_equal('10.0.0.' + x.to_s, s.next_ip)
17
+ }
18
+ assert_nil(s.next_ip)
19
+
20
+ s.reset
21
+
22
+ 0.upto(255) { |x|
23
+ assert_equal('10.0.0.' + x.to_s, s.next_ip)
24
+ }
25
+ assert_nil(s.next_ip)
26
+ end
27
+
28
+ end
@@ -0,0 +1,272 @@
1
+ require 'singleton'
2
+ require 'thread'
3
+ require 'rex/socket'
4
+
5
+ module Rex
6
+ module Socket
7
+
8
+ ###
9
+ #
10
+ # This class provides a global routing table that associates subnets with Comm
11
+ # classes. Comm classes are used to instantiate objects that are tied to
12
+ # remote network entities. For example, the Local Comm class is used to
13
+ # building network connections directly from the local machine whereas, for
14
+ # instance, a Meterpreter Comm would build a local socket pair that is
15
+ # associated with a connection established by a remote entity. This can be
16
+ # seen as a uniform way of communicating with hosts through arbitrary
17
+ # channels.
18
+ #
19
+ ###
20
+ class SwitchBoard
21
+
22
+ include Singleton
23
+ include Enumerable
24
+
25
+ def initialize
26
+ @_initialized = false
27
+ end
28
+
29
+ ###
30
+ #
31
+ # This class represents a logical switch board route.
32
+ # TODO: Enable this to work with IPv6 addresses
33
+ #
34
+ ###
35
+ class Route
36
+ def initialize(subnet, netmask, comm)
37
+ self.subnet = subnet
38
+ self.netmask = netmask
39
+ self.comm = comm
40
+ self.subnet_nbo = Socket.resolv_nbo_i(subnet)
41
+ self.netmask_nbo = Socket.resolv_nbo_i(netmask)
42
+ end
43
+
44
+ #
45
+ # Sort according to bitmask
46
+ #
47
+ def <=>(other)
48
+ self.bitmask <=> other.bitmask
49
+ end
50
+
51
+ #
52
+ # Convert the netmask to a bitmask and cache it.
53
+ #
54
+ def bitmask
55
+ @_bitmask = Socket.net2bitmask(self.netmask) if (@_bitmask == nil)
56
+ @_bitmask
57
+ end
58
+
59
+ attr_reader :subnet, :netmask, :comm
60
+ attr_reader :subnet_nbo, :netmask_nbo
61
+ protected
62
+ attr_writer :subnet, :netmask, :comm
63
+ attr_writer :subnet_nbo, :netmask_nbo
64
+ end
65
+
66
+ ##
67
+ #
68
+ # Class method wrappers
69
+ #
70
+ ##
71
+
72
+ #
73
+ # Adds a route to the switch board routing table using the supplied Comm
74
+ # instance.
75
+ #
76
+ def self.add_route(subnet, mask, comm)
77
+ self.instance.add_route(subnet, mask, comm)
78
+ end
79
+
80
+ #
81
+ # Removes a route from the switch board routing table for the supplied
82
+ # subnet routing through the supplied Comm instance.
83
+ #
84
+ def self.remove_route(subnet, mask, comm)
85
+ self.instance.remove_route(subnet, mask, comm)
86
+ end
87
+
88
+ #
89
+ # Flush all the routes from the switch board routing table.
90
+ #
91
+ def self.flush_routes
92
+ self.instance.flush_routes
93
+ end
94
+
95
+ #
96
+ # Enumerate each route in the routing table.
97
+ #
98
+ def self.each(&block)
99
+ self.instance.each(&block)
100
+ end
101
+
102
+ #
103
+ # Returns the array of routes.
104
+ #
105
+ def self.routes
106
+ self.instance.routes
107
+ end
108
+
109
+ def self.route_exists?(subnet, mask)
110
+ self.instance.route_exists?(subnet, mask)
111
+ end
112
+
113
+ #
114
+ # Returns the Comm instance that should be used for the supplied address.
115
+ # If no comm can be found, the default Local Comm is returned.
116
+ #
117
+ def self.best_comm(addr)
118
+ self.instance.best_comm(addr)
119
+ end
120
+
121
+ #
122
+ # Removes all routes that go through the supplied Comm.
123
+ #
124
+ def self.remove_by_comm(comm)
125
+ self.instance.remove_by_comm(comm)
126
+ end
127
+
128
+ ##
129
+ #
130
+ # Instance methods
131
+ #
132
+ ##
133
+
134
+ #
135
+ # Adds a route for a given subnet and netmask destined through a given comm
136
+ # instance.
137
+ #
138
+ def add_route(subnet, mask, comm)
139
+ # If a bitmask was supplied, convert it.
140
+ netmask = (mask.to_s =~ /^\d+$/) ? Rex::Socket.bit2netmask(mask.to_i) : mask
141
+ rv = true
142
+
143
+ _init
144
+
145
+ mutex.synchronize {
146
+ # If the route already exists, return false to the caller.
147
+ if (route_exists?(subnet, netmask) == false)
148
+ self.routes << Route.new(subnet, netmask, comm)
149
+ else
150
+ rv = false
151
+ end
152
+ }
153
+
154
+ rv
155
+ end
156
+
157
+ #
158
+ # Removes a route for a given subnet and netmask destined through a given
159
+ # comm instance.
160
+ #
161
+ def remove_route(subnet, mask, comm)
162
+ # If a bitmask was supplied, convert it.
163
+ netmask = (mask.to_s =~ /^\d+$/) ? Rex::Socket.bit2netmask(mask.to_i) : mask
164
+ rv = false
165
+
166
+ _init
167
+
168
+ mutex.synchronize {
169
+ self.routes.delete_if { |route|
170
+ if (route.subnet == subnet and route.netmask == netmask and route.comm == comm)
171
+ rv = true
172
+ else
173
+ false
174
+ end
175
+ }
176
+ }
177
+
178
+ rv
179
+ end
180
+
181
+ #
182
+ # Flushes all established routes.
183
+ #
184
+ def flush_routes
185
+ _init
186
+
187
+ self.routes = Array.new
188
+ end
189
+
190
+ #
191
+ # Checks to see if a route already exists for the supplied subnet and
192
+ # netmask.
193
+ #
194
+ def route_exists?(subnet, netmask)
195
+ each { |route|
196
+ return true if (route.subnet == subnet and route.netmask == netmask)
197
+ }
198
+
199
+ false
200
+ end
201
+
202
+ #
203
+ # Enumerates each entry in the routing table.
204
+ #
205
+ def each(&block)
206
+ _init
207
+
208
+ routes.each(&block)
209
+ end
210
+
211
+ #
212
+ # Finds the best possible comm for the supplied target address.
213
+ #
214
+ def best_comm(addr)
215
+
216
+ addr_nbo = Socket.resolv_nbo_i(addr)
217
+ comm = nil
218
+ msb = 0
219
+
220
+ each { |route|
221
+ if ((route.subnet_nbo & route.netmask_nbo) ==
222
+ (addr_nbo & route.netmask_nbo))
223
+ if (route.bitmask >= msb)
224
+ comm = route.comm
225
+ msb = route.bitmask
226
+ end
227
+ end
228
+ }
229
+
230
+ comm
231
+ end
232
+
233
+ #
234
+ # Remove all routes that go through the supplied comm.
235
+ #
236
+ def remove_by_comm(comm)
237
+ _init
238
+ mutex.synchronize {
239
+ routes.delete_if { |route|
240
+ route.comm == comm
241
+ }
242
+ }
243
+ end
244
+
245
+ #
246
+ # The routes array.
247
+ #
248
+ attr_reader :routes
249
+ #
250
+ # The mutex protecting the routes array.
251
+ #
252
+ attr_reader :mutex
253
+
254
+ protected
255
+
256
+ attr_writer :routes, :mutex # :nodoc:
257
+
258
+ #
259
+ # Initializes the underlying stuff.
260
+ #
261
+ def _init
262
+ if (@_initialized != true)
263
+ @_initialized = true
264
+ self.routes = Array.new
265
+ self.mutex = Mutex.new
266
+ end
267
+ end
268
+
269
+ end
270
+
271
+ end
272
+ end