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,211 @@
1
+ module Rex
2
+ module IO
3
+
4
+ ###
5
+ #
6
+ # This mixin provides the framework and interface for implementing a streaming
7
+ # server that can listen for and accept stream client connections. Stream
8
+ # servers extend this class and are required to implement the following
9
+ # methods:
10
+ #
11
+ # accept
12
+ # fd
13
+ #
14
+ ###
15
+ module StreamServer
16
+
17
+ ##
18
+ #
19
+ # Abstract methods
20
+ #
21
+ ##
22
+
23
+ ##
24
+ #
25
+ # Default server monitoring and client management implementation follows
26
+ # below.
27
+ #
28
+ ##
29
+
30
+ #
31
+ # This callback is notified when a client connects.
32
+ #
33
+ def on_client_connect(client)
34
+ if (on_client_connect_proc)
35
+ on_client_connect_proc.call(client)
36
+ end
37
+ end
38
+
39
+ #
40
+ # This callback is notified when a client connection has data that needs to
41
+ # be processed.
42
+ #
43
+ def on_client_data(client)
44
+ if (on_client_data_proc)
45
+ on_client_data_proc.call(client)
46
+ end
47
+ end
48
+
49
+ #
50
+ # This callback is notified when a client connection has closed.
51
+ #
52
+ def on_client_close(client)
53
+ if (on_client_close_proc)
54
+ on_client_close_proc.call(client)
55
+ end
56
+ end
57
+
58
+ #
59
+ # Start monitoring the listener socket for connections and keep track of
60
+ # all client connections.
61
+ #
62
+ def start
63
+ self.clients = []
64
+
65
+ self.listener_thread = Rex::ThreadFactory.spawn("StreamServerListener", false) {
66
+ monitor_listener
67
+ }
68
+ self.clients_thread = Rex::ThreadFactory.spawn("StreamServerClientMonitor", false) {
69
+ monitor_clients
70
+ }
71
+ end
72
+
73
+ #
74
+ # Terminates the listener monitoring threads and closes all active clients.
75
+ #
76
+ def stop
77
+ self.listener_thread.kill
78
+ self.clients_thread.kill
79
+
80
+ self.clients.each { |cli|
81
+ close_client(cli)
82
+ }
83
+ end
84
+
85
+ #
86
+ # This method closes a client connection and cleans up the resources
87
+ # associated with it.
88
+ #
89
+ def close_client(client)
90
+ if (client)
91
+ clients.delete(client)
92
+
93
+ begin
94
+ client.close
95
+ rescue IOError
96
+ end
97
+ end
98
+ end
99
+
100
+ #
101
+ # This method waits on the server listener thread
102
+ #
103
+ def wait
104
+ self.listener_thread.join if self.listener_thread
105
+ end
106
+
107
+ ##
108
+ #
109
+ # Callback procedures.
110
+ #
111
+ ##
112
+
113
+ #
114
+ # This callback procedure can be set and will be called when new clients
115
+ # connect.
116
+ #
117
+ attr_accessor :on_client_connect_proc
118
+ #
119
+ # This callback procedure can be set and will be called when clients
120
+ # have data to be processed.
121
+ #
122
+ attr_accessor :on_client_data_proc
123
+ #
124
+ # This callback procedure can be set and will be called when a client
125
+ # disconnects from the server.
126
+ #
127
+ attr_accessor :on_client_close_proc
128
+
129
+ attr_accessor :clients # :nodoc:
130
+ attr_accessor :listener_thread, :clients_thread # :nodoc:
131
+
132
+ protected
133
+
134
+ #
135
+ # This method monitors the listener socket for new connections and calls
136
+ # the +on_client_connect+ callback routine.
137
+ #
138
+ def monitor_listener
139
+
140
+ while true
141
+ begin
142
+ cli = accept
143
+ if not cli
144
+ elog("The accept() returned nil in stream server listener monitor: #{fd.inspect}")
145
+ ::IO.select(nil, nil, nil, 0.10)
146
+ next
147
+ end
148
+
149
+ # Append to the list of clients
150
+ self.clients << cli
151
+
152
+ # Initialize the connection processing
153
+ on_client_connect(cli)
154
+
155
+ # Skip exceptions caused by accept() [ SSL ]
156
+ rescue ::EOFError, ::Errno::ECONNRESET, ::Errno::ENOTCONN, ::Errno::ECONNABORTED
157
+ rescue ::Interrupt
158
+ raise $!
159
+ rescue ::Exception
160
+ elog("Error in stream server server monitor: #{$!}")
161
+ rlog(ExceptionCallStack)
162
+ break
163
+ end
164
+ end
165
+ end
166
+
167
+ #
168
+ # This method monitors client connections for data and calls the
169
+ # +on_client_data+ routine when new data arrives.
170
+ #
171
+ def monitor_clients
172
+ begin
173
+ if (clients.length == 0)
174
+ Rex::ThreadSafe::sleep(0.25)
175
+ next
176
+ end
177
+
178
+ sd = Rex::ThreadSafe.select(clients)
179
+
180
+ sd[0].each { |cfd|
181
+ begin
182
+ on_client_data(cfd)
183
+ rescue ::EOFError, ::Errno::ECONNRESET, ::Errno::ENOTCONN, ::Errno::ECONNABORTED
184
+ on_client_close(cfd)
185
+ close_client(cfd)
186
+ rescue ::Interrupt
187
+ raise $!
188
+ rescue ::Exception
189
+ close_client(cfd)
190
+ elog("Error in stream server client monitor: #{$!}")
191
+ rlog(ExceptionCallStack)
192
+
193
+ end
194
+ }
195
+
196
+ rescue ::Rex::StreamClosedError => e
197
+ # Remove the closed stream from the list
198
+ clients.delete(e.stream)
199
+ rescue ::Interrupt
200
+ raise $!
201
+ rescue ::Exception
202
+ elog("Error in stream server client monitor: #{$!}")
203
+ rlog(ExceptionCallStack)
204
+ end while true
205
+ end
206
+
207
+ end
208
+
209
+ end
210
+ end
211
+
@@ -0,0 +1,187 @@
1
+ module Rex
2
+
3
+ ###
4
+ #
5
+ # This class is the concrete representation of an abstract job.
6
+ #
7
+ ###
8
+ class Job
9
+
10
+ #
11
+ # Creates an individual job instance and initializes it with the supplied
12
+ # parameters.
13
+ #
14
+ def initialize(container, jid, name, ctx, run_proc, clean_proc)
15
+ self.container = container
16
+ self.jid = jid
17
+ self.name = name
18
+ self.run_proc = run_proc
19
+ self.clean_proc = clean_proc
20
+ self.ctx = ctx
21
+ self.start_time = nil
22
+ end
23
+
24
+ #
25
+ # Runs the job in the context of its own thread if the async flag is false.
26
+ # Otherwise, the job is run inline.
27
+ #
28
+ def start(async = false)
29
+ self.start_time = Time.now
30
+ if (async)
31
+ self.job_thread = Rex::ThreadFactory.spawn("JobID(#{jid})-#{name}", false) {
32
+ # Deschedule our thread momentarily
33
+ ::IO.select(nil, nil, nil, 0.01)
34
+
35
+ begin
36
+ run_proc.call(ctx)
37
+ ensure
38
+ clean_proc.call(ctx)
39
+ container.remove_job(self)
40
+ end
41
+ }
42
+ else
43
+ begin
44
+ run_proc.call(ctx)
45
+ rescue ::Exception
46
+ container.stop_job(jid)
47
+ raise $!
48
+ end
49
+ end
50
+ end
51
+
52
+ #
53
+ # Stops the job if it's currently running and calls its cleanup procedure
54
+ #
55
+ def stop
56
+ if (self.job_thread)
57
+ self.job_thread.kill
58
+ self.job_thread = nil
59
+ end
60
+
61
+ clean_proc.call(ctx) if (clean_proc)
62
+ end
63
+
64
+ #
65
+ # The name of the job.
66
+ #
67
+ attr_reader :name
68
+
69
+ #
70
+ # The job identifier as assigned by the job container.
71
+ #
72
+ attr_reader :jid
73
+
74
+ #
75
+ # The time at which this job was started.
76
+ #
77
+ attr_reader :start_time
78
+
79
+ #
80
+ # Some job context.
81
+ #
82
+ attr_reader :ctx
83
+
84
+ protected
85
+
86
+ attr_writer :name #:nodoc:
87
+ attr_writer :jid #:nodoc:
88
+ attr_accessor :job_thread #:nodoc:
89
+ attr_accessor :container #:nodoc:
90
+ attr_accessor :run_proc #:nodoc:
91
+ attr_accessor :clean_proc #:nodoc:
92
+ attr_writer :ctx #:nodoc:
93
+ attr_writer :start_time #:nodoc:
94
+
95
+ end
96
+
97
+ ###
98
+ #
99
+ # This class contains zero or more abstract jobs that can be enumerated and
100
+ # stopped in a generic fashion. This is used to provide a mechanism for
101
+ # keeping track of arbitrary contexts that may or may not require a dedicated
102
+ # thread.
103
+ #
104
+ ###
105
+ class JobContainer < Hash
106
+
107
+ def initialize
108
+ self.job_id_pool = 0
109
+ end
110
+
111
+ #
112
+ # Adds an already running task as a symbolic job to the container.
113
+ #
114
+ def add_job(name, ctx, run_proc, clean_proc)
115
+ real_name = name
116
+ count = 0
117
+ jid = job_id_pool
118
+
119
+ self.job_id_pool += 1
120
+
121
+ # If we were not supplied with a job name, pick one from the hat
122
+ if (real_name == nil)
123
+ real_name = '#' + jid.to_s
124
+ end
125
+
126
+ # Find a unique job name
127
+ while (j = self[real_name])
128
+ real_name = name + " #{count}"
129
+ count += 1
130
+ end
131
+
132
+ j = Job.new(self, jid, real_name, ctx, run_proc, clean_proc)
133
+
134
+ self[jid.to_s] = j
135
+ end
136
+
137
+ #
138
+ # Starts a job using the supplied name and run/clean procedures.
139
+ #
140
+ def start_job(name, ctx, run_proc, clean_proc = nil)
141
+ j = add_job(name, ctx, run_proc, clean_proc)
142
+ j.start
143
+
144
+ j.jid
145
+ end
146
+
147
+ #
148
+ # Starts a background job that doesn't call the cleanup routine or run
149
+ # the run_proc in its own thread. Rather, the run_proc is called
150
+ # immediately and the clean_proc is never called until the job is removed
151
+ # from the job container.
152
+ #
153
+ def start_bg_job(name, ctx, run_proc, clean_proc = nil, async = true)
154
+ j = add_job(name, ctx, run_proc, clean_proc)
155
+ j.start(async)
156
+
157
+ j.jid
158
+ end
159
+
160
+ #
161
+ # Stops the job with the supplied name and forces it to cleanup. Stopping
162
+ # the job also leads to its removal.
163
+ #
164
+ def stop_job(jid)
165
+ if (j = self[jid.to_s])
166
+ j.stop
167
+
168
+ remove_job(j)
169
+ end
170
+ end
171
+
172
+ #
173
+ # Removes a job that was previously running. This is typically called when
174
+ # a job completes its task.
175
+ #
176
+ def remove_job(inst)
177
+ self.delete(inst.jid.to_s)
178
+ end
179
+
180
+ protected
181
+
182
+ attr_accessor :job_id_pool # :nodoc:
183
+
184
+ end
185
+
186
+ end
187
+
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require 'rex/constants' # for LEV_'s
4
+ require 'rex/logging/log_dispatcher'
@@ -0,0 +1,179 @@
1
+ require 'rex/sync'
2
+ require 'rex/logging/log_sink'
3
+
4
+ module Rex
5
+ module Logging
6
+
7
+ ###
8
+ #
9
+ # The log dispatcher associates log sources with log sinks. A log source
10
+ # is a unique identity that is associated with one and only one log sink.
11
+ # For instance, the framework-core registers the 'core'
12
+ #
13
+ ###
14
+ class LogDispatcher
15
+
16
+ #
17
+ # Creates the global log dispatcher instance and initializes it for use.
18
+ #
19
+ def initialize()
20
+ self.log_sinks = {}
21
+ self.log_levels = {}
22
+ self.log_sinks_lock = Mutex.new
23
+ end
24
+
25
+ #
26
+ # Returns the sink that is associated with the supplied source.
27
+ #
28
+ def [](src)
29
+ sink = nil
30
+
31
+ log_sinks_lock.synchronize {
32
+ sink = log_sinks[src]
33
+ }
34
+
35
+ return sink
36
+ end
37
+
38
+ #
39
+ # Calls the source association routie.
40
+ #
41
+ def []=(src, sink)
42
+ store(src, sink)
43
+ end
44
+
45
+ #
46
+ # Associates the supplied source with the supplied sink. If a log level
47
+ # has already been defined for the source, the level argument is ignored.
48
+ # Use set_log_level to alter it.
49
+ #
50
+ def store(src, sink, level = 0)
51
+ log_sinks_lock.synchronize {
52
+ if (log_sinks[src] == nil)
53
+ log_sinks[src] = sink
54
+
55
+ set_log_level(src, level) if (log_levels[src] == nil)
56
+ else
57
+ raise(
58
+ RuntimeError,
59
+ "The supplied log source #{src} is already registered.",
60
+ caller)
61
+ end
62
+ }
63
+ end
64
+
65
+ #
66
+ # Removes a source association if one exists.
67
+ #
68
+ def delete(src)
69
+ sink = nil
70
+
71
+ log_sinks_lock.synchronize {
72
+ sink = log_sinks[src]
73
+
74
+ log_sinks.delete(src)
75
+ }
76
+
77
+ if (sink)
78
+ sink.cleanup
79
+
80
+ return true
81
+ end
82
+
83
+ return false
84
+ end
85
+
86
+ #
87
+ # Performs the actual log operation against the supplied source
88
+ #
89
+ def log(sev, src, level, msg, from)
90
+ log_sinks_lock.synchronize {
91
+ if ((sink = log_sinks[src]))
92
+ next if (log_levels[src] and level > log_levels[src])
93
+
94
+ sink.log(sev, src, level, msg, from)
95
+ end
96
+ }
97
+ end
98
+
99
+ #
100
+ # This method sets the log level threshold for a given source.
101
+ #
102
+ def set_level(src, level)
103
+ log_levels[src] = level.to_i
104
+ end
105
+
106
+ #
107
+ # This method returns the log level threshold of a given source.
108
+ #
109
+ def get_level(src)
110
+ log_levels[src]
111
+ end
112
+
113
+ attr_accessor :log_sinks, :log_sinks_lock # :nodoc:
114
+ attr_accessor :log_levels # :nodoc:
115
+ end
116
+
117
+ end
118
+ end
119
+
120
+ ###
121
+ #
122
+ # An instance of the log dispatcher exists in the global namespace, along
123
+ # with stubs for many of the common logging methods. Various sources can
124
+ # register themselves as a log sink such that logs can be directed at
125
+ # various targets depending on where they're sourced from. By doing it
126
+ # this way, things like sessions can use the global logging stubs and
127
+ # still be directed at the correct log file.
128
+ #
129
+ ###
130
+ ExceptionCallStack = "__EXCEPTCALLSTACK__"
131
+
132
+ def dlog(msg, src = 'core', level = 0, from = caller)
133
+ $dispatcher.log(LOG_DEBUG, src, level, msg, from)
134
+ end
135
+
136
+ def elog(msg, src = 'core', level = 0, from = caller)
137
+ $dispatcher.log(LOG_ERROR, src, level, msg, from)
138
+ end
139
+
140
+ def wlog(msg, src = 'core', level = 0, from = caller)
141
+ $dispatcher.log(LOG_WARN, src, level, msg, from)
142
+ end
143
+
144
+ def ilog(msg, src = 'core', level = 0, from = caller)
145
+ $dispatcher.log(LOG_INFO, src, level, msg, from)
146
+ end
147
+
148
+ def rlog(msg, src = 'core', level = 0, from = caller)
149
+ if (msg == ExceptionCallStack)
150
+ msg = "\nCall stack:\n" + $@.join("\n") + "\n"
151
+ end
152
+
153
+ $dispatcher.log(LOG_RAW, src, level, msg, from)
154
+ end
155
+
156
+ def log_source_registered?(src)
157
+ ($dispatcher[src] != nil)
158
+ end
159
+
160
+ def register_log_source(src, sink, level = nil)
161
+ $dispatcher[src] = sink
162
+
163
+ set_log_level(src, level) if (level)
164
+ end
165
+
166
+ def deregister_log_source(src)
167
+ $dispatcher.delete(src)
168
+ end
169
+
170
+ def set_log_level(src, level)
171
+ $dispatcher.set_level(src, level)
172
+ end
173
+
174
+ def get_log_level(src)
175
+ $dispatcher.get_level(src)
176
+ end
177
+
178
+ # Creates the global log dispatcher
179
+ $dispatcher = Rex::Logging::LogDispatcher.new