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
@@ -0,0 +1,187 @@
1
+ shared_examples_for 'component_option' do
2
+
3
+ let(:subject) do
4
+ described_class.new( :option_name,
5
+ description: 'Description',
6
+ required: true,
7
+ value: 'my value',
8
+ default: 'default value'
9
+ )
10
+ end
11
+
12
+ it "supports #{Arachni::RPC::Serializer}" do
13
+ subject.should == Arachni::RPC::Serializer.deep_clone( subject )
14
+ end
15
+
16
+ describe '#to_rpc_data' do
17
+ let(:data) { subject.to_rpc_data }
18
+
19
+ %w(name description default value type).each do |attribute|
20
+ it "includes '#{attribute}'" do
21
+ data[attribute].should == subject.send( attribute )
22
+ end
23
+ end
24
+
25
+ it "includes 'class'" do
26
+ data['class'].should == subject.class.to_s
27
+ end
28
+
29
+ it "includes 'required'" do
30
+ data['required'].should == subject.required?
31
+ end
32
+ end
33
+
34
+ describe '.from_rpc_data' do
35
+ let(:restored) { described_class.from_rpc_data data }
36
+ let(:data) { Arachni::RPC::Serializer.rpc_data( subject ) }
37
+
38
+ %w(name description default value type class).each do |attribute|
39
+ it "restores '#{attribute}'" do
40
+ restored.send( attribute ).should == subject.send( attribute )
41
+ end
42
+ end
43
+
44
+ it "restores 'required'" do
45
+ restored.required?.should == subject.required?
46
+ end
47
+ end
48
+
49
+ describe '#initialize' do
50
+ context 'when passed invalid options' do
51
+ it "raises #{ArgumentError}" do
52
+ expect { described_class.new( :myname, stuff: 1 ) }.to raise_error ArgumentError
53
+ end
54
+ end
55
+ end
56
+
57
+ describe '#name' do
58
+ it 'returns the name of the option' do
59
+ name = 'myname'
60
+ described_class.new( name ).name.should == name.to_sym
61
+ end
62
+ end
63
+
64
+ describe '#description' do
65
+ it 'returns the description' do
66
+ description = 'a description'
67
+ described_class.new( '', description: description ).description.should == description
68
+ end
69
+ end
70
+
71
+ describe '#default' do
72
+ it 'returns the default value' do
73
+ default = 'default value'
74
+ described_class.new( '', default: default ).default.should == default
75
+ end
76
+ end
77
+
78
+ describe '#required?' do
79
+ context 'when the option is mandatory' do
80
+ it 'returns true' do
81
+ described_class.new( '', required: true ).required?.should be_true
82
+ end
83
+ end
84
+
85
+ context 'when the option is not mandatory' do
86
+ it 'returns false' do
87
+ described_class.new( '', required: false ).required?.should be_false
88
+ end
89
+ end
90
+
91
+ context 'by default' do
92
+ it 'returns false' do
93
+ described_class.new( '' ).required?.should be_false
94
+ end
95
+ end
96
+ end
97
+
98
+ describe '#missing_value?' do
99
+ context 'when the option is required' do
100
+ context 'and the value is not empty' do
101
+ it 'returns false' do
102
+ described_class.new( '', required: true, value: 'stuff' ).missing_value?.should be_false
103
+ end
104
+ end
105
+
106
+ context 'and the value is nil' do
107
+ it 'returns true' do
108
+ described_class.new( '', required: true ).missing_value?.should be_true
109
+ end
110
+ end
111
+ end
112
+
113
+ context 'when the option is not required' do
114
+ context 'and the value is not empty' do
115
+ it 'returns false' do
116
+ described_class.new( '', value: 'true' ).missing_value?.should be_false
117
+ end
118
+ end
119
+
120
+ context 'and the value is empty' do
121
+ it 'returns false' do
122
+ described_class.new( '' ).missing_value?.should be_false
123
+ end
124
+ end
125
+ end
126
+ end
127
+
128
+ describe '#value=' do
129
+ it 'sets #value' do
130
+ option = described_class.new( '' )
131
+ option.value = 1
132
+ option.value.should == 1
133
+ end
134
+ end
135
+
136
+ describe '#value' do
137
+ it 'returns the set value' do
138
+ option = described_class.new( '' )
139
+ option.value = 1
140
+ option.value.should == 1
141
+ end
142
+ end
143
+
144
+ describe '#effective_value' do
145
+ it 'returns the set value' do
146
+ option = described_class.new( '' )
147
+ option.value = 1
148
+ option.value.should == 1
149
+ end
150
+ end
151
+
152
+ describe '#effective_value' do
153
+ it 'returns the value as is' do
154
+ described_class.new( '', value: 'blah' ).effective_value.should == 'blah'
155
+ end
156
+
157
+ context 'when no #value is set' do
158
+ it 'returns #default' do
159
+ described_class.new( '', default: 'test' ).effective_value.should == 'test'
160
+ end
161
+ end
162
+ end
163
+
164
+ describe '#to_h' do
165
+ let(:option) do
166
+ described_class.new( :my_name,
167
+ description: 'My description',
168
+ required: true,
169
+ default: 'stuff'
170
+ )
171
+ end
172
+
173
+ %w(name description value default type).each do |m|
174
+ it "includes :#{m}" do
175
+ option.to_h[m.to_sym].should == option.send(m)
176
+ end
177
+ end
178
+
179
+ it 'includes :required' do
180
+ option.to_h[:required].should == option.required?
181
+ end
182
+
183
+ it 'is aliased to #to_hash' do
184
+ option.to_hash.should == option.to_h
185
+ end
186
+ end
187
+ end
@@ -0,0 +1,131 @@
1
+ require 'spec_helper'
2
+
3
+ shared_examples_for 'element' do
4
+ it_should_behave_like 'with_scope'
5
+
6
+ let :normalized_url do
7
+ Arachni::Utilities.normalize_url( 'http://test.com' )
8
+ end
9
+ let(:page) { Factory[:page].dup }
10
+
11
+ it "supports #{Arachni::RPC::Serializer}" do
12
+ subject.should == Arachni::RPC::Serializer.deep_clone( subject )
13
+ end
14
+
15
+ rpc_attributes = if described_class.ancestors.include? Arachni::Element::Capabilities::Auditable::DOM
16
+ %w(url)
17
+ else
18
+ %w(url initialization_options)
19
+ end
20
+
21
+ describe '#to_rpc_data' do
22
+ let(:data) { subject.to_rpc_data }
23
+
24
+ it "includes 'url'" do
25
+ data['url'].should == subject.url
26
+ end
27
+
28
+ if rpc_attributes.include? 'initialization_options'
29
+ it "includes 'initialization_options'" do
30
+ init = subject.initialization_options.dup
31
+
32
+ if init.is_a?( Hash )
33
+ if init[:transition]
34
+ init[:transition] = init[:transition].to_rpc_data
35
+ end
36
+
37
+ if init[:template]
38
+ init[:template] = init[:template].source
39
+ end
40
+
41
+ if init[:expires]
42
+ init[:expires] = init[:expires].to_s
43
+ end
44
+
45
+ end
46
+
47
+ data['initialization_options'].should == init
48
+ end
49
+ end
50
+
51
+ it "includes 'class'" do
52
+ data['class'].should == subject.class.to_s
53
+ end
54
+
55
+ it 'excludes #page' do
56
+ data.should_not include 'page'
57
+ end
58
+ end
59
+
60
+ describe '.from_rpc_data' do
61
+ let(:restored) { described_class.from_rpc_data data }
62
+ let(:data) { Arachni::RPC::Serializer.rpc_data( subject ) }
63
+
64
+ rpc_attributes.each do |attribute|
65
+ it "restores '#{attribute}'" do
66
+ v1 = restored.send( attribute )
67
+ v2 = subject.send( attribute )
68
+
69
+ if attribute == 'initialization_options' && v1.is_a?( Hash ) && v1.include?( :expires )
70
+ v1.delete(:expires).to_s.should == v2.delete(:expires).to_s
71
+ end
72
+
73
+ v1.should == v2
74
+ end
75
+ end
76
+ end
77
+
78
+ describe '#marshal_dump' do
79
+ it 'excludes #page' do
80
+ subject.page = page
81
+ subject.marshal_dump.should_not include :page
82
+ end
83
+ end
84
+
85
+ describe '#url=',
86
+ if: !described_class.ancestors.include?( Arachni::Element::Capabilities::Auditable::DOM ) do
87
+ it 'normalizes the passed URL' do
88
+ url = 'http://test.com/some stuff#frag!'
89
+ subject.url = url
90
+ subject.url.should == Arachni::Utilities.normalize_url( url )
91
+ end
92
+ end
93
+
94
+ describe '#page=' do
95
+ it 'sets the associated page' do
96
+ subject.page = page
97
+ subject.page.should == page
98
+ end
99
+ end
100
+
101
+ describe '#dup' do
102
+ it 'returns a copy of self' do
103
+ subject.dup.should == subject
104
+ end
105
+
106
+ it 'copies #page' do
107
+ subject.page = page
108
+ subject.dup.page.should == page
109
+ end
110
+ end
111
+
112
+ describe '#to_h' do
113
+ let(:hash) { subject.to_h }
114
+
115
+ it 'includes the #type' do
116
+ hash[:type].should == subject.type
117
+ end
118
+
119
+ it 'includes the #url' do
120
+ hash[:url].should == subject.url
121
+ end
122
+
123
+ it 'includes the element class as a string' do
124
+ hash[:class].should == described_class.to_s
125
+ end
126
+
127
+ it 'is aliased to #to_hash' do
128
+ hash.should == subject.to_hash
129
+ end
130
+ end
131
+ end
@@ -1,383 +1,241 @@
1
1
  shared_examples_for 'auditable' do |options = {}|
2
+ it_should_behave_like 'inputtable', options
3
+ it_should_behave_like 'submittable'
4
+ it_should_behave_like 'mutable', options
5
+ it_should_behave_like 'with_auditor'
2
6
 
3
- let( :auditable ) { described_class }
4
- let( :opts ) do
7
+ let(:opts) do
5
8
  {
6
- single_input: false,
7
- url: nil
9
+ single_input: false,
10
+ supports_nulls: true
8
11
  }.merge( options )
9
12
  end
10
13
 
11
- def load( yaml )
12
- YAML.load( yaml )
14
+ before :each do
15
+ @framework ||= Arachni::Framework.new
16
+ @page = Arachni::Page.from_url( url )
17
+ @auditor = Auditor.new( @page, @framework )
13
18
  end
14
19
 
15
- before :all do
16
- @url = options[:url]
17
- @auditor = Auditor.new( nil, Arachni::Framework.new )
20
+ after :each do
21
+ @framework.clean_up
22
+ @framework.reset
23
+ reset_options
24
+ end
18
25
 
19
- @auditable = described_class.new( @url + '/submit', 'param' => 'val' )
20
- @auditable.auditor = @auditor
26
+ let(:auditor) { @auditor }
27
+ let(:default_input_value) { 'val' }
28
+ let(:seed) { 'my_seed' }
21
29
 
22
- @orphan = described_class.new( @url + '/submit', 'param' => 'val' )
30
+ let(:auditable) do
31
+ s = subject.dup
32
+ s.auditor = auditor
33
+ s.inputs = { 'param' => default_input_value }
34
+ s
35
+ end
36
+ let(:other) do
37
+ new = auditable.dup
38
+ new.inputs = { stuff: 'blah' }
39
+ new
40
+ end
23
41
 
24
- # will sleep 2 secs before each response
25
- @sleep = described_class.new( @url + '/sleep', 'param' => 'val' )
26
- @sleep.auditor = @auditor
42
+ def has_parameter_extractor?
43
+ begin
44
+ auditable_extract_parameters
45
+ rescue NoMethodError
46
+ return false
47
+ rescue
48
+ end
27
49
 
28
- @orig = described_class.new( @url, 'param' => 'val' )
50
+ true
51
+ end
29
52
 
30
- @seed = 'my_seed'
31
- @default_input_value = @auditable.auditable['param']
53
+ it "supports #{Arachni::RPC::Serializer}" do
54
+ auditable.should == Arachni::RPC::Serializer.deep_clone( auditable )
32
55
  end
33
56
 
34
- before :each do
35
- Arachni::Element::Capabilities::Auditable.reset
57
+ describe '#to_rpc_data' do
58
+ let(:data) { auditable.to_rpc_data }
59
+
60
+ it 'excludes #audit_options' do
61
+ data.should_not include 'audit_options'
62
+ end
63
+ end
64
+
65
+ describe '#reset' do
66
+ it 'clears #audit_options' do
67
+ auditable.audit_options[:stuff] = true
68
+ auditable.reset
69
+ auditable.audit_options.should be_empty
70
+ end
71
+ end
72
+
73
+ describe '#dup' do
74
+ let(:dupped) { auditable.dup }
75
+
76
+ it 'preserves #audit_options' do
77
+ audited = nil
78
+ dupped.audit( seed ) { |_, m| audited = m }
79
+ run
80
+
81
+ audited.audit_options.should be_any
82
+ dupped = audited.dup
83
+ dupped.audit_options.should == audited.audit_options
84
+
85
+ dupped2 = dupped.dup
86
+ dupped.audit_options.clear
87
+
88
+ dupped2.audit_options.should == audited.audit_options
89
+ end
36
90
  end
37
91
 
38
92
  describe '.skip_like' do
39
93
  it 'skips elements based on the block\'s return value' do
40
94
  audited = false
41
- @auditable.audit( 'seed' ){ audited = true }
42
- @auditable.http.run
95
+ auditable.audit( 'seed' ){ audited = true }
96
+ run
43
97
  audited.should be_true
44
98
 
45
99
  Arachni::Element::Capabilities::Auditable.reset
46
- Arachni::Element::Capabilities::Auditable.skip_like do |element|
47
- element.action.end_with? '/submit'
100
+ Arachni::Element::Capabilities::Auditable.skip_like do
101
+ true
48
102
  end
49
103
 
50
104
  audited = false
51
- @auditable.audit( 'seed' ){ audited = true }
52
- @auditable.http.run
105
+ auditable.audit( 'seed' ){ audited = true }
106
+ run
53
107
  audited.should be_false
54
108
  end
55
109
 
56
110
  it 'skips element mutations based on the block\'s return value' do
57
- i = 0
58
- (@auditable.audit( 'seed' ){ i += 1 }).should be_true
59
- @auditable.http.run
60
- i.should == (@auditable.is_a?( Arachni::Form) ? 5 : 4)
111
+ called = false
112
+ auditable.audit( 'seed' ){ called = true }
113
+ run
114
+ called.should be_true
61
115
 
62
116
  Arachni::Element::Capabilities::Auditable.reset
63
117
  Arachni::Element::Capabilities::Auditable.skip_like do |element|
64
- element.altered == 'param'
118
+ !!element.affected_input_name
65
119
  end
66
120
 
67
121
  i = 0
68
- (@auditable.audit( 'seed' ){ i += 1}).should be_true
69
- @auditable.http.run
70
- i.should == (@auditable.is_a?( Arachni::Form) ? 1 : 0)
122
+ auditable.audit( 'seed' ){ i += 1 }
123
+ run
124
+ i.should == 0
71
125
  end
72
126
  end
73
127
 
74
- describe '#use_anonymous_auditor' do
75
- it 'uses an anonymous auditor' do
76
- elem = auditable.new( @url, 'param' => 'val' )
77
- elem.auditor.should be_nil
78
- elem.use_anonymous_auditor
79
- elem.auditor.should be_true
80
- elem.auditor.fancy_name.should be_true
81
- end
82
- end
83
-
84
- describe '#has_inputs?' do
85
- before do
86
- @has_inputs = auditable.new( @url, { 'param' => 'val', 'param2' => 'val2' } )
87
- @keys = @has_inputs.auditable.keys
88
- @sym_keys = @keys.map( &:to_sym )
89
-
90
- @non_existent_keys = @keys.map { |k| "#{k}1" }
91
- @non_existent_sym_keys = @sym_keys.map { |k| "#{k}1".to_sym }
92
- end
93
- context 'when the given inputs are' do
94
- context 'Variable arguments' do
95
- context 'when it has the given inputs' do
96
- it 'returns true' do
97
- @keys.each do |k|
98
- @has_inputs.has_inputs?( k.to_s.to_sym ).should be_true
99
- @has_inputs.has_inputs?( k.to_s ).should be_true
100
- end
101
-
102
- @has_inputs.has_inputs?( *@sym_keys ).should be_true
103
- @has_inputs.has_inputs?( *@keys ).should be_true
104
- end
105
- end
106
- context 'when it does not have the given inputs' do
107
- it 'returns false' do
108
- @has_inputs.has_inputs?( *@non_existent_sym_keys ).should be_false
109
- @has_inputs.has_inputs?( *@non_existent_keys ).should be_false
110
-
111
- @has_inputs.has_inputs?( @non_existent_keys.first ).should be_false
112
- end
113
- end
114
- end
128
+ describe '#audit_id' do
129
+ let(:action) { "#{url}/action" }
115
130
 
116
- context Array do
117
- context 'when it has the given inputs' do
118
- it 'returns true' do
119
- @has_inputs.has_inputs?( @sym_keys ).should be_true
120
- @has_inputs.has_inputs?( @keys ).should be_true
121
- end
122
- end
123
- context 'when it does not have the given inputs' do
124
- it 'returns false' do
125
- @has_inputs.has_inputs?( @non_existent_sym_keys ).should be_false
126
- @has_inputs.has_inputs?( @non_existent_keys ).should be_false
127
- end
128
- end
129
- end
131
+ it 'takes into account the #auditor class' do
132
+ auditable.auditor = 1
133
+ id = auditable.audit_id
130
134
 
131
- context Hash do
132
- context 'when it has the given inputs (names and values)' do
133
- it 'returns true' do
134
- hash = @has_inputs.auditable.
135
- inject( {} ) { |h, (k, v)| h[k] = v; h}
135
+ auditable.auditor = '2'
136
+ auditable.audit_id.should_not == id
136
137
 
137
- hash_sym = @has_inputs.auditable.
138
- inject( {} ) { |h, (k, v)| h[k.to_sym] = v; h}
138
+ auditable.auditor = 1
139
+ id = auditable.audit_id
139
140
 
140
- @has_inputs.has_inputs?( hash_sym ).should be_true
141
- @has_inputs.has_inputs?( hash ).should be_true
142
- end
143
- end
144
- context 'when it does not have the given inputs' do
145
- it 'returns false' do
146
- hash = @has_inputs.auditable.
147
- inject( {} ) { |h, (k, v)| h[k] = "#{v}1"; h}
148
-
149
- hash_sym = @has_inputs.auditable.
150
- inject( {} ) { |h, (k, v)| h[k.to_sym] = "#{v}1"; h}
151
-
152
- @has_inputs.has_inputs?( hash_sym ).should be_false
153
- @has_inputs.has_inputs?( hash ).should be_false
154
- end
155
- end
156
- end
141
+ auditable.auditor = 2
142
+ auditable.audit_id.should == id
157
143
  end
158
- end
159
144
 
160
- describe '#auditable' do
161
- it 'returns a frozen hash of auditable inputs' do
162
- @auditable.auditable.should == { 'param' => 'val' }
145
+ it 'takes into account #action' do
146
+ e = auditable.dup
147
+ e.stub(:action) { action }
163
148
 
164
- raised = false
165
- begin
166
- @auditable.auditable['stuff'] = true
167
- rescue
168
- raised = true
169
- end
170
-
171
- @auditable.auditable.should == { 'param' => 'val' }
149
+ c = auditable.dup
150
+ c.stub(:action) { "#{action}2" }
172
151
 
173
- raised.should be_true
152
+ e.audit_id.should_not == c.audit_id
174
153
  end
175
- end
176
154
 
177
- describe '#auditable=' do
178
- it 'assigns a hash of auditable inputs' do
179
- @auditable.auditable.should == { 'param' => 'val' }
155
+ it 'takes into account #type' do
156
+ e = auditable.dup
157
+ e.stub(:type) { :blah }
180
158
 
181
- a = @auditable.dup
182
- a.auditable = { 'param1' => 'val1' }
183
- a.auditable.should == { 'param1' => 'val1' }
184
- a.should_not == @auditable
185
- end
159
+ c = auditable.dup
160
+ c.stub(:type) { :blooh }
186
161
 
187
- it 'converts all inputs to strings' do
188
- e = auditable.new( @url, { 'key' => nil } )
189
- e.auditable.should == { 'key' => '' }
162
+ e.audit_id.should_not == c.audit_id
190
163
  end
191
- end
192
164
 
193
- describe '#update' do
194
- it 'updates the auditable inputs using the given hash and return self' do
195
- a = @auditable.dup
165
+ it 'takes into account #inputs names' do
166
+ e = auditable.dup
167
+ e.stub(:inputs) { {input1: 'stuff' } }
196
168
 
197
- updates = if opts[:single_input]
198
- { 'param' => 'val1' }
199
- else
200
- { 'param' => 'val1', 'another_param' => 'val3' }
201
- end
202
- a.update( updates )
203
-
204
- a.auditable.should == updates
205
- a.hash.should_not == @auditable.hash
206
-
207
- c = a.dup
208
- cupdates = { 'param' => '' }
209
- a.update( cupdates )
210
- a.auditable.should == updates.merge( cupdates )
211
- c.should_not == a
212
-
213
- if !opts[:single_input]
214
- c = a.dup
215
- c.update( stuff: '1' ).update( other_stuff: '2' )
216
- c['stuff'].should == '1'
217
- c['other_stuff'].should == '2'
218
- end
219
- end
169
+ c = auditable.dup
170
+ c.stub(:inputs) { {input1: 'stuff2' } }
171
+ e.audit_id.should == c.audit_id
220
172
 
221
- it 'converts all inputs to strings' do
222
- e = auditable.new( @url, 'key' => 'stuff' )
223
- e.update( { 'key' => nil } )
224
- e.auditable.should == { 'key' => '' }
225
- end
226
- end
173
+ e = auditable.dup
174
+ e.stub(:inputs) { {input1: 'stuff' } }
227
175
 
228
- describe '#changes' do
229
- it 'returns the changes the inputs have sustained' do
230
- if !opts[:single_input]
231
- [
232
- { 'param' => 'val1', 'another_param' => 'val3' },
233
- { 'another_param' => 'val3' },
234
- { 'new stuff' => 'houa!' },
235
- { 'new stuff' => 'houa!' },
236
- {}
237
- ].each do |updates|
238
- a = @auditable.dup
239
- a.update( updates )
240
- a.changes.should == updates
241
- end
242
- else
243
- [
244
- { 'param' => 'val1' },
245
- { 'param' => 'val3' },
246
- {}
247
- ].each do |updates|
248
- a = @auditable.dup
249
- a.update( updates )
250
- a.changes.should == updates
251
- end
252
- end
253
- end
254
- end
176
+ c = auditable.dup
177
+ c.stub(:inputs) { {input2: 'stuff' } }
255
178
 
256
- describe '#[]' do
257
- it ' serves as a reader to the #auditable hash' do
258
- e = auditable.new( @url, { 'key' => 'stuff', 'key2' => 'val' } )
259
- e['key'].should == 'stuff'
179
+ e.audit_id.should_not == c.audit_id
260
180
  end
261
- end
262
181
 
263
- describe '#[]=' do
264
- it 'serves as a writer to the #auditable hash' do
265
- e = auditable.new( @url, { 'key' => 'stuff', 'key2' => 'val' } )
266
- h = e.hash
267
-
268
- e['key'] = 'val2'
269
-
270
- h.should_not == e.hash
271
-
272
- e['key'].should == e.auditable['key']
273
- e['key'].should == 'val2'
182
+ it 'takes into account the given payload' do
183
+ id = auditable.audit_id( '1' )
184
+ auditable.audit_id( '2' ).should_not == id
274
185
  end
275
186
  end
276
187
 
277
- describe '#orig' do
278
- it 'should be frozen' do
279
- orig_auditable = @orig.auditable.dup
280
- is_frozen = false
281
- begin
282
- @orig.orig['ff'] = 'ffss'
283
- rescue RuntimeError
284
- is_frozen = true
285
- end
286
- is_frozen.should be_true
287
- @orig.orig.should == orig_auditable
288
- end
289
- context 'when auditable' do
290
- context 'has been modified' do
291
- it 'returns original input name/vals' do
292
- orig_auditable = @orig.auditable.dup
293
- @orig.auditable = {}
294
- @orig.orig.should == orig_auditable
295
- @orig.auditable = orig_auditable.dup
296
- end
297
- end
298
- context 'has not been modified' do
299
- it 'returns #auditable' do
300
- @orig.orig.should == @orig.auditable
301
- end
302
- end
303
- end
304
- it 'aliased to #original' do
305
- @orig.orig.should == @orig.original
306
- end
307
- end
188
+ describe '#coverage_id' do
189
+ let(:action) { "#{url}/action" }
308
190
 
309
- describe '#reset' do
310
- it 'returns the auditable inputs to their original state' do
311
- orig = @orig.auditable.dup
312
- @orig.update( orig.keys.first => 'value' )
313
- (@orig.auditable != orig).should be_true
314
- @orig.reset
315
- @orig.auditable.should == orig
316
- end
317
- end
191
+ it 'takes into account #action' do
192
+ e = auditable.dup
193
+ e.stub(:action) { action }
318
194
 
319
- describe '#remove_auditor' do
320
- it 'removes the auditor' do
321
- @orig.auditor = :some_auditor
322
- @orig.auditor.should == :some_auditor
323
- @orig.remove_auditor
324
- @orig.auditor.should be_nil
325
- end
326
- end
195
+ c = auditable.dup
196
+ c.stub(:action) { "#{action}2" }
327
197
 
328
- describe '#orphan?' do
329
- context 'when it has no auditor' do
330
- it 'returns true' do
331
- @orphan.orphan?.should be_true
332
- end
198
+ e.coverage_id.should_not == c.coverage_id
333
199
  end
334
- context 'when it has an auditor' do
335
- it 'returns true' do
336
- @auditable.orphan?.should be_false
337
- end
338
- end
339
- end
340
200
 
341
- describe '#submit' do
342
- it 'submits the element using its auditable inputs as params' do
343
- submitted = nil
201
+ it 'takes into account #type' do
202
+ e = auditable.dup
203
+ e.stub(:type) { :blah }
344
204
 
345
- @auditable.submit do |res|
346
- submitted = load( res.body )
347
- end
205
+ c = auditable.dup
206
+ c.stub(:type) { :blooh }
348
207
 
349
- @auditor.http.run
350
- @auditable.auditable.should == submitted
208
+ e.coverage_id.should_not == c.coverage_id
351
209
  end
352
210
 
353
- context 'when it has no auditor' do
354
- it 'falls back to using the anonymous auditor' do
355
- submitted = nil
211
+ it 'takes into account #inputs names' do
212
+ e = auditable.dup
213
+ e.stub(:inputs) { {input1: 'stuff' } }
356
214
 
357
- elem = auditable.new( @url + '/submit', 'param' => 'val' )
358
- elem.auditor.should be_nil
215
+ c = auditable.dup
216
+ c.stub(:inputs) { {input1: 'stuff2' } }
217
+ e.coverage_id.should == c.coverage_id
359
218
 
360
- elem.submit do |res|
361
- submitted = load( res.body )
362
- end
363
- elem.auditor.should be_true
219
+ e = auditable.dup
220
+ e.stub(:inputs) { {input1: 'stuff' } }
364
221
 
365
- elem.http.run
222
+ c = auditable.dup
223
+ c.stub(:inputs) { {input2: 'stuff' } }
366
224
 
367
- elem.auditable.should == submitted
368
- end
225
+ e.coverage_id.should_not == c.coverage_id
369
226
  end
370
227
  end
371
228
 
372
- describe '#audit' do
373
- before( :each ) do
374
- Arachni::Element::Capabilities::Auditable.reset
375
- Arachni::Platform::Manager.reset
229
+ describe '#coverage_hash' do
230
+ it 'returns the String#persistent_hash of #coverage_id' do
231
+ subject.coverage_hash.should == subject.coverage_id.persistent_hash
376
232
  end
233
+ end
377
234
 
235
+ describe '#audit' do
378
236
  context 'when no block is given' do
379
237
  it 'raises ArgumentError' do
380
- expect { @auditable.audit( 'stuff' ) }.to raise_error ArgumentError
238
+ expect { auditable.audit( 'stuff' ) }.to raise_error ArgumentError
381
239
  end
382
240
  end
383
241
 
@@ -387,38 +245,61 @@ shared_examples_for 'auditable' do |options = {}|
387
245
  payload = 'stuff-here'
388
246
  injected = nil
389
247
 
390
- @auditable.audit( payload,
391
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |_, _, element|
392
- injected = element.opts[:injected_orig]
248
+ auditable.audit( payload,
249
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ],
250
+ skip_original: true
251
+ ) do |_, element|
252
+ injected = element.affected_input_value
393
253
  end
394
254
 
395
- @auditor.http.run
255
+ run
396
256
  injected.should == payload
397
257
  end
258
+
259
+ context 'with invalid data' do
260
+ it 'is ignored' do
261
+ payload = 'stuff-here'
262
+ called = 0
263
+
264
+ described_class.any_instance.stub(:valid_input_data?) { |i| i != payload }
265
+
266
+ auditable.audit( payload,
267
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ],
268
+ skip_original: true
269
+ ) { |_, element| ap element.inputs; called += 1 }
270
+ run
271
+
272
+ called.should == 0
273
+ end
274
+ end
398
275
  end
399
276
  context Array do
400
277
  it 'injects all supplied payload' do
401
278
  payloads = [ 'stuff-here', 'stuff-here-2' ]
402
279
  injected = []
403
280
 
404
- @auditable.audit( payloads,
405
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |_, _, element|
406
- injected << element.opts[:injected_orig]
281
+ auditable.audit( payloads,
282
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ],
283
+ skip_original: true
284
+ ) do |_, element|
285
+ injected << element.affected_input_value
407
286
  end
408
287
 
409
- @auditor.http.run
288
+ run
410
289
  injected.uniq.sort.should == payloads.sort
411
290
  end
412
291
 
413
292
  context 'and is empty' do
414
293
  it 'returns nil' do
415
294
  injected = []
416
- @auditable.audit( [],
417
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |_, _, element|
418
- injected << element.opts[:injected_orig]
295
+ auditable.audit( [],
296
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ],
297
+ skip_original: true
298
+ ) do |_, element|
299
+ injected << element.affected_input_value
419
300
  end.should be_nil
420
301
 
421
- @auditor.http.run
302
+ run
422
303
  injected.should be_empty
423
304
  end
424
305
  end
@@ -436,13 +317,15 @@ shared_examples_for 'auditable' do |options = {}|
436
317
 
437
318
  injected = []
438
319
 
439
- @auditable.platforms.update %w(unix php apache)
440
- @auditable.audit( payloads,
441
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |_, _, element|
442
- injected << element.opts[:injected_orig]
320
+ auditable.platforms.update %w(unix php apache)
321
+ auditable.audit( payloads,
322
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ],
323
+ skip_original: true
324
+ ) do |_, element|
325
+ injected << element.affected_input_value
443
326
  end.should be_true
444
327
 
445
- @auditor.http.run
328
+ run
446
329
 
447
330
  payloads.delete( :windows )
448
331
  payloads.delete( :aspx )
@@ -453,12 +336,12 @@ shared_examples_for 'auditable' do |options = {}|
453
336
  context 'and is empty' do
454
337
  it 'returns nil' do
455
338
  injected = []
456
- @auditable.audit( {},
457
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |_, _, element|
458
- injected << element.opts[:injected_orig]
339
+ auditable.audit( {},
340
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ] ) do |_, element|
341
+ injected << element.affected_input_value
459
342
  end.should be_nil
460
343
 
461
- @auditor.http.run
344
+ run
462
345
  injected.should be_empty
463
346
  end
464
347
  end
@@ -467,8 +350,7 @@ shared_examples_for 'auditable' do |options = {}|
467
350
  it 'injects all given payloads' do
468
351
  payloads = {
469
352
  linux: [ 'linux-payload-1', 'linux-payload-2' ],
470
- freebsd: 'freebsd-payload',
471
- openbsd: [ 'openbsd-payload-1', 'openbsd-payload-2' ],
353
+ bsd: 'freebsd-payload',
472
354
  php: [ 'php-payload-1', 'php-payload-2' ],
473
355
  apache: 'apache-payload',
474
356
  windows: 'windows-payload',
@@ -477,12 +359,15 @@ shared_examples_for 'auditable' do |options = {}|
477
359
 
478
360
  injected = []
479
361
 
480
- @auditable.audit( payloads,
481
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |_, _, element|
482
- injected << element.opts[:injected_orig]
362
+ auditable.platforms.clear
363
+ auditable.audit( payloads,
364
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ],
365
+ skip_original: true
366
+ ) do |_, element|
367
+ injected << element.affected_input_value
483
368
  end.should be_true
484
369
 
485
- @auditor.http.run
370
+ run
486
371
 
487
372
  injected.uniq.sort.should == payloads.values.flatten.sort
488
373
  end
@@ -497,13 +382,13 @@ shared_examples_for 'auditable' do |options = {}|
497
382
 
498
383
  injected = []
499
384
 
500
- @auditable.platforms.update %w(unix php apache)
501
- @auditable.audit( payloads,
502
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |_, _, element|
503
- injected << element.opts[:injected_orig]
385
+ auditable.platforms.update %w(unix php apache)
386
+ auditable.audit( payloads,
387
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ] ) do |_, element|
388
+ injected << element.affected_input_value
504
389
  end.should be_nil
505
390
 
506
- @auditor.http.run
391
+ run
507
392
 
508
393
  payloads.delete( :windows )
509
394
  payloads.delete( :aspx )
@@ -516,9 +401,9 @@ shared_examples_for 'auditable' do |options = {}|
516
401
  describe 'other' do
517
402
  it 'raises ArgumentError' do
518
403
  expect do
519
- @auditable.audit( :stuff,
520
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |_, _, element|
521
- injected << element.opts[:injected_orig]
404
+ auditable.audit( :stuff,
405
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ] ) do |_, element|
406
+ injected << element.affected_input_value
522
407
  end
523
408
  end.to raise_error ArgumentError
524
409
  end
@@ -526,67 +411,88 @@ shared_examples_for 'auditable' do |options = {}|
526
411
  end
527
412
 
528
413
  context 'when called with option' do
414
+ describe :submit do
415
+ it 'uses them for the #submit call' do
416
+ options = { cookies: { stuff: 'blah' }}
417
+
418
+ called = false
419
+ each = proc do |mutation|
420
+ mutation.should receive(:submit).with(options)
421
+ called = true
422
+ end
423
+ auditable.audit( seed, each_mutation: each, submit: options ){}
424
+
425
+ called.should be_true
426
+ end
427
+ end
428
+
529
429
  describe :each_mutation do
530
430
  it 'is passed each generated mutation' do
431
+ pending if !has_parameter_extractor?
432
+
531
433
  submitted = nil
532
434
  cnt = 0
533
435
 
534
436
  each_mutation = proc { |_| cnt += 1 }
535
437
 
536
- @auditable.audit( @seed, each_mutation: each_mutation,
537
- skip_orig: true,
538
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |res, opts|
539
- submitted = load( res.body )
438
+ auditable.audit( seed, each_mutation: each_mutation,
439
+ skip_original: true,
440
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ] ) do |res, _|
441
+ submitted = auditable_extract_parameters( res )
540
442
  end
541
443
 
542
- @auditor.http.run
444
+ run
543
445
  cnt.should == 1
544
- @auditable.auditable == submitted
446
+ auditable.inputs == submitted
545
447
  end
546
448
 
547
449
  it 'is able to modify mutations on the fly' do
450
+ pending if !has_parameter_extractor?
451
+
548
452
  submitted = nil
549
453
 
550
454
  modified_seed = 'houa!'
551
455
  each_mutation = proc do |mutation|
552
- mutation.altered_value = modified_seed
456
+ mutation.affected_input_value = modified_seed
553
457
  end
554
458
 
555
- @auditable.audit( @seed, each_mutation: each_mutation,
556
- skip_orig: true,
557
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |res, opts|
558
- submitted = load( res.body )
459
+ auditable.audit( seed, each_mutation: each_mutation,
460
+ skip_original: true,
461
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ] ) do |res, _|
462
+ submitted = auditable_extract_parameters( res )
559
463
  end
560
464
 
561
- @auditor.http.run
465
+ run
562
466
  submitted.values.first.should == modified_seed
563
467
  end
564
468
 
565
469
  context 'when it returns one or more elements of the same type' do
566
470
  it 'audits those elements too' do
471
+ pending if !has_parameter_extractor?
472
+
567
473
  injected = []
568
474
  cnt = 0
569
475
 
570
476
  each_mutation = proc do |mutation|
571
477
  m = mutation.dup
572
- m.altered_value = 'houa!'
478
+ m.affected_input_value = 'houa!'
573
479
 
574
480
  c = mutation.dup
575
- c.altered_value = 'houa2!'
481
+ c.affected_input_value = 'houa2!'
576
482
 
577
483
  [m, c]
578
484
  end
579
485
 
580
- @auditable.audit( @seed, each_mutation: each_mutation,
581
- skip_orig: true,
582
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |res, opts|
583
- injected << load( res.body ).values.first
486
+ auditable.audit( seed, each_mutation: each_mutation,
487
+ skip_original: true,
488
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ] ) do |res, _|
489
+ injected << auditable_extract_parameters( res ).values.first
584
490
  cnt += 1
585
491
  end
586
492
 
587
- @auditor.http.run
493
+ run
588
494
  cnt.should == 3
589
- injected.sort.should == [ @seed, 'houa!', 'houa2!'].sort
495
+ injected.sort.should == [ seed, 'houa!', 'houa2!'].sort
590
496
  end
591
497
  end
592
498
  end
@@ -594,21 +500,14 @@ shared_examples_for 'auditable' do |options = {}|
594
500
  describe :skip_like do
595
501
  describe Proc do
596
502
  it 'skips mutations based on the block\'s return value' do
597
- auditable = described_class.new(
598
- @url + '/submit',
599
- 'param' => 'val',
600
- 'param2' => 'val2'
601
- )
602
- auditable.auditor = @auditor
603
-
604
503
  audited = []
605
- skip_like = proc { |m| m.altered != 'param' }
504
+ skip_like = proc { |m| m.affected_input_name != 'param' }
606
505
 
607
- auditable.audit( @seed, skip_orig: true, skip_like: skip_like ) do |_, _, m|
608
- audited << m.altered
506
+ auditable.audit( seed, skip_original: true, skip_like: skip_like ) do |_, m|
507
+ audited << m.affected_input_name
609
508
  end
610
509
 
611
- @auditor.http.run
510
+ run
612
511
 
613
512
  audited.uniq!
614
513
  audited.size.should == 1
@@ -618,24 +517,16 @@ shared_examples_for 'auditable' do |options = {}|
618
517
 
619
518
  describe Array do
620
519
  it 'skips mutations based on the blocks\' return value' do
621
- auditable = described_class.new(
622
- @url + '/submit',
623
- 'param' => 'val',
624
- 'param2' => 'val2',
625
- 'param3' => 'val3'
626
- )
627
- auditable.auditor = @auditor
628
-
629
520
  audited = []
630
521
  skip_like = []
631
- skip_like << proc { |m| m.altered == 'param2' }
632
- skip_like << proc { |m| m.altered == 'param3' }
522
+ skip_like << proc { |m| m.affected_input_name == 'param2' }
523
+ skip_like << proc { |m| m.affected_input_name == 'param3' }
633
524
 
634
- auditable.audit( @seed, skip_orig: true, skip_like: skip_like ) do |_, _, m|
635
- audited << m.altered
525
+ auditable.audit( seed, skip_original: true, skip_like: skip_like ) do |_, m|
526
+ audited << m.affected_input_name
636
527
  end
637
528
 
638
- @auditor.http.run
529
+ run
639
530
 
640
531
  audited.uniq!
641
532
  audited.size.should == 1
@@ -645,75 +536,83 @@ shared_examples_for 'auditable' do |options = {}|
645
536
  end
646
537
 
647
538
  describe :format do
648
- describe 'Arachni::Module::Auditor::Format::STRAIGHT' do
539
+ describe 'Arachni::Check::Auditor::Format::STRAIGHT' do
649
540
  it 'injects the seed as is' do
541
+ pending if !has_parameter_extractor?
542
+
650
543
  injected = nil
651
544
  cnt = 0
652
545
 
653
- @auditable.audit( @seed,
654
- skip_orig: true,
655
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ] ) do |res, opts|
656
- injected = load( res.body )[opts[:altered]]
546
+ auditable.audit( seed,
547
+ skip_original: true,
548
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ] ) do |res, e|
549
+ injected = auditable_extract_parameters( res )[e.affected_input_name]
657
550
  cnt += 1
658
551
  end
659
552
 
660
- @auditor.http.run
553
+ run
661
554
  cnt.should == 1
662
- injected.should == @seed
555
+ injected.should == seed
663
556
  end
664
557
  end
665
558
 
666
- describe 'Arachni::Module::Auditor::Format::APPEND' do
559
+ describe 'Arachni::Check::Auditor::Format::APPEND' do
667
560
  it 'appends the seed to the existing value of the input' do
561
+ pending if !has_parameter_extractor?
562
+
668
563
  injected = nil
669
564
  cnt = 0
670
565
 
671
- @auditable.audit( @seed,
672
- skip_orig: true,
673
- format: [ Arachni::Module::Auditor::Format::APPEND ] ) do |res, opts|
674
- injected = load( res.body )[opts[:altered]]
566
+ auditable.audit( seed,
567
+ skip_original: true,
568
+ format: [ Arachni::Check::Auditor::Format::APPEND ] ) do |res, e|
569
+ injected = auditable_extract_parameters( res )[e.affected_input_name]
675
570
  cnt += 1
676
571
  end
677
572
 
678
- @auditor.http.run
573
+ run
679
574
  cnt.should == 1
680
- injected.should == @default_input_value + @seed
575
+ injected.should == default_input_value + seed
681
576
  end
682
577
  end
683
578
 
684
- describe 'Arachni::Module::Auditor::Format::NULL' do
579
+ describe 'Arachni::Check::Auditor::Format::NULL' do
685
580
  it 'terminates the seed with a null character',
686
- if: described_class != Arachni::Element::Header do
581
+ if: described_class != Arachni::Element::Header &&
582
+ described_class.is_a?( Arachni::Element::Capabilities::Auditable::DOM ) do
583
+ pending if !has_parameter_extractor?
687
584
 
688
585
  injected = nil
689
586
  cnt = 0
690
- @auditable.audit( @seed,
691
- skip_orig: true,
692
- format: [ Arachni::Module::Auditor::Format::NULL ] ) do |res, opts|
693
- injected = load( res.body )[opts[:altered]]
587
+ auditable.audit( seed,
588
+ skip_original: true,
589
+ format: [ Arachni::Check::Auditor::Format::NULL ] ) do |res, e|
590
+ injected = auditable_extract_parameters( res )[e.affected_input_name]
694
591
  cnt += 1
695
592
  end
696
593
 
697
- @auditor.http.run
594
+ run
698
595
  cnt.should == 1
699
- auditable.decode( injected ).should == @seed + "\0"
596
+ auditable.decode( injected ).should == seed + "\0"
700
597
  end
701
598
  end
702
599
 
703
- describe 'Arachni::Module::Auditor::Format::SEMICOLON' do
600
+ describe 'Arachni::Check::Auditor::Format::SEMICOLON' do
704
601
  it 'prepends the seed with a semicolon' do
602
+ pending if !has_parameter_extractor?
603
+
705
604
  injected = nil
706
605
  cnt = 0
707
606
 
708
- format = [ Arachni::Module::Auditor::Format::SEMICOLON ]
709
- @auditable.audit( @seed, skip_orig: true, format: format ) do |res, opts|
710
- injected = load( res.body )[opts[:altered]]
607
+ format = [ Arachni::Check::Auditor::Format::SEMICOLON ]
608
+ auditable.audit( seed, skip_original: true, format: format ) do |res, e|
609
+ injected = auditable_extract_parameters( res )[e.affected_input_name]
711
610
  cnt += 1
712
611
  end
713
- @auditor.http.run
612
+ run
714
613
  cnt.should == 1
715
614
 
716
- auditable.decode( injected ).should == ";" + @seed
615
+ auditable.decode( injected ).should == ";" + seed
717
616
  end
718
617
  end
719
618
  end
@@ -721,8 +620,8 @@ shared_examples_for 'auditable' do |options = {}|
721
620
  describe :redundant do
722
621
  before do
723
622
  @audit_opts = {
724
- format: [ Arachni::Module::Auditor::Format::STRAIGHT ],
725
- skip_orig: true
623
+ format: [ Arachni::Check::Auditor::Format::STRAIGHT ],
624
+ skip_original: true
726
625
  }
727
626
  end
728
627
 
@@ -730,9 +629,9 @@ shared_examples_for 'auditable' do |options = {}|
730
629
  it 'allows redundant audits' do
731
630
  cnt = 0
732
631
  5.times do |i|
733
- @auditable.audit( @seed, @audit_opts.merge( redundant: true )){ cnt += 1 }
632
+ auditable.audit( seed, @audit_opts.merge( redundant: true )){ cnt += 1 }
734
633
  end
735
- @auditor.http.run
634
+ run
736
635
  cnt.should == 5
737
636
  end
738
637
  end
@@ -741,9 +640,9 @@ shared_examples_for 'auditable' do |options = {}|
741
640
  it 'does not allow redundant requests/audits' do
742
641
  cnt = 0
743
642
  5.times do |i|
744
- @auditable.audit( @seed, @audit_opts.merge( redundant: false )){ cnt += 1 }
643
+ auditable.audit( seed, @audit_opts.merge( redundant: false )){ cnt += 1 }
745
644
  end
746
- @auditor.http.run
645
+ run
747
646
  cnt.should == 1
748
647
  end
749
648
  end
@@ -752,138 +651,78 @@ shared_examples_for 'auditable' do |options = {}|
752
651
  it 'does not allow redundant requests/audits' do
753
652
  cnt = 0
754
653
  5.times do |i|
755
- @auditable.audit( @seed, @audit_opts ){ cnt += 1 }
654
+ auditable.audit( seed, @audit_opts ){ cnt += 1 }
756
655
  end
757
- @auditor.http.run
656
+ run
758
657
  cnt.should == 1
759
658
  end
760
659
  end
761
660
  end
762
-
763
- describe :async do
764
-
765
- context true do
766
- it 'performs all HTTP requests asynchronously' do
767
- before = Time.now
768
- @sleep.audit( @seed, async: true ){}
769
- @auditor.http.run
770
-
771
- # should take as long as the longest request
772
- # and since we're doing this locally the longest
773
- # request must take less than a second.
774
- #
775
- # so it should be 2 when converted into an Int
776
- (Time.now - before).to_i.should == 2
777
- end
778
- end
779
-
780
- context false do
781
- it 'performs all HTTP requests synchronously' do
782
- before = Time.now
783
- @sleep.audit( @seed, async: false ){}
784
- @auditor.http.run
785
-
786
- (Time.now - before).should > 4.0
787
- end
788
- end
789
-
790
- context 'default' do
791
- it 'performs all HTTP requests asynchronously' do
792
- before = Time.now
793
- @sleep.audit( @seed ){}
794
- @auditor.http.run
795
-
796
- (Time.now - before).to_i.should == 2
797
- end
798
- end
799
-
800
- end
801
661
  end
802
662
 
803
- context 'when the exclude_vectors option is set' do
663
+ context "when the #{Arachni::OptionGroups::Audit}#exclude_vector_patterns option is set" do
804
664
  it 'skips those vectors by name' do
805
- e = auditable.new( @url + '/submit', 'include_this' => 'param', 'exclude_this' => 'param' )
806
-
807
- Arachni::Options.exclude_vectors << 'exclude_this'
808
- Arachni::Options.exclude_vectors << Arachni::Element::Form::ORIGINAL_VALUES
665
+ Arachni::Options.audit.exclude_vector_patterns = auditable.inputs.keys
809
666
 
810
667
  audited = []
811
- e.audit( @seed ) { |_, _, elem| audited << elem.altered }.should be_true
812
- e.http.run
668
+ auditable.audit( seed, skip_original: true ) do |_, elem|
669
+ audited << elem.affected_input_name
670
+ end.should be_true
813
671
 
814
- audited.uniq.should == %w(include_this)
815
- end
816
- end
817
- context 'when called with no opts' do
818
- it 'uses the defaults' do
819
- cnt = 0
820
- @auditable.audit( @seed ) { cnt += 1 }
821
- @auditor.http.run
822
- cnt.should == 4
672
+ run
673
+ audited.should be_empty
823
674
  end
824
675
  end
825
676
 
826
- context 'when it has no auditor' do
827
- it 'falls back to using the anonymous auditor' do
828
- elem = auditable.new( @url, 'param' => 'val' )
829
- elem.auditor.should be_nil
830
-
831
- elem.taint_analysis( 'test' )
832
- elem.auditor.should be_true
833
- elem.http.run
834
-
835
- elem.auditor.issues.size.should == 1
836
- elem.auditor.raw_issues.size.should == 1
837
- issue = elem.auditor.raw_issues.first
838
- issue.elem.should == elem.type
839
- issue.id.should == 'test'
840
- issue.method.to_s.downcase.should == 'get'
841
- issue.name.should == 'Anonymous auditor'
842
- issue.var.should == 'param'
843
-
844
- elem.auditor.raw_issues.should == Arachni::Module::Manager.results
845
- elem.auditor.issues.should == elem.auditor.auditstore.issues
846
- elem.auditor.auditstore.should == Arachni::AuditStore.new(
847
- options: Arachni::Options.instance.to_h,
848
- issues: issues )
849
- end
850
- end
677
+ context "when #{Arachni::OptionGroups::Audit}#vector?" do
678
+ context 'returns true' do
679
+ it 'audits the input' do
680
+ Arachni::Options.audit.stub(:vector?){ true }
851
681
 
852
- context 'when the action matches a #skip_path? rule' do
853
- it 'returns immediately' do
854
- ran = false
855
- @auditable.audit( @seed ) { ran = true }
856
- @auditor.http.run
857
- ran.should be_true
682
+ audited = []
683
+ auditable.audit( seed, skip_original: true ) do |_, elem|
684
+ audited << elem.affected_input_name
685
+ end.should be_true
858
686
 
859
- Arachni::Element::Capabilities::Auditable.reset
687
+ run
688
+ audited.should_not be_empty
689
+ end
690
+ end
860
691
 
861
- opts = Arachni::Options.instance
862
- opts.exclude << @auditable.action
692
+ context 'returns false' do
693
+ it 'skips the input' do
694
+ Arachni::Options.audit.stub(:vector?){ false }
863
695
 
864
- ran = false
865
- @auditable.audit( @seed ) { ran = true }
866
- @auditor.http.run
867
- ran.should be_false
696
+ audited = []
697
+ auditable.audit( seed, skip_original: true ) do |_, elem|
698
+ audited << elem.affected_input_name
699
+ end.should be_true
868
700
 
869
- opts.exclude.clear
701
+ run
702
+ audited.should be_empty
703
+ end
704
+ end
705
+ end
870
706
 
871
- Arachni::Element::Capabilities::Auditable.reset
707
+ context "when #{described_class::Scope}#out?" do
708
+ context true do
709
+ it 'returns immediately' do
710
+ described_class::Scope.any_instance.stub(:out?) { true }
872
711
 
873
- ran = false
874
- @auditable.audit( @seed ) { ran = true }
875
- @auditor.http.run
876
- ran.should be_true
712
+ ran = false
713
+ auditable.audit( seed ) { ran = true }.should be_false
714
+ run
715
+ ran.should be_false
716
+ end
877
717
  end
878
718
  end
879
719
 
880
720
  context 'when the element has no auditable inputs' do
881
721
  it 'returns immediately' do
882
- e = auditable.new( @url + '/submit' )
883
-
884
722
  ran = false
885
- e.audit( @seed ) { ran = true }.should be_false
886
- e.http.run
723
+ auditable.inputs = {}
724
+ auditable.audit( seed ) { ran = true }.should be_false
725
+ run
887
726
 
888
727
  ran.should be_false
889
728
  end
@@ -893,135 +732,63 @@ shared_examples_for 'auditable' do |options = {}|
893
732
  it 'is skipped' do
894
733
 
895
734
  ran = false
896
- @auditable.audit( @seed ) { ran = true }.should be_true
897
- @auditor.http.run
735
+ auditable.audit( seed ) { ran = true }.should be_true
736
+ run
898
737
  ran.should be_true
899
738
 
900
739
  Arachni::Element::Capabilities::Auditable.reset
901
740
 
902
- def @auditor.skip?( elem )
741
+ def auditor.skip?( elem )
903
742
  true
904
743
  end
905
744
 
906
745
  ran = false
907
- @auditable.audit( @seed ) { ran = true }.should be_true
908
- @auditor.http.run
746
+ auditable.audit( seed ) { ran = true }.should be_true
747
+ run
909
748
  ran.should be_false
910
749
 
911
750
  Arachni::Element::Capabilities::Auditable.reset
912
751
 
913
- def @auditor.skip?( elem )
752
+ def auditor.skip?( elem )
914
753
  false
915
754
  end
916
755
 
917
756
  ran = false
918
- @auditable.audit( @seed ) { ran = true }.should be_true
919
- @auditor.http.run
757
+ auditable.audit( seed ) { ran = true }.should be_true
758
+ run
920
759
  ran.should be_true
921
760
  end
922
761
  end
923
762
 
924
763
  context 'when the element\'s #skip? method returns true for a mutation' do
925
764
  it 'is skipped' do
926
-
927
765
  ran = false
928
- @auditable.audit( @seed ) { ran = true }.should be_true
929
- @auditor.http.run
766
+ auditable.audit( seed ) { ran = true }.should be_true
767
+ run
930
768
  ran.should be_true
931
769
 
932
770
  Arachni::Element::Capabilities::Auditable.reset
933
771
 
934
- def @auditable.skip?( elem )
772
+ def auditable.skip?( elem )
935
773
  true
936
774
  end
937
775
 
938
776
  ran = false
939
- @auditable.audit( @seed ) { ran = true }.should be_true
940
- @auditor.http.run
777
+ auditable.audit( seed ) { ran = true }.should be_true
778
+ run
941
779
  ran.should be_false
942
780
 
943
781
  Arachni::Element::Capabilities::Auditable.reset
944
782
 
945
- def @auditable.skip?( elem )
783
+ def auditable.skip?( elem )
946
784
  false
947
785
  end
948
786
 
949
787
  ran = false
950
- @auditable.audit( @seed ) { ran = true }.should be_true
951
- @auditor.http.run
788
+ auditable.audit( seed ) { ran = true }.should be_true
789
+ run
952
790
  ran.should be_true
953
791
  end
954
792
  end
955
-
956
- describe '.restrict_to_elements' do
957
- after { Arachni::Element::Capabilities::Auditable.reset_instance_scope }
958
-
959
- context 'when set' do
960
- it 'restricts the audit to the provided elements' do
961
- scope_id_arr = [ @auditable.scope_audit_id ]
962
- Arachni::Element::Capabilities::Auditable.restrict_to_elements( scope_id_arr )
963
- performed = false
964
- @sleep.audit( '' ){ performed = true }
965
- @sleep.http.run
966
- performed.should be_false
967
-
968
- performed = false
969
- @auditable.audit( '' ){ performed = true }
970
- @auditable.http.run
971
- performed.should be_true
972
- end
973
-
974
- describe '#override_instance_scope' do
975
-
976
- after { @sleep.reset_scope_override }
977
-
978
- context 'when called' do
979
- it 'overrides scope restrictions' do
980
- scope_id_arr = [ @auditable.scope_audit_id ]
981
- Arachni::Element::Capabilities::Auditable.restrict_to_elements( scope_id_arr )
982
- performed = false
983
- @sleep.audit( '' ){ performed = true }
984
- @sleep.http.run
985
- performed.should be_false
986
-
987
- @sleep.override_instance_scope
988
- performed = false
989
- @sleep.audit( '' ){ performed = true }
990
- @sleep.http.run
991
- performed.should be_true
992
- end
993
-
994
- describe '#override_instance_scope?' do
995
- it 'returns true' do
996
- @sleep.override_instance_scope
997
- @sleep.override_instance_scope?.should be_true
998
- end
999
- end
1000
- end
1001
-
1002
- context 'when not called' do
1003
- describe '#override_instance_scope?' do
1004
- it 'returns false' do
1005
- @sleep.override_instance_scope?.should be_false
1006
- end
1007
- end
1008
- end
1009
- end
1010
- end
1011
-
1012
- context 'when not set' do
1013
- it 'does not impose audit restrictions' do
1014
- performed = false
1015
- @sleep.audit( '' ){ performed = true }
1016
- @sleep.http.run
1017
- performed.should be_true
1018
-
1019
- performed = false
1020
- @auditable.audit( '' ){ performed = true }
1021
- @auditable.http.run
1022
- performed.should be_true
1023
- end
1024
- end
1025
- end
1026
793
  end
1027
794
  end