arachni 0.4.7 → 1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1585) hide show
  1. checksums.yaml +5 -13
  2. data/AUTHORS.md +1 -1
  3. data/CHANGELOG.md +211 -0
  4. data/CONTRIBUTORS.md +1 -0
  5. data/Gemfile +23 -2
  6. data/LICENSE.md +34 -1
  7. data/README.md +211 -127
  8. data/Rakefile +79 -67
  9. data/arachni.gemspec +54 -62
  10. data/bin/arachni +6 -18
  11. data/bin/arachni_console +5 -13
  12. data/bin/arachni_multi +6 -16
  13. data/bin/arachni_reporter +12 -0
  14. data/bin/arachni_restore +12 -0
  15. data/bin/arachni_rpc +6 -16
  16. data/bin/arachni_rpcd +6 -17
  17. data/bin/arachni_rpcd_monitor +6 -18
  18. data/bin/arachni_script +8 -19
  19. data/components/checks/active/code_injection.rb +123 -0
  20. data/components/checks/active/code_injection_php_input_wrapper.rb +99 -0
  21. data/components/checks/active/code_injection_timing.rb +106 -0
  22. data/components/checks/active/csrf.rb +218 -0
  23. data/components/checks/active/file_inclusion.rb +152 -0
  24. data/components/checks/active/ldap_injection.rb +109 -0
  25. data/{modules/audit/ldapi → components/checks/active/ldap_injection}/errors.txt +0 -0
  26. data/components/checks/active/no_sql_injection.rb +94 -0
  27. data/components/checks/active/no_sql_injection/patterns/mongodb +1 -0
  28. data/{extras/placeholder → components/checks/active/no_sql_injection/regexp_ignore.txt} +0 -0
  29. data/components/checks/active/no_sql_injection_differential.rb +78 -0
  30. data/components/checks/active/os_cmd_injection.rb +116 -0
  31. data/components/checks/active/os_cmd_injection_timing.rb +92 -0
  32. data/components/checks/active/path_traversal.rb +174 -0
  33. data/components/checks/active/response_splitting.rb +94 -0
  34. data/components/checks/active/rfi.rb +172 -0
  35. data/components/checks/active/session_fixation.rb +117 -0
  36. data/components/checks/active/source_code_disclosure.rb +177 -0
  37. data/components/checks/active/sql_injection.rb +123 -0
  38. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/access +0 -0
  39. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/coldfusion +0 -0
  40. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/db2 +0 -0
  41. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/emc +0 -0
  42. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/firebird +0 -0
  43. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/frontbase +0 -0
  44. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/hsqldb +0 -0
  45. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/informix +0 -0
  46. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/ingres +0 -0
  47. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/interbase +0 -0
  48. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/maxdb +0 -0
  49. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/mssql +0 -0
  50. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/mysql +0 -0
  51. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/oracle +0 -0
  52. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/pgsql +0 -0
  53. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/sqlite +0 -0
  54. data/{modules/audit/sqli → components/checks/active/sql_injection}/patterns/sybase +0 -0
  55. data/{modules/audit/sqli → components/checks/active/sql_injection}/regexp_ignore.txt +0 -0
  56. data/components/checks/active/sql_injection_differential.rb +114 -0
  57. data/{modules/audit/sqli_blind_rdiff → components/checks/active/sql_injection_differential}/payloads.txt +0 -0
  58. data/components/checks/active/sql_injection_timing.rb +98 -0
  59. data/{modules/audit/sqli_blind_timing → components/checks/active/sql_injection_timing}/mssql.txt +0 -0
  60. data/{modules/audit/sqli_blind_timing → components/checks/active/sql_injection_timing}/mysql.txt +0 -0
  61. data/{modules/audit/sqli_blind_timing → components/checks/active/sql_injection_timing}/pgsql.txt +0 -0
  62. data/components/checks/active/trainer.rb +40 -0
  63. data/components/checks/active/unvalidated_redirect.rb +108 -0
  64. data/components/checks/active/xpath_injection.rb +87 -0
  65. data/{modules/audit/xpath → components/checks/active/xpath_injection}/errors.txt +0 -0
  66. data/components/checks/active/xss.rb +169 -0
  67. data/components/checks/active/xss_dom.rb +119 -0
  68. data/components/checks/active/xss_dom_inputs.rb +132 -0
  69. data/components/checks/active/xss_dom_script_context.rb +118 -0
  70. data/components/checks/active/xss_event.rb +165 -0
  71. data/components/checks/active/xss_path.rb +146 -0
  72. data/components/checks/active/xss_script_context.rb +207 -0
  73. data/components/checks/active/xss_tag.rb +135 -0
  74. data/components/checks/passive/allowed_methods.rb +92 -0
  75. data/components/checks/passive/backdoors.rb +79 -0
  76. data/{modules/recon → components/checks/passive}/backdoors/filenames.txt +0 -0
  77. data/components/checks/passive/backup_directories.rb +86 -0
  78. data/components/checks/passive/backup_directories/formats.txt +56 -0
  79. data/components/checks/passive/backup_files.rb +99 -0
  80. data/components/checks/passive/backup_files/formats.txt +106 -0
  81. data/components/checks/passive/common_directories.rb +81 -0
  82. data/{modules/recon → components/checks/passive}/common_directories/directories.txt +0 -0
  83. data/components/checks/passive/common_files.rb +73 -0
  84. data/components/checks/passive/common_files/filenames.txt +24 -0
  85. data/components/checks/passive/directory_listing.rb +129 -0
  86. data/components/checks/passive/grep/captcha.rb +73 -0
  87. data/components/checks/passive/grep/cookie_set_for_parent_domain.rb +71 -0
  88. data/components/checks/passive/grep/credit_card.rb +124 -0
  89. data/components/checks/passive/grep/cvs_svn_users.rb +75 -0
  90. data/components/checks/passive/grep/emails.rb +53 -0
  91. data/components/checks/passive/grep/form_upload.rb +75 -0
  92. data/components/checks/passive/grep/hsts.rb +74 -0
  93. data/components/checks/passive/grep/html_objects.rb +45 -0
  94. data/components/checks/passive/grep/http_only_cookies.rb +72 -0
  95. data/components/checks/passive/grep/insecure_cookies.rb +74 -0
  96. data/components/checks/passive/grep/mixed_resource.rb +109 -0
  97. data/components/checks/passive/grep/password_autocomplete.rb +80 -0
  98. data/components/checks/passive/grep/private_ip.rb +73 -0
  99. data/components/checks/passive/grep/ssn.rb +62 -0
  100. data/components/checks/passive/grep/unencrypted_password_forms.rb +88 -0
  101. data/components/checks/passive/htaccess_limit.rb +71 -0
  102. data/components/checks/passive/http_put.rb +91 -0
  103. data/components/checks/passive/interesting_responses.rb +88 -0
  104. data/components/checks/passive/localstart_asp.rb +88 -0
  105. data/components/checks/passive/origin_spoof_access_restriction_bypass.rb +83 -0
  106. data/components/checks/passive/webdav.rb +101 -0
  107. data/components/checks/passive/xst.rb +90 -0
  108. data/components/fingerprinters/frameworks/rack.rb +33 -0
  109. data/components/fingerprinters/languages/asp.rb +34 -0
  110. data/components/fingerprinters/languages/aspx.rb +55 -0
  111. data/components/fingerprinters/languages/jsp.rb +34 -0
  112. data/components/fingerprinters/languages/php.rb +35 -0
  113. data/components/fingerprinters/languages/python.rb +32 -0
  114. data/components/fingerprinters/languages/ruby.rb +33 -0
  115. data/components/fingerprinters/os/bsd.rb +28 -0
  116. data/components/fingerprinters/os/linux.rb +34 -0
  117. data/components/fingerprinters/os/solaris.rb +33 -0
  118. data/components/fingerprinters/os/unix.rb +28 -0
  119. data/components/fingerprinters/os/windows.rb +33 -0
  120. data/components/fingerprinters/servers/apache.rb +28 -0
  121. data/components/fingerprinters/servers/iis.rb +28 -0
  122. data/components/fingerprinters/servers/jetty.rb +28 -0
  123. data/components/fingerprinters/servers/nginx.rb +28 -0
  124. data/components/fingerprinters/servers/tomcat.rb +28 -0
  125. data/components/path_extractors/anchors.rb +29 -0
  126. data/components/path_extractors/areas.rb +29 -0
  127. data/components/path_extractors/comments.rb +21 -0
  128. data/components/path_extractors/forms.rb +29 -0
  129. data/components/path_extractors/frames.rb +29 -0
  130. data/components/path_extractors/generic.rb +76 -0
  131. data/components/path_extractors/links.rb +29 -0
  132. data/components/path_extractors/meta_refresh.rb +50 -0
  133. data/components/path_extractors/scripts.rb +31 -0
  134. data/components/plugins/autologin.rb +120 -0
  135. data/components/plugins/beep_notify.rb +43 -0
  136. data/components/plugins/content_types.rb +110 -0
  137. data/components/plugins/cookie_collector.rb +94 -0
  138. data/components/plugins/defaults/autothrottle.rb +73 -0
  139. data/components/plugins/defaults/healthmap.rb +79 -0
  140. data/components/plugins/defaults/meta/remedies/discovery.rb +122 -0
  141. data/components/plugins/defaults/meta/remedies/timing_attacks.rb +98 -0
  142. data/components/plugins/defaults/meta/uniformity.rb +55 -0
  143. data/components/plugins/email_notify.rb +112 -0
  144. data/components/plugins/form_dicattack.rb +128 -0
  145. data/components/plugins/http_dicattack.rb +102 -0
  146. data/components/plugins/proxy.rb +492 -0
  147. data/{plugins → components/plugins}/proxy/panel/403_forbidden.html.erb +0 -0
  148. data/{plugins → components/plugins}/proxy/panel/404_not_found.html.erb +0 -0
  149. data/{plugins → components/plugins}/proxy/panel/css/bootstrap-responsive.css +0 -0
  150. data/{plugins → components/plugins}/proxy/panel/css/bootstrap.min.css +0 -0
  151. data/{plugins → components/plugins}/proxy/panel/css/panel.css +0 -0
  152. data/{plugins → components/plugins}/proxy/panel/help.html.erb +0 -0
  153. data/{plugins → components/plugins}/proxy/panel/img/glyphicons-halflings-white.png +0 -0
  154. data/{plugins → components/plugins}/proxy/panel/img/glyphicons-halflings.png +0 -0
  155. data/{plugins → components/plugins}/proxy/panel/img/record.png +0 -0
  156. data/{plugins → components/plugins}/proxy/panel/inspect.html.erb +0 -0
  157. data/{plugins → components/plugins}/proxy/panel/js/bootstrap.min.js +0 -0
  158. data/{plugins → components/plugins}/proxy/panel/js/jquery.min.js +0 -0
  159. data/{plugins → components/plugins}/proxy/panel/js/panel.js +0 -0
  160. data/{plugins → components/plugins}/proxy/panel/layout.html.erb +0 -0
  161. data/components/plugins/proxy/panel/page_accordion.html.erb +67 -0
  162. data/{plugins → components/plugins}/proxy/panel/page_twin_accordion.html.erb +0 -0
  163. data/components/plugins/proxy/panel/panel.html.erb +69 -0
  164. data/{plugins → components/plugins}/proxy/panel/shutdown_message.html.erb +0 -0
  165. data/{plugins → components/plugins}/proxy/panel/sign_in.html.erb +0 -0
  166. data/{plugins → components/plugins}/proxy/panel/vectors.yml.erb +0 -0
  167. data/{plugins → components/plugins}/proxy/panel/verify_login_check.html.erb +0 -0
  168. data/{plugins → components/plugins}/proxy/panel/verify_login_final.html.erb +0 -0
  169. data/components/plugins/proxy/panel/verify_login_sequence.html.erb +45 -0
  170. data/components/plugins/proxy/template_scope.rb +130 -0
  171. data/components/plugins/script.rb +48 -0
  172. data/components/plugins/uncommon_headers.rb +92 -0
  173. data/components/plugins/vector_feed.rb +225 -0
  174. data/components/plugins/waf_detector.rb +169 -0
  175. data/components/reporters/ap.rb +38 -0
  176. data/components/reporters/html.rb +468 -0
  177. data/components/reporters/html/default.erb +68 -0
  178. data/components/reporters/html/default/configuration.erb +78 -0
  179. data/components/reporters/html/default/css/lib/bootstrap-theme.min.css +7 -0
  180. data/components/reporters/html/default/css/lib/bootstrap.min.css +7 -0
  181. data/components/reporters/html/default/css/lib/c3.css +203 -0
  182. data/components/reporters/html/default/css/lib/font-awesome.min.css +4 -0
  183. data/components/reporters/html/default/css/main.css +140 -0
  184. data/components/reporters/html/default/fonts/FontAwesome.otf +0 -0
  185. data/components/reporters/html/default/fonts/fontawesome-webfont.eot +0 -0
  186. data/components/reporters/html/default/fonts/fontawesome-webfont.svg +504 -0
  187. data/components/reporters/html/default/fonts/fontawesome-webfont.ttf +0 -0
  188. data/components/reporters/html/default/fonts/fontawesome-webfont.woff +0 -0
  189. data/components/reporters/html/default/fonts/glyphicons-halflings-regular.eot +0 -0
  190. data/components/reporters/html/default/fonts/glyphicons-halflings-regular.svg +229 -0
  191. data/components/reporters/html/default/fonts/glyphicons-halflings-regular.ttf +0 -0
  192. data/components/reporters/html/default/fonts/glyphicons-halflings-regular.woff +0 -0
  193. data/components/reporters/html/default/issue.erb +81 -0
  194. data/components/reporters/html/default/issue/details.erb +68 -0
  195. data/components/reporters/html/default/issue/info.erb +74 -0
  196. data/components/reporters/html/default/issue/page.erb +117 -0
  197. data/components/reporters/html/default/issue/page/body.erb +42 -0
  198. data/components/reporters/html/default/issue/page/sink/data_flow.erb +95 -0
  199. data/components/reporters/html/default/issue/page/sink/data_flow/arguments.erb +70 -0
  200. data/components/reporters/html/default/issue/page/sink/data_flow/source.erb +1 -0
  201. data/components/reporters/html/default/issue/page/sink/execution_flow.erb +63 -0
  202. data/components/reporters/html/default/issue/page/sink/frame/source.erb +32 -0
  203. data/components/reporters/html/default/issue/page/sink/trace/table.erb +127 -0
  204. data/components/reporters/html/default/issue/page/transitions.erb +86 -0
  205. data/components/reporters/html/default/issue/platform.erb +8 -0
  206. data/components/reporters/html/default/issue/remarks.erb +28 -0
  207. data/components/reporters/html/default/issue/vector.erb +40 -0
  208. data/components/reporters/html/default/issues.erb +46 -0
  209. data/components/reporters/html/default/issues/grouped.erb +147 -0
  210. data/components/reporters/html/default/js/charts.js.erb +117 -0
  211. data/components/reporters/html/default/js/configuration.js.erb +12 -0
  212. data/components/reporters/html/default/js/helpers.js +107 -0
  213. data/components/reporters/html/default/js/init.js.erb +23 -0
  214. data/components/reporters/html/default/js/lib/bootstrap.min.js +6 -0
  215. data/components/reporters/html/default/js/lib/c3.min.js +3 -0
  216. data/components/reporters/html/default/js/lib/d3.min.js +5 -0
  217. data/components/reporters/html/default/js/lib/jquery.min.js +4 -0
  218. data/components/reporters/html/default/navigation.erb +136 -0
  219. data/components/reporters/html/default/plugins.erb +30 -0
  220. data/components/reporters/html/default/shared/hash.erb +10 -0
  221. data/components/reporters/html/default/shared/hash_table.erb +22 -0
  222. data/components/reporters/html/default/sitemap.erb +29 -0
  223. data/components/reporters/html/default/summary.erb +34 -0
  224. data/components/reporters/html/default/summary/charts.erb +67 -0
  225. data/components/reporters/html/default/summary/issues.erb +129 -0
  226. data/components/reporters/json.rb +44 -0
  227. data/components/reporters/marshal.rb +38 -0
  228. data/components/reporters/plugin_formatters/html/autologin.rb +50 -0
  229. data/components/reporters/plugin_formatters/html/content_types.rb +59 -0
  230. data/components/reporters/plugin_formatters/html/cookie_collector.rb +46 -0
  231. data/components/reporters/plugin_formatters/html/form_dicattack.rb +36 -0
  232. data/components/reporters/plugin_formatters/html/healthmap.rb +88 -0
  233. data/components/reporters/plugin_formatters/html/http_dicattack.rb +36 -0
  234. data/components/reporters/plugin_formatters/html/uncommon_headers.rb +40 -0
  235. data/components/reporters/plugin_formatters/html/uniformity.rb +55 -0
  236. data/components/reporters/plugin_formatters/html/waf_detector.rb +69 -0
  237. data/components/reporters/plugin_formatters/stdout/autologin.rb +25 -0
  238. data/components/reporters/plugin_formatters/stdout/content_types.rb +39 -0
  239. data/components/reporters/plugin_formatters/stdout/cookie_collector.rb +31 -0
  240. data/components/reporters/plugin_formatters/stdout/form_dicattack.rb +24 -0
  241. data/components/reporters/plugin_formatters/stdout/healthmap.rb +41 -0
  242. data/components/reporters/plugin_formatters/stdout/http_dicattack.rb +24 -0
  243. data/components/reporters/plugin_formatters/stdout/uncommon_headers.rb +29 -0
  244. data/components/reporters/plugin_formatters/stdout/uniformity.rb +35 -0
  245. data/components/reporters/plugin_formatters/stdout/waf_detector.rb +21 -0
  246. data/components/reporters/plugin_formatters/xml/autologin.rb +28 -0
  247. data/components/reporters/plugin_formatters/xml/content_types.rb +36 -0
  248. data/components/reporters/plugin_formatters/xml/cookie_collector.rb +32 -0
  249. data/components/reporters/plugin_formatters/xml/form_dicattack.rb +22 -0
  250. data/components/reporters/plugin_formatters/xml/healthmap.rb +30 -0
  251. data/components/reporters/plugin_formatters/xml/http_dicattack.rb +22 -0
  252. data/components/reporters/plugin_formatters/xml/uncommon_headers.rb +29 -0
  253. data/components/reporters/plugin_formatters/xml/uniformity.rb +23 -0
  254. data/components/reporters/plugin_formatters/xml/waf_detector.rb +22 -0
  255. data/components/reporters/stdout.rb +226 -0
  256. data/components/reporters/txt.rb +50 -0
  257. data/components/reporters/xml.rb +285 -0
  258. data/components/reporters/xml/schema.xsd +664 -0
  259. data/components/reporters/yaml.rb +37 -0
  260. data/{rpcd_handlers → components/services}/placeholder +0 -0
  261. data/lib/arachni.rb +29 -18
  262. data/lib/arachni/banner.rb +5 -13
  263. data/lib/arachni/browser.rb +1292 -0
  264. data/lib/arachni/browser/element_locator.rb +137 -0
  265. data/lib/arachni/browser/javascript.rb +383 -0
  266. data/lib/arachni/browser/javascript/dom_monitor.rb +31 -0
  267. data/lib/arachni/browser/javascript/proxy.rb +92 -0
  268. data/lib/arachni/browser/javascript/proxy/stub.rb +90 -0
  269. data/lib/arachni/browser/javascript/scripts/dom_monitor.js +146 -0
  270. data/lib/arachni/browser/javascript/scripts/taint_tracer.js +486 -0
  271. data/lib/arachni/browser/javascript/taint_tracer.rb +101 -0
  272. data/lib/arachni/browser/javascript/taint_tracer/frame.rb +73 -0
  273. data/lib/arachni/browser/javascript/taint_tracer/frame/called_function.rb +78 -0
  274. data/lib/arachni/browser/javascript/taint_tracer/sink/base.rb +63 -0
  275. data/lib/arachni/browser/javascript/taint_tracer/sink/data_flow.rb +83 -0
  276. data/lib/arachni/browser/javascript/taint_tracer/sink/execution_flow.rb +30 -0
  277. data/lib/arachni/browser_cluster.rb +414 -0
  278. data/lib/arachni/browser_cluster/job.rb +193 -0
  279. data/lib/arachni/browser_cluster/job/result.rb +29 -0
  280. data/lib/arachni/browser_cluster/jobs/browser_provider.rb +27 -0
  281. data/lib/arachni/browser_cluster/jobs/resource_exploration.rb +60 -0
  282. data/lib/arachni/browser_cluster/jobs/resource_exploration/event_trigger.rb +43 -0
  283. data/lib/arachni/browser_cluster/jobs/resource_exploration/event_trigger/result.rb +23 -0
  284. data/lib/arachni/browser_cluster/jobs/resource_exploration/result.rb +23 -0
  285. data/lib/arachni/browser_cluster/jobs/taint_trace.rb +48 -0
  286. data/lib/arachni/browser_cluster/jobs/taint_trace/event_trigger.rb +33 -0
  287. data/lib/arachni/browser_cluster/jobs/taint_trace/event_trigger/result.rb +23 -0
  288. data/lib/arachni/browser_cluster/jobs/taint_trace/result.rb +23 -0
  289. data/lib/arachni/browser_cluster/worker.rb +277 -0
  290. data/lib/arachni/check.rb +12 -0
  291. data/lib/arachni/check/auditor.rb +612 -0
  292. data/lib/arachni/check/base.rb +177 -0
  293. data/lib/arachni/check/manager.rb +137 -0
  294. data/lib/arachni/component.rb +11 -0
  295. data/lib/arachni/component/base.rb +62 -0
  296. data/lib/arachni/component/manager.rb +92 -90
  297. data/lib/arachni/component/options.rb +6 -28
  298. data/lib/arachni/component/options/address.rb +14 -30
  299. data/lib/arachni/component/options/base.rb +96 -81
  300. data/lib/arachni/component/options/bool.rb +20 -37
  301. data/lib/arachni/component/options/float.rb +12 -31
  302. data/lib/arachni/component/options/int.rb +14 -31
  303. data/lib/arachni/component/options/multiple_choice.rb +40 -0
  304. data/lib/arachni/component/options/object.rb +16 -0
  305. data/lib/arachni/component/options/path.rb +12 -25
  306. data/lib/arachni/component/options/port.rb +15 -25
  307. data/lib/arachni/component/options/string.rb +10 -32
  308. data/lib/arachni/component/options/url.rb +15 -30
  309. data/lib/arachni/component/output.rb +33 -0
  310. data/lib/arachni/component/utilities.rb +49 -0
  311. data/lib/arachni/data.rb +109 -0
  312. data/lib/arachni/data/framework.rb +160 -0
  313. data/lib/arachni/data/framework/rpc.rb +68 -0
  314. data/lib/arachni/data/issues.rb +227 -0
  315. data/lib/arachni/data/plugins.rb +109 -0
  316. data/lib/arachni/data/session.rb +48 -0
  317. data/lib/arachni/element/base.rb +131 -82
  318. data/lib/arachni/element/body.rb +43 -13
  319. data/lib/arachni/element/capabilities/analyzable.rb +46 -0
  320. data/lib/arachni/element/capabilities/analyzable/differential.rb +436 -0
  321. data/lib/arachni/element/capabilities/analyzable/taint.rb +218 -0
  322. data/lib/arachni/element/capabilities/analyzable/timeout.rb +433 -0
  323. data/lib/arachni/element/capabilities/auditable.rb +172 -577
  324. data/lib/arachni/element/capabilities/auditable/dom.rb +156 -0
  325. data/lib/arachni/element/capabilities/inputtable.rb +267 -0
  326. data/lib/arachni/element/capabilities/mutable.rb +197 -155
  327. data/lib/arachni/element/capabilities/refreshable.rb +31 -24
  328. data/lib/arachni/element/capabilities/submittable.rb +128 -0
  329. data/lib/arachni/element/capabilities/with_auditor.rb +60 -0
  330. data/lib/arachni/element/capabilities/with_auditor/output.rb +33 -0
  331. data/lib/arachni/element/capabilities/with_dom.rb +40 -0
  332. data/lib/arachni/element/capabilities/with_node.rb +52 -0
  333. data/lib/arachni/element/capabilities/with_scope.rb +25 -0
  334. data/lib/arachni/element/capabilities/with_scope/scope.rb +38 -0
  335. data/lib/arachni/element/cookie.rb +337 -862
  336. data/lib/arachni/element/cookie/dom.rb +67 -0
  337. data/lib/arachni/element/form.rb +326 -756
  338. data/lib/arachni/element/form/dom.rb +52 -0
  339. data/lib/arachni/element/generic_dom.rb +133 -0
  340. data/lib/arachni/element/header.rb +46 -46
  341. data/lib/arachni/element/link.rb +134 -172
  342. data/lib/arachni/element/link/dom.rb +128 -0
  343. data/lib/arachni/element/link_template.rb +268 -0
  344. data/lib/arachni/element/link_template/dom.rb +143 -0
  345. data/lib/arachni/element/path.rb +24 -13
  346. data/lib/arachni/element/server.rb +89 -13
  347. data/lib/arachni/element_filter.rb +101 -99
  348. data/lib/arachni/error.rb +5 -15
  349. data/lib/arachni/ethon/easy.rb +22 -0
  350. data/lib/arachni/framework.rb +841 -476
  351. data/lib/arachni/http.rb +6 -714
  352. data/lib/arachni/http/client.rb +801 -0
  353. data/lib/arachni/http/cookie_jar.rb +50 -51
  354. data/lib/arachni/http/headers.rb +122 -0
  355. data/lib/arachni/http/message.rb +76 -0
  356. data/lib/arachni/http/message/scope.rb +35 -0
  357. data/lib/arachni/http/proxy_server.rb +303 -0
  358. data/{plugins/proxy → lib/arachni/http/proxy_server}/ssl-interceptor-cert.pem +0 -0
  359. data/{plugins/proxy → lib/arachni/http/proxy_server}/ssl-interceptor-pkey.pem +0 -0
  360. data/lib/arachni/http/request.rb +471 -0
  361. data/lib/arachni/http/request/scope.rb +30 -0
  362. data/lib/arachni/http/response.rb +226 -0
  363. data/lib/arachni/http/response/scope.rb +67 -0
  364. data/lib/arachni/issue.rb +389 -223
  365. data/lib/arachni/issue/severity.rb +34 -0
  366. data/lib/arachni/issue/severity/base.rb +39 -0
  367. data/lib/arachni/option_group.rb +137 -0
  368. data/lib/arachni/option_groups.rb +13 -0
  369. data/lib/arachni/option_groups/audit.rb +226 -0
  370. data/lib/arachni/option_groups/browser_cluster.rb +50 -0
  371. data/lib/arachni/option_groups/datastore.rb +31 -0
  372. data/lib/arachni/option_groups/dispatcher.rb +132 -0
  373. data/lib/arachni/option_groups/http.rb +174 -0
  374. data/lib/arachni/option_groups/input.rb +156 -0
  375. data/lib/arachni/option_groups/output.rb +22 -0
  376. data/lib/arachni/option_groups/paths.rb +63 -0
  377. data/lib/arachni/option_groups/rpc.rb +87 -0
  378. data/lib/arachni/option_groups/scope.rb +233 -0
  379. data/lib/arachni/option_groups/session.rb +54 -0
  380. data/lib/arachni/option_groups/snapshot.rb +22 -0
  381. data/lib/arachni/options.rb +286 -1486
  382. data/lib/arachni/page.rb +504 -108
  383. data/lib/arachni/page/dom.rb +280 -0
  384. data/lib/arachni/page/dom/transition.rb +302 -0
  385. data/lib/arachni/page/scope.rb +53 -0
  386. data/lib/arachni/parser.rb +177 -210
  387. data/lib/arachni/platform.rb +5 -13
  388. data/lib/arachni/platform/fingerprinter.rb +24 -23
  389. data/lib/arachni/platform/list.rb +48 -27
  390. data/lib/arachni/platform/manager.rb +146 -83
  391. data/lib/arachni/plugin.rb +5 -13
  392. data/lib/arachni/plugin/base.rb +90 -110
  393. data/lib/arachni/plugin/formatter.rb +40 -0
  394. data/lib/arachni/plugin/manager.rb +129 -108
  395. data/lib/arachni/processes.rb +6 -14
  396. data/lib/arachni/processes/dispatchers.rb +51 -58
  397. data/lib/arachni/processes/executables/base.rb +9 -0
  398. data/lib/arachni/processes/executables/dispatcher.rb +6 -0
  399. data/lib/arachni/processes/executables/instance.rb +13 -0
  400. data/lib/arachni/processes/helpers.rb +4 -12
  401. data/lib/arachni/processes/helpers/dispatchers.rb +8 -12
  402. data/lib/arachni/processes/helpers/instances.rb +13 -13
  403. data/lib/arachni/processes/helpers/processes.rb +8 -28
  404. data/lib/arachni/processes/instances.rb +86 -63
  405. data/lib/arachni/processes/manager.rb +89 -52
  406. data/lib/arachni/report.rb +282 -15
  407. data/lib/arachni/reporter.rb +12 -0
  408. data/lib/arachni/reporter/base.rb +126 -0
  409. data/lib/arachni/reporter/formatter_manager.rb +20 -0
  410. data/lib/arachni/reporter/manager.rb +54 -0
  411. data/lib/arachni/reporter/options.rb +47 -0
  412. data/lib/arachni/rpc/client/base.rb +27 -35
  413. data/lib/arachni/rpc/client/dispatcher.rb +13 -21
  414. data/lib/arachni/rpc/client/instance.rb +45 -40
  415. data/lib/arachni/rpc/client/instance/framework.rb +88 -0
  416. data/lib/arachni/rpc/client/instance/service.rb +106 -0
  417. data/lib/arachni/rpc/serializer.rb +98 -0
  418. data/lib/arachni/rpc/server/active_options.rb +26 -42
  419. data/lib/arachni/rpc/server/base.rb +35 -26
  420. data/lib/arachni/rpc/server/check/manager.rb +38 -0
  421. data/lib/arachni/rpc/server/dispatcher.rb +125 -211
  422. data/lib/arachni/rpc/server/dispatcher/node.rb +36 -50
  423. data/lib/arachni/rpc/server/dispatcher/service.rb +153 -0
  424. data/lib/arachni/rpc/server/framework.rb +83 -176
  425. data/lib/arachni/rpc/server/framework/distributor.rb +292 -271
  426. data/lib/arachni/rpc/server/framework/master.rb +164 -296
  427. data/lib/arachni/rpc/server/framework/multi_instance.rb +96 -128
  428. data/lib/arachni/rpc/server/framework/slave.rb +79 -89
  429. data/lib/arachni/rpc/server/instance.rb +362 -413
  430. data/lib/arachni/rpc/server/output.rb +33 -147
  431. data/lib/arachni/rpc/server/plugin/manager.rb +18 -54
  432. data/lib/arachni/ruby.rb +5 -14
  433. data/lib/arachni/ruby/array.rb +4 -14
  434. data/lib/arachni/ruby/hash.rb +47 -15
  435. data/lib/arachni/ruby/io.rb +4 -14
  436. data/lib/arachni/ruby/object.rb +10 -52
  437. data/lib/arachni/ruby/set.rb +4 -12
  438. data/lib/arachni/ruby/string.rb +60 -40
  439. data/lib/arachni/ruby/webrick.rb +4 -12
  440. data/lib/arachni/ruby/webrick/cookie.rb +4 -12
  441. data/lib/arachni/ruby/webrick/httprequest.rb +4 -12
  442. data/lib/arachni/scope.rb +40 -0
  443. data/lib/arachni/selenium/webdriver/remote/http/typhoeus.rb +46 -0
  444. data/lib/arachni/session.rb +150 -173
  445. data/lib/arachni/snapshot.rb +181 -0
  446. data/lib/arachni/state.rb +122 -0
  447. data/lib/arachni/state/audit.rb +57 -0
  448. data/lib/arachni/state/element_filter.rb +67 -0
  449. data/lib/arachni/state/framework.rb +419 -0
  450. data/lib/arachni/state/framework/rpc.rb +63 -0
  451. data/lib/arachni/state/http.rb +60 -0
  452. data/lib/arachni/state/options.rb +39 -0
  453. data/lib/arachni/state/plugins.rb +94 -0
  454. data/lib/arachni/support.rb +6 -15
  455. data/lib/arachni/support/buffer.rb +5 -13
  456. data/lib/arachni/support/buffer/autoflush.rb +5 -15
  457. data/lib/arachni/support/buffer/base.rb +41 -70
  458. data/lib/arachni/support/cache.rb +5 -13
  459. data/lib/arachni/support/cache/base.rb +45 -50
  460. data/lib/arachni/support/cache/least_cost_replacement.rb +9 -19
  461. data/lib/arachni/support/cache/least_recently_used.rb +5 -15
  462. data/lib/arachni/support/cache/preference.rb +11 -20
  463. data/lib/arachni/support/cache/random_replacement.rb +10 -15
  464. data/lib/arachni/support/crypto.rb +5 -13
  465. data/lib/arachni/support/crypto/rsa_aes_cbc.rb +15 -27
  466. data/lib/arachni/support/database.rb +5 -13
  467. data/lib/arachni/support/database/base.rb +20 -37
  468. data/lib/arachni/support/database/hash.rb +265 -350
  469. data/lib/arachni/support/database/queue.rb +86 -27
  470. data/lib/arachni/support/lookup.rb +5 -13
  471. data/lib/arachni/support/lookup/base.rb +33 -26
  472. data/lib/arachni/support/lookup/hash_set.rb +11 -15
  473. data/lib/arachni/support/lookup/moolb.rb +9 -20
  474. data/lib/arachni/support/mixins.rb +14 -0
  475. data/lib/arachni/support/mixins/observable.rb +105 -0
  476. data/lib/arachni/support/mixins/terminal.rb +65 -0
  477. data/lib/arachni/support/profiler.rb +130 -0
  478. data/lib/arachni/support/signature.rb +37 -67
  479. data/lib/arachni/trainer.rb +57 -97
  480. data/lib/arachni/ui/foo/output.rb +31 -33
  481. data/lib/arachni/uri.rb +456 -462
  482. data/lib/arachni/uri/scope.rb +168 -0
  483. data/lib/arachni/utilities.rb +125 -147
  484. data/lib/arachni/version.rb +4 -12
  485. data/lib/arachni/watir/element.rb +17 -0
  486. data/lib/version +1 -1
  487. data/{spec/support/servers/modules/audit/sqli/jdbc → profiles/placeholder} +0 -0
  488. data/spec/arachni/browser/element_locator_spec.rb +228 -0
  489. data/spec/arachni/browser/javascript/dom_monitor_spec.rb +195 -0
  490. data/spec/arachni/browser/javascript/proxy/stub_spec.rb +106 -0
  491. data/spec/arachni/browser/javascript/proxy_spec.rb +144 -0
  492. data/spec/arachni/browser/javascript/taint_tracer/frame/called_function_spec.rb +72 -0
  493. data/spec/arachni/browser/javascript/taint_tracer/frame_spec.rb +46 -0
  494. data/spec/arachni/browser/javascript/taint_tracer/sink/data_flow_spec.rb +81 -0
  495. data/spec/arachni/browser/javascript/taint_tracer/sink/execution_flow_spec.rb +47 -0
  496. data/spec/arachni/browser/javascript/taint_tracer_spec.rb +1304 -0
  497. data/spec/arachni/browser/javascript_spec.rb +355 -0
  498. data/spec/arachni/browser_cluster/job/result_spec.rb +14 -0
  499. data/spec/arachni/browser_cluster/job_spec.rb +264 -0
  500. data/spec/arachni/browser_cluster/jobs/resource_exploration/event_trigger/result_spec.rb +7 -0
  501. data/spec/arachni/browser_cluster/jobs/resource_exploration/event_trigger_spec.rb +68 -0
  502. data/spec/arachni/browser_cluster/jobs/resource_exploration/result_spec.rb +7 -0
  503. data/spec/arachni/browser_cluster/jobs/resource_exploration_spec.rb +89 -0
  504. data/spec/arachni/browser_cluster/jobs/taint_tracer_spec.rb +149 -0
  505. data/spec/arachni/browser_cluster/worker_spec.rb +314 -0
  506. data/spec/arachni/browser_cluster_spec.rb +543 -0
  507. data/spec/arachni/browser_spec.rb +2368 -0
  508. data/spec/arachni/check/auditor_spec.rb +1089 -0
  509. data/spec/arachni/check/base_spec.rb +33 -0
  510. data/spec/arachni/check/manager_spec.rb +100 -0
  511. data/spec/arachni/component/base_spec.rb +64 -0
  512. data/spec/arachni/component/manager_spec.rb +37 -26
  513. data/spec/arachni/component/options/address_spec.rb +5 -11
  514. data/spec/arachni/component/options/base_spec.rb +29 -81
  515. data/spec/arachni/component/options/bool_spec.rb +16 -19
  516. data/spec/arachni/component/options/float_spec.rb +17 -16
  517. data/spec/arachni/component/options/int_spec.rb +17 -20
  518. data/spec/arachni/component/options/multiple_choice_spec.rb +82 -0
  519. data/spec/arachni/component/options/object_spec.rb +24 -0
  520. data/spec/arachni/component/options/path_spec.rb +8 -11
  521. data/spec/arachni/component/options/port_spec.rb +16 -15
  522. data/spec/arachni/component/options/string_spec.rb +8 -17
  523. data/spec/arachni/component/options/url_spec.rb +16 -14
  524. data/spec/arachni/component/utilities_spec.rb +30 -0
  525. data/spec/arachni/{module → component}/utilities_spec/read_file.txt +0 -0
  526. data/spec/arachni/data/framework/rpc_spec.rb +72 -0
  527. data/spec/arachni/data/framework_spec.rb +266 -0
  528. data/spec/arachni/data/issues_spec.rb +347 -0
  529. data/spec/arachni/data/plugins_spec.rb +102 -0
  530. data/spec/arachni/data/session_spec.rb +59 -0
  531. data/spec/arachni/data_spec.rb +71 -0
  532. data/spec/arachni/element/body_spec.rb +63 -4
  533. data/spec/arachni/element/capabilities/analyzable/differential_spec.rb +135 -0
  534. data/spec/arachni/element/capabilities/analyzable/taint_spec.rb +355 -0
  535. data/spec/arachni/element/capabilities/analyzable/timeout_spec.rb +386 -0
  536. data/spec/arachni/element/capabilities/with_scope/scope_spec.rb +25 -0
  537. data/spec/arachni/element/cookie/dom_spec.rb +145 -0
  538. data/spec/arachni/element/cookie_spec.rb +147 -108
  539. data/spec/arachni/element/form/dom_spec.rb +146 -0
  540. data/spec/arachni/element/form_spec.rb +519 -271
  541. data/spec/arachni/element/generic_dom_spec.rb +113 -0
  542. data/spec/arachni/element/header_spec.rb +68 -20
  543. data/spec/arachni/element/link/dom_spec.rb +206 -0
  544. data/spec/arachni/element/link_spec.rb +218 -130
  545. data/spec/arachni/element/link_template/dom_spec.rb +218 -0
  546. data/spec/arachni/element/link_template_spec.rb +403 -0
  547. data/spec/arachni/element/path_spec.rb +28 -4
  548. data/spec/arachni/element/server_spec.rb +171 -4
  549. data/spec/arachni/element_filter_spec.rb +227 -96
  550. data/spec/arachni/framework_spec.rb +1099 -759
  551. data/spec/arachni/http/client_spec.rb +1470 -0
  552. data/spec/arachni/http/cookie_jar_spec.rb +164 -130
  553. data/spec/arachni/http/headers_spec.rb +111 -0
  554. data/spec/arachni/http/message_spec.rb +5 -0
  555. data/spec/arachni/http/proxy_server_spec.rb +354 -0
  556. data/spec/arachni/http/request_spec.rb +602 -0
  557. data/spec/arachni/http/response/scope_spec.rb +135 -0
  558. data/spec/arachni/http/response_spec.rb +350 -0
  559. data/spec/arachni/issue/severity/base_spec.rb +15 -0
  560. data/spec/arachni/issue/severity_spec.rb +43 -0
  561. data/spec/arachni/issue_spec.rb +547 -284
  562. data/spec/arachni/option_groups/audit_spec.rb +298 -0
  563. data/spec/arachni/option_groups/browser_cluster_spec.rb +12 -0
  564. data/spec/arachni/option_groups/datastore_spec.rb +54 -0
  565. data/spec/arachni/option_groups/dispatcher_spec.rb +123 -0
  566. data/spec/arachni/option_groups/http_spec.rb +42 -0
  567. data/spec/arachni/option_groups/input_spec.rb +202 -0
  568. data/spec/arachni/option_groups/output_spec.rb +11 -0
  569. data/spec/arachni/option_groups/paths_spec.rb +34 -0
  570. data/spec/arachni/option_groups/rpc_spec.rb +13 -0
  571. data/spec/arachni/option_groups/scope_spec.rb +237 -0
  572. data/spec/arachni/option_groups/session_spec.rb +51 -0
  573. data/spec/arachni/option_groups/snapshot_spec.rb +11 -0
  574. data/spec/arachni/options_spec.rb +202 -756
  575. data/spec/arachni/page/dom/transition_spec.rb +515 -0
  576. data/spec/arachni/page/dom_spec.rb +308 -0
  577. data/spec/arachni/page/scope_spec.rb +80 -0
  578. data/spec/arachni/page_spec.rb +789 -175
  579. data/spec/arachni/parser_spec.rb +308 -200
  580. data/spec/arachni/platform/fingerprinter_spec.rb +51 -52
  581. data/spec/arachni/platform/manager_spec.rb +146 -34
  582. data/spec/arachni/plugin/base_spec.rb +97 -0
  583. data/spec/arachni/plugin/manager_spec.rb +186 -80
  584. data/spec/arachni/report_spec.rb +275 -0
  585. data/spec/arachni/reporter/base_spec.rb +96 -0
  586. data/spec/arachni/reporter/manager_spec.rb +38 -0
  587. data/spec/arachni/reporter/options_spec.rb +48 -0
  588. data/spec/arachni/rpc/client/base_spec.rb +43 -45
  589. data/spec/arachni/rpc/client/dispatcher_spec.rb +3 -3
  590. data/spec/arachni/rpc/client/instance_spec.rb +18 -40
  591. data/spec/arachni/rpc/server/active_options_spec.rb +35 -296
  592. data/spec/arachni/rpc/server/base_spec.rb +12 -6
  593. data/spec/arachni/rpc/server/checks/manager_spec.rb +48 -0
  594. data/spec/arachni/rpc/server/dispatcher/node_spec.rb +47 -74
  595. data/spec/arachni/rpc/server/dispatcher/service_spec.rb +99 -0
  596. data/spec/arachni/rpc/server/dispatcher_spec.rb +77 -38
  597. data/spec/arachni/rpc/server/framework/distributor_spec.rb +356 -396
  598. data/spec/arachni/rpc/server/framework_multi_spec.rb +336 -0
  599. data/spec/arachni/rpc/server/framework_spec.rb +396 -0
  600. data/spec/arachni/rpc/server/instance_spec.rb +480 -281
  601. data/spec/arachni/rpc/server/output_spec.rb +9 -212
  602. data/spec/arachni/rpc/server/plugin/manager_spec.rb +6 -11
  603. data/spec/arachni/ruby/hash_spec.rb +30 -0
  604. data/spec/arachni/ruby/object_spec.rb +0 -16
  605. data/spec/arachni/ruby/string_spec.rb +98 -6
  606. data/spec/arachni/scope_spec.rb +13 -0
  607. data/spec/arachni/session_spec.rb +279 -251
  608. data/spec/arachni/snapshot_spec.rb +127 -0
  609. data/spec/arachni/state/audit_spec.rb +107 -0
  610. data/spec/arachni/state/element_filter_spec.rb +66 -0
  611. data/spec/arachni/state/framework/rpc_spec.rb +85 -0
  612. data/spec/arachni/state/framework_spec.rb +853 -0
  613. data/spec/arachni/state/http_spec.rb +63 -0
  614. data/spec/arachni/state/options_spec.rb +55 -0
  615. data/spec/arachni/state/plugins_spec.rb +76 -0
  616. data/spec/arachni/state_spec.rb +87 -0
  617. data/spec/arachni/support/cache/least_cost_replacement_spec.rb +30 -32
  618. data/spec/arachni/support/cache/least_recently_used_spec.rb +39 -40
  619. data/spec/arachni/support/cache/preference_spec.rb +17 -18
  620. data/spec/arachni/support/cache/random_replacement_spec.rb +19 -20
  621. data/spec/arachni/support/database/queue_spec.rb +200 -32
  622. data/spec/arachni/support/lookup/hash_set_spec.rb +74 -0
  623. data/spec/arachni/support/mixins/observable_spec.rb +81 -0
  624. data/spec/arachni/support/signature_spec.rb +9 -25
  625. data/spec/arachni/trainer_spec.rb +141 -124
  626. data/spec/arachni/uri/scope_spec.rb +416 -0
  627. data/spec/arachni/uri_spec.rb +187 -195
  628. data/spec/arachni/utilities_spec.rb +178 -525
  629. data/spec/components/checks/active/code_injection_spec.rb +26 -0
  630. data/spec/components/checks/active/code_injection_timing_spec.rb +26 -0
  631. data/spec/components/checks/active/csrf_spec.rb +44 -0
  632. data/spec/components/checks/active/file_inclusion_spec.rb +56 -0
  633. data/spec/components/checks/active/ldap_injection_spec.rb +16 -0
  634. data/spec/components/checks/active/no_sql_injection_differential_spec.rb +15 -0
  635. data/spec/components/checks/active/no_sql_injection_spec.rb +28 -0
  636. data/spec/components/checks/active/os_cmd_injection_spec.rb +26 -0
  637. data/spec/components/checks/active/os_cmd_injection_timing_spec.rb +26 -0
  638. data/spec/components/checks/active/path_traversal_spec.rb +42 -0
  639. data/spec/components/checks/active/response_splitting_spec.rb +22 -0
  640. data/spec/components/checks/active/rfi_spec.rb +20 -0
  641. data/spec/components/checks/active/session_fixation_spec.rb +20 -0
  642. data/spec/components/checks/active/source_code_disclosure_spec.rb +26 -0
  643. data/spec/components/checks/active/sql_injection_differential_spec.rb +15 -0
  644. data/spec/components/checks/active/sql_injection_spec.rb +142 -0
  645. data/spec/components/checks/active/sql_injection_timing_spec.rb +24 -0
  646. data/spec/components/checks/active/trainer_spec.rb +36 -0
  647. data/spec/components/checks/active/unvalidated_redirect_spec.rb +20 -0
  648. data/spec/components/checks/active/xpath_injection_spec.rb +16 -0
  649. data/spec/components/checks/active/xss_dom_inputs_spec.rb +32 -0
  650. data/spec/components/checks/active/xss_dom_script_context_spec.rb +63 -0
  651. data/spec/components/checks/active/xss_dom_spec.rb +67 -0
  652. data/spec/components/checks/active/xss_event_spec.rb +15 -0
  653. data/spec/components/checks/active/xss_path_spec.rb +15 -0
  654. data/spec/components/checks/active/xss_script_context_spec.rb +22 -0
  655. data/spec/components/checks/active/xss_spec.rb +22 -0
  656. data/spec/components/checks/active/xss_tag_spec.rb +15 -0
  657. data/spec/components/checks/passive/allowed_methods_spec.rb +15 -0
  658. data/spec/components/checks/passive/backdoors_spec.rb +15 -0
  659. data/spec/components/checks/passive/backup_directories_spec.rb +15 -0
  660. data/spec/components/checks/passive/backup_files_spec.rb +15 -0
  661. data/spec/components/checks/passive/common_directories_spec.rb +15 -0
  662. data/spec/components/checks/passive/common_files_spec.rb +15 -0
  663. data/spec/components/checks/passive/directory_listing_spec.rb +15 -0
  664. data/spec/components/checks/passive/grep/captcha_spec.rb +15 -0
  665. data/spec/components/checks/passive/grep/cookie_set_for_parent_domain_spec.rb +15 -0
  666. data/spec/components/checks/passive/grep/credit_card_spec.rb +15 -0
  667. data/spec/components/checks/passive/grep/cvs_svn_users_spec.rb +15 -0
  668. data/spec/components/checks/passive/grep/emails_spec.rb +15 -0
  669. data/spec/components/checks/passive/grep/form_upload_spec.rb +15 -0
  670. data/spec/components/checks/passive/grep/hsts_spec.rb +17 -0
  671. data/spec/components/checks/passive/grep/html_objects_spec.rb +15 -0
  672. data/spec/components/checks/passive/grep/http_only_cookies_spec.rb +15 -0
  673. data/spec/components/checks/passive/grep/insecure_cookies_spec.rb +15 -0
  674. data/spec/components/checks/passive/grep/mixed_resource_spec.rb +16 -0
  675. data/spec/components/checks/passive/grep/password_autocomplete_spec.rb +15 -0
  676. data/spec/components/checks/passive/grep/private_ip_spec.rb +22 -0
  677. data/spec/components/checks/passive/grep/ssn_spec.rb +15 -0
  678. data/spec/components/checks/passive/grep/unencrypted_password_forms_spec.rb +15 -0
  679. data/spec/components/checks/passive/htaccess_limit_spec.rb +15 -0
  680. data/spec/components/checks/passive/http_put_spec.rb +15 -0
  681. data/spec/components/checks/passive/interesting_responses_spec.rb +23 -0
  682. data/spec/components/checks/passive/localstart_asp_spec.rb +15 -0
  683. data/spec/components/checks/passive/origin_spoof_access_restriction_bypass_spec.rb +15 -0
  684. data/spec/components/checks/passive/webdav_spec.rb +15 -0
  685. data/spec/components/checks/passive/xst_spec.rb +15 -0
  686. data/spec/components/fingerprinters/frameworks/rack_spec.rb +42 -0
  687. data/spec/components/fingerprinters/languages/asp_spec.rb +38 -0
  688. data/spec/components/fingerprinters/languages/aspx_spec.rb +79 -0
  689. data/spec/components/fingerprinters/languages/jsp_spec.rb +56 -0
  690. data/spec/components/fingerprinters/languages/php_spec.rb +59 -0
  691. data/spec/components/fingerprinters/languages/python_spec.rb +23 -0
  692. data/spec/components/fingerprinters/languages/ruby.rb +34 -0
  693. data/spec/components/fingerprinters/os/bsd_spec.rb +26 -0
  694. data/spec/components/fingerprinters/os/linux_spec.rb +34 -0
  695. data/spec/components/fingerprinters/os/solaris_spec.rb +34 -0
  696. data/spec/components/fingerprinters/os/unix_spec.rb +26 -0
  697. data/spec/components/fingerprinters/os/windows_spec.rb +34 -0
  698. data/spec/components/fingerprinters/servers/apache_spec.rb +26 -0
  699. data/spec/components/fingerprinters/servers/iis_spec.rb +28 -0
  700. data/spec/components/fingerprinters/servers/jetty_spec.rb +28 -0
  701. data/spec/components/fingerprinters/servers/nginx_spec.rb +26 -0
  702. data/spec/components/fingerprinters/servers/tomcat_spec.rb +28 -0
  703. data/spec/{path_extractors → components/path_extractors}/anchors_spec.rb +0 -0
  704. data/spec/{path_extractors → components/path_extractors}/areas_spec.rb +0 -0
  705. data/spec/components/path_extractors/comments_spec.rb +23 -0
  706. data/spec/{path_extractors → components/path_extractors}/forms_spec.rb +0 -0
  707. data/spec/{path_extractors → components/path_extractors}/frames_spec.rb +0 -0
  708. data/spec/{path_extractors → components/path_extractors}/generic_spec.rb +0 -0
  709. data/spec/{path_extractors → components/path_extractors}/links_spec.rb +0 -0
  710. data/spec/{path_extractors → components/path_extractors}/meta_refresh_spec.rb +0 -0
  711. data/spec/components/path_extractors/scripts_spec.rb +30 -0
  712. data/spec/components/plugins/autologin_spec.rb +96 -0
  713. data/spec/components/plugins/autothrottle_spec.rb +56 -0
  714. data/spec/components/plugins/content_types_spec.rb +91 -0
  715. data/spec/components/plugins/cookie_collector_spec.rb +41 -0
  716. data/spec/components/plugins/form_dicattack_spec.rb +54 -0
  717. data/spec/components/plugins/healthmap_spec.rb +40 -0
  718. data/spec/components/plugins/http_dicattack_spec.rb +40 -0
  719. data/spec/components/plugins/meta/remedies/discovery_spec.rb +23 -0
  720. data/spec/components/plugins/meta/remedies/timing_attacks_spec.rb +31 -0
  721. data/spec/components/plugins/meta/uniformity_spec.rb +29 -0
  722. data/spec/components/plugins/script_spec.rb +13 -0
  723. data/spec/components/plugins/uncommon_headers_spec.rb +64 -0
  724. data/spec/components/plugins/vector_feed_spec.rb +169 -0
  725. data/spec/components/plugins/waf_detector_spec.rb +50 -0
  726. data/spec/components/reporters/ap_spec.rb +9 -0
  727. data/spec/components/reporters/html_spec.rb +9 -0
  728. data/spec/components/reporters/json_spec.rb +17 -0
  729. data/spec/components/reporters/marshal_spec.rb +13 -0
  730. data/spec/components/reporters/stdout_spec.rb +9 -0
  731. data/spec/components/reporters/txt_spec.rb +8 -0
  732. data/spec/components/reporters/xml_spec.rb +9 -0
  733. data/spec/components/reporters/yaml_spec.rb +14 -0
  734. data/spec/external/wavsep/active/lfi_spec.rb +1 -1
  735. data/spec/external/wavsep/active/obsolete_files_spec.rb +225 -0
  736. data/spec/external/wavsep/active/rfi_spec.rb +1 -1
  737. data/spec/external/wavsep/active/sqli_spec.rb +8 -6
  738. data/spec/external/wavsep/active/unvalidated_redirect_spec.rb +57 -0
  739. data/spec/external/wavsep/active/xss_dom_spec.rb +27 -0
  740. data/spec/external/wavsep/active/xss_spec.rb +13 -3
  741. data/spec/external/wavsep/false_positives/lfi_spec.rb +4 -16
  742. data/spec/external/wavsep/false_positives/obsolete_files_spec.rb +21 -0
  743. data/spec/external/wavsep/false_positives/rfi_spec.rb +2 -2
  744. data/spec/external/wavsep/false_positives/sqli_spec.rb +4 -15
  745. data/spec/external/wavsep/false_positives/unvalidated_redirect_spec.rb +21 -0
  746. data/spec/external/wavsep/false_positives/xss_spec.rb +2 -2
  747. data/spec/spec_helper.rb +17 -18
  748. data/spec/support/factories/browser/javascript/taint_tracer/frame.rb +10 -0
  749. data/spec/support/factories/browser/javascript/taint_tracer/frame/called_function.rb +11 -0
  750. data/spec/support/factories/browser/javascript/taint_tracer/sink/data_flow.rb +14 -0
  751. data/spec/support/factories/browser/javascript/taint_tracer/sink/execution_flow.rb +10 -0
  752. data/spec/support/factories/browser_cluster/job.rb +27 -0
  753. data/spec/support/factories/element/cookie.rb +7 -0
  754. data/spec/support/factories/element/form.rb +12 -0
  755. data/spec/support/factories/element/header.rb +5 -0
  756. data/spec/support/factories/element/link.rb +11 -0
  757. data/spec/support/factories/element/link_template.rb +11 -0
  758. data/spec/support/factories/http/request.rb +9 -0
  759. data/spec/support/factories/http/response.rb +42 -0
  760. data/spec/support/factories/issue.rb +67 -0
  761. data/spec/support/factories/page.rb +7 -0
  762. data/spec/support/factories/page/dom.rb +13 -0
  763. data/spec/support/factories/page/dom/transition.rb +21 -0
  764. data/spec/support/factories/scan_report.rb +35 -0
  765. data/spec/support/factories/vector.rb +32 -0
  766. data/spec/support/fixtures/check_with_invalid_platforms/with_invalid_platforms.rb +37 -0
  767. data/spec/support/fixtures/checks/test.rb +58 -0
  768. data/spec/support/fixtures/checks/test2.rb +41 -0
  769. data/spec/support/fixtures/checks/test3.rb +41 -0
  770. data/spec/support/fixtures/executables/node.rb +47 -0
  771. data/spec/support/fixtures/fingerprinters/test.rb +5 -13
  772. data/spec/support/fixtures/option_groups/input.yml +2 -0
  773. data/spec/support/fixtures/plugins/bad.rb +5 -13
  774. data/spec/support/fixtures/plugins/defaults/default.rb +6 -14
  775. data/spec/support/fixtures/plugins/distributable.rb +7 -15
  776. data/spec/support/fixtures/plugins/loop.rb +5 -13
  777. data/spec/support/fixtures/plugins/suspendable.rb +44 -0
  778. data/spec/support/fixtures/plugins/wait.rb +6 -14
  779. data/spec/support/fixtures/plugins/with_options.rb +20 -16
  780. data/spec/support/fixtures/plugins_with_priorities/p0.rb +17 -0
  781. data/spec/support/fixtures/plugins_with_priorities/p00.rb +17 -0
  782. data/spec/support/fixtures/plugins_with_priorities/p1.rb +17 -0
  783. data/spec/support/fixtures/plugins_with_priorities/p2.rb +17 -0
  784. data/spec/support/fixtures/plugins_with_priorities/p22.rb +17 -0
  785. data/spec/support/fixtures/plugins_with_priorities/p222.rb +17 -0
  786. data/spec/support/fixtures/plugins_with_priorities/p_nil.rb +16 -0
  787. data/spec/support/fixtures/plugins_with_priorities/p_nil2.rb +16 -0
  788. data/spec/support/fixtures/report.afr +0 -0
  789. data/spec/support/fixtures/reporters/base_spec/plugin_formatters/with_formatters/foobar.rb +13 -0
  790. data/spec/support/fixtures/reporters/base_spec/with_formatters.rb +15 -0
  791. data/spec/support/fixtures/reporters/base_spec/with_outfile.rb +16 -0
  792. data/spec/support/fixtures/reporters/base_spec/without_outfile.rb +12 -0
  793. data/spec/support/fixtures/reporters/manager_spec/afr.rb +13 -0
  794. data/spec/support/fixtures/reporters/manager_spec/foo.rb +18 -0
  795. data/spec/support/fixtures/rescan.afr.tpl +4 -5
  796. data/spec/support/fixtures/run_check/body.rb +48 -0
  797. data/spec/support/fixtures/run_check/cookies.rb +48 -0
  798. data/spec/support/fixtures/run_check/empty.rb +34 -0
  799. data/spec/support/fixtures/run_check/flch.rb +53 -0
  800. data/spec/support/fixtures/run_check/forms.rb +48 -0
  801. data/spec/support/fixtures/run_check/headers.rb +48 -0
  802. data/spec/support/fixtures/run_check/links.rb +48 -0
  803. data/spec/support/fixtures/run_check/nil.rb +47 -0
  804. data/spec/support/fixtures/run_check/path.rb +48 -0
  805. data/spec/support/fixtures/run_check/server.rb +48 -0
  806. data/spec/support/fixtures/services/echo.rb +64 -0
  807. data/spec/support/fixtures/taint_check/taint.rb +38 -0
  808. data/spec/support/fixtures/wait_check/wait.rb +38 -0
  809. data/spec/support/helpers/auditor.rb +18 -5
  810. data/spec/support/helpers/browser.rb +6 -0
  811. data/spec/support/helpers/browser_cluster/jobs/taint_tracer.rb +32 -0
  812. data/spec/support/helpers/framework.rb +5 -13
  813. data/spec/support/helpers/misc.rb +4 -12
  814. data/spec/support/helpers/pages.rb +18 -0
  815. data/spec/support/helpers/paths.rb +4 -12
  816. data/spec/support/helpers/requires.rb +5 -13
  817. data/spec/support/helpers/resets.rb +12 -19
  818. data/spec/support/helpers/web_server.rb +11 -15
  819. data/spec/support/lib/factory.rb +115 -0
  820. data/spec/support/lib/web_server_client.rb +49 -0
  821. data/spec/support/lib/web_server_dispatcher.rb +33 -0
  822. data/spec/support/lib/web_server_manager.rb +29 -32
  823. data/spec/support/pems/cacert.pem +35 -37
  824. data/spec/support/pems/client/cert.pem +35 -37
  825. data/spec/support/pems/client/key.pem +49 -49
  826. data/spec/support/pems/server/cert.pem +35 -37
  827. data/spec/support/pems/server/key.pem +49 -49
  828. data/spec/support/servers/arachni/browser.rb +836 -0
  829. data/spec/support/servers/arachni/browser/javascript.rb +7 -0
  830. data/spec/support/servers/arachni/browser/javascript/angular-1.2.8.js +20554 -0
  831. data/spec/support/servers/arachni/browser/javascript/angular-route.js +911 -0
  832. data/spec/support/servers/arachni/browser/javascript/dom_monitor.rb +90 -0
  833. data/spec/support/servers/arachni/browser/javascript/jquery-2.0.3.js +8829 -0
  834. data/spec/support/servers/arachni/browser/javascript/proxy.rb +17 -0
  835. data/spec/support/servers/arachni/browser/javascript/taint_tracer.rb +714 -0
  836. data/spec/support/servers/arachni/browser_cluster/jobs/event_trigger.rb +25 -0
  837. data/spec/support/servers/arachni/browser_https.rb +60 -0
  838. data/spec/support/servers/arachni/check/auditor.rb +247 -0
  839. data/spec/support/servers/arachni/element/body.rb +5 -0
  840. data/spec/support/servers/arachni/element/capabilities/analyzable/differential.rb +162 -0
  841. data/spec/support/servers/arachni/element/capabilities/{auditable → analyzable}/taint.rb +0 -0
  842. data/spec/support/servers/arachni/element/capabilities/analyzable/timeout.rb +37 -0
  843. data/spec/support/servers/arachni/element/cookie.rb +1 -1
  844. data/spec/support/servers/arachni/element/cookie/cookie_dom.rb +21 -0
  845. data/spec/support/servers/arachni/element/form.rb +6 -22
  846. data/spec/support/servers/arachni/element/form/form_dom.rb +50 -0
  847. data/spec/support/servers/arachni/element/header.rb +7 -8
  848. data/spec/support/servers/arachni/element/link.rb +15 -7
  849. data/spec/support/servers/arachni/element/link/link_dom.rb +49 -0
  850. data/spec/support/servers/arachni/element/link_template.rb +11 -0
  851. data/spec/support/servers/arachni/element/link_template/link_template_dom.rb +43 -0
  852. data/spec/support/servers/arachni/framework.rb +18 -0
  853. data/spec/support/servers/arachni/http/client.rb +176 -0
  854. data/spec/support/servers/arachni/http/proxy_server.rb +9 -0
  855. data/spec/support/servers/arachni/http/proxy_server_https.rb +25 -0
  856. data/spec/support/servers/arachni/page/page_dom.rb +83 -0
  857. data/spec/support/servers/arachni/parser.rb +4 -0
  858. data/spec/support/servers/arachni/rpc/server/{framework_hpg.rb → framework_multi.rb} +0 -0
  859. data/spec/support/servers/arachni/session.rb +43 -9
  860. data/spec/support/servers/arachni/trainer.rb +11 -7
  861. data/spec/support/servers/checks/active/code_injection.rb +163 -0
  862. data/spec/support/servers/checks/active/code_injection_timing.rb +134 -0
  863. data/spec/support/servers/{modules/audit → checks/active}/csrf.rb +0 -0
  864. data/spec/support/servers/checks/active/file_inclusion.rb +228 -0
  865. data/spec/support/servers/checks/active/ldap_injection.rb +88 -0
  866. data/spec/support/servers/checks/active/no_sql_injection.rb +134 -0
  867. data/spec/support/servers/checks/active/no_sql_injection/mongodb +1 -0
  868. data/spec/support/servers/checks/active/no_sql_injection_differential.rb +61 -0
  869. data/spec/support/servers/checks/active/os_cmd_injection.rb +172 -0
  870. data/spec/support/servers/checks/active/os_cmd_injection_timing.rb +118 -0
  871. data/spec/support/servers/checks/active/path_traversal.rb +219 -0
  872. data/spec/support/servers/checks/active/response_splitting.rb +138 -0
  873. data/spec/support/servers/{modules/audit → checks/active}/rfi.rb +0 -0
  874. data/spec/support/servers/checks/active/session_fixation.rb +111 -0
  875. data/spec/support/servers/checks/active/source_code_disclosure.rb +118 -0
  876. data/spec/support/servers/checks/active/sql_injection.rb +133 -0
  877. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/access +0 -0
  878. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/coldfusion +0 -0
  879. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/db2 +0 -0
  880. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/emc +0 -0
  881. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/firebird +0 -0
  882. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/frontbase +0 -0
  883. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/hsqldb +0 -0
  884. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/informix +0 -0
  885. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/ingres +0 -0
  886. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/interbase +0 -0
  887. data/spec/support/servers/checks/active/sql_injection/jdbc +0 -0
  888. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/maxdb +0 -0
  889. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/mssql +0 -0
  890. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/mysql +0 -0
  891. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/oracle +0 -0
  892. data/spec/support/servers/{modules/audit/sqli/postgresql → checks/active/sql_injection/pgsql} +0 -0
  893. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/sqlite +0 -0
  894. data/spec/support/servers/{modules/audit/sqli → checks/active/sql_injection}/sybase +0 -0
  895. data/spec/support/servers/{modules/audit/sqli_blind_rdiff.rb → checks/active/sql_injection_differential.rb} +0 -0
  896. data/spec/support/servers/checks/active/sql_injection_timing.rb +145 -0
  897. data/spec/support/servers/{modules/audit/trainer_module.rb → checks/active/trainer_check.rb} +0 -0
  898. data/spec/support/servers/checks/active/unvalidated_redirect.rb +141 -0
  899. data/spec/support/servers/checks/active/xpath_injection.rb +121 -0
  900. data/spec/support/servers/{modules/audit/xpath → checks/active/xpath_injection}/dotnet +0 -0
  901. data/spec/support/servers/{modules/audit/xpath → checks/active/xpath_injection}/general +0 -0
  902. data/spec/support/servers/{modules/audit/xpath → checks/active/xpath_injection}/java +0 -0
  903. data/spec/support/servers/{modules/audit/xpath → checks/active/xpath_injection}/libxml2 +0 -0
  904. data/spec/support/servers/{modules/audit/xpath → checks/active/xpath_injection}/php +0 -0
  905. data/spec/support/servers/checks/active/xss.rb +239 -0
  906. data/spec/support/servers/checks/active/xss_dom.rb +133 -0
  907. data/spec/support/servers/checks/active/xss_dom_inputs.rb +35 -0
  908. data/spec/support/servers/checks/active/xss_dom_script_context.rb +139 -0
  909. data/spec/support/servers/checks/active/xss_event.rb +80 -0
  910. data/spec/support/servers/{modules/audit → checks/active}/xss_path.rb +0 -0
  911. data/spec/support/servers/checks/active/xss_script_context.rb +90 -0
  912. data/spec/support/servers/{modules/audit → checks/active}/xss_tag.rb +0 -0
  913. data/spec/support/servers/checks/check_server.rb +14 -0
  914. data/spec/support/servers/{modules/recon → checks/passive}/allowed_methods.rb +0 -0
  915. data/spec/support/servers/checks/passive/backdoors.rb +4 -0
  916. data/spec/support/servers/checks/passive/backup_directories.rb +15 -0
  917. data/spec/support/servers/checks/passive/backup_files.rb +15 -0
  918. data/spec/support/servers/checks/passive/common_directories.rb +6 -0
  919. data/spec/support/servers/checks/passive/common_files.rb +6 -0
  920. data/spec/support/servers/checks/passive/directory_listing.rb +30 -0
  921. data/spec/support/servers/{modules/recon → checks/passive}/grep/captcha.rb +0 -0
  922. data/spec/support/servers/checks/passive/grep/cookie_set_for_parent_domain.rb +21 -0
  923. data/spec/support/servers/{modules/recon → checks/passive}/grep/credit_card.rb +0 -0
  924. data/spec/support/servers/{modules/recon → checks/passive}/grep/cvs_svn_users.rb +0 -0
  925. data/spec/support/servers/checks/passive/grep/emails.rb +23 -0
  926. data/spec/support/servers/{modules/recon → checks/passive}/grep/form_upload.rb +0 -0
  927. data/spec/support/servers/checks/passive/grep/hsts_https.rb +37 -0
  928. data/spec/support/servers/{modules/recon → checks/passive}/grep/html_objects.rb +0 -0
  929. data/spec/support/servers/{modules/recon → checks/passive}/grep/http_only_cookies.rb +0 -0
  930. data/spec/support/servers/checks/passive/grep/insecure_cookies_https.rb +40 -0
  931. data/spec/support/servers/checks/passive/grep/mixed_resource_https.rb +69 -0
  932. data/spec/support/servers/checks/passive/grep/password_autocomplete.rb +33 -0
  933. data/spec/support/servers/{modules/recon → checks/passive}/grep/private_ip.rb +0 -0
  934. data/spec/support/servers/{modules/recon → checks/passive}/grep/ssn.rb +0 -0
  935. data/spec/support/servers/checks/passive/grep/unencrypted_password_forms.rb +33 -0
  936. data/spec/support/servers/{modules/recon → checks/passive}/htaccess_limit.rb +0 -0
  937. data/spec/support/servers/checks/passive/http_put.rb +7 -0
  938. data/spec/support/servers/checks/passive/interesting_responses.rb +5 -0
  939. data/spec/support/servers/{modules/recon → checks/passive}/localstart_asp.rb +0 -0
  940. data/spec/support/servers/checks/passive/origin_spoof_access_restriction_bypass.rb +30 -0
  941. data/spec/support/servers/checks/passive/webdav.rb +25 -0
  942. data/spec/support/servers/{modules/recon → checks/passive}/xst.rb +0 -0
  943. data/spec/support/servers/plugins/meta/remedies/discovery.rb +2 -2
  944. data/spec/support/servers/plugins/meta/remedies/timing_attacks.rb +2 -0
  945. data/spec/support/shared/browser/javascript/taint_tracer/sink/base.rb +36 -0
  946. data/spec/support/shared/check.rb +198 -0
  947. data/spec/support/shared/component.rb +15 -4
  948. data/spec/support/shared/component/options/base.rb +187 -0
  949. data/spec/support/shared/element/base.rb +131 -0
  950. data/spec/support/shared/element/capabilities/auditable.rb +371 -604
  951. data/spec/support/shared/element/capabilities/auditable/dom.rb +303 -0
  952. data/spec/support/shared/element/capabilities/inputtable.rb +499 -0
  953. data/spec/support/shared/element/capabilities/mutable.rb +362 -0
  954. data/spec/support/shared/element/capabilities/refreshable.rb +26 -26
  955. data/spec/support/shared/element/capabilities/submitable.rb +155 -0
  956. data/spec/support/shared/element/capabilities/with_auditor.rb +75 -0
  957. data/spec/support/shared/element/capabilities/with_dom.rb +39 -0
  958. data/spec/support/shared/element/capabilities/with_node.rb +42 -0
  959. data/spec/support/shared/element/capabilities/with_scope.rb +22 -0
  960. data/spec/support/shared/external/wavsep.rb +30 -9
  961. data/spec/support/shared/http/message.rb +72 -0
  962. data/spec/support/shared/option_group.rb +98 -0
  963. data/spec/support/shared/path_extractor.rb +1 -1
  964. data/spec/support/shared/plugin.rb +33 -16
  965. data/spec/support/shared/reporter.rb +41 -0
  966. data/spec/support/shared/support/cache.rb +341 -0
  967. data/spec/support/shared/support/lookup.rb +93 -13
  968. data/ui/cli/framework.rb +466 -0
  969. data/ui/cli/framework/option_parser.rb +628 -0
  970. data/ui/cli/option_parser.rb +104 -0
  971. data/ui/cli/output.rb +377 -0
  972. data/ui/cli/reporter.rb +52 -0
  973. data/ui/cli/reporter/option_parser.rb +102 -0
  974. data/ui/cli/restored_framework.rb +127 -0
  975. data/ui/cli/restored_framework/option_parser.rb +115 -0
  976. data/ui/cli/rpc/client/dispatcher_monitor.rb +157 -0
  977. data/ui/cli/rpc/client/dispatcher_monitor/option_parser.rb +41 -0
  978. data/ui/cli/rpc/client/instance.rb +294 -0
  979. data/ui/cli/rpc/client/local.rb +65 -0
  980. data/ui/cli/rpc/client/local/option_parser.rb +35 -0
  981. data/ui/cli/rpc/client/remote.rb +84 -0
  982. data/ui/cli/rpc/client/remote/option_parser.rb +99 -0
  983. data/ui/cli/rpc/server/dispatcher.rb +36 -0
  984. data/ui/cli/rpc/server/dispatcher/option_parser.rb +165 -0
  985. data/ui/cli/utilities.rb +228 -0
  986. metadata +1260 -1266
  987. data/EXPLOITATION.md +0 -431
  988. data/HACKING.md +0 -120
  989. data/NOTICE +0 -12
  990. data/data/crypto/public.pem +0 -9
  991. data/external/metasploit/LICENSE +0 -24
  992. data/external/metasploit/plugins/arachni.rb +0 -516
  993. data/external/metasploit/plugins/arachni/modules/auxiliary/arachni_sqlmap.rb +0 -91
  994. data/external/metasploit/plugins/arachni/modules/exploits/unix/webapp/arachni_exec.rb +0 -142
  995. data/external/metasploit/plugins/arachni/modules/exploits/unix/webapp/arachni_path_traversal.rb +0 -113
  996. data/external/metasploit/plugins/arachni/modules/exploits/unix/webapp/arachni_php_eval.rb +0 -150
  997. data/external/metasploit/plugins/arachni/modules/exploits/unix/webapp/arachni_php_include.rb +0 -141
  998. data/fingerprinters/frameworks/rack.rb +0 -41
  999. data/fingerprinters/languages/asp.rb +0 -42
  1000. data/fingerprinters/languages/aspx.rb +0 -63
  1001. data/fingerprinters/languages/jsp.rb +0 -42
  1002. data/fingerprinters/languages/php.rb +0 -43
  1003. data/fingerprinters/languages/python.rb +0 -40
  1004. data/fingerprinters/languages/ruby.rb +0 -41
  1005. data/fingerprinters/os/bsd.rb +0 -36
  1006. data/fingerprinters/os/linux.rb +0 -42
  1007. data/fingerprinters/os/solaris.rb +0 -41
  1008. data/fingerprinters/os/unix.rb +0 -36
  1009. data/fingerprinters/os/windows.rb +0 -41
  1010. data/fingerprinters/servers/apache.rb +0 -36
  1011. data/fingerprinters/servers/iis.rb +0 -36
  1012. data/fingerprinters/servers/jetty.rb +0 -36
  1013. data/fingerprinters/servers/nginx.rb +0 -36
  1014. data/fingerprinters/servers/tomcat.rb +0 -36
  1015. data/gfx/README.md +0 -18
  1016. data/gfx/compiled/banner.png +0 -0
  1017. data/gfx/compiled/favicon.ico +0 -0
  1018. data/gfx/compiled/icon.png +0 -0
  1019. data/gfx/compiled/logo.png +0 -0
  1020. data/gfx/compiled/spider.png +0 -0
  1021. data/gfx/font/Beneath_the_Surface.ttf +0 -0
  1022. data/gfx/font/bts_readme.txt +0 -14
  1023. data/gfx/source/banner.svg +0 -999
  1024. data/gfx/source/icon.svg +0 -627
  1025. data/gfx/source/logo.svg +0 -672
  1026. data/gfx/source/spider.png +0 -0
  1027. data/gfx/source/spider.svg +0 -277
  1028. data/lib/arachni/audit_store.rb +0 -321
  1029. data/lib/arachni/component/options/enum.rb +0 -51
  1030. data/lib/arachni/element/capabilities/auditable/rdiff.rb +0 -489
  1031. data/lib/arachni/element/capabilities/auditable/taint.rb +0 -238
  1032. data/lib/arachni/element/capabilities/auditable/timeout.rb +0 -469
  1033. data/lib/arachni/mixins/observable.rb +0 -91
  1034. data/lib/arachni/mixins/progress_bar.rb +0 -87
  1035. data/lib/arachni/mixins/terminal.rb +0 -112
  1036. data/lib/arachni/module.rb +0 -20
  1037. data/lib/arachni/module/auditor.rb +0 -618
  1038. data/lib/arachni/module/base.rb +0 -188
  1039. data/lib/arachni/module/manager.rb +0 -255
  1040. data/lib/arachni/module/output.rb +0 -68
  1041. data/lib/arachni/module/utilities.rb +0 -64
  1042. data/lib/arachni/report/base.rb +0 -201
  1043. data/lib/arachni/report/manager.rb +0 -86
  1044. data/lib/arachni/rpc/server/dispatcher/handler.rb +0 -166
  1045. data/lib/arachni/rpc/server/module/manager.rb +0 -46
  1046. data/lib/arachni/rpc/server/spider.rb +0 -404
  1047. data/lib/arachni/ruby/enumerable.rb +0 -29
  1048. data/lib/arachni/spider.rb +0 -477
  1049. data/lib/arachni/support/key_filler.rb +0 -68
  1050. data/lib/arachni/support/queue.rb +0 -18
  1051. data/lib/arachni/support/queue/disk.rb +0 -171
  1052. data/lib/arachni/typhoeus/hydra.rb +0 -56
  1053. data/lib/arachni/typhoeus/request.rb +0 -80
  1054. data/lib/arachni/typhoeus/response.rb +0 -103
  1055. data/lib/arachni/typhoeus/utils.rb +0 -25
  1056. data/lib/arachni/ui/cli/cli.rb +0 -469
  1057. data/lib/arachni/ui/cli/output.rb +0 -391
  1058. data/lib/arachni/ui/cli/rpc/dispatcher_monitor.rb +0 -188
  1059. data/lib/arachni/ui/cli/rpc/instance.rb +0 -407
  1060. data/lib/arachni/ui/cli/rpc/local.rb +0 -80
  1061. data/lib/arachni/ui/cli/rpc/remote.rb +0 -134
  1062. data/lib/arachni/ui/cli/utilities.rb +0 -509
  1063. data/modules/audit/code_injection.rb +0 -137
  1064. data/modules/audit/code_injection_php_input_wrapper.rb +0 -109
  1065. data/modules/audit/code_injection_timing.rb +0 -122
  1066. data/modules/audit/csrf.rb +0 -225
  1067. data/modules/audit/file_inclusion.rb +0 -156
  1068. data/modules/audit/ldapi.rb +0 -97
  1069. data/modules/audit/os_cmd_injection.rb +0 -109
  1070. data/modules/audit/os_cmd_injection_timing.rb +0 -98
  1071. data/modules/audit/path_traversal.rb +0 -170
  1072. data/modules/audit/response_splitting.rb +0 -99
  1073. data/modules/audit/rfi.rb +0 -181
  1074. data/modules/audit/session_fixation.rb +0 -117
  1075. data/modules/audit/source_code_disclosure.rb +0 -179
  1076. data/modules/audit/sqli.rb +0 -148
  1077. data/modules/audit/sqli_blind_rdiff.rb +0 -138
  1078. data/modules/audit/sqli_blind_timing.rb +0 -126
  1079. data/modules/audit/trainer.rb +0 -49
  1080. data/modules/audit/unvalidated_redirect.rb +0 -91
  1081. data/modules/audit/xpath.rb +0 -97
  1082. data/modules/audit/xss.rb +0 -154
  1083. data/modules/audit/xss_event.rb +0 -153
  1084. data/modules/audit/xss_path.rb +0 -152
  1085. data/modules/audit/xss_script_tag.rb +0 -137
  1086. data/modules/audit/xss_tag.rb +0 -137
  1087. data/modules/recon/allowed_methods.rb +0 -99
  1088. data/modules/recon/backdoors.rb +0 -82
  1089. data/modules/recon/backup_files.rb +0 -100
  1090. data/modules/recon/backup_files/extensions.txt +0 -28
  1091. data/modules/recon/common_directories.rb +0 -87
  1092. data/modules/recon/common_files.rb +0 -78
  1093. data/modules/recon/common_files/filenames.txt +0 -21
  1094. data/modules/recon/directory_listing.rb +0 -133
  1095. data/modules/recon/grep/captcha.rb +0 -74
  1096. data/modules/recon/grep/credit_card.rb +0 -128
  1097. data/modules/recon/grep/cvs_svn_users.rb +0 -81
  1098. data/modules/recon/grep/emails.rb +0 -73
  1099. data/modules/recon/grep/form_upload.rb +0 -86
  1100. data/modules/recon/grep/html_objects.rb +0 -56
  1101. data/modules/recon/grep/http_only_cookies.rb +0 -82
  1102. data/modules/recon/grep/insecure_cookies.rb +0 -82
  1103. data/modules/recon/grep/mixed_resource.rb +0 -113
  1104. data/modules/recon/grep/password_autocomplete.rb +0 -85
  1105. data/modules/recon/grep/private_ip.rb +0 -70
  1106. data/modules/recon/grep/ssn.rb +0 -66
  1107. data/modules/recon/grep/unencrypted_password_forms.rb +0 -103
  1108. data/modules/recon/htaccess_limit.rb +0 -76
  1109. data/modules/recon/http_put.rb +0 -95
  1110. data/modules/recon/interesting_responses.rb +0 -91
  1111. data/modules/recon/localstart_asp.rb +0 -97
  1112. data/modules/recon/webdav.rb +0 -106
  1113. data/modules/recon/x_forwarded_for_access_restriction_bypass.rb +0 -76
  1114. data/modules/recon/xst.rb +0 -103
  1115. data/path_extractors/anchors.rb +0 -37
  1116. data/path_extractors/areas.rb +0 -37
  1117. data/path_extractors/forms.rb +0 -37
  1118. data/path_extractors/frames.rb +0 -37
  1119. data/path_extractors/generic.rb +0 -84
  1120. data/path_extractors/links.rb +0 -37
  1121. data/path_extractors/meta_refresh.rb +0 -58
  1122. data/path_extractors/scripts.rb +0 -38
  1123. data/plugins/autologin.rb +0 -133
  1124. data/plugins/beep_notify.rb +0 -49
  1125. data/plugins/content_types.rb +0 -107
  1126. data/plugins/cookie_collector.rb +0 -85
  1127. data/plugins/defaults/autothrottle.rb +0 -78
  1128. data/plugins/defaults/healthmap.rb +0 -89
  1129. data/plugins/defaults/meta/remedies/discovery.rb +0 -138
  1130. data/plugins/defaults/meta/remedies/timing_attacks.rb +0 -117
  1131. data/plugins/defaults/meta/uniformity.rb +0 -82
  1132. data/plugins/defaults/resolver.rb +0 -60
  1133. data/plugins/email_notify.rb +0 -106
  1134. data/plugins/form_dicattack.rb +0 -123
  1135. data/plugins/http_dicattack.rb +0 -108
  1136. data/plugins/libnotify.rb +0 -82
  1137. data/plugins/profiler.rb +0 -179
  1138. data/plugins/proxy.rb +0 -502
  1139. data/plugins/proxy/panel/page_accordion.html.erb +0 -67
  1140. data/plugins/proxy/panel/panel.html.erb +0 -69
  1141. data/plugins/proxy/panel/verify_login_sequence.html.erb +0 -45
  1142. data/plugins/proxy/server.rb +0 -215
  1143. data/plugins/proxy/template_scope.rb +0 -138
  1144. data/plugins/rescan.rb +0 -59
  1145. data/plugins/script.rb +0 -53
  1146. data/plugins/uncommon_headers.rb +0 -92
  1147. data/plugins/vector_feed.rb +0 -226
  1148. data/plugins/waf_detector.rb +0 -167
  1149. data/profiles/full.afp +0 -48
  1150. data/reports/afr.rb +0 -44
  1151. data/reports/ap.rb +0 -46
  1152. data/reports/html.rb +0 -273
  1153. data/reports/html/default.erb +0 -82
  1154. data/reports/html/default/configuration.erb +0 -126
  1155. data/reports/html/default/css/jquery-ui.css +0 -570
  1156. data/reports/html/default/css/jquery.jqplot.min.css +0 -1
  1157. data/reports/html/default/css/main.css +0 -391
  1158. data/reports/html/default/headers.erb +0 -19
  1159. data/reports/html/default/issue.erb +0 -178
  1160. data/reports/html/default/issues.erb +0 -52
  1161. data/reports/html/default/js/charts.js +0 -147
  1162. data/reports/html/default/js/helpers.js +0 -53
  1163. data/reports/html/default/js/init.js +0 -72
  1164. data/reports/html/default/js/lib/jqplot.barRenderer.min.js +0 -57
  1165. data/reports/html/default/js/lib/jqplot.categoryAxisRenderer.min.js +0 -57
  1166. data/reports/html/default/js/lib/jqplot.cursor.min.js +0 -57
  1167. data/reports/html/default/js/lib/jqplot.pieRenderer.min.js +0 -57
  1168. data/reports/html/default/js/lib/jqplot.pointLabels.min.js +0 -57
  1169. data/reports/html/default/js/lib/jquery-ui.min.js +0 -404
  1170. data/reports/html/default/js/lib/jquery.jqplot.min.js +0 -57
  1171. data/reports/html/default/js/lib/jquery.min.js +0 -167
  1172. data/reports/html/default/plugins.erb +0 -22
  1173. data/reports/html/default/search.erb +0 -8
  1174. data/reports/html/default/sitemap.erb +0 -15
  1175. data/reports/html/default/summary.erb +0 -75
  1176. data/reports/html/default/summary_issue.erb +0 -20
  1177. data/reports/json.rb +0 -52
  1178. data/reports/marshal.rb +0 -46
  1179. data/reports/metareport.rb +0 -104
  1180. data/reports/plugin_formatters/html/autologin.rb +0 -45
  1181. data/reports/plugin_formatters/html/content_types.rb +0 -67
  1182. data/reports/plugin_formatters/html/cookie_collector.rb +0 -52
  1183. data/reports/plugin_formatters/html/discovery.rb +0 -45
  1184. data/reports/plugin_formatters/html/form_dicattack.rb +0 -40
  1185. data/reports/plugin_formatters/html/healthmap.rb +0 -60
  1186. data/reports/plugin_formatters/html/http_dicattack.rb +0 -40
  1187. data/reports/plugin_formatters/html/profiler.rb +0 -36
  1188. data/reports/plugin_formatters/html/profiler/template.erb +0 -84
  1189. data/reports/plugin_formatters/html/resolver.rb +0 -55
  1190. data/reports/plugin_formatters/html/timing_attacks.rb +0 -51
  1191. data/reports/plugin_formatters/html/uncommon_headers.rb +0 -47
  1192. data/reports/plugin_formatters/html/uniformity.rb +0 -54
  1193. data/reports/plugin_formatters/html/waf_detector.rb +0 -38
  1194. data/reports/plugin_formatters/stdout/autologin.rb +0 -38
  1195. data/reports/plugin_formatters/stdout/content_types.rb +0 -51
  1196. data/reports/plugin_formatters/stdout/cookie_collector.rb +0 -43
  1197. data/reports/plugin_formatters/stdout/discovery.rb +0 -37
  1198. data/reports/plugin_formatters/stdout/form_dicattack.rb +0 -34
  1199. data/reports/plugin_formatters/stdout/healthmap.rb +0 -49
  1200. data/reports/plugin_formatters/stdout/http_dicattack.rb +0 -34
  1201. data/reports/plugin_formatters/stdout/profiler.rb +0 -66
  1202. data/reports/plugin_formatters/stdout/resolver.rb +0 -29
  1203. data/reports/plugin_formatters/stdout/timing_attacks.rb +0 -37
  1204. data/reports/plugin_formatters/stdout/uncommon_headers.rb +0 -37
  1205. data/reports/plugin_formatters/stdout/uniformity.rb +0 -48
  1206. data/reports/plugin_formatters/stdout/waf_detector.rb +0 -31
  1207. data/reports/plugin_formatters/xml/autologin.rb +0 -41
  1208. data/reports/plugin_formatters/xml/content_types.rb +0 -61
  1209. data/reports/plugin_formatters/xml/cookie_collector.rb +0 -45
  1210. data/reports/plugin_formatters/xml/discovery.rb +0 -38
  1211. data/reports/plugin_formatters/xml/form_dicattack.rb +0 -34
  1212. data/reports/plugin_formatters/xml/healthmap.rb +0 -58
  1213. data/reports/plugin_formatters/xml/http_dicattack.rb +0 -33
  1214. data/reports/plugin_formatters/xml/profiler.rb +0 -80
  1215. data/reports/plugin_formatters/xml/resolver.rb +0 -33
  1216. data/reports/plugin_formatters/xml/timing_attacks.rb +0 -39
  1217. data/reports/plugin_formatters/xml/uncommon_headers.rb +0 -38
  1218. data/reports/plugin_formatters/xml/uniformity.rb +0 -54
  1219. data/reports/plugin_formatters/xml/waf_detector.rb +0 -34
  1220. data/reports/stdout.rb +0 -203
  1221. data/reports/txt.rb +0 -58
  1222. data/reports/xml.rb +0 -176
  1223. data/reports/xml/buffer.rb +0 -97
  1224. data/reports/yaml.rb +0 -46
  1225. data/spec/arachni/audit_store_spec.rb +0 -239
  1226. data/spec/arachni/component/options/enum_spec.rb +0 -51
  1227. data/spec/arachni/element/base_spec.rb +0 -138
  1228. data/spec/arachni/element/capabilities/auditable/rdiff_spec.rb +0 -134
  1229. data/spec/arachni/element/capabilities/auditable/taint_spec.rb +0 -409
  1230. data/spec/arachni/element/capabilities/auditable/timeout_spec.rb +0 -157
  1231. data/spec/arachni/element/capabilities/mutable_spec.rb +0 -284
  1232. data/spec/arachni/http_spec.rb +0 -962
  1233. data/spec/arachni/mixins/observable_spec.rb +0 -75
  1234. data/spec/arachni/mixins/progress_bar_spec.rb +0 -47
  1235. data/spec/arachni/module/auditor_spec.rb +0 -544
  1236. data/spec/arachni/module/manager_spec.rb +0 -150
  1237. data/spec/arachni/module/utilities_spec.rb +0 -30
  1238. data/spec/arachni/report/base_spec.rb +0 -61
  1239. data/spec/arachni/report/manager_spec.rb +0 -82
  1240. data/spec/arachni/rpc/server/dispatcher/handler_spec.rb +0 -102
  1241. data/spec/arachni/rpc/server/framework_hpg_spec.rb +0 -376
  1242. data/spec/arachni/rpc/server/framework_simple_spec.rb +0 -501
  1243. data/spec/arachni/rpc/server/modules/manager_spec.rb +0 -47
  1244. data/spec/arachni/rpc/server/spider_spec.rb +0 -68
  1245. data/spec/arachni/ruby/enumerable_spec.rb +0 -37
  1246. data/spec/arachni/spider_spec.rb +0 -539
  1247. data/spec/arachni/support/cache/base_spec.rb +0 -282
  1248. data/spec/arachni/support/key_filler.rb +0 -60
  1249. data/spec/arachni/support/queue/disk_spec.rb +0 -116
  1250. data/spec/arachni/typhoeus/requrest_spec.rb +0 -58
  1251. data/spec/arachni/typhoeus/response_spec.rb +0 -171
  1252. data/spec/fingerprinters/frameworks/rack_spec.rb +0 -41
  1253. data/spec/fingerprinters/languages/asp_spec.rb +0 -40
  1254. data/spec/fingerprinters/languages/aspx_spec.rb +0 -78
  1255. data/spec/fingerprinters/languages/jsp_spec.rb +0 -58
  1256. data/spec/fingerprinters/languages/php_spec.rb +0 -61
  1257. data/spec/fingerprinters/languages/python_spec.rb +0 -23
  1258. data/spec/fingerprinters/languages/ruby.rb +0 -34
  1259. data/spec/fingerprinters/os/bsd_spec.rb +0 -26
  1260. data/spec/fingerprinters/os/linux_spec.rb +0 -34
  1261. data/spec/fingerprinters/os/solaris_spec.rb +0 -34
  1262. data/spec/fingerprinters/os/unix_spec.rb +0 -26
  1263. data/spec/fingerprinters/os/windows_spec.rb +0 -34
  1264. data/spec/fingerprinters/servers/apache_spec.rb +0 -26
  1265. data/spec/fingerprinters/servers/iis_spec.rb +0 -28
  1266. data/spec/fingerprinters/servers/jetty_spec.rb +0 -28
  1267. data/spec/fingerprinters/servers/nginx_spec.rb +0 -26
  1268. data/spec/fingerprinters/servers/tomcat_spec.rb +0 -28
  1269. data/spec/modules/audit/code_injection_spec.rb +0 -25
  1270. data/spec/modules/audit/code_injection_timing_spec.rb +0 -24
  1271. data/spec/modules/audit/csrf_spec.rb +0 -45
  1272. data/spec/modules/audit/file_inclusion_spec.rb +0 -25
  1273. data/spec/modules/audit/ldapi_spec.rb +0 -19
  1274. data/spec/modules/audit/os_cmd_injection_spec.rb +0 -24
  1275. data/spec/modules/audit/os_cmd_injection_timing_spec.rb +0 -24
  1276. data/spec/modules/audit/path_traversal_spec.rb +0 -23
  1277. data/spec/modules/audit/response_splitting_spec.rb +0 -19
  1278. data/spec/modules/audit/rfi_spec.rb +0 -19
  1279. data/spec/modules/audit/session_fixation_spec.rb +0 -23
  1280. data/spec/modules/audit/source_code_disclosure_spec.rb +0 -24
  1281. data/spec/modules/audit/sqli_blind_rdiff_spec.rb +0 -19
  1282. data/spec/modules/audit/sqli_blind_timing_spec.rb +0 -23
  1283. data/spec/modules/audit/sqli_spec.rb +0 -25
  1284. data/spec/modules/audit/trainer_spec.rb +0 -35
  1285. data/spec/modules/audit/unvalidated_redirect_spec.rb +0 -24
  1286. data/spec/modules/audit/xpath_spec.rb +0 -25
  1287. data/spec/modules/audit/xss_event_spec.rb +0 -19
  1288. data/spec/modules/audit/xss_path_spec.rb +0 -19
  1289. data/spec/modules/audit/xss_script_tag_spec.rb +0 -27
  1290. data/spec/modules/audit/xss_spec.rb +0 -24
  1291. data/spec/modules/audit/xss_tag_spec.rb +0 -19
  1292. data/spec/modules/recon/allowed_methods_spec.rb +0 -19
  1293. data/spec/modules/recon/backdoors_spec.rb +0 -19
  1294. data/spec/modules/recon/backup_files_spec.rb +0 -19
  1295. data/spec/modules/recon/common_directories_spec.rb +0 -19
  1296. data/spec/modules/recon/common_files_spec.rb +0 -19
  1297. data/spec/modules/recon/directory_listing_spec.rb +0 -19
  1298. data/spec/modules/recon/grep/captcha_spec.rb +0 -19
  1299. data/spec/modules/recon/grep/credit_card_spec.rb +0 -19
  1300. data/spec/modules/recon/grep/cvs_svn_users_spec.rb +0 -19
  1301. data/spec/modules/recon/grep/emails_spec.rb +0 -19
  1302. data/spec/modules/recon/grep/form_upload_spec.rb +0 -19
  1303. data/spec/modules/recon/grep/html_objects_spec.rb +0 -19
  1304. data/spec/modules/recon/grep/http_only_cookies_spec.rb +0 -19
  1305. data/spec/modules/recon/grep/insecure_cookies_spec.rb +0 -19
  1306. data/spec/modules/recon/grep/mixed_resource_spec.rb +0 -20
  1307. data/spec/modules/recon/grep/password_autocomplete_spec.rb +0 -19
  1308. data/spec/modules/recon/grep/private_ip_spec.rb +0 -26
  1309. data/spec/modules/recon/grep/ssn_spec.rb +0 -19
  1310. data/spec/modules/recon/grep/unencrypted_password_forms_spec.rb +0 -19
  1311. data/spec/modules/recon/htaccess_limit_spec.rb +0 -19
  1312. data/spec/modules/recon/http_put_spec.rb +0 -19
  1313. data/spec/modules/recon/interesting_responses_spec.rb +0 -30
  1314. data/spec/modules/recon/localstart_asp_spec.rb +0 -19
  1315. data/spec/modules/recon/webdav_spec.rb +0 -19
  1316. data/spec/modules/recon/x_forwarded_for_access_restriction_bypass_spec.rb +0 -19
  1317. data/spec/modules/recon/xst_spec.rb +0 -19
  1318. data/spec/path_extractors/scripts_spec.rb +0 -19
  1319. data/spec/plugins/autologin_spec.rb +0 -94
  1320. data/spec/plugins/autothrottle_spec.rb +0 -45
  1321. data/spec/plugins/content_types_spec.rb +0 -93
  1322. data/spec/plugins/cookie_collector_spec.rb +0 -49
  1323. data/spec/plugins/form_dicattack_spec.rb +0 -60
  1324. data/spec/plugins/healthmap_spec.rb +0 -40
  1325. data/spec/plugins/http_dicattack_spec.rb +0 -40
  1326. data/spec/plugins/meta/remedies/discovery_spec.rb +0 -21
  1327. data/spec/plugins/meta/remedies/timing_attacks_spec.rb +0 -34
  1328. data/spec/plugins/meta/uniformity_spec.rb +0 -83
  1329. data/spec/plugins/profiler_spec.rb +0 -82
  1330. data/spec/plugins/rescan_spec.rb +0 -26
  1331. data/spec/plugins/resolver_spec.rb +0 -16
  1332. data/spec/plugins/script_spec.rb +0 -12
  1333. data/spec/plugins/uncommon_headers_spec.rb +0 -64
  1334. data/spec/plugins/vector_feed_spec.rb +0 -167
  1335. data/spec/plugins/waf_detector_spec.rb +0 -41
  1336. data/spec/reports/afr_spec.rb +0 -13
  1337. data/spec/reports/ap_spec.rb +0 -9
  1338. data/spec/reports/html_spec.rb +0 -13
  1339. data/spec/reports/json_spec.rb +0 -17
  1340. data/spec/reports/marshal_spec.rb +0 -13
  1341. data/spec/reports/stdout_spec.rb +0 -9
  1342. data/spec/reports/txt_spec.rb +0 -8
  1343. data/spec/reports/xml_spec.rb +0 -13
  1344. data/spec/reports/yaml_spec.rb +0 -13
  1345. data/spec/support/fixtures/auditstore.afr +0 -76074
  1346. data/spec/support/fixtures/modules/test.rb +0 -58
  1347. data/spec/support/fixtures/modules/test2.rb +0 -46
  1348. data/spec/support/fixtures/modules/test3.rb +0 -46
  1349. data/spec/support/fixtures/plugins/spider_hook.rb +0 -50
  1350. data/spec/support/fixtures/reports/base_spec/plugin_formatters/with_formatters/foobar.rb +0 -21
  1351. data/spec/support/fixtures/reports/base_spec/with_formatters.rb +0 -23
  1352. data/spec/support/fixtures/reports/base_spec/with_outfile.rb +0 -24
  1353. data/spec/support/fixtures/reports/base_spec/without_outfile.rb +0 -20
  1354. data/spec/support/fixtures/reports/manager_spec/afr.rb +0 -21
  1355. data/spec/support/fixtures/reports/manager_spec/foo.rb +0 -26
  1356. data/spec/support/fixtures/rpcd_handlers/echo.rb +0 -68
  1357. data/spec/support/fixtures/run_mod/body.rb +0 -58
  1358. data/spec/support/fixtures/run_mod/cookies.rb +0 -58
  1359. data/spec/support/fixtures/run_mod/empty.rb +0 -58
  1360. data/spec/support/fixtures/run_mod/flch.rb +0 -63
  1361. data/spec/support/fixtures/run_mod/forms.rb +0 -58
  1362. data/spec/support/fixtures/run_mod/headers.rb +0 -58
  1363. data/spec/support/fixtures/run_mod/links.rb +0 -58
  1364. data/spec/support/fixtures/run_mod/nil.rb +0 -57
  1365. data/spec/support/fixtures/run_mod/path.rb +0 -58
  1366. data/spec/support/fixtures/run_mod/server.rb +0 -58
  1367. data/spec/support/fixtures/taint_module/taint.rb +0 -48
  1368. data/spec/support/fixtures/wait_module/wait.rb +0 -48
  1369. data/spec/support/logs/Dispatcher - 1332-56847.log +0 -9
  1370. data/spec/support/logs/Dispatcher - 1361-63434.log +0 -21
  1371. data/spec/support/logs/Dispatcher - 1545-55308.log +0 -9
  1372. data/spec/support/logs/Dispatcher - 1559-18938.log +0 -19
  1373. data/spec/support/logs/Dispatcher - 1568-25013.log +0 -17
  1374. data/spec/support/logs/Dispatcher - 1577-55689.log +0 -13
  1375. data/spec/support/logs/Dispatcher - 1586-18577.log +0 -9
  1376. data/spec/support/logs/Dispatcher - 1595-49353.log +0 -9
  1377. data/spec/support/logs/Dispatcher - 1604-27831.log +0 -11
  1378. data/spec/support/logs/Dispatcher - 1617-57444.log +0 -11
  1379. data/spec/support/logs/Dispatcher - 1631-28737.log +0 -11
  1380. data/spec/support/logs/Dispatcher - 1644-21815.log +0 -33
  1381. data/spec/support/logs/Dispatcher - 1738-53470.log +0 -21
  1382. data/spec/support/logs/Dispatcher - 1747-64173.log +0 -21
  1383. data/spec/support/logs/Dispatcher - 1756-11866.log +0 -23
  1384. data/spec/support/logs/Dispatcher - 1798-12175.log +0 -19
  1385. data/spec/support/logs/Dispatcher - 1807-22790.log +0 -17
  1386. data/spec/support/logs/Dispatcher - 1816-57823.log +0 -15
  1387. data/spec/support/logs/Dispatcher - 1831-64825.log +0 -11
  1388. data/spec/support/logs/Dispatcher - 1845-27623.log +0 -9
  1389. data/spec/support/logs/Dispatcher - 1854-26066.log +0 -9
  1390. data/spec/support/logs/Dispatcher - 1863-37486.log +0 -9
  1391. data/spec/support/logs/Dispatcher - 1874-22463.log +0 -9
  1392. data/spec/support/logs/Dispatcher - 1883-41263.log +0 -11
  1393. data/spec/support/logs/Dispatcher - 1900-53660.log +0 -9
  1394. data/spec/support/logs/Dispatcher - 1909-44423.log +0 -9
  1395. data/spec/support/logs/Dispatcher - 1921-58931.log +0 -9
  1396. data/spec/support/logs/Dispatcher - 1993-6448.log +0 -63
  1397. data/spec/support/logs/Dispatcher - 2002-19206.log +0 -43
  1398. data/spec/support/logs/Dispatcher - 2011-11852.log +0 -39
  1399. data/spec/support/logs/Dispatcher - 2020-65055.log +0 -34
  1400. data/spec/support/logs/Dispatcher - 2029-48445.log +0 -28
  1401. data/spec/support/logs/Dispatcher - 2038-55271.log +0 -21
  1402. data/spec/support/logs/Dispatcher - 2047-45722.log +0 -13
  1403. data/spec/support/logs/Dispatcher - 2057-48194.log +0 -9
  1404. data/spec/support/logs/Dispatcher - 2189-39843.log +0 -19
  1405. data/spec/support/logs/Dispatcher - 2199-15985.log +0 -21
  1406. data/spec/support/logs/Dispatcher - 2208-22080.log +0 -15
  1407. data/spec/support/logs/Dispatcher - 2221-37690.log +0 -19
  1408. data/spec/support/logs/Dispatcher - 2230-47867.log +0 -21
  1409. data/spec/support/logs/Dispatcher - 2239-27060.log +0 -15
  1410. data/spec/support/logs/Dispatcher - 2358-8967.log +0 -17
  1411. data/spec/support/logs/Dispatcher - 2367-27103.log +0 -21
  1412. data/spec/support/logs/Dispatcher - 2376-16287.log +0 -13
  1413. data/spec/support/logs/Dispatcher - 2389-9109.log +0 -19
  1414. data/spec/support/logs/Dispatcher - 2398-62926.log +0 -21
  1415. data/spec/support/logs/Dispatcher - 2407-48685.log +0 -15
  1416. data/spec/support/logs/Dispatcher - 2459-62480.log +0 -17
  1417. data/spec/support/logs/Dispatcher - 2470-57894.log +0 -21
  1418. data/spec/support/logs/Dispatcher - 2479-51883.log +0 -13
  1419. data/spec/support/logs/Dispatcher - 2493-36944.log +0 -17
  1420. data/spec/support/logs/Dispatcher - 2503-59143.log +0 -21
  1421. data/spec/support/logs/Dispatcher - 2513-33084.log +0 -13
  1422. data/spec/support/logs/Dispatcher - 25430-46306.log +0 -9
  1423. data/spec/support/logs/Dispatcher - 25457-10711.log +0 -23
  1424. data/spec/support/logs/Dispatcher - 25603-48892.log +0 -9
  1425. data/spec/support/logs/Dispatcher - 25613-24775.log +0 -19
  1426. data/spec/support/logs/Dispatcher - 25622-59684.log +0 -17
  1427. data/spec/support/logs/Dispatcher - 25631-23195.log +0 -13
  1428. data/spec/support/logs/Dispatcher - 25640-9810.log +0 -9
  1429. data/spec/support/logs/Dispatcher - 25649-52757.log +0 -9
  1430. data/spec/support/logs/Dispatcher - 25658-58550.log +0 -11
  1431. data/spec/support/logs/Dispatcher - 25671-30871.log +0 -11
  1432. data/spec/support/logs/Dispatcher - 25684-48620.log +0 -11
  1433. data/spec/support/logs/Dispatcher - 25697-18124.log +0 -37
  1434. data/spec/support/logs/Dispatcher - 25762-35321.log +0 -21
  1435. data/spec/support/logs/Dispatcher - 25771-64633.log +0 -21
  1436. data/spec/support/logs/Dispatcher - 25780-43558.log +0 -23
  1437. data/spec/support/logs/Dispatcher - 25821-43561.log +0 -19
  1438. data/spec/support/logs/Dispatcher - 25830-39112.log +0 -17
  1439. data/spec/support/logs/Dispatcher - 25839-44093.log +0 -15
  1440. data/spec/support/logs/Dispatcher - 25852-12057.log +0 -11
  1441. data/spec/support/logs/Dispatcher - 25866-49029.log +0 -9
  1442. data/spec/support/logs/Dispatcher - 25875-32179.log +0 -9
  1443. data/spec/support/logs/Dispatcher - 25884-62703.log +0 -9
  1444. data/spec/support/logs/Dispatcher - 25894-4228.log +0 -9
  1445. data/spec/support/logs/Dispatcher - 25903-6709.log +0 -11
  1446. data/spec/support/logs/Dispatcher - 25917-29651.log +0 -9
  1447. data/spec/support/logs/Dispatcher - 25926-12708.log +0 -9
  1448. data/spec/support/logs/Dispatcher - 25935-54092.log +0 -9
  1449. data/spec/support/logs/Dispatcher - 25990-26756.log +0 -63
  1450. data/spec/support/logs/Dispatcher - 25999-4016.log +0 -43
  1451. data/spec/support/logs/Dispatcher - 26008-52076.log +0 -39
  1452. data/spec/support/logs/Dispatcher - 26017-48497.log +0 -34
  1453. data/spec/support/logs/Dispatcher - 26026-28839.log +0 -28
  1454. data/spec/support/logs/Dispatcher - 26035-54215.log +0 -21
  1455. data/spec/support/logs/Dispatcher - 26044-27216.log +0 -13
  1456. data/spec/support/logs/Dispatcher - 26054-53464.log +0 -9
  1457. data/spec/support/logs/Dispatcher - 26163-65271.log +0 -19
  1458. data/spec/support/logs/Dispatcher - 26173-58105.log +0 -21
  1459. data/spec/support/logs/Dispatcher - 26182-40848.log +0 -15
  1460. data/spec/support/logs/Dispatcher - 26195-2855.log +0 -19
  1461. data/spec/support/logs/Dispatcher - 26204-35297.log +0 -21
  1462. data/spec/support/logs/Dispatcher - 26213-59588.log +0 -15
  1463. data/spec/support/logs/Dispatcher - 26333-40774.log +0 -17
  1464. data/spec/support/logs/Dispatcher - 26342-45541.log +0 -21
  1465. data/spec/support/logs/Dispatcher - 26351-3349.log +0 -13
  1466. data/spec/support/logs/Dispatcher - 26364-37456.log +0 -19
  1467. data/spec/support/logs/Dispatcher - 26373-37340.log +0 -21
  1468. data/spec/support/logs/Dispatcher - 26382-54864.log +0 -15
  1469. data/spec/support/logs/Dispatcher - 26434-3070.log +0 -17
  1470. data/spec/support/logs/Dispatcher - 26448-14295.log +0 -21
  1471. data/spec/support/logs/Dispatcher - 26474-30587.log +0 -13
  1472. data/spec/support/logs/Dispatcher - 26500-32529.log +0 -17
  1473. data/spec/support/logs/Dispatcher - 26509-16952.log +0 -21
  1474. data/spec/support/logs/Dispatcher - 26519-43332.log +0 -13
  1475. data/spec/support/logs/Dispatcher - 26750-61867.log +0 -19
  1476. data/spec/support/logs/Dispatcher - 26759-22532.log +0 -21
  1477. data/spec/support/logs/Dispatcher - 26768-18231.log +0 -15
  1478. data/spec/support/logs/Dispatcher - 26792-41661.log +0 -21
  1479. data/spec/support/logs/Dispatcher - 26801-14384.log +0 -25
  1480. data/spec/support/logs/Dispatcher - 26810-2591.log +0 -15
  1481. data/spec/support/logs/Dispatcher - 26846-14591.log +0 -17
  1482. data/spec/support/logs/Dispatcher - 26855-15708.log +0 -21
  1483. data/spec/support/logs/Dispatcher - 26864-2062.log +0 -13
  1484. data/spec/support/logs/Dispatcher - 26877-14471.log +0 -21
  1485. data/spec/support/logs/Dispatcher - 26886-49795.log +0 -25
  1486. data/spec/support/logs/Dispatcher - 26895-21093.log +0 -15
  1487. data/spec/support/logs/Dispatcher - 26931-30049.log +0 -17
  1488. data/spec/support/logs/Dispatcher - 26940-34273.log +0 -21
  1489. data/spec/support/logs/Dispatcher - 26949-30040.log +0 -13
  1490. data/spec/support/logs/Dispatcher - 26962-8152.log +0 -17
  1491. data/spec/support/logs/Dispatcher - 26971-53062.log +0 -21
  1492. data/spec/support/logs/Dispatcher - 26980-7548.log +0 -13
  1493. data/spec/support/logs/Dispatcher - 2737-20989.log +0 -19
  1494. data/spec/support/logs/Dispatcher - 2746-5423.log +0 -21
  1495. data/spec/support/logs/Dispatcher - 2755-53393.log +0 -15
  1496. data/spec/support/logs/Dispatcher - 27615-41812.log +0 -19
  1497. data/spec/support/logs/Dispatcher - 27624-43683.log +0 -21
  1498. data/spec/support/logs/Dispatcher - 27633-11593.log +0 -15
  1499. data/spec/support/logs/Dispatcher - 27658-12186.log +0 -21
  1500. data/spec/support/logs/Dispatcher - 27667-15575.log +0 -25
  1501. data/spec/support/logs/Dispatcher - 27676-17207.log +0 -15
  1502. data/spec/support/logs/Dispatcher - 27712-2233.log +0 -17
  1503. data/spec/support/logs/Dispatcher - 27721-3842.log +0 -21
  1504. data/spec/support/logs/Dispatcher - 27730-22695.log +0 -13
  1505. data/spec/support/logs/Dispatcher - 27743-8364.log +0 -21
  1506. data/spec/support/logs/Dispatcher - 27752-6140.log +0 -25
  1507. data/spec/support/logs/Dispatcher - 27761-25015.log +0 -15
  1508. data/spec/support/logs/Dispatcher - 27797-9270.log +0 -17
  1509. data/spec/support/logs/Dispatcher - 2780-58168.log +0 -21
  1510. data/spec/support/logs/Dispatcher - 27806-48623.log +0 -21
  1511. data/spec/support/logs/Dispatcher - 27815-58778.log +0 -13
  1512. data/spec/support/logs/Dispatcher - 27828-29742.log +0 -17
  1513. data/spec/support/logs/Dispatcher - 27837-46211.log +0 -21
  1514. data/spec/support/logs/Dispatcher - 27846-16143.log +0 -13
  1515. data/spec/support/logs/Dispatcher - 2789-29375.log +0 -25
  1516. data/spec/support/logs/Dispatcher - 2798-10983.log +0 -15
  1517. data/spec/support/logs/Dispatcher - 2836-2354.log +0 -17
  1518. data/spec/support/logs/Dispatcher - 2845-65341.log +0 -21
  1519. data/spec/support/logs/Dispatcher - 2854-18936.log +0 -13
  1520. data/spec/support/logs/Dispatcher - 2867-51979.log +0 -21
  1521. data/spec/support/logs/Dispatcher - 2876-21086.log +0 -25
  1522. data/spec/support/logs/Dispatcher - 2887-17393.log +0 -15
  1523. data/spec/support/logs/Dispatcher - 2930-37394.log +0 -17
  1524. data/spec/support/logs/Dispatcher - 2943-46737.log +0 -21
  1525. data/spec/support/logs/Dispatcher - 2956-37866.log +0 -13
  1526. data/spec/support/logs/Dispatcher - 2976-21012.log +0 -17
  1527. data/spec/support/logs/Dispatcher - 2990-48082.log +0 -21
  1528. data/spec/support/logs/Dispatcher - 2999-16391.log +0 -13
  1529. data/spec/support/logs/Instance - 2204-45164.error.log +0 -356
  1530. data/spec/support/logs/Instance - 2475-49789.error.log +0 -356
  1531. data/spec/support/logs/Instance - 2509-39450.error.log +0 -455
  1532. data/spec/support/logs/Instance - 2533-5785.error.log +0 -354
  1533. data/spec/support/logs/Instance - 2539-42941.error.log +0 -356
  1534. data/spec/support/logs/Instance - 26178-57631.error.log +0 -324
  1535. data/spec/support/logs/Instance - 26458-60253.error.log +0 -326
  1536. data/spec/support/logs/Instance - 26514-44685.error.log +0 -423
  1537. data/spec/support/logs/Instance - 26538-43093.error.log +0 -322
  1538. data/spec/support/logs/Instance - 26544-52217.error.log +0 -328
  1539. data/spec/support/logs/Instance - 26682-37056.error.log +0 -345
  1540. data/spec/support/logs/Instance - 2669-56818.error.log +0 -354
  1541. data/spec/support/logs/Instance - 27547-3928.error.log +0 -309
  1542. data/spec/support/servers/arachni/element/capabilities/auditable/rdiff.rb +0 -162
  1543. data/spec/support/servers/arachni/element/capabilities/auditable/timeout.rb +0 -34
  1544. data/spec/support/servers/arachni/http.rb +0 -127
  1545. data/spec/support/servers/arachni/http_auth.rb +0 -9
  1546. data/spec/support/servers/arachni/module/auditor.rb +0 -136
  1547. data/spec/support/servers/arachni/rpc/server/framework_simple.rb +0 -30
  1548. data/spec/support/servers/arachni/spider.rb +0 -234
  1549. data/spec/support/servers/arachni/spider_https.rb +0 -58
  1550. data/spec/support/servers/modules/audit/code_injection.rb +0 -139
  1551. data/spec/support/servers/modules/audit/code_injection_timing.rb +0 -110
  1552. data/spec/support/servers/modules/audit/file_inclusion.rb +0 -202
  1553. data/spec/support/servers/modules/audit/ldapi.rb +0 -73
  1554. data/spec/support/servers/modules/audit/os_cmd_injection.rb +0 -140
  1555. data/spec/support/servers/modules/audit/os_cmd_injection_timing.rb +0 -103
  1556. data/spec/support/servers/modules/audit/path_traversal.rb +0 -197
  1557. data/spec/support/servers/modules/audit/response_splitting.rb +0 -114
  1558. data/spec/support/servers/modules/audit/session_fixation.rb +0 -87
  1559. data/spec/support/servers/modules/audit/source_code_disclosure.rb +0 -95
  1560. data/spec/support/servers/modules/audit/sqli.rb +0 -118
  1561. data/spec/support/servers/modules/audit/sqli_blind_timing.rb +0 -121
  1562. data/spec/support/servers/modules/audit/unvalidated_redirect.rb +0 -115
  1563. data/spec/support/servers/modules/audit/xpath.rb +0 -111
  1564. data/spec/support/servers/modules/audit/xss.rb +0 -152
  1565. data/spec/support/servers/modules/audit/xss_event.rb +0 -80
  1566. data/spec/support/servers/modules/audit/xss_script_tag.rb +0 -73
  1567. data/spec/support/servers/modules/module_server.rb +0 -14
  1568. data/spec/support/servers/modules/recon/backdoors.rb +0 -4
  1569. data/spec/support/servers/modules/recon/backup_files.rb +0 -28
  1570. data/spec/support/servers/modules/recon/common_directories.rb +0 -6
  1571. data/spec/support/servers/modules/recon/common_files.rb +0 -6
  1572. data/spec/support/servers/modules/recon/directory_listing.rb +0 -30
  1573. data/spec/support/servers/modules/recon/grep/emails.rb +0 -21
  1574. data/spec/support/servers/modules/recon/grep/insecure_cookies.rb +0 -21
  1575. data/spec/support/servers/modules/recon/grep/mixed_resource.rb +0 -83
  1576. data/spec/support/servers/modules/recon/grep/password_autocomplete.rb +0 -33
  1577. data/spec/support/servers/modules/recon/grep/unencrypted_password_forms.rb +0 -33
  1578. data/spec/support/servers/modules/recon/http_put.rb +0 -7
  1579. data/spec/support/servers/modules/recon/interesting_responses.rb +0 -5
  1580. data/spec/support/servers/modules/recon/webdav.rb +0 -25
  1581. data/spec/support/servers/modules/recon/x_forwarded_for_access_restriction_bypass.rb +0 -16
  1582. data/spec/support/servers/plugins/profiler.rb +0 -82
  1583. data/spec/support/servers/plugins/rescan.rb +0 -31
  1584. data/spec/support/shared/module.rb +0 -162
  1585. data/spec/support/shared/reports.rb +0 -47
@@ -1,74 +1,65 @@
1
1
  # encoding: utf-8
2
2
 
3
3
  =begin
4
- Copyright 2010-2014 Tasos Laskos <tasos.laskos@gmail.com>
4
+ Copyright 2010-2014 Tasos Laskos <tasos.laskos@arachni-scanner.com>
5
5
 
6
- Licensed under the Apache License, Version 2.0 (the "License");
7
- you may not use this file except in compliance with the License.
8
- You may obtain a copy of the License at
9
-
10
- http://www.apache.org/licenses/LICENSE-2.0
11
-
12
- Unless required by applicable law or agreed to in writing, software
13
- distributed under the License is distributed on an "AS IS" BASIS,
14
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- See the License for the specific language governing permissions and
16
- limitations under the License.
6
+ This file is part of the Arachni Framework project and is subject to
7
+ redistribution and commercial restrictions. Please see the Arachni Framework
8
+ web site for more information on licensing and terms of use.
17
9
  =end
18
10
 
19
11
  require 'rubygems'
12
+ require 'monitor'
20
13
  require 'bundler/setup'
21
14
 
22
15
  require 'ap'
23
16
  require 'pp'
24
17
 
25
- require File.expand_path( File.dirname( __FILE__ ) ) + '/options'
18
+ require_relative 'options'
26
19
 
27
20
  module Arachni
28
21
 
29
- lib = Options.dir['lib']
22
+ lib = Options.paths.lib
30
23
  require lib + 'version'
31
24
  require lib + 'ruby'
32
25
  require lib + 'error'
33
- require lib + 'support'
26
+ require lib + 'scope'
34
27
  require lib + 'utilities'
28
+ require lib + 'support'
35
29
  require lib + 'uri'
36
- require lib + 'component/manager'
30
+ require lib + 'component'
37
31
  require lib + 'platform'
38
- require lib + 'spider'
32
+ require lib + 'http'
33
+ require lib + 'snapshot'
39
34
  require lib + 'parser'
40
35
  require lib + 'issue'
41
- require lib + 'module'
36
+ require lib + 'check'
42
37
  require lib + 'plugin'
43
- require lib + 'audit_store'
44
- require lib + 'http'
45
38
  require lib + 'report'
39
+ require lib + 'reporter'
46
40
  require lib + 'session'
47
41
  require lib + 'trainer'
42
+ require lib + 'browser_cluster'
48
43
 
49
- require Options.dir['mixins'] + 'progress_bar'
50
-
51
- #
52
- # The Framework class ties together all the components.
44
+ # The Framework class ties together all the systems.
53
45
  #
54
- # It's the brains of the operation, it bosses the rest of the classes around.
55
- # It runs the audit, loads modules and reports and runs them according to
46
+ # It's the brains of the operation, it bosses the rest of the subsystems around.
47
+ # It runs the audit, loads checks and reports and runs them according to
56
48
  # user options.
57
49
  #
58
- # @author Tasos "Zapotek" Laskos <tasos.laskos@gmail.com>
59
- #
50
+ # @author Tasos "Zapotek" Laskos <tasos.laskos@arachni-scanner.com>
60
51
  class Framework
61
- #
62
- # include the output interface but try to use it as little as possible
63
- #
64
- # the UI classes should take care of communicating with the user
65
- #
66
52
  include UI::Output
67
53
 
68
54
  include Utilities
69
- include Mixins::Observable
55
+ include Support::Mixins::Observable
56
+
57
+ # @!method on_page_audit( &block )
58
+ advertise :on_page_audit
59
+
60
+ # @!method after_page_audit( &block )
61
+ advertise :after_page_audit
70
62
 
71
- #
72
63
  # {Framework} error namespace.
73
64
  #
74
65
  # All {Framework} errors inherit from and live under it.
@@ -76,97 +67,87 @@ class Framework
76
67
  # When I say Framework I mean the {Framework} class, not the
77
68
  # entire Arachni Framework.
78
69
  #
79
- # @author Tasos "Zapotek" Laskos <tasos.laskos@gmail.com>
80
- #
70
+ # @author Tasos "Zapotek" Laskos <tasos.laskos@arachni-scanner.com>
81
71
  class Error < Arachni::Error
82
72
  end
83
73
 
84
- # The version of this class.
85
- REVISION = '0.2.8'
86
-
87
74
  # How many times to request a page upon failure.
88
75
  AUDIT_PAGE_MAX_TRIES = 5
89
76
 
90
- # @return [Options] Instance options
91
- attr_reader :opts
77
+ # @return [Options]
78
+ # System options
79
+ attr_reader :options
92
80
 
93
- # @return [Arachni::Report::Manager]
94
- attr_reader :reports
81
+ # @return [Arachni::Reporter::Manager]
82
+ attr_reader :reporters
95
83
 
96
- # @return [Arachni::Module::Manager]
97
- attr_reader :modules
84
+ # @return [Arachni::Check::Manager]
85
+ attr_reader :checks
98
86
 
99
87
  # @return [Arachni::Plugin::Manager]
100
88
  attr_reader :plugins
101
89
 
102
- # @return [Session] Web application session manager.
90
+ # @return [Session]
91
+ # Web application session manager.
103
92
  attr_reader :session
104
93
 
105
- # @return [Spider] Web application spider.
106
- attr_reader :spider
107
-
108
94
  # @return [Arachni::HTTP]
109
95
  attr_reader :http
110
96
 
111
- # @return [Array] URLs of all discovered pages.
112
- attr_reader :sitemap
113
-
114
97
  # @return [Trainer]
115
98
  attr_reader :trainer
116
99
 
117
- # @return [Integer] Total number of pages added to their audit queue.
118
- attr_reader :page_queue_total_size
119
-
120
- # @return [Integer] Total number of urls added to their audit queue.
121
- attr_reader :url_queue_total_size
122
-
123
100
  # @return [Array<String>]
124
101
  # Page URLs which elicited no response from the server and were not audited.
125
102
  # Not determined by HTTP status codes, we're talking network failures here.
126
103
  attr_reader :failures
127
104
 
105
+ # @param [String] afs
106
+ # Path to an `.afs.` (Arachni Framework Snapshot) file created by {#suspend}.
128
107
  #
129
- # @param [Options] opts
108
+ # @return [Framework]
109
+ # Restored instance.
110
+ def self.restore( afs, &block )
111
+ framework = new
112
+ framework.restore( afs )
113
+
114
+ if block_given?
115
+ begin
116
+ block.call framework
117
+ ensure
118
+ framework.clean_up
119
+ framework.reset
120
+ end
121
+ end
122
+
123
+ framework
124
+ end
125
+
126
+ # @param [Options] options
130
127
  # @param [Block] block
131
128
  # Block to be passed a {Framework} instance which will then be {#reset}.
132
- #
133
- def initialize( opts = Arachni::Options.instance, &block )
129
+ def initialize( options = Arachni::Options.instance, &block )
130
+ super()
134
131
 
135
132
  Encoding.default_external = 'BINARY'
136
133
  Encoding.default_internal = 'BINARY'
137
134
 
138
- @opts = opts
135
+ @options = options
139
136
 
140
- @modules = Module::Manager.new( self )
141
- @reports = Report::Manager.new( @opts )
142
- @plugins = Plugin::Manager.new( self )
137
+ @checks = Check::Manager.new( self )
138
+ @reporters = Reporter::Manager.new
139
+ @plugins = Plugin::Manager.new( self )
143
140
 
144
- @session = Session.new( @opts )
145
- reset_spider
146
- @http = HTTP.instance
141
+ reset_session
142
+ @http = HTTP::Client.instance
147
143
 
148
144
  reset_trainer
149
145
 
150
- # will store full-fledged pages generated by the Trainer since these
151
- # may not be be accessible simply by their URL
152
- @page_queue = Support::Database::Queue.new
153
- @page_queue_total_size = 0
146
+ # Deep clone the redundancy rules to preserve their original counters
147
+ # for the reports.
148
+ @orig_redundant = options.scope.redundant_path_patterns.deep_clone
154
149
 
155
- # will hold paths found by the spider in order to be converted to pages
156
- # and ultimately audited by the modules
157
- @url_queue = Queue.new
158
- @url_queue_total_size = 0
159
-
160
- # deep clone the redundancy rules to preserve their counter
161
- # for the reports
162
- @orig_redundant = @opts.redundant.deep_clone
163
-
164
- @running = false
165
- @status = :ready
166
- @paused = []
167
-
168
- @auditmap = []
169
- @sitemap = []
150
+ state.status = :ready
170
151
 
171
152
  @current_url = ''
172
153
 
@@ -174,353 +155,402 @@ class Framework
174
155
  @failures = []
175
156
  @retries = {}
176
157
 
158
+ @after_page_audit_blocks = []
159
+
160
+ # Little helper to run a piece of code and reset the framework to be
161
+ # ready to be reused.
177
162
  if block_given?
178
- block.call self
179
- reset
163
+ begin
164
+ block.call self
165
+ ensure
166
+ clean_up
167
+ reset
168
+ end
180
169
  end
181
170
  end
182
171
 
183
- #
172
+ # @return [Integer]
173
+ # Total number of pages added to the {#push_to_page_queue page audit queue}.
174
+ def page_queue_total_size
175
+ data.page_queue_total_size
176
+ end
177
+
178
+ # @return [Integer]
179
+ # Total number of URLs added to the {#push_to_url_queue URL audit queue}.
180
+ def url_queue_total_size
181
+ data.url_queue_total_size
182
+ end
183
+
184
+ # @return [Hash<String, Integer>]
185
+ # List of crawled URLs with their HTTP codes.
186
+ def sitemap
187
+ data.sitemap
188
+ end
189
+
190
+ # @return [BrowserCluster, nil]
191
+ # A lazy-loaded browser cluster or `nil` if
192
+ # {OptionGroups::BrowserCluster#pool_size} or
193
+ # {OptionGroups::Scope#dom_depth_limit} are 0 or not
194
+ # {#host_has_browser?}.
195
+ def browser_cluster
196
+ return if options.browser_cluster.pool_size == 0 ||
197
+ Options.scope.dom_depth_limit == 0 || !host_has_browser?
198
+
199
+ # Initialization may take a while so since we lazy load this make sure
200
+ # that only one thread gets to this code at a time.
201
+ synchronize { @browser_cluster ||= BrowserCluster.new }
202
+ end
203
+
184
204
  # Starts the scan.
185
205
  #
186
206
  # @param [Block] block
187
- # A block to call after the audit has finished but before running the reports.
188
- #
207
+ # A block to call after the audit has finished but before running {#reporters}.
189
208
  def run( &block )
190
209
  prepare
210
+ handle_signals
211
+ return if aborted?
191
212
 
192
- # catch exceptions so that if something breaks down or the user opted to
193
- # exit the reports will still run with whatever results Arachni managed to gather
213
+ # Catch exceptions so that if something breaks down or the user opted to
214
+ # exit the reporters will still run with whatever results Arachni managed
215
+ # to gather.
194
216
  exception_jail( false ){ audit }
217
+ # print_with_statistics
218
+
219
+ return if aborted?
220
+ return if suspended?
195
221
 
196
222
  clean_up
197
223
  exception_jail( false ){ block.call } if block_given?
198
- @status = :done
199
-
200
- # run reports
201
- @reports.run( audit_store ) if !@reports.empty?
224
+ state.status = :done
202
225
 
203
226
  true
204
227
  end
205
228
 
206
- #
207
- # Runs loaded modules against a given `page`
208
- #
209
- # It will audit just the given page and not use the {Trainer} -- i.e. ignore
210
- # any new elements that might appear as a result.
229
+ # @return [State::Framework]
230
+ def state
231
+ State.framework
232
+ end
233
+
234
+ # @return [Data::Framework]
235
+ def data
236
+ Data.framework
237
+ end
238
+
239
+ # @note Will update the {HTTP::Client#cookie_jar} with {Page#cookie_jar}.
240
+ # @note It will audit just the given `page` and not any subsequent pages
241
+ # discovered by the {Trainer} -- i.e. ignore any new elements that might
242
+ # appear as a result.
243
+ # @note It will pass the `page` to the {BrowserCluster} for analysis if the
244
+ # {Page::Scope#dom_depth_limit_reached? DOM depth limit} has
245
+ # not been reached and push resulting pages to {#push_to_page_queue} but
246
+ # will not audit those pages either.
211
247
  #
212
248
  # @param [Page] page
213
- #
249
+ # Runs loaded checks against `page`
214
250
  def audit_page( page )
215
251
  return if !page
216
252
 
217
- if skip_page? page
218
- print_info "Ignoring page due to exclusion criteria: #{page.url}"
253
+ if page.scope.out?
254
+ print_info "Ignoring page due to exclusion criteria: #{page.dom.url}"
219
255
  return false
220
256
  end
221
257
 
222
- @auditmap << page.url
223
- @sitemap |= @auditmap
224
- @sitemap.uniq!
258
+ # Initialize the BrowserCluster.
259
+ browser_cluster
260
+
261
+ state.audited_page_count += 1
262
+ add_to_sitemap( page )
263
+ sitemap.merge!( browser_sitemap )
225
264
 
226
265
  print_line
227
- print_status "Auditing: [HTTP: #{page.code}] #{page.url}"
266
+ print_status "[HTTP: #{page.code}] #{page.dom.url}"
267
+ # print_object_space
268
+ # print_with_statistics
228
269
 
229
270
  if page.platforms.any?
230
271
  print_info "Identified as: #{page.platforms.to_a.join( ', ' )}"
231
272
  end
232
273
 
233
- call_on_audit_page( page )
234
-
235
- @current_url = page.url.to_s
236
-
237
- @modules.schedule.each do |mod|
238
- wait_if_paused
239
- run_module_against_page( mod, page )
274
+ if crawl?
275
+ pushed = push_paths_from_page( page )
276
+ print_info "Analysis resulted in #{pushed.size} usable paths."
240
277
  end
241
278
 
242
- harvest_http_responses
279
+ if host_has_browser?
280
+ print_info "DOM depth: #{page.dom.depth} (Limit: #{options.scope.dom_depth_limit})"
243
281
 
244
- if !Module::Auditor.timeout_candidates.empty?
245
- print_line
246
- print_status "Verifying timeout-analysis candidates for: #{page.url}"
247
- print_info '---------------------------------------'
248
- Module::Auditor.timeout_audit_run
282
+ if page.dom.transitions.any?
283
+ print_info ' Transitions:'
284
+ page.dom.print_transitions( method(:print_info), ' ' )
285
+ end
249
286
  end
250
287
 
251
- true
252
- end
253
-
254
- def on_audit_page( &block )
255
- add_on_audit_page( &block )
256
- end
257
- alias :on_run_mods :on_audit_page
258
-
259
- # @return [Bool]
260
- # `true` if the {Options#link_count_limit} has been reached, `false`
261
- # otherwise.
262
- def link_count_limit_reached?
263
- @opts.link_count_limit_reached? @sitemap.size
264
- end
288
+ notify_on_page_audit( page )
265
289
 
266
- #
267
- # Returns the following framework stats:
268
- #
269
- # * `:requests` -- HTTP request count
270
- # * `:responses` -- HTTP response count
271
- # * `:time_out_count` -- Amount of timed-out requests
272
- # * `:time` -- Amount of running time
273
- # * `:avg` -- Average requests per second
274
- # * `:sitemap_size` -- Number of discovered pages
275
- # * `:auditmap_size` -- Number of audited pages
276
- # * `:progress` -- Progress percentage
277
- # * `:curr_res_time` -- Average response time for the current burst of requests
278
- # * `:curr_res_cnt` -- Amount of responses for the current burst
279
- # * `:curr_avg` -- Average requests per second for the current burst
280
- # * `:average_res_time` -- Average response time
281
- # * `:max_concurrency` -- Current maximum concurrency of HTTP requests
282
- # * `:current_page` -- URL of the currently audited page
283
- # * `:eta` -- Estimated time of arrival i.e. estimated remaining time
284
- #
285
- # @param [Bool] refresh_time updates the running time of the audit
286
- # (usefully when you want stats while paused without messing with the clocks)
287
- #
288
- # @param [Bool] override_refresh
289
- #
290
- # @return [Hash]
291
- #
292
- def stats( refresh_time = false, override_refresh = false )
293
- req_cnt = http.request_count
294
- res_cnt = http.response_count
290
+ @current_url = page.dom.url.to_s
295
291
 
296
- @opts.start_datetime = Time.now if !@opts.start_datetime
292
+ http.update_cookies( page.cookie_jar )
293
+ perform_browser_analysis( page )
297
294
 
298
- sitemap_sz = @sitemap.size
299
- auditmap_sz = @auditmap.size
295
+ # Run checks which **don't** benefit from fingerprinting first, so that
296
+ # we can use the responses of their HTTP requests to fingerprint the
297
+ # webapp platforms, so that the checks which **do** benefit from knowing
298
+ # the remote platforms can run more efficiently.
299
+ ran = false
300
+ @checks.without_platforms.values.each do |check|
301
+ ran = true
302
+ check_page( check, page )
303
+ end
304
+ harvest_http_responses if ran
305
+ run_http = ran
300
306
 
301
- if( !refresh_time || auditmap_sz == sitemap_sz ) && !override_refresh
302
- @opts.delta_time ||= Time.now - @opts.start_datetime
303
- else
304
- @opts.delta_time = Time.now - @opts.start_datetime
307
+ ran = false
308
+ @checks.with_platforms.values.each do |check|
309
+ ran = true
310
+ check_page( check, page )
305
311
  end
312
+ harvest_http_responses if ran
313
+ run_http ||= ran
306
314
 
307
- avg = 0
308
- avg = (res_cnt / @opts.delta_time).to_i if res_cnt > 0
315
+ if Check::Auditor.has_timeout_candidates?
316
+ print_line
317
+ print_status "Verifying timeout-analysis candidates for: #{page.dom.url}"
318
+ print_info '---------------------------------------'
319
+ Check::Auditor.timeout_audit_run
320
+ run_http = true
321
+ end
309
322
 
310
- # We need to remove URLs that lead to redirects from the sitemap
311
- # when calculating the progress %.
312
- #
313
- # This is because even though these URLs are valid webapp paths
314
- # they are not actual pages and thus can't be audited;
315
- # so the sitemap and auditmap will never match and the progress will
316
- # never get to 100% which may confuse users.
317
- #
318
- sitemap_sz -= spider.redirects.size
319
- sitemap_sz = 0 if sitemap_sz < 0
323
+ # Makes it easier on the GC.
324
+ page.clear_cache
320
325
 
321
- # Progress of audit is calculated as:
322
- # amount of audited pages / amount of all discovered pages
323
- progress = (Float( auditmap_sz ) / sitemap_sz) * 100
326
+ notify_after_page_audit( page )
327
+ run_http
328
+ end
324
329
 
325
- progress = Float( sprintf( '%.2f', progress ) ) rescue 0.0
330
+ # @return [Bool]
331
+ # `true` if the environment has a browser, `false` otherwise.
332
+ def host_has_browser?
333
+ Browser.has_executable?
334
+ end
326
335
 
327
- # Sometimes progress may slightly exceed 100% which can cause a few
328
- # strange stuff to happen.
329
- progress = 100.0 if progress > 100.0
336
+ # @return [Bool]
337
+ # `true` if the {OptionGroups::Scope#page_limit} has been reached,
338
+ # `false` otherwise.
339
+ def page_limit_reached?
340
+ options.scope.page_limit_reached?( sitemap.size )
341
+ end
330
342
 
331
- # Make sure to keep weirdness at bay.
332
- progress = 0.0 if progress < 0.0
343
+ def crawl?
344
+ options.scope.crawl? && options.scope.restrict_paths.empty?
345
+ end
333
346
 
334
- pb = Mixins::ProgressBar.eta( progress, @opts.start_datetime )
347
+ # @return [Bool]
348
+ # `true` if the framework can process more pages, `false` is scope limits
349
+ # have been reached.
350
+ def accepts_more_pages?
351
+ crawl? && !page_limit_reached?
352
+ end
335
353
 
354
+ # @return [Hash]
355
+ #
356
+ # Framework statistics:
357
+ #
358
+ # * `:http` -- {HTTP::Client#statistics}
359
+ # * `:runtime` -- Scan runtime in seconds.
360
+ # * `:found_pages` -- Number of discovered pages.
361
+ # * `:audited_pages` -- Number of audited pages.
362
+ # * `:current_page` -- URL of the currently audited page.
363
+ # * `:status` -- {#status}
364
+ # * `:messages` -- {#status_messages}
365
+ def statistics
336
366
  {
337
- requests: req_cnt,
338
- responses: res_cnt,
339
- time_out_count: http.time_out_count,
340
- time: audit_store.delta_time,
341
- avg: avg,
342
- sitemap_size: auditstore_sitemap.size,
343
- auditmap_size: auditmap_sz,
344
- progress: progress,
345
- curr_res_time: http.curr_res_time,
346
- curr_res_cnt: http.curr_res_cnt,
347
- curr_avg: http.curr_res_per_second,
348
- average_res_time: http.average_res_time,
349
- max_concurrency: http.max_concurrency,
350
- current_page: @current_url,
351
- eta: pb
367
+ http: http.statistics,
368
+ runtime: @start_datetime ? Time.now - @start_datetime : 0,
369
+ found_pages: sitemap.size,
370
+ audited_pages: state.audited_page_count,
371
+ current_page: @current_url
352
372
  }
353
373
  end
354
374
 
355
- #
356
- # Pushes a page to the page audit queue and updates {#page_queue_total_size}
357
- #
375
+ # @return [Array<String>]
376
+ # Messages providing more information about the current {#status} of
377
+ # the framework.
378
+ def status_messages
379
+ state.status_messages
380
+ end
381
+
358
382
  # @param [Page] page
383
+ # Page to push to the page audit queue -- increases {#page_queue_total_size}
359
384
  #
360
385
  # @return [Bool]
361
386
  # `true` if push was successful, `false` if the `page` matched any
362
- # exclusion criteria.
363
- #
364
- def push_to_page_queue( page )
365
- return false if skip_page? page
387
+ # exclusion criteria or has already been seen.
388
+ def push_to_page_queue( page, force = false )
389
+ return false if !force && (!accepts_more_pages? || state.page_seen?( page ) ||
390
+ page.scope.out? || page.scope.redundant?)
391
+
392
+ # We want to update from the already loaded page cache (if there is one)
393
+ # as we have to store the page anyways (needs to go through Browser analysis)
394
+ # and it's not worth the resources to parse its elements.
395
+ #
396
+ # We're basically doing this to give the Browser and Trainer a better
397
+ # view of what elements have been seen, so that they won't feed us pages
398
+ # with elements that they think are new, but have been provided to us by
399
+ # some other component; however, it wouldn't be the end of the world if
400
+ # that were to happen.
401
+ ElementFilter.update_from_page_cache page
366
402
 
367
- @page_queue << page
368
- @page_queue_total_size += 1
403
+ data.push_to_page_queue page
404
+ state.page_seen page
369
405
 
370
- @sitemap |= [page.url]
371
406
  true
372
407
  end
373
408
 
374
- #
375
- # Pushes a URL to the URL audit queue and updates {#url_queue_total_size}
376
- #
377
409
  # @param [String] url
410
+ # URL to push to the audit queue -- increases {#url_queue_total_size}
378
411
  #
379
412
  # @return [Bool]
380
413
  # `true` if push was successful, `false` if the `url` matched any
381
- # exclusion criteria.
382
- #
383
- def push_to_url_queue( url )
384
- return false if skip_path? url
414
+ # exclusion criteria or has already been seen.
415
+ def push_to_url_queue( url, force = false )
416
+ return if !force && !accepts_more_pages?
385
417
 
386
- abs = to_absolute( url )
418
+ url = to_absolute( url ) || url
419
+ if state.url_seen?( url ) || skip_path?( url ) || redundant_path?( url )
420
+ return false
421
+ end
387
422
 
388
- @url_queue.push( abs ? abs : url )
389
- @url_queue_total_size += 1
423
+ data.push_to_url_queue url
424
+ state.url_seen url
390
425
 
391
- @sitemap |= [url]
392
- false
426
+ true
393
427
  end
394
428
 
395
- #
396
- # @return [AuditStore] Scan results.
397
- #
398
- # @see AuditStore
399
- #
400
- def audit_store
401
- opts = @opts.to_hash.deep_clone
429
+ # @return [Report]
430
+ # Scan results.
431
+ def report
432
+ opts = options.to_hash.deep_clone
402
433
 
403
434
  # restore the original redundancy rules and their counters
404
- opts['redundant'] = @orig_redundant
405
- opts['mods'] = @modules.keys
406
-
407
- AuditStore.new(
408
- version: version,
409
- revision: revision,
410
- options: opts,
411
- sitemap: (auditstore_sitemap || []).sort,
412
- issues: @modules.results,
413
- plugins: @plugins.results
435
+ opts[:scope][:redundant_path_patterns] = @orig_redundant
436
+
437
+ Report.new(
438
+ options: options,
439
+ sitemap: sitemap,
440
+ issues: Data.issues.sort,
441
+ plugins: @plugins.results,
442
+ start_datetime: @start_datetime,
443
+ finish_datetime: @finish_datetime
414
444
  )
415
445
  end
416
- alias :auditstore :audit_store
417
446
 
447
+ # Runs a reporter component and returns the contents of the generated report.
418
448
  #
419
- # Runs a report component and returns the contents of the generated report.
420
- #
421
- # Only accepts reports which support an `outfile` option.
449
+ # Only accepts reporters which support an `outfile` option.
422
450
  #
423
451
  # @param [String] name
424
- # Name of the report component to run, as presented by {#list_reports}'s
452
+ # Name of the reporter component to run, as presented by {#list_reporters}'s
425
453
  # `:shortname` key.
426
- # @param [AuditStore] external_report
454
+ # @param [Report] external_report
427
455
  # Report to use -- defaults to the local one.
428
456
  #
429
- # @return [String] Scan report.
457
+ # @return [String]
458
+ # Scan report.
430
459
  #
431
460
  # @raise [Component::Error::NotFound]
432
- # If the given report name doesn't correspond to a valid report component.
461
+ # If the given reporter name doesn't correspond to a valid reporter component.
433
462
  #
434
463
  # @raise [Component::Options::Error::Invalid]
435
- # If the requested report doesn't format the scan results as a String.
436
- #
437
- def report_as( name, external_report = auditstore )
438
- if !@reports.available.include?( name.to_s )
439
- fail Component::Error::NotFound, "Report '#{name}' could not be found."
464
+ # If the requested reporter doesn't format the scan results as a String.
465
+ def report_as( name, external_report = report )
466
+ if !@reporters.available.include?( name.to_s )
467
+ fail Component::Error::NotFound, "Reporter '#{name}' could not be found."
440
468
  end
441
469
 
442
- loaded = @reports.loaded
470
+ loaded = @reporters.loaded
443
471
  begin
444
- @reports.clear
472
+ @reporters.clear
445
473
 
446
- if !@reports[name].has_outfile?
474
+ if !@reporters[name].has_outfile?
447
475
  fail Component::Options::Error::Invalid,
448
- "Report '#{name}' cannot format the audit results as a String."
476
+ "Reporter '#{name}' cannot format the audit results as a String."
449
477
  end
450
478
 
451
- outfile = "/#{Dir.tmpdir}/arachn_report_as.#{name}"
452
- @reports.run_one( name, external_report, 'outfile' => outfile )
479
+ outfile = "#{Dir.tmpdir}/#{generate_token}"
480
+ @reporters.run( name, external_report, outfile: outfile )
453
481
 
454
- IO.read( outfile )
482
+ IO.binread( outfile )
455
483
  ensure
456
484
  File.delete( outfile ) if outfile
457
- @reports.clear
458
- @reports.load loaded
485
+ @reporters.clear
486
+ @reporters.load loaded
459
487
  end
460
488
  end
461
489
 
462
- # @return [Array<Hash>] Information about all available modules.
463
- def list_modules
464
- loaded = @modules.loaded
490
+ # @return [Array<Hash>]
491
+ # Information about all available {Checks}.
492
+ def list_checks( patterns = nil )
493
+ loaded = @checks.loaded
465
494
 
466
495
  begin
467
- @modules.clear
468
- @modules.available.map do |name|
469
- path = @modules.name_to_path( name )
470
- next if !lsmod_match?( path )
496
+ @checks.clear
497
+ @checks.available.map do |name|
498
+ path = @checks.name_to_path( name )
499
+ next if !list_check?( path, patterns )
471
500
 
472
- @modules[name].info.merge(
473
- mod_name: name,
501
+ @checks[name].info.merge(
474
502
  shortname: name,
475
- author: [@modules[name].info[:author]].
503
+ author: [@checks[name].info[:author]].
476
504
  flatten.map { |a| a.strip },
477
- path: path.strip
505
+ path: path.strip,
506
+ platforms: @checks[name].platforms,
507
+ elements: @checks[name].elements
478
508
  )
479
509
  end.compact
480
510
  ensure
481
- @modules.clear
482
- @modules.load loaded
511
+ @checks.clear
512
+ @checks.load loaded
483
513
  end
484
514
  end
485
- alias :lsmod :list_modules
486
515
 
487
- # @return [Array<Hash>] Information about all available reports.
488
- def list_reports
489
- loaded = @reports.loaded
516
+ # @return [Array<Hash>]
517
+ # Information about all available {Reporters}.
518
+ def list_reporters( patterns = nil )
519
+ loaded = @reporters.loaded
490
520
 
491
521
  begin
492
- @reports.clear
493
- @reports.available.map do |report|
494
- path = @reports.name_to_path( report )
495
- next if !lsrep_match?( path )
522
+ @reporters.clear
523
+ @reporters.available.map do |report|
524
+ path = @reporters.name_to_path( report )
525
+ next if !list_reporter?( path, patterns )
496
526
 
497
- @reports[report].info.merge(
498
- rep_name: report,
527
+ @reporters[report].info.merge(
528
+ options: @reporters[report].info[:options] || [],
499
529
  shortname: report,
500
530
  path: path,
501
- author: [@reports[report].info[:author]].
531
+ author: [@reporters[report].info[:author]].
502
532
  flatten.map { |a| a.strip }
503
533
  )
504
534
  end.compact
505
535
  ensure
506
- @reports.clear
507
- @reports.load loaded
536
+ @reporters.clear
537
+ @reporters.load loaded
508
538
  end
509
539
  end
510
- alias :lsrep :list_reports
511
540
 
512
- # @return [Array<Hash>] Information about all available plugins.
513
- def list_plugins
541
+ # @return [Array<Hash>]
542
+ # Information about all available {Plugins}.
543
+ def list_plugins( patterns = nil )
514
544
  loaded = @plugins.loaded
515
545
 
516
546
  begin
517
547
  @plugins.clear
518
548
  @plugins.available.map do |plugin|
519
549
  path = @plugins.name_to_path( plugin )
520
- next if !lsplug_match?( path )
550
+ next if !list_plugin?( path, patterns )
521
551
 
522
552
  @plugins[plugin].info.merge(
523
- plug_name: plugin,
553
+ options: @plugins[plugin].info[:options] || [],
524
554
  shortname: plugin,
525
555
  path: path,
526
556
  author: [@plugins[plugin].info[:author]].
@@ -532,9 +562,9 @@ class Framework
532
562
  @plugins.load loaded
533
563
  end
534
564
  end
535
- alias :lsplug :list_plugins
536
565
 
537
- # @return [Array<Hash>] Information about all available platforms.
566
+ # @return [Array<Hash>]
567
+ # Information about all available platforms.
538
568
  def list_platforms
539
569
  platforms = Platform::Manager.new
540
570
  platforms.valid.inject({}) do |h, platform|
@@ -544,264 +574,598 @@ class Framework
544
574
  h
545
575
  end
546
576
  end
547
- alias :lsplat :list_platforms
548
577
 
549
- # @return [String]
578
+ # @return [Symbol]
550
579
  # Status of the instance, possible values are (in order):
551
580
  #
552
- # * `ready` -- Initialised and waiting for instructions.
553
- # * `preparing` -- Getting ready to start (i.e. initing plugins etc.).
554
- # * `crawling` -- The instance is crawling the target webapp.
555
- # * `auditing` -- The instance is currently auditing the webapp.
556
- # * `paused` -- The instance has been paused (if applicable).
557
- # * `cleanup` -- The scan has completed and the instance is cleaning up
558
- # after itself (i.e. waiting for plugins to finish etc.).
559
- # * `done` -- The scan has completed, you can grab the report and shutdown.
560
- #
581
+ # * `:ready` -- {#initialize Initialised} and waiting for instructions.
582
+ # * `:preparing` -- Getting ready to start (i.e. initializing plugins etc.).
583
+ # * `:scanning` -- The instance is currently {#run auditing} the webapp.
584
+ # * `:pausing` -- The instance is being {#pause paused} (if applicable).
585
+ # * `:paused` -- The instance has been {#pause paused} (if applicable).
586
+ # * `:suspending` -- The instance is being {#suspend suspended} (if applicable).
587
+ # * `:suspended` -- The instance has being {#suspend suspended} (if applicable).
588
+ # * `:cleanup` -- The scan has completed and the instance is
589
+ # {Framework#clean_up cleaning up} after itself (i.e. waiting for
590
+ # plugins to finish etc.).
591
+ # * `:aborted` -- The scan has been {Framework#abort}, you can grab the
592
+ # report and shutdown.
593
+ # * `:done` -- The scan has completed, you can grab the report and shutdown.
561
594
  def status
562
- return 'paused' if paused?
563
- @status.to_s
595
+ state.status
564
596
  end
565
597
 
566
- # @return [Bool] `true` if the framework is running, `false` otherwise.
598
+ # @return [Bool]
599
+ # `true` if the framework is running, `false` otherwise. This is `true`
600
+ # even if the scan is {#paused?}.
567
601
  def running?
568
- @running
602
+ state.running?
569
603
  end
570
604
 
571
- # @return [Bool] `true` if the framework is paused or in the process of.
605
+ # @return [Bool]
606
+ # `true` if the system is scanning, `false` otherwise.
607
+ def scanning?
608
+ state.scanning?
609
+ end
610
+
611
+ # @return [Bool]
612
+ # `true` if the framework is paused, `false` otherwise.
572
613
  def paused?
573
- !@paused.empty?
614
+ state.paused?
574
615
  end
575
616
 
576
- # @return [TrueClass]
577
- # Pauses the framework on a best effort basis, might take a while to take effect.
578
- def pause
579
- spider.pause
580
- @paused << caller
581
- true
617
+ # @return [Bool]
618
+ # `true` if the framework has been instructed to pause (i.e. is in the
619
+ # process of being paused or has been paused), `false` otherwise.
620
+ def pause?
621
+ state.pause?
582
622
  end
583
623
 
584
- # @return [TrueClass] Resumes the scan/audit.
585
- def resume
586
- @paused.delete( caller )
587
- spider.resume
588
- true
624
+ # @return [Bool]
625
+ # `true` if the framework is in the process of pausing, `false` otherwise.
626
+ def pausing?
627
+ state.pausing?
589
628
  end
590
629
 
591
- # @return [String] Returns the version of the framework.
592
- def version
593
- Arachni::VERSION
630
+ # @note Each call from a unique caller is counted as a pause request
631
+ # and in order for the system to resume **all** pause callers need to
632
+ # {#resume} it.
633
+ #
634
+ # Pauses the framework on a best effort basis.
635
+ #
636
+ # @param [Bool] wait
637
+ # Wait until the system has been paused.
638
+ #
639
+ # @return [Integer]
640
+ # ID identifying this pause request.
641
+ def pause( wait = true )
642
+ id = generate_token.hash
643
+ state.pause id, wait
644
+ id
594
645
  end
595
646
 
596
- # @return [String] Returns the revision of the {Framework} (this) class.
597
- def revision
598
- REVISION
647
+ # @return [Bool]
648
+ # `true` if the framework {#run} has been aborted, `false` otherwise.
649
+ def aborted?
650
+ state.aborted?
599
651
  end
600
652
 
653
+ # @return [Bool]
654
+ # `true` if the framework has been instructed to abort (i.e. is in the
655
+ # process of being aborted or has been aborted), `false` otherwise.
656
+ def abort?
657
+ state.abort?
658
+ end
659
+
660
+ # @return [Bool]
661
+ # `true` if the framework is in the process of aborting, `false` otherwise.
662
+ def aborting?
663
+ state.aborting?
664
+ end
665
+
666
+ # Aborts the framework {#run} on a best effort basis.
667
+ #
668
+ # @param [Bool] wait
669
+ # Wait until the system has been aborted.
670
+ def abort( wait = true )
671
+ state.abort wait
672
+ end
673
+
674
+ # @note Each call from a unique caller is counted as a pause request
675
+ # and in order for the system to resume **all** pause callers need to
676
+ # {#resume} it.
677
+ #
678
+ # Removes a {#pause} request for the current caller.
679
+ #
680
+ # @param [Integer] id
681
+ # ID of the {#pause} request.
682
+ def resume( id )
683
+ state.resume id
684
+ end
685
+
686
+ # Writes a {Snapshot.dump} to disk and aborts the scan.
687
+ #
688
+ # @param [Bool] wait
689
+ # Wait for the system to write it state to disk.
601
690
  #
691
+ # @return [String,nil]
692
+ # Path to the state file `wait` is `true`, `nil` otherwise.
693
+ def suspend( wait = true )
694
+ state.suspend( wait )
695
+ return snapshot_path if wait
696
+ nil
697
+ end
698
+
699
+ # @return [Bool]
700
+ # `true` if the system is in the process of being suspended, `false`
701
+ # otherwise.
702
+ def suspend?
703
+ state.suspend?
704
+ end
705
+
706
+ # @return [Bool]
707
+ # `true` if the system has been suspended, `false` otherwise.
708
+ def suspended?
709
+ state.suspended?
710
+ end
711
+
712
+ # @return [String]
713
+ # Provisioned {#suspend} dump file for this instance.
714
+ def snapshot_path
715
+ return @state_archive if @state_archive
716
+
717
+ default_filename =
718
+ "#{URI(options.url).host} #{Time.now.to_s.gsub( ':', '_' )} #{generate_token}.afs"
719
+
720
+ location = options.snapshot.save_path
721
+
722
+ if !location
723
+ location = default_filename
724
+ elsif File.directory? location
725
+ location += "/#{default_filename}"
726
+ end
727
+
728
+ @state_archive ||= File.expand_path( location )
729
+ end
730
+
731
+ # @param [String] afs
732
+ # Path to an `.afs.` (Arachni Framework Snapshot) file created by {#suspend}.
733
+ #
734
+ # @return [Framework]
735
+ # Restored instance.
736
+ def restore( afs )
737
+ Snapshot.load afs
738
+
739
+ browser_job_update_skip_states state.browser_skip_states
740
+
741
+ checks.load Options.checks
742
+ plugins.load Options.plugins.keys
743
+
744
+ nil
745
+ end
746
+
747
+ def wait_for_browser?
748
+ @browser_cluster && !browser_cluster.done?
749
+ end
750
+
602
751
  # Cleans up the framework; should be called after running the audit or
603
752
  # after canceling a running scan.
604
753
  #
605
754
  # It stops the clock and waits for the plugins to finish up.
606
- #
607
- def clean_up
608
- @status = :cleanup
755
+ def clean_up( shutdown_browsers = true )
756
+ return if @cleaned_up
757
+ @cleaned_up = true
609
758
 
610
- @page_queue.clear
759
+ state.status = :cleanup
611
760
 
612
- @opts.finish_datetime = Time.now
613
- @opts.start_datetime ||= Time.now
761
+ sitemap.merge!( browser_sitemap )
762
+
763
+ if shutdown_browsers
764
+ state.set_status_message :browser_cluster_shutdown
765
+ shutdown_browser_cluster
766
+ end
614
767
 
615
- @opts.delta_time = @opts.finish_datetime - @opts.start_datetime
768
+ state.set_status_message :clearing_queues
769
+ page_queue.clear
770
+ url_queue.clear
616
771
 
617
- # make sure this is disabled or it'll break report output
772
+ @finish_datetime = Time.now
773
+ @start_datetime ||= Time.now
774
+
775
+ # Make sure this is disabled or it'll break reporter output.
618
776
  disable_only_positives
619
777
 
620
- @running = false
778
+ state.running = false
621
779
 
622
- # wait for the plugins to finish
780
+ state.set_status_message :waiting_for_plugins
623
781
  @plugins.block
624
782
 
783
+ # Plugins may need the session right till the very end so save it for last.
784
+ @session.clean_up
785
+ @session = nil
786
+
625
787
  true
626
788
  end
627
789
 
628
- def reset_spider
629
- @spider = Spider.new( @opts )
790
+ def browser_job_skip_states
791
+ return if !@browser_cluster
792
+ browser_cluster.skip_states( browser_job.id )
630
793
  end
631
794
 
632
- def reset_trainer
633
- @trainer = Trainer.new( self )
795
+ # @return [String]
796
+ # Returns the version of the framework.
797
+ def version
798
+ Arachni::VERSION
634
799
  end
635
800
 
801
+ # @note Prefer this from {.reset} if you already have an instance.
802
+ # @note You should first reset {Arachni::Options}.
636
803
  #
637
804
  # Resets everything and allows the framework to be re-used.
638
- #
639
- # You should first update {Arachni::Options}.
640
- #
641
- # Prefer this if you already have an instance.
642
- #
643
805
  def reset
644
- @page_queue_total_size = 0
645
- @url_queue_total_size = 0
806
+ @cleaned_up = false
807
+ @browser_job = nil
808
+
646
809
  @failures.clear
647
810
  @retries.clear
648
- @sitemap.clear
649
- @page_queue.clear
650
811
 
651
- # this needs to be first so that the HTTP lib will be reset before
652
- # the rest
812
+ # This needs to happen before resetting the other components so they
813
+ # will be able to put in their hooks.
653
814
  self.class.reset
654
815
 
655
816
  clear_observers
656
817
  reset_trainer
657
- reset_spider
658
- @modules.clear
659
- @reports.clear
818
+ reset_session
819
+ @checks.clear
820
+ @reporters.clear
660
821
  @plugins.clear
661
822
  end
662
823
 
824
+ # @note You should first reset {Arachni::Options}.
663
825
  #
664
- # Resets everything and allows the framework to be re-used.
665
- #
666
- # You should first update {Arachni::Options}.
667
- #
826
+ # Resets everything and allows the framework environment to be re-used.
668
827
  def self.reset
669
- UI::Output.reset_output_options
828
+ State.clear
829
+ Data.clear
830
+
670
831
  Platform::Manager.reset
671
- Module::Auditor.reset
832
+ Check::Auditor.reset
672
833
  ElementFilter.reset
673
834
  Element::Capabilities::Auditable.reset
674
- Module::Manager.reset
835
+ Element::Capabilities::Analyzable.reset
836
+ Check::Manager.reset
675
837
  Plugin::Manager.reset
676
- Report::Manager.reset
677
- HTTP.reset
838
+ Reporter::Manager.reset
839
+ HTTP::Client.reset
840
+ end
841
+
842
+ # @private
843
+ def reset_trainer
844
+ @trainer = Trainer.new( self )
678
845
  end
679
846
 
680
847
  private
681
848
 
849
+ def shutdown_browser_cluster
850
+ return if !@browser_cluster
851
+
852
+ browser_cluster.shutdown
853
+
854
+ @browser_cluster = nil
855
+ @browser_job = nil
856
+ end
857
+
858
+ def push_paths_from_page( page )
859
+ page.paths.select { |path| push_to_url_queue( path ) }
860
+ end
861
+
862
+ def browser_sitemap
863
+ return {} if !@browser_cluster
864
+ browser_cluster.sitemap
865
+ end
866
+
867
+ def browser_job_update_skip_states( states )
868
+ return if states.empty?
869
+ browser_cluster.update_skip_states browser_job.id, states
870
+ end
871
+
872
+ def reset_session
873
+ @session.clean_up if @session
874
+ @session = Session.new
875
+ end
876
+
877
+ def abort_if_signaled
878
+ return if !abort?
879
+ clean_up
880
+ state.aborted
881
+ end
882
+
883
+ def suspend_if_signaled
884
+ return if !suspend?
885
+ suspend_to_disk
886
+ end
887
+
888
+ def suspend_to_disk
889
+ while wait_for_browser?
890
+ last_pending_jobs ||= 0
891
+ pending_jobs = browser_cluster.pending_job_counter
892
+
893
+ if pending_jobs != last_pending_jobs
894
+ state.set_status_message :waiting_for_browser_cluster_jobs, pending_jobs
895
+ print_info "Suspending: #{status_messages.first}"
896
+ end
897
+
898
+ last_pending_jobs = pending_jobs
899
+ sleep 0.1
900
+ end
901
+
902
+ # Make sure the component options are up to date with what's actually
903
+ # happening.
904
+ options.checks = checks.loaded
905
+ options.plugins = plugins.loaded.
906
+ inject({}) { |h, name| h[name.to_s] = Options.plugins[name.to_s] || {}; h }
907
+
908
+ if browser_job_skip_states
909
+ state.browser_skip_states.merge browser_job_skip_states
910
+ end
911
+
912
+ state.set_status_message :suspending_plugins
913
+ @plugins.suspend
914
+
915
+ state.set_status_message :saving_snapshot, snapshot_path
916
+ Snapshot.dump( snapshot_path )
917
+ state.clear_status_messages
918
+
919
+ clean_up
920
+
921
+ state.set_status_message :snapshot_location, snapshot_path
922
+ print_info status_messages.first
923
+ state.suspended
924
+ end
925
+
926
+ def handle_signals
927
+ wait_if_paused
928
+ abort_if_signaled
929
+ suspend_if_signaled
930
+ end
931
+
932
+ def wait_if_paused
933
+ state.paused if pause?
934
+ sleep 0.2 while pause? && !abort?
935
+ end
936
+
937
+ # @note Must be called before calling any audit methods.
682
938
  #
683
939
  # Prepares the framework for the audit.
684
940
  #
685
- # Sets the status to 'running', starts the clock and runs the plugins.
686
- #
687
- # Must be called just before calling {#audit}.
688
- #
941
+ # * Sets the status to `:preparing`.
942
+ # * Starts the clock.
943
+ # * Runs the plugins.
689
944
  def prepare
690
- @status = :preparing
691
- @running = true
692
- @opts.start_datetime = Time.now
945
+ state.status = :preparing
946
+ state.running = true
947
+ @start_datetime = Time.now
693
948
 
694
- # run all plugins
695
- @plugins.run
949
+ Snapshot.restored? ? @plugins.restore : @plugins.run
696
950
  end
697
951
 
952
+ def handle_browser_page( page )
953
+ synchronize do
954
+ return if !push_to_page_queue page
955
+
956
+ pushed_paths = nil
957
+ if crawl?
958
+ pushed_paths = push_paths_from_page( page ).size
959
+ end
960
+
961
+ print_status "Got new page from the browser-cluster: #{page.dom.url}"
962
+ print_info "DOM depth: #{page.dom.depth} (Limit: #{options.scope.dom_depth_limit})"
963
+
964
+ if page.dom.transitions.any?
965
+ print_info ' Transitions:'
966
+ page.dom.print_transitions( method(:print_info), ' ' )
967
+ end
968
+
969
+ if pushed_paths
970
+ print_info " -- Analysis resulted in #{pushed_paths} usable paths."
971
+ end
972
+ end
973
+ end
974
+
975
+ # Passes the `page` to {BrowserCluster#queue} and then pushes
976
+ # the resulting pages to {#push_to_page_queue}.
698
977
  #
699
- # Performs the audit
700
- #
701
- # Runs the spider, pushes each page or url to their respective audit queue,
702
- # calls {#audit_queues}, runs the timeout attacks ({Arachni::Module::Auditor.timeout_audit_run}) and finally re-runs
703
- # {#audit_queues} in case the timing attacks uncovered a new page.
704
- #
978
+ # @param [Page] page
979
+ # Page to analyze.
980
+ def perform_browser_analysis( page )
981
+ return if !browser_cluster || !accepts_more_pages? ||
982
+ Options.scope.dom_depth_limit.to_i < page.dom.depth + 1 ||
983
+ !page.has_script?
984
+
985
+ browser_cluster.queue( browser_job.forward( resource: page ) ) do |response|
986
+ handle_browser_page response.page
987
+ end
988
+
989
+ true
990
+ end
991
+
992
+ def browser_job
993
+ # We'll recycle the same job since all of them will have the same
994
+ # callback. This will force the BrowserCluster to use the same block
995
+ # for all queued jobs.
996
+ #
997
+ # Also, this job should never end so that all analysis operations
998
+ # share the same state.
999
+ @browser_job ||= BrowserCluster::Jobs::ResourceExploration.new(
1000
+ never_ending: true
1001
+ )
1002
+ end
1003
+
1004
+ # Performs the audit.
705
1005
  def audit
706
- wait_if_paused
1006
+ handle_signals
1007
+ return if aborted?
1008
+
1009
+ state.status = :scanning if !pausing?
1010
+
1011
+ push_to_url_queue( options.url )
1012
+ options.scope.restrict_paths.each { |url| push_to_url_queue( url, true ) }
1013
+
1014
+ # Initialize the BrowserCluster.
1015
+ browser_cluster
1016
+
1017
+ # Keep auditing until there are no more resources in the queues and the
1018
+ # browsers have stopped spinning.
1019
+ loop do
1020
+ show_workload_msg = true
1021
+ while !has_audit_workload? && wait_for_browser?
1022
+ if show_workload_msg
1023
+ print_line
1024
+ print_status 'Workload exhausted, waiting for new pages' <<
1025
+ ' from the browser-cluster...'
1026
+ end
1027
+ show_workload_msg = false
1028
+
1029
+ last_pending_jobs ||= 0
1030
+ pending_jobs = browser_cluster.pending_job_counter
1031
+ if pending_jobs != last_pending_jobs
1032
+ browser_cluster.print_info "Pending jobs: #{pending_jobs}"
1033
+ end
1034
+ last_pending_jobs = pending_jobs
707
1035
 
708
- @status = :crawling
709
-
710
- # if we're restricted to a given list of paths there's no reason to run the spider
711
- if @opts.restrict_paths && !@opts.restrict_paths.empty?
712
- @opts.restrict_paths = @opts.restrict_paths.map { |p| to_absolute( p ) }
713
- @sitemap = @opts.restrict_paths.dup
714
- @opts.restrict_paths.each { |url| push_to_url_queue( url ) }
715
- else
716
- # initiates the crawl
717
- spider.run do |page|
718
- @sitemap |= spider.sitemap
719
- push_to_url_queue page.url
720
-
721
- next if page.platforms.empty?
722
- print_info "Identified as: #{page.platforms.to_a.join( ', ' )}"
1036
+ sleep 0.1
723
1037
  end
1038
+
1039
+ audit_queues
1040
+
1041
+ break if page_limit_reached?
1042
+ break if !has_audit_workload? && !wait_for_browser?
724
1043
  end
1044
+ end
725
1045
 
726
- audit_queues
1046
+ def has_audit_workload?
1047
+ !url_queue.empty? || !page_queue.empty?
727
1048
  end
728
1049
 
729
- #
730
- # Audits the URL and Page queues
731
- #
1050
+ def page_queue
1051
+ data.page_queue
1052
+ end
1053
+
1054
+ def url_queue
1055
+ data.url_queue
1056
+ end
1057
+
1058
+ # Audits the {Data::Framework.url_queue URL} and {Data::Framework.page_queue Page}
1059
+ # queues while maintaining a valid session with the webapp if we've got
1060
+ # login capabilities.
732
1061
  def audit_queues
733
- return if modules.empty?
1062
+ return if @audit_queues_done == false || !has_audit_workload? ||
1063
+ page_limit_reached?
734
1064
 
735
- @status = :auditing
1065
+ @audit_queues_done = false
736
1066
 
737
1067
  # If for some reason we've got pages in the page queue this early,
738
1068
  # consume them and get it over with.
739
1069
  audit_page_queue
740
1070
 
741
- # Go through the URLs discovered by the spider, repeat the request
742
- # and parse the responses into page objects
743
- #
744
- # Yes...repeating the request is wasteful but we can't store the
745
- # responses of the spider to consume them here because there's no way
746
- # of knowing how big the site will be.
747
- while !@url_queue.empty?
748
- page = Page.from_url( @url_queue.pop, precision: 2 )
1071
+ next_page = nil
1072
+ while !suspended? && !page_limit_reached? &&
1073
+ (page = next_page || pop_page_from_url_queue)
749
1074
 
750
- @retries[page.url.hash] ||= 0
1075
+ # Helps us schedule the next page to be grabbed along with the audit
1076
+ # requests for the current page to avoid blocking.
1077
+ next_page = nil
1078
+ next_page_call = proc do
1079
+ pop_page_from_url_queue { |p| next_page = p }
1080
+ end
751
1081
 
752
- if page.code == 0
753
- if @retries[page.url.hash] >= AUDIT_PAGE_MAX_TRIES
754
- @failures << page.url
1082
+ # If we can login capabilities make sure that our session is valid
1083
+ # before grabbing and auditing the next page.
1084
+ if session.can_login?
1085
+ # Schedule the login check to happen along with the audit requests
1086
+ # to prevent blocking and grab the next page as well.
1087
+ session.logged_in? do |bool|
1088
+ next next_page_call.call if bool
755
1089
 
756
- print_error "Giving up trying to audit: #{page.url}"
757
- print_error "Couldn't get a response after #{AUDIT_PAGE_MAX_TRIES} tries."
758
- else
759
- print_bad "Retrying for: #{page.url}"
760
- @retries[page.url.hash] += 1
761
- @url_queue << page.url
1090
+ session.login
1091
+ next_page_call
762
1092
  end
1093
+ else
1094
+ next_page_call.call
1095
+ end
763
1096
 
764
- next
1097
+ # We're counting on piggybacking the next page retrieval with the
1098
+ # page audit, however if there wasn't an audit we need to force an
1099
+ # HTTP run.
1100
+ audit_page( page ) or http.run
1101
+
1102
+ if next_page && suspend?
1103
+ data.page_queue << next_page
765
1104
  end
766
1105
 
767
- audit_page Page.from_url( page.url, precision: 2 )
1106
+ handle_signals
768
1107
 
769
1108
  # Consume pages somehow triggered by the audit and pushed by the
770
- # trainer or plugins or whatever now to avoid keeping them in RAM.
1109
+ # trainer or plugins or whatever.
771
1110
  audit_page_queue
772
1111
  end
773
1112
 
774
1113
  audit_page_queue
775
- end
776
1114
 
777
- #
778
- # Audits the page queue
779
- #
780
- def audit_page_queue
781
- # this will run until no new elements appear for the given page
782
- audit_page( @page_queue.pop ) while !@page_queue.empty?
1115
+ @audit_queues_done = true
1116
+ true
783
1117
  end
784
1118
 
785
- #
786
- # Special sitemap for the {#auditstore}.
787
- #
788
- # Used only under special circumstances, will usually return the {#sitemap}
789
- # but can be overridden by the {::Arachni::RPC::Framework}.
790
- #
791
- # @return [Array]
792
- #
793
- def auditstore_sitemap
794
- @sitemap
1119
+ def pop_page_from_url_queue( &block )
1120
+ return if url_queue.empty?
1121
+
1122
+ grabbed_page = nil
1123
+ Page.from_url( url_queue.pop, http: { update_cookies: true } ) do |page|
1124
+ @retries[page.url.hash] ||= 0
1125
+
1126
+ if (location = page.response.headers['Location'])
1127
+ print_info "Scheduled #{page.code} redirection: #{page.url} => #{location}"
1128
+ push_to_url_queue to_absolute( location, page.url )
1129
+ end
1130
+
1131
+ if page.code != 0
1132
+ grabbed_page = page
1133
+ block.call grabbed_page if block_given?
1134
+ next
1135
+ end
1136
+
1137
+ if @retries[page.url.hash] >= AUDIT_PAGE_MAX_TRIES
1138
+ @failures << page.url
1139
+
1140
+ print_error "Giving up trying to audit: #{page.url}"
1141
+ print_error "Couldn't get a response after #{AUDIT_PAGE_MAX_TRIES} tries."
1142
+ else
1143
+ print_bad "Retrying for: #{page.url}"
1144
+ @retries[page.url.hash] += 1
1145
+ url_queue << page.url
1146
+ end
1147
+
1148
+ grabbed_page = nil
1149
+ block.call grabbed_page if block_given?
1150
+ end
1151
+ http.run if !block_given?
1152
+ grabbed_page
795
1153
  end
796
1154
 
797
- def caller
798
- if /^(.+?):(\d+)(?::in `(.*)')?/ =~ ::Kernel.caller[1]
799
- Regexp.last_match[1]
1155
+ # Audits the page queue.
1156
+ #
1157
+ # @see #pop_page_from_queue
1158
+ def audit_page_queue
1159
+ while !suspended? && !page_limit_reached? && (page = pop_page_from_queue)
1160
+ audit_page( page )
1161
+ handle_signals
800
1162
  end
801
1163
  end
802
1164
 
803
- def wait_if_paused
804
- ::IO::select( nil, nil, nil, 1 ) while paused?
1165
+ # @return [Page]
1166
+ def pop_page_from_queue
1167
+ return if page_queue.empty?
1168
+ page_queue.pop
805
1169
  end
806
1170
 
807
1171
  def harvest_http_responses
@@ -814,43 +1178,44 @@ class Framework
814
1178
 
815
1179
  # Needed for some HTTP callbacks.
816
1180
  http.run
817
-
818
- session.ensure_logged_in
819
1181
  end
820
1182
 
1183
+ # Passes a page to the check and runs it.
1184
+ # It also handles any exceptions thrown by the check at runtime.
821
1185
  #
822
- # Passes a page to the module and runs it.
823
- # It also handles any exceptions thrown by the module at runtime.
824
- #
825
- # @see Page
826
- #
827
- # @param [Arachni::Module::Base] mod the module to run
1186
+ # @param [Check::Base] check
1187
+ # Check to run.
828
1188
  # @param [Page] page
829
- #
830
- def run_module_against_page( mod, page )
1189
+ def check_page( check, page )
831
1190
  begin
832
- @modules.run_one( mod, page )
833
- rescue SystemExit
834
- raise
1191
+ @checks.run_one( check, page )
835
1192
  rescue => e
836
- print_error "Error in #{mod.to_s}: #{e.to_s}"
1193
+ print_error "Error in #{check.to_s}: #{e.to_s}"
837
1194
  print_error_backtrace e
838
1195
  end
839
1196
  end
840
1197
 
841
- def lsrep_match?( path )
842
- regexp_array_match( @opts.lsrep, path )
1198
+ def add_to_sitemap( page )
1199
+ data.add_page_to_sitemap( page )
1200
+ end
1201
+
1202
+ def list_reporter?( path, patterns = nil )
1203
+ regexp_array_match( patterns, path )
843
1204
  end
844
1205
 
845
- def lsmod_match?( path )
846
- regexp_array_match( @opts.lsmod, path )
1206
+ def list_check?( path, patterns = nil )
1207
+ regexp_array_match( patterns, path )
847
1208
  end
848
1209
 
849
- def lsplug_match?( path )
850
- regexp_array_match( @opts.lsplug, path )
1210
+ def list_plugin?( path, patterns = nil )
1211
+ regexp_array_match( patterns, path )
851
1212
  end
852
1213
 
853
1214
  def regexp_array_match( regexps, str )
1215
+ regexps = [regexps].flatten.compact.
1216
+ map { |s| s.is_a?( Regexp ) ? s : Regexp.new( s.to_s ) }
1217
+ return true if regexps.empty?
1218
+
854
1219
  cnt = 0
855
1220
  regexps.each { |filter| cnt += 1 if str =~ filter }
856
1221
  cnt == regexps.size