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,279 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ $:.unshift(File.join(File.dirname(__FILE__), '..', '..'))
4
+
5
+ require 'test/unit'
6
+ require 'rex/exploitation/opcodedb'
7
+ require 'rex/socket'
8
+
9
+ class Rex::Exploitation::OpcodeDb::UnitTest < Test::Unit::TestCase
10
+
11
+ Klass = Rex::Exploitation::OpcodeDb::Client
12
+ SrvPort = 60000
13
+
14
+ def test_meta_types
15
+ srv_cli
16
+
17
+ begin
18
+ proc_req_resp(%q{<Array><Hash><Entry name="id">1</Entry><Entry name="name">foo</Entry></Hash><Hash><Entry name="id">2</Entry><Entry name="name">dog</Entry></Hash></Array>})
19
+
20
+ mt = @r.meta_types
21
+
22
+ assert_kind_of(Array, mt)
23
+ assert_equal(2, mt.length)
24
+ assert_equal(1, mt[0].id)
25
+ assert_equal("foo", mt[0].name)
26
+ assert_equal(2, mt[1].id)
27
+ assert_equal("dog", mt[1].name)
28
+ ensure
29
+ @s.close
30
+ end
31
+ end
32
+
33
+ def test_groups
34
+ srv_cli
35
+
36
+ begin
37
+ proc_req_resp(%q{<Array><Hash><Entry name="id">47</Entry><Entry name="name">foo</Entry></Hash><Hash><Entry name="id">2</Entry><Entry name="name">dog</Entry></Hash></Array>})
38
+
39
+ mt = @r.groups
40
+
41
+ assert_kind_of(Array, mt)
42
+ assert_equal(2, mt.length)
43
+ assert_equal(47, mt[0].id)
44
+ assert_equal("foo", mt[0].name)
45
+ assert_equal(2, mt[1].id)
46
+ assert_equal("dog", mt[1].name)
47
+ ensure
48
+ @s.close
49
+ end
50
+ end
51
+
52
+ def test_platforms
53
+ srv_cli
54
+
55
+ begin
56
+ proc_req_resp(%q{<Array><Hash><Entry name="id">12</Entry><Entry name="name">Windows XP SP2</Entry><Entry name="desc">Windows Coolness</Entry><Entry name="maj_ver">5</Entry><Entry name="min_ver">1</Entry><Entry name="maj_patch_level">2</Entry><Entry name="min_patch_level">0</Entry><Entry name="modules">10</Entry></Hash></Array>})
57
+
58
+ osv = @r.platforms
59
+
60
+ assert_kind_of(Array, osv)
61
+ assert_equal(1, osv.length)
62
+ assert_equal(12, osv[0].id)
63
+ assert_equal("Windows XP SP2", osv[0].name)
64
+ assert_equal("Windows Coolness", osv[0].desc)
65
+ assert_equal(5, osv[0].maj_ver)
66
+ assert_equal(1, osv[0].min_ver)
67
+ assert_equal(2, osv[0].maj_patch_level)
68
+ assert_equal(0, osv[0].min_patch_level)
69
+ assert_equal(10, osv[0].modules)
70
+ ensure
71
+ @s.close
72
+ end
73
+ end
74
+
75
+ def test_modules
76
+ srv_cli
77
+
78
+ begin
79
+ proc_req_resp(%q{<Array><Hash>
80
+ <Entry name="id">1</Entry>
81
+ <Entry name="name">kernel32.dll</Entry>
82
+ <Entry name="locale">
83
+ <Hash>
84
+ <Entry name="id">4</Entry>
85
+ <Entry name="name">English</Entry>
86
+ </Hash>
87
+ </Entry>
88
+ <Entry name="maj_maj_ver">4</Entry>
89
+ <Entry name="maj_min_ver">100</Entry>
90
+ <Entry name="min_maj_ver">2</Entry>
91
+ <Entry name="min_min_ver">7</Entry>
92
+ <Entry name="timestamp">403242822</Entry>
93
+ <Entry name="base_address">100000000</Entry>
94
+ <Entry name="image_size">40000</Entry>
95
+ <Entry name="segments">
96
+ <Array>
97
+ <Hash>
98
+ <Entry name="type">text</Entry>
99
+ <Entry name="base_address">3228094</Entry>
100
+ <Entry name="segment_size">4000</Entry>
101
+ <Entry name="writable">true</Entry>
102
+ <Entry name="readable">true</Entry>
103
+ <Entry name="executable">false</Entry>
104
+ </Hash>
105
+ </Array>
106
+ </Entry>
107
+ <Entry name="imports">
108
+ <Array>
109
+ <Hash>
110
+ <Entry name="name">FoolFunction</Entry>
111
+ <Entry name="address">3242344</Entry>
112
+ <Entry name="ordinal">5</Entry>
113
+ </Hash>
114
+ </Array>
115
+ </Entry>
116
+ <Entry name="exports">
117
+ <Array>
118
+ <Hash>
119
+ <Entry name="name">FoolFunctionExport</Entry>
120
+ <Entry name="address">32423445</Entry>
121
+ <Entry name="ordinal">51</Entry>
122
+ </Hash>
123
+ </Array>
124
+ </Entry>
125
+ </Hash></Array>})
126
+
127
+ m = @r.modules
128
+
129
+ assert_kind_of(Array, m)
130
+ assert_equal(1, m[0].id)
131
+ assert_equal("kernel32.dll", m[0].name)
132
+ assert_equal(4, m[0].locale.id)
133
+ assert_equal("English", m[0].locale.name)
134
+ assert_equal(4, m[0].maj_maj_ver)
135
+ assert_equal(100, m[0].maj_min_ver)
136
+ assert_equal(2, m[0].min_maj_ver)
137
+ assert_equal(7, m[0].min_min_ver)
138
+ assert_equal(403242822, m[0].timestamp.to_i)
139
+ assert_equal(100000000, m[0].base_address)
140
+ assert_equal(40000, m[0].image_size)
141
+ assert_kind_of(Array, m[0].segments)
142
+ assert_equal("text", m[0].segments[0].type)
143
+ assert_equal(3228094, m[0].segments[0].base_address)
144
+ assert_equal(4000, m[0].segments[0].size)
145
+ assert_equal(true, m[0].segments[0].writable)
146
+ assert_equal(true, m[0].segments[0].readable)
147
+ assert_equal(false, m[0].segments[0].executable)
148
+ assert_kind_of(Array, m[0].imports)
149
+ assert_equal("FoolFunction", m[0].imports[0].name)
150
+ assert_equal(3242344, m[0].imports[0].address)
151
+ assert_equal(5, m[0].imports[0].ordinal)
152
+ assert_kind_of(Array, m[0].exports)
153
+ assert_equal("FoolFunctionExport", m[0].exports[0].name)
154
+ assert_equal(32423445, m[0].exports[0].address)
155
+ assert_equal(51, m[0].exports[0].ordinal)
156
+ ensure
157
+ @s.close
158
+ end
159
+ end
160
+
161
+ def test_locales
162
+ srv_cli
163
+
164
+ begin
165
+ proc_req_resp(%q{<Array><Hash>
166
+ <Entry name="id">4</Entry>
167
+ <Entry name="name">English</Entry>
168
+ </Hash>
169
+ <Hash>
170
+ <Entry name="id">5</Entry>
171
+ <Entry name="name">French</Entry>
172
+ </Hash></Array>})
173
+
174
+ l = @r.locales
175
+
176
+ assert_kind_of(Array, l)
177
+ assert_equal(2, l.length)
178
+ assert_equal(4, l[0].id)
179
+ assert_equal("English", l[0].name)
180
+ assert_equal(5, l[1].id)
181
+ assert_equal("French", l[1].name)
182
+ ensure
183
+ @s.close
184
+ end
185
+ end
186
+
187
+ def test_search
188
+ srv_cli
189
+
190
+ begin
191
+ proc_req_resp(%q{
192
+ <Array>
193
+ <Hash>
194
+ <Entry name="id">400</Entry>
195
+ <Entry name="address">34242324</Entry>
196
+ <Entry name="type">
197
+ <Hash>
198
+ <Entry name="id">4</Entry>
199
+ <Entry name="name">jmp esp</Entry>
200
+ <Entry name="group">
201
+ <Hash>
202
+ <Entry name="id">40</Entry>
203
+ <Entry name="name">reg</Entry>
204
+ </Hash>
205
+ </Entry>
206
+ </Hash>
207
+ </Entry>
208
+ </Hash>
209
+ </Array>})
210
+
211
+ o = @r.search
212
+
213
+ assert_kind_of(Array, o)
214
+ assert_equal(1, o.length)
215
+ assert_equal(400, o[0].id)
216
+ assert_equal(34242324, o[0].address)
217
+ assert_equal(4, o[0].type.id)
218
+ assert_equal("jmp esp", o[0].type.name)
219
+ assert_equal(40, o[0].group.id)
220
+ assert_equal("reg", o[0].group.name)
221
+ ensure
222
+ @s.close
223
+ end
224
+ end
225
+
226
+ def test_statistics
227
+ srv_cli
228
+
229
+ begin
230
+ proc_req_resp(%q{
231
+ <Hash>
232
+ <Entry name="modules">40</Entry>
233
+ <Entry name="opcodes">50</Entry>
234
+ <Entry name="opcode_types">60</Entry>
235
+ <Entry name="platforms">70</Entry>
236
+ <Entry name="architectures">80</Entry>
237
+ <Entry name="module_segments">90</Entry>
238
+ <Entry name="module_imports">100</Entry>
239
+ <Entry name="module_exports">110</Entry>
240
+ <Entry name="last_update">120</Entry>
241
+ </Hash>
242
+ })
243
+
244
+ s = @r.statistics
245
+
246
+ assert_equal(40, s.modules)
247
+ assert_equal(50, s.opcodes)
248
+ assert_equal(60, s.opcode_types)
249
+ assert_equal(70, s.platforms)
250
+ assert_equal(80, s.architectures)
251
+ assert_equal(90, s.module_segments)
252
+ assert_equal(100, s.module_imports)
253
+ assert_equal(110, s.module_exports)
254
+ assert_equal(120, s.last_update.to_i)
255
+ ensure
256
+ @s.close
257
+ end
258
+ end
259
+
260
+ protected
261
+
262
+ def srv_cli
263
+ @r = Klass.new('127.0.0.1', SrvPort)
264
+ @s = Rex::Socket::TcpServer.create(
265
+ 'LocalHost' => '127.0.0.1',
266
+ 'LocalPort' => SrvPort)
267
+ end
268
+
269
+ def proc_req_resp(buf)
270
+ thr = Thread.new {
271
+ cli = @s.accept
272
+ @buffer = cli.get
273
+
274
+ cli.put("HTTP/1.0 200 OK\r\nConnection: close\r\n\r\n#{buf}")
275
+ cli.close
276
+ }
277
+ end
278
+
279
+ end
@@ -0,0 +1,92 @@
1
+ require 'rex/text'
2
+ require 'rex/arch/x86'
3
+
4
+ module Rex
5
+ module Exploitation
6
+
7
+ ###
8
+ #
9
+ # This class provides methods for generating SEH registration records
10
+ # in a dynamic and flexible fashion. The records can be generated with
11
+ # the short jump at a random offset into the next pointer and with random
12
+ # padding in between the handler and the attacker's payload.
13
+ #
14
+ ###
15
+ class Seh
16
+
17
+ #
18
+ # Creates a new instance of the class and initializes it with the supplied
19
+ # bad character list. The space argument denotes how much room is
20
+ # available for random padding and the NOP argument can be used to generate
21
+ # a random NOP sled that is better than 0x90.
22
+ #
23
+ def initialize(badchars = nil, space = nil, nop = nil)
24
+ self.badchars = badchars || ''
25
+ self.space = (space && space > 121) ? 121 : space
26
+ self.nop = nop
27
+ end
28
+
29
+ #
30
+ # Generates an SEH record
31
+ #
32
+ def generate_seh_record(handler, dynamic=false)
33
+ if (dynamic)
34
+ generate_dynamic_seh_record(handler)
35
+ else
36
+ generate_static_seh_record(handler)
37
+ end
38
+ end
39
+
40
+ #
41
+ # Generates a fake SEH registration record with the supplied handler
42
+ # address for the handler, and a nop generator to use when generating
43
+ # padding inside the next pointer. The NOP generator must implement the
44
+ # 'generate_sled' method that takes a length and a list of bad
45
+ # characters.
46
+ #
47
+ def generate_dynamic_seh_record(handler)
48
+
49
+ # Generate the padding up to the size specified or 121 characters
50
+ # maximum to account for the maximum range of a short jump plus the
51
+ # record size.
52
+ pad = rand(space || 121)
53
+ rsize = pad + 8
54
+
55
+ # Calculate the random index into the next ptr to store the short jump
56
+ # instruction
57
+ jmpidx = rand(3)
58
+
59
+ # Build the prefixed sled for the bytes that come before the short jump
60
+ # instruction
61
+ sled = (nop) ? nop.generate_sled(jmpidx, badchars) : ("\x90" * jmpidx)
62
+
63
+ # Seed the record and any space after the record with random text
64
+ record = Rex::Text.rand_text(rsize, badchars)
65
+
66
+ # Build the next pointer and short jump instruction
67
+ record[jmpidx, 2] = Rex::Arch::X86.jmp_short((rsize - jmpidx) - 2)
68
+ record[0, jmpidx] = sled
69
+
70
+ # Set the handler in the registration record
71
+ record[4, 4] = [ handler ].pack('V')
72
+
73
+ # Return the generated record to the caller
74
+ record
75
+ end
76
+
77
+ #
78
+ # Generates a static SEH registration record with a specific handler and
79
+ # next pointer.
80
+ #
81
+ def generate_static_seh_record(handler)
82
+ "\xeb\x06" + Rex::Text.rand_text(2, badchars) + [ handler ].pack('V')
83
+ end
84
+
85
+ protected
86
+
87
+ attr_accessor :badchars, :space, :nop # :nodoc:
88
+
89
+ end
90
+
91
+ end
92
+ end
@@ -0,0 +1,19 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ $:.unshift(File.join(File.dirname(__FILE__), '..', '..'))
4
+
5
+ require 'test/unit'
6
+ require 'rex/exploitation/seh'
7
+
8
+ class Rex::Exploitation::Seh::UnitTest < Test::Unit::TestCase
9
+
10
+ Klass = Rex::Exploitation::Seh
11
+
12
+ def test_static_record
13
+ r = Klass.new
14
+ record = r.generate_static_seh_record(0x41414141)
15
+ assert_equal("\xeb\x06", record[0, 2])
16
+ assert_equal("\x41\x41\x41\x41", record[4, 4])
17
+ end
18
+
19
+ end
@@ -0,0 +1,84 @@
1
+ require 'find'
2
+ require 'rex/compat'
3
+
4
+ module Rex
5
+
6
+ ###
7
+ #
8
+ # This class provides helper methods for dealing with files that are not
9
+ # supplied by the standard ruby API.
10
+ #
11
+ ###
12
+ module FileUtils
13
+
14
+ #
15
+ # This method searches the PATH environment variable for
16
+ # a fully qualified path to the supplied file name.
17
+ #
18
+ def self.find_full_path(file_name)
19
+
20
+ # Check for the absolute fast first
21
+ if (file_name[0,1] == "/" and ::File.exists?(file_name) and ::File::Stat.new(file_name))
22
+ return file_name
23
+ end
24
+
25
+ path = Rex::Compat.getenv('PATH')
26
+ if (path)
27
+ path.split(::File::PATH_SEPARATOR).each { |base|
28
+ begin
29
+ path = base + ::File::SEPARATOR + file_name
30
+ if (::File::Stat.new(path))
31
+ return path
32
+ end
33
+ rescue
34
+ end
35
+ }
36
+ end
37
+ return nil
38
+ end
39
+
40
+ end
41
+
42
+ module Find
43
+ #
44
+ # Identical to Find.find from Ruby, but follows symlinks to directories.
45
+ # See http://blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-talk/68671
46
+ #
47
+ def self.find(*paths)
48
+ paths.collect!{|d| d.dup}
49
+ while file = paths.shift
50
+ catch(:prune) do
51
+ yield file.dup.taint
52
+ next unless File.exist? file
53
+ begin
54
+ if File.stat(file).directory? then
55
+ d = Dir.open(file)
56
+ begin
57
+ for f in d
58
+ next if f == "." or f == ".."
59
+ if File::ALT_SEPARATOR and file =~ /^(?:[\/\\]|[A-Za-z]:[\/\\]?)$/ then
60
+ f = file + f
61
+ elsif file == "/" then
62
+ f = "/" + f
63
+ else
64
+ f = File.join(file, f)
65
+ end
66
+ paths.unshift f.untaint
67
+ end
68
+ ensure
69
+ d.close
70
+ end
71
+ end
72
+ rescue Errno::ENOENT, Errno::EACCES
73
+ end
74
+ end
75
+ end
76
+ end
77
+
78
+ def self.prune
79
+ throw :prune
80
+ end
81
+
82
+ end
83
+
84
+ end