librex 0.0.20 → 0.0.21

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 (435) hide show
  1. data/Rakefile +1 -0
  2. data/lib/rex/LICENSE +29 -0
  3. data/lib/rex/arch.rb +103 -0
  4. data/lib/rex/arch/sparc.rb +75 -0
  5. data/lib/rex/arch/sparc.rb.ut.rb +18 -0
  6. data/lib/rex/arch/x86.rb +513 -0
  7. data/lib/rex/arch/x86.rb.ut.rb +93 -0
  8. data/lib/rex/assembly/nasm.rb +104 -0
  9. data/lib/rex/assembly/nasm.rb.ut.rb +22 -0
  10. data/lib/rex/codepage.map +104 -0
  11. data/lib/rex/compat.rb +311 -0
  12. data/lib/rex/constants.rb +113 -0
  13. data/lib/rex/elfparsey.rb +11 -0
  14. data/lib/rex/elfparsey/elf.rb +123 -0
  15. data/lib/rex/elfparsey/elfbase.rb +258 -0
  16. data/lib/rex/elfparsey/exceptions.rb +27 -0
  17. data/lib/rex/elfscan.rb +12 -0
  18. data/lib/rex/elfscan/scanner.rb +207 -0
  19. data/lib/rex/elfscan/search.rb +46 -0
  20. data/lib/rex/encoder/alpha2.rb +31 -0
  21. data/lib/rex/encoder/alpha2/alpha_mixed.rb +68 -0
  22. data/lib/rex/encoder/alpha2/alpha_upper.rb +79 -0
  23. data/lib/rex/encoder/alpha2/generic.rb +114 -0
  24. data/lib/rex/encoder/alpha2/unicode_mixed.rb +117 -0
  25. data/lib/rex/encoder/alpha2/unicode_upper.rb +129 -0
  26. data/lib/rex/encoder/ndr.rb +89 -0
  27. data/lib/rex/encoder/ndr.rb.ut.rb +44 -0
  28. data/lib/rex/encoder/nonalpha.rb +61 -0
  29. data/lib/rex/encoder/nonupper.rb +64 -0
  30. data/lib/rex/encoder/xdr.rb +106 -0
  31. data/lib/rex/encoder/xdr.rb.ut.rb +29 -0
  32. data/lib/rex/encoder/xor.rb +69 -0
  33. data/lib/rex/encoder/xor/dword.rb +13 -0
  34. data/lib/rex/encoder/xor/dword_additive.rb +13 -0
  35. data/lib/rex/encoders/xor_dword.rb +35 -0
  36. data/lib/rex/encoders/xor_dword_additive.rb +53 -0
  37. data/lib/rex/encoders/xor_dword_additive.rb.ut.rb +12 -0
  38. data/lib/rex/encoding/xor.rb +20 -0
  39. data/lib/rex/encoding/xor.rb.ts.rb +14 -0
  40. data/lib/rex/encoding/xor/byte.rb +15 -0
  41. data/lib/rex/encoding/xor/byte.rb.ut.rb +21 -0
  42. data/lib/rex/encoding/xor/dword.rb +21 -0
  43. data/lib/rex/encoding/xor/dword.rb.ut.rb +15 -0
  44. data/lib/rex/encoding/xor/dword_additive.rb +92 -0
  45. data/lib/rex/encoding/xor/dword_additive.rb.ut.rb +15 -0
  46. data/lib/rex/encoding/xor/exceptions.rb +17 -0
  47. data/lib/rex/encoding/xor/generic.rb +146 -0
  48. data/lib/rex/encoding/xor/generic.rb.ut.rb +120 -0
  49. data/lib/rex/encoding/xor/qword.rb +15 -0
  50. data/lib/rex/encoding/xor/word.rb +21 -0
  51. data/lib/rex/encoding/xor/word.rb.ut.rb +13 -0
  52. data/lib/rex/exceptions.rb +275 -0
  53. data/lib/rex/exceptions.rb.ut.rb +44 -0
  54. data/lib/rex/exploitation/cmdstager.rb +9 -0
  55. data/lib/rex/exploitation/cmdstager/base.rb +175 -0
  56. data/lib/rex/exploitation/cmdstager/debug_asm.rb +142 -0
  57. data/lib/rex/exploitation/cmdstager/debug_write.rb +136 -0
  58. data/lib/rex/exploitation/cmdstager/tftp.rb +63 -0
  59. data/lib/rex/exploitation/cmdstager/vbs.rb +128 -0
  60. data/lib/rex/exploitation/egghunter.rb +277 -0
  61. data/lib/rex/exploitation/egghunter.rb.ut.rb +25 -0
  62. data/lib/rex/exploitation/encryptjs.rb +77 -0
  63. data/lib/rex/exploitation/heaplib.js.b64 +331 -0
  64. data/lib/rex/exploitation/heaplib.rb +94 -0
  65. data/lib/rex/exploitation/javascriptosdetect.rb +897 -0
  66. data/lib/rex/exploitation/obfuscatejs.rb +335 -0
  67. data/lib/rex/exploitation/omelet.rb +320 -0
  68. data/lib/rex/exploitation/omelet.rb.ut.rb +13 -0
  69. data/lib/rex/exploitation/opcodedb.rb +818 -0
  70. data/lib/rex/exploitation/opcodedb.rb.ut.rb +279 -0
  71. data/lib/rex/exploitation/seh.rb +92 -0
  72. data/lib/rex/exploitation/seh.rb.ut.rb +19 -0
  73. data/lib/rex/file.rb +112 -0
  74. data/lib/rex/file.rb.ut.rb +16 -0
  75. data/lib/rex/image_source.rb +12 -0
  76. data/lib/rex/image_source/disk.rb +60 -0
  77. data/lib/rex/image_source/image_source.rb +46 -0
  78. data/lib/rex/image_source/memory.rb +37 -0
  79. data/lib/rex/io/bidirectional_pipe.rb +157 -0
  80. data/lib/rex/io/datagram_abstraction.rb +35 -0
  81. data/lib/rex/io/ring_buffer.rb +364 -0
  82. data/lib/rex/io/stream.rb +319 -0
  83. data/lib/rex/io/stream_abstraction.rb +197 -0
  84. data/lib/rex/io/stream_server.rb +211 -0
  85. data/lib/rex/job_container.rb +187 -0
  86. data/lib/rex/logging.rb +4 -0
  87. data/lib/rex/logging/log_dispatcher.rb +179 -0
  88. data/lib/rex/logging/log_sink.rb +42 -0
  89. data/lib/rex/logging/sinks/flatfile.rb +55 -0
  90. data/lib/rex/logging/sinks/stderr.rb +43 -0
  91. data/lib/rex/machparsey.rb +9 -0
  92. data/lib/rex/machparsey/exceptions.rb +34 -0
  93. data/lib/rex/machparsey/mach.rb +209 -0
  94. data/lib/rex/machparsey/machbase.rb +408 -0
  95. data/lib/rex/machscan.rb +9 -0
  96. data/lib/rex/machscan/scanner.rb +217 -0
  97. data/lib/rex/mime.rb +9 -0
  98. data/lib/rex/mime/header.rb +77 -0
  99. data/lib/rex/mime/message.rb +144 -0
  100. data/lib/rex/mime/part.rb +20 -0
  101. data/lib/rex/nop/opty2.rb +108 -0
  102. data/lib/rex/nop/opty2.rb.ut.rb +23 -0
  103. data/lib/rex/nop/opty2_tables.rb +300 -0
  104. data/lib/rex/ole.rb +205 -0
  105. data/lib/rex/ole/clsid.rb +47 -0
  106. data/lib/rex/ole/difat.rb +141 -0
  107. data/lib/rex/ole/directory.rb +231 -0
  108. data/lib/rex/ole/direntry.rb +240 -0
  109. data/lib/rex/ole/docs/dependencies.txt +8 -0
  110. data/lib/rex/ole/docs/references.txt +1 -0
  111. data/lib/rex/ole/fat.rb +99 -0
  112. data/lib/rex/ole/header.rb +204 -0
  113. data/lib/rex/ole/minifat.rb +77 -0
  114. data/lib/rex/ole/propset.rb +144 -0
  115. data/lib/rex/ole/samples/create_ole.rb +27 -0
  116. data/lib/rex/ole/samples/dir.rb +35 -0
  117. data/lib/rex/ole/samples/dump_stream.rb +34 -0
  118. data/lib/rex/ole/samples/ole_info.rb +23 -0
  119. data/lib/rex/ole/storage.rb +395 -0
  120. data/lib/rex/ole/stream.rb +53 -0
  121. data/lib/rex/ole/substorage.rb +49 -0
  122. data/lib/rex/ole/util.rb +157 -0
  123. data/lib/rex/parser/arguments.rb +97 -0
  124. data/lib/rex/parser/arguments.rb.ut.rb +67 -0
  125. data/lib/rex/parser/ini.rb +185 -0
  126. data/lib/rex/parser/ini.rb.ut.rb +29 -0
  127. data/lib/rex/parser/ip360_aspl_xml.rb +102 -0
  128. data/lib/rex/parser/ip360_xml.rb +97 -0
  129. data/lib/rex/parser/nessus_xml.rb +118 -0
  130. data/lib/rex/parser/netsparker_xml.rb +94 -0
  131. data/lib/rex/parser/nexpose_xml.rb +136 -0
  132. data/lib/rex/parser/nmap_xml.rb +137 -0
  133. data/lib/rex/parser/retina_xml.rb +109 -0
  134. data/lib/rex/payloads.rb +1 -0
  135. data/lib/rex/payloads/win32.rb +2 -0
  136. data/lib/rex/payloads/win32/common.rb +26 -0
  137. data/lib/rex/payloads/win32/kernel.rb +53 -0
  138. data/lib/rex/payloads/win32/kernel/common.rb +54 -0
  139. data/lib/rex/payloads/win32/kernel/migration.rb +12 -0
  140. data/lib/rex/payloads/win32/kernel/recovery.rb +50 -0
  141. data/lib/rex/payloads/win32/kernel/stager.rb +194 -0
  142. data/lib/rex/peparsey.rb +12 -0
  143. data/lib/rex/peparsey/exceptions.rb +32 -0
  144. data/lib/rex/peparsey/pe.rb +212 -0
  145. data/lib/rex/peparsey/pe_memdump.rb +63 -0
  146. data/lib/rex/peparsey/pebase.rb +1680 -0
  147. data/lib/rex/peparsey/section.rb +136 -0
  148. data/lib/rex/pescan.rb +13 -0
  149. data/lib/rex/pescan/analyze.rb +309 -0
  150. data/lib/rex/pescan/scanner.rb +206 -0
  151. data/lib/rex/pescan/search.rb +56 -0
  152. data/lib/rex/platforms.rb +1 -0
  153. data/lib/rex/platforms/windows.rb +51 -0
  154. data/lib/rex/poly.rb +132 -0
  155. data/lib/rex/poly/block.rb +477 -0
  156. data/lib/rex/poly/register.rb +100 -0
  157. data/lib/rex/poly/register/x86.rb +40 -0
  158. data/lib/rex/post.rb +8 -0
  159. data/lib/rex/post/dir.rb +51 -0
  160. data/lib/rex/post/file.rb +172 -0
  161. data/lib/rex/post/file_stat.rb +220 -0
  162. data/lib/rex/post/gen.pl +13 -0
  163. data/lib/rex/post/io.rb +182 -0
  164. data/lib/rex/post/meterpreter.rb +4 -0
  165. data/lib/rex/post/meterpreter/channel.rb +445 -0
  166. data/lib/rex/post/meterpreter/channel_container.rb +54 -0
  167. data/lib/rex/post/meterpreter/channels/pool.rb +160 -0
  168. data/lib/rex/post/meterpreter/channels/pools/file.rb +62 -0
  169. data/lib/rex/post/meterpreter/channels/pools/stream_pool.rb +103 -0
  170. data/lib/rex/post/meterpreter/channels/stream.rb +87 -0
  171. data/lib/rex/post/meterpreter/client.rb +364 -0
  172. data/lib/rex/post/meterpreter/client_core.rb +274 -0
  173. data/lib/rex/post/meterpreter/dependencies.rb +3 -0
  174. data/lib/rex/post/meterpreter/extension.rb +32 -0
  175. data/lib/rex/post/meterpreter/extensions/espia/espia.rb +58 -0
  176. data/lib/rex/post/meterpreter/extensions/espia/tlv.rb +16 -0
  177. data/lib/rex/post/meterpreter/extensions/incognito/incognito.rb +94 -0
  178. data/lib/rex/post/meterpreter/extensions/incognito/tlv.rb +21 -0
  179. data/lib/rex/post/meterpreter/extensions/networkpug/networkpug.rb +57 -0
  180. data/lib/rex/post/meterpreter/extensions/networkpug/tlv.rb +15 -0
  181. data/lib/rex/post/meterpreter/extensions/priv/fs.rb +118 -0
  182. data/lib/rex/post/meterpreter/extensions/priv/passwd.rb +61 -0
  183. data/lib/rex/post/meterpreter/extensions/priv/priv.rb +111 -0
  184. data/lib/rex/post/meterpreter/extensions/priv/tlv.rb +28 -0
  185. data/lib/rex/post/meterpreter/extensions/sniffer/sniffer.rb +101 -0
  186. data/lib/rex/post/meterpreter/extensions/sniffer/tlv.rb +26 -0
  187. data/lib/rex/post/meterpreter/extensions/stdapi/constants.rb +333 -0
  188. data/lib/rex/post/meterpreter/extensions/stdapi/fs/dir.rb +282 -0
  189. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file.rb +266 -0
  190. data/lib/rex/post/meterpreter/extensions/stdapi/fs/file_stat.rb +103 -0
  191. data/lib/rex/post/meterpreter/extensions/stdapi/fs/io.rb +48 -0
  192. data/lib/rex/post/meterpreter/extensions/stdapi/net/config.rb +144 -0
  193. data/lib/rex/post/meterpreter/extensions/stdapi/net/interface.rb +73 -0
  194. data/lib/rex/post/meterpreter/extensions/stdapi/net/route.rb +56 -0
  195. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket.rb +137 -0
  196. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_client_channel.rb +180 -0
  197. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/tcp_server_channel.rb +167 -0
  198. data/lib/rex/post/meterpreter/extensions/stdapi/net/socket_subsystem/udp_channel.rb +208 -0
  199. data/lib/rex/post/meterpreter/extensions/stdapi/railgun.rb.ts.rb +6 -0
  200. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb +38106 -0
  201. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/api_constants.rb.ut.rb +31 -0
  202. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb +47 -0
  203. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/buffer_item.rb.ut.rb +36 -0
  204. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_advapi32.rb +1818 -0
  205. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_iphlpapi.rb +96 -0
  206. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_kernel32.rb +3848 -0
  207. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_netapi32.rb +26 -0
  208. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ntdll.rb +153 -0
  209. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_shell32.rb +21 -0
  210. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_user32.rb +3169 -0
  211. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/def/def_ws2_32.rb +599 -0
  212. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll.rb +318 -0
  213. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb +100 -0
  214. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_function.rb.ut.rb +42 -0
  215. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb +148 -0
  216. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/dll_helper.rb.ut.rb +127 -0
  217. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/multicall.rb +309 -0
  218. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/railgun.rb +204 -0
  219. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/tlv.rb +51 -0
  220. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/util.rb +630 -0
  221. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb +75 -0
  222. data/lib/rex/post/meterpreter/extensions/stdapi/railgun/win_const_manager.rb.ut.rb +103 -0
  223. data/lib/rex/post/meterpreter/extensions/stdapi/stdapi.rb +149 -0
  224. data/lib/rex/post/meterpreter/extensions/stdapi/sys/config.rb +97 -0
  225. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log.rb +192 -0
  226. data/lib/rex/post/meterpreter/extensions/stdapi/sys/event_log_subsystem/event_record.rb +41 -0
  227. data/lib/rex/post/meterpreter/extensions/stdapi/sys/power.rb +61 -0
  228. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process.rb +370 -0
  229. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/image.rb +129 -0
  230. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/io.rb +55 -0
  231. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/memory.rb +336 -0
  232. data/lib/rex/post/meterpreter/extensions/stdapi/sys/process_subsystem/thread.rb +141 -0
  233. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry.rb +279 -0
  234. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_key.rb +193 -0
  235. data/lib/rex/post/meterpreter/extensions/stdapi/sys/registry_subsystem/registry_value.rb +102 -0
  236. data/lib/rex/post/meterpreter/extensions/stdapi/sys/thread.rb +180 -0
  237. data/lib/rex/post/meterpreter/extensions/stdapi/tlv.rb +211 -0
  238. data/lib/rex/post/meterpreter/extensions/stdapi/ui.rb +227 -0
  239. data/lib/rex/post/meterpreter/extensions/stdapi/webcam/webcam.rb +63 -0
  240. data/lib/rex/post/meterpreter/inbound_packet_handler.rb +30 -0
  241. data/lib/rex/post/meterpreter/object_aliases.rb +83 -0
  242. data/lib/rex/post/meterpreter/packet.rb +688 -0
  243. data/lib/rex/post/meterpreter/packet_dispatcher.rb +431 -0
  244. data/lib/rex/post/meterpreter/packet_parser.rb +94 -0
  245. data/lib/rex/post/meterpreter/packet_response_waiter.rb +83 -0
  246. data/lib/rex/post/meterpreter/ui/console.rb +137 -0
  247. data/lib/rex/post/meterpreter/ui/console/command_dispatcher.rb +62 -0
  248. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/core.rb +730 -0
  249. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/espia.rb +108 -0
  250. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/incognito.rb +241 -0
  251. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/networkpug.rb +231 -0
  252. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv.rb +61 -0
  253. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/elevate.rb +98 -0
  254. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/passwd.rb +51 -0
  255. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/priv/timestomp.rb +132 -0
  256. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/sniffer.rb +187 -0
  257. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi.rb +65 -0
  258. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/fs.rb +442 -0
  259. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/net.rb +298 -0
  260. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/sys.rb +486 -0
  261. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/ui.rb +315 -0
  262. data/lib/rex/post/meterpreter/ui/console/command_dispatcher/stdapi/webcam.rb +157 -0
  263. data/lib/rex/post/meterpreter/ui/console/interactive_channel.rb +95 -0
  264. data/lib/rex/post/permission.rb +26 -0
  265. data/lib/rex/post/process.rb +57 -0
  266. data/lib/rex/post/thread.rb +57 -0
  267. data/lib/rex/post/ui.rb +52 -0
  268. data/lib/rex/proto.rb +13 -0
  269. data/lib/rex/proto.rb.ts.rb +8 -0
  270. data/lib/rex/proto/dcerpc.rb +6 -0
  271. data/lib/rex/proto/dcerpc.rb.ts.rb +9 -0
  272. data/lib/rex/proto/dcerpc/client.rb +361 -0
  273. data/lib/rex/proto/dcerpc/client.rb.ut.rb +491 -0
  274. data/lib/rex/proto/dcerpc/exceptions.rb +150 -0
  275. data/lib/rex/proto/dcerpc/handle.rb +47 -0
  276. data/lib/rex/proto/dcerpc/handle.rb.ut.rb +85 -0
  277. data/lib/rex/proto/dcerpc/ndr.rb +72 -0
  278. data/lib/rex/proto/dcerpc/ndr.rb.ut.rb +41 -0
  279. data/lib/rex/proto/dcerpc/packet.rb +253 -0
  280. data/lib/rex/proto/dcerpc/packet.rb.ut.rb +56 -0
  281. data/lib/rex/proto/dcerpc/response.rb +187 -0
  282. data/lib/rex/proto/dcerpc/response.rb.ut.rb +15 -0
  283. data/lib/rex/proto/dcerpc/uuid.rb +84 -0
  284. data/lib/rex/proto/dcerpc/uuid.rb.ut.rb +46 -0
  285. data/lib/rex/proto/dhcp.rb +7 -0
  286. data/lib/rex/proto/dhcp/constants.rb +33 -0
  287. data/lib/rex/proto/dhcp/server.rb +292 -0
  288. data/lib/rex/proto/drda.rb +5 -0
  289. data/lib/rex/proto/drda.rb.ts.rb +17 -0
  290. data/lib/rex/proto/drda/constants.rb +49 -0
  291. data/lib/rex/proto/drda/constants.rb.ut.rb +23 -0
  292. data/lib/rex/proto/drda/packet.rb +252 -0
  293. data/lib/rex/proto/drda/packet.rb.ut.rb +109 -0
  294. data/lib/rex/proto/drda/utils.rb +123 -0
  295. data/lib/rex/proto/drda/utils.rb.ut.rb +84 -0
  296. data/lib/rex/proto/http.rb +5 -0
  297. data/lib/rex/proto/http.rb.ts.rb +12 -0
  298. data/lib/rex/proto/http/client.rb +821 -0
  299. data/lib/rex/proto/http/client.rb.ut.rb +95 -0
  300. data/lib/rex/proto/http/handler.rb +46 -0
  301. data/lib/rex/proto/http/handler/erb.rb +128 -0
  302. data/lib/rex/proto/http/handler/erb.rb.ut.rb +21 -0
  303. data/lib/rex/proto/http/handler/erb.rb.ut.rb.rhtml +1 -0
  304. data/lib/rex/proto/http/handler/proc.rb +60 -0
  305. data/lib/rex/proto/http/handler/proc.rb.ut.rb +24 -0
  306. data/lib/rex/proto/http/header.rb +161 -0
  307. data/lib/rex/proto/http/header.rb.ut.rb +46 -0
  308. data/lib/rex/proto/http/packet.rb +407 -0
  309. data/lib/rex/proto/http/packet.rb.ut.rb +165 -0
  310. data/lib/rex/proto/http/request.rb +356 -0
  311. data/lib/rex/proto/http/request.rb.ut.rb +214 -0
  312. data/lib/rex/proto/http/response.rb +90 -0
  313. data/lib/rex/proto/http/response.rb.ut.rb +149 -0
  314. data/lib/rex/proto/http/server.rb +369 -0
  315. data/lib/rex/proto/http/server.rb.ut.rb +79 -0
  316. data/lib/rex/proto/ntlm.rb +7 -0
  317. data/lib/rex/proto/ntlm.rb.ut.rb +177 -0
  318. data/lib/rex/proto/ntlm/base.rb +326 -0
  319. data/lib/rex/proto/ntlm/constants.rb +74 -0
  320. data/lib/rex/proto/ntlm/crypt.rb +415 -0
  321. data/lib/rex/proto/ntlm/exceptions.rb +16 -0
  322. data/lib/rex/proto/ntlm/message.rb +536 -0
  323. data/lib/rex/proto/ntlm/utils.rb +764 -0
  324. data/lib/rex/proto/proxy/socks4a.rb +440 -0
  325. data/lib/rex/proto/rfb.rb +19 -0
  326. data/lib/rex/proto/rfb.rb.ut.rb +37 -0
  327. data/lib/rex/proto/rfb/cipher.rb +84 -0
  328. data/lib/rex/proto/rfb/client.rb +207 -0
  329. data/lib/rex/proto/rfb/constants.rb +52 -0
  330. data/lib/rex/proto/smb.rb +7 -0
  331. data/lib/rex/proto/smb.rb.ts.rb +8 -0
  332. data/lib/rex/proto/smb/client.rb +1952 -0
  333. data/lib/rex/proto/smb/client.rb.ut.rb +223 -0
  334. data/lib/rex/proto/smb/constants.rb +1047 -0
  335. data/lib/rex/proto/smb/constants.rb.ut.rb +18 -0
  336. data/lib/rex/proto/smb/crypt.rb +36 -0
  337. data/lib/rex/proto/smb/evasions.rb +66 -0
  338. data/lib/rex/proto/smb/exceptions.rb +858 -0
  339. data/lib/rex/proto/smb/simpleclient.rb +306 -0
  340. data/lib/rex/proto/smb/simpleclient.rb.ut.rb +128 -0
  341. data/lib/rex/proto/smb/utils.rb +103 -0
  342. data/lib/rex/proto/smb/utils.rb.ut.rb +20 -0
  343. data/lib/rex/proto/sunrpc.rb +1 -0
  344. data/lib/rex/proto/sunrpc/client.rb +195 -0
  345. data/lib/rex/proto/tftp.rb +12 -0
  346. data/lib/rex/proto/tftp/constants.rb +39 -0
  347. data/lib/rex/proto/tftp/server.rb +497 -0
  348. data/lib/rex/proto/tftp/server.rb.ut.rb +28 -0
  349. data/lib/rex/script.rb +42 -0
  350. data/lib/rex/script/base.rb +59 -0
  351. data/lib/rex/script/meterpreter.rb +15 -0
  352. data/lib/rex/script/shell.rb +9 -0
  353. data/lib/rex/service.rb +48 -0
  354. data/lib/rex/service_manager.rb +141 -0
  355. data/lib/rex/service_manager.rb.ut.rb +32 -0
  356. data/lib/rex/services/local_relay.rb +423 -0
  357. data/lib/rex/socket.rb +684 -0
  358. data/lib/rex/socket.rb.ut.rb +107 -0
  359. data/lib/rex/socket/comm.rb +119 -0
  360. data/lib/rex/socket/comm/local.rb +412 -0
  361. data/lib/rex/socket/comm/local.rb.ut.rb +75 -0
  362. data/lib/rex/socket/ip.rb +130 -0
  363. data/lib/rex/socket/parameters.rb +345 -0
  364. data/lib/rex/socket/parameters.rb.ut.rb +51 -0
  365. data/lib/rex/socket/range_walker.rb +346 -0
  366. data/lib/rex/socket/range_walker.rb.ut.rb +55 -0
  367. data/lib/rex/socket/ssl_tcp.rb +184 -0
  368. data/lib/rex/socket/ssl_tcp.rb.ut.rb +39 -0
  369. data/lib/rex/socket/ssl_tcp_server.rb +122 -0
  370. data/lib/rex/socket/ssl_tcp_server.rb.ut.rb +61 -0
  371. data/lib/rex/socket/subnet_walker.rb +75 -0
  372. data/lib/rex/socket/subnet_walker.rb.ut.rb +28 -0
  373. data/lib/rex/socket/switch_board.rb +278 -0
  374. data/lib/rex/socket/switch_board.rb.ut.rb +52 -0
  375. data/lib/rex/socket/tcp.rb +76 -0
  376. data/lib/rex/socket/tcp.rb.ut.rb +64 -0
  377. data/lib/rex/socket/tcp_server.rb +66 -0
  378. data/lib/rex/socket/tcp_server.rb.ut.rb +44 -0
  379. data/lib/rex/socket/udp.rb +164 -0
  380. data/lib/rex/socket/udp.rb.ut.rb +44 -0
  381. data/lib/rex/struct2.rb +5 -0
  382. data/lib/rex/struct2/c_struct.rb +181 -0
  383. data/lib/rex/struct2/c_struct_template.rb +39 -0
  384. data/lib/rex/struct2/constant.rb +26 -0
  385. data/lib/rex/struct2/element.rb +44 -0
  386. data/lib/rex/struct2/generic.rb +73 -0
  387. data/lib/rex/struct2/restraint.rb +54 -0
  388. data/lib/rex/struct2/s_string.rb +72 -0
  389. data/lib/rex/struct2/s_struct.rb +111 -0
  390. data/lib/rex/sync.rb +6 -0
  391. data/lib/rex/sync/event.rb +94 -0
  392. data/lib/rex/sync/read_write_lock.rb +176 -0
  393. data/lib/rex/sync/ref.rb +57 -0
  394. data/lib/rex/sync/thread_safe.rb +82 -0
  395. data/lib/rex/test.rb +35 -0
  396. data/lib/rex/text.rb +1163 -0
  397. data/lib/rex/text.rb.ut.rb +190 -0
  398. data/lib/rex/thread_factory.rb +42 -0
  399. data/lib/rex/time.rb +65 -0
  400. data/lib/rex/transformer.rb +115 -0
  401. data/lib/rex/transformer.rb.ut.rb +38 -0
  402. data/lib/rex/ui.rb +21 -0
  403. data/lib/rex/ui/interactive.rb +298 -0
  404. data/lib/rex/ui/output.rb +78 -0
  405. data/lib/rex/ui/output/none.rb +18 -0
  406. data/lib/rex/ui/progress_tracker.rb +96 -0
  407. data/lib/rex/ui/subscriber.rb +149 -0
  408. data/lib/rex/ui/text/color.rb +97 -0
  409. data/lib/rex/ui/text/color.rb.ut.rb +18 -0
  410. data/lib/rex/ui/text/dispatcher_shell.rb +467 -0
  411. data/lib/rex/ui/text/input.rb +117 -0
  412. data/lib/rex/ui/text/input/buffer.rb +75 -0
  413. data/lib/rex/ui/text/input/readline.rb +129 -0
  414. data/lib/rex/ui/text/input/socket.rb +95 -0
  415. data/lib/rex/ui/text/input/stdio.rb +45 -0
  416. data/lib/rex/ui/text/irb_shell.rb +57 -0
  417. data/lib/rex/ui/text/output.rb +80 -0
  418. data/lib/rex/ui/text/output/buffer.rb +61 -0
  419. data/lib/rex/ui/text/output/file.rb +43 -0
  420. data/lib/rex/ui/text/output/socket.rb +43 -0
  421. data/lib/rex/ui/text/output/stdio.rb +40 -0
  422. data/lib/rex/ui/text/progress_tracker.rb +56 -0
  423. data/lib/rex/ui/text/progress_tracker.rb.ut.rb +34 -0
  424. data/lib/rex/ui/text/shell.rb +328 -0
  425. data/lib/rex/ui/text/table.rb +279 -0
  426. data/lib/rex/ui/text/table.rb.ut.rb +55 -0
  427. data/lib/rex/zip.rb +93 -0
  428. data/lib/rex/zip/archive.rb +184 -0
  429. data/lib/rex/zip/blocks.rb +182 -0
  430. data/lib/rex/zip/entry.rb +104 -0
  431. data/lib/rex/zip/samples/comment.rb +32 -0
  432. data/lib/rex/zip/samples/mkwar.rb +138 -0
  433. data/lib/rex/zip/samples/mkzip.rb +19 -0
  434. data/lib/rex/zip/samples/recursive.rb +58 -0
  435. metadata +434 -1
@@ -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,112 @@
1
+ require 'find'
2
+ require 'rex/compat'
3
+ require 'tempfile'
4
+
5
+ module Rex
6
+
7
+ ###
8
+ #
9
+ # This class provides helper methods for dealing with files that are not
10
+ # supplied by the standard ruby API.
11
+ #
12
+ ###
13
+ module FileUtils
14
+
15
+ #
16
+ # This methods cleans the supplied path of directory traversal sequences
17
+ # It must accept path/with/..a/folder../starting/or/ending/in/two/dots
18
+ # but clean ../something as well as path/with/..\traversal
19
+ #
20
+ def self.clean_path(old)
21
+ path = old
22
+ while(path.index(/\/..\/|\/..\\|\\..\\|\\..\/|\A..\\|\A..\//) != nil)
23
+ path.gsub!(/\A..\\|\A..\//,'') #eliminate starting ..\ or ../
24
+ path.gsub!(/\/..\/|\/..\\/,'/') #clean linux style
25
+ path.gsub!(/\\..\\|\\..\//,'\\') #clean windows style
26
+ end
27
+ path
28
+ end
29
+
30
+ #
31
+ # This method searches the PATH environment variable for
32
+ # a fully qualified path to the supplied file name.
33
+ #
34
+ def self.find_full_path(file_name)
35
+
36
+ # Check for the absolute fast first
37
+ if (file_name[0,1] == "/" and ::File.exists?(file_name) and ::File::Stat.new(file_name))
38
+ return file_name
39
+ end
40
+
41
+ path = Rex::Compat.getenv('PATH')
42
+ if (path)
43
+ path.split(::File::PATH_SEPARATOR).each { |base|
44
+ begin
45
+ # Deal with Windows paths surrounded by quotes. Prevents
46
+ # silliness like trying to look for
47
+ # '"C:\\framework\\nmap"\\nmap.exe' which will always fail.
48
+ base = $1 if base =~ /^"(.*)"$/
49
+ path = base + ::File::SEPARATOR + file_name
50
+ if (::File::Stat.new(path) and not ::File.directory?(path))
51
+ return path
52
+ end
53
+ rescue
54
+ end
55
+ }
56
+ end
57
+ return nil
58
+ end
59
+
60
+ end
61
+
62
+ class Quickfile < ::Tempfile
63
+ def initialize(*args)
64
+ super(*args)
65
+ self.binmode
66
+ ObjectSpace.undefine_finalizer(self)
67
+ end
68
+ end
69
+
70
+ module Find
71
+ #
72
+ # Identical to Find.find from Ruby, but follows symlinks to directories.
73
+ # See http://blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-talk/68671
74
+ #
75
+ def self.find(*paths)
76
+ paths.collect!{|d| d.dup}
77
+ while file = paths.shift
78
+ catch(:prune) do
79
+ yield file.dup.taint
80
+ next unless File.exist? file
81
+ begin
82
+ if File.stat(file).directory? then
83
+ d = Dir.open(file)
84
+ begin
85
+ for f in d
86
+ next if f == "." or f == ".."
87
+ if File::ALT_SEPARATOR and file =~ /^(?:[\/\\]|[A-Za-z]:[\/\\]?)$/ then
88
+ f = file + f
89
+ elsif file == "/" then
90
+ f = "/" + f
91
+ else
92
+ f = File.join(file, f)
93
+ end
94
+ paths.unshift f.untaint
95
+ end
96
+ ensure
97
+ d.close
98
+ end
99
+ end
100
+ rescue Errno::ENOENT, Errno::EACCES
101
+ end
102
+ end
103
+ end
104
+ end
105
+
106
+ def self.prune
107
+ throw :prune
108
+ end
109
+
110
+ end
111
+
112
+ end