watobo 0.9.19 → 0.9.20

Sign up to get free protection for your applications and to get access to all the features.
Files changed (266) hide show
  1. data/CHANGELOG.md +104 -0
  2. data/bin/nfq_server.rb +8 -20
  3. data/bin/watobo_gui.rb +8 -20
  4. data/config/forwarding_proxy.yml +2 -2
  5. data/lib/watobo.rb +12 -22
  6. data/lib/watobo/adapters.rb +12 -24
  7. data/lib/watobo/adapters/data_store.rb +76 -66
  8. data/lib/watobo/adapters/file/file_store.rb +295 -307
  9. data/lib/watobo/adapters/session_store.rb +13 -25
  10. data/lib/watobo/ca.rb +9 -21
  11. data/lib/watobo/config.rb +205 -217
  12. data/lib/watobo/constants.rb +8 -20
  13. data/lib/watobo/core.rb +11 -23
  14. data/lib/watobo/core/active_check.rb +11 -21
  15. data/lib/watobo/core/active_checks.rb +57 -69
  16. data/lib/watobo/core/ca.rb +388 -398
  17. data/lib/watobo/core/cert_store.rb +42 -54
  18. data/lib/watobo/core/chat.rb +100 -112
  19. data/lib/watobo/core/chats.rb +271 -275
  20. data/lib/watobo/core/client_cert_store.rb +33 -45
  21. data/lib/watobo/core/conversation.rb +56 -68
  22. data/lib/watobo/core/cookie.rb +31 -43
  23. data/lib/watobo/core/finding.rb +74 -86
  24. data/lib/watobo/core/findings.rb +113 -125
  25. data/lib/watobo/core/forwarding_proxy.rb +44 -35
  26. data/lib/watobo/core/fuzz_gen.rb +8 -20
  27. data/lib/watobo/core/intercept_carver.rb +176 -188
  28. data/lib/watobo/core/intercept_filter.rb +243 -255
  29. data/lib/watobo/core/interceptor.rb +106 -118
  30. data/lib/watobo/core/min_class.rb +12 -24
  31. data/lib/watobo/core/netfilter_queue.rb +178 -190
  32. data/lib/watobo/core/ott_cache.rb +152 -148
  33. data/lib/watobo/core/parameter.rb +53 -58
  34. data/lib/watobo/core/passive_check.rb +8 -20
  35. data/lib/watobo/core/passive_checks.rb +56 -68
  36. data/lib/watobo/core/passive_scanner.rb +54 -66
  37. data/lib/watobo/core/plugin.rb +19 -31
  38. data/lib/watobo/core/project.rb +8 -20
  39. data/lib/watobo/core/proxy.rb +51 -63
  40. data/lib/watobo/core/request.rb +128 -120
  41. data/lib/watobo/core/response.rb +59 -61
  42. data/lib/watobo/core/scanner.rb +8 -20
  43. data/lib/watobo/core/scanner3.rb +413 -425
  44. data/lib/watobo/core/scope.rb +91 -103
  45. data/lib/watobo/core/session.rb +109 -87
  46. data/lib/watobo/core/sid_cache.rb +106 -118
  47. data/lib/watobo/core/subscriber.rb +33 -45
  48. data/lib/watobo/defaults.rb +29 -41
  49. data/lib/watobo/external/diff/lcs.rb +8 -20
  50. data/lib/watobo/external/diff/lcs/array.rb +8 -20
  51. data/lib/watobo/external/diff/lcs/block.rb +8 -20
  52. data/lib/watobo/external/diff/lcs/callbacks.rb +8 -20
  53. data/lib/watobo/external/diff/lcs/change.rb +8 -20
  54. data/lib/watobo/external/diff/lcs/hunk.rb +8 -20
  55. data/lib/watobo/external/diff/lcs/ldiff.rb +8 -20
  56. data/lib/watobo/external/diff/lcs/string.rb +8 -20
  57. data/lib/watobo/externals.rb +14 -26
  58. data/lib/watobo/framework.rb +12 -24
  59. data/lib/watobo/framework/create_project.rb +68 -80
  60. data/lib/watobo/framework/init.rb +8 -20
  61. data/lib/watobo/framework/init_modules.rb +8 -20
  62. data/lib/watobo/framework/license_text.rb +36 -48
  63. data/lib/watobo/framework/load_chat.rb +21 -33
  64. data/lib/watobo/gui.rb +121 -133
  65. data/lib/watobo/gui/about_watobo.rb +8 -20
  66. data/lib/watobo/gui/browser_preview.rb +8 -20
  67. data/lib/watobo/gui/certificate_dialog.rb +8 -20
  68. data/lib/watobo/gui/chat_diff.rb +11 -21
  69. data/lib/watobo/gui/chatviewer_frame.rb +10 -22
  70. data/lib/watobo/gui/checkboxtree.rb +8 -20
  71. data/lib/watobo/gui/checks_policy_frame.rb +8 -20
  72. data/lib/watobo/gui/client_cert_dialog.rb +10 -21
  73. data/lib/watobo/gui/confirm_scan_dialog.rb +8 -20
  74. data/lib/watobo/gui/conversation_table.rb +54 -44
  75. data/lib/watobo/gui/conversation_table_ctrl.rb +215 -227
  76. data/lib/watobo/gui/conversation_table_ctrl2.rb +385 -393
  77. data/lib/watobo/gui/csrf_token_dialog.rb +11 -25
  78. data/lib/watobo/gui/custom_viewer.rb +357 -369
  79. data/lib/watobo/gui/dashboard.rb +8 -20
  80. data/lib/watobo/gui/define_scope_frame.rb +8 -20
  81. data/lib/watobo/gui/differ_frame.rb +223 -235
  82. data/lib/watobo/gui/edit_comment.rb +8 -20
  83. data/lib/watobo/gui/edit_scope_dialog.rb +8 -20
  84. data/lib/watobo/gui/export_dialog.rb +114 -0
  85. data/lib/watobo/gui/finding_info.rb +9 -21
  86. data/lib/watobo/gui/findings_tree.rb +8 -20
  87. data/lib/watobo/gui/full_scan_dialog.rb +8 -20
  88. data/lib/watobo/gui/fuzzer_gui.rb +8 -20
  89. data/lib/watobo/gui/goto_url_dialog.rb +78 -90
  90. data/lib/watobo/gui/hex_viewer.rb +25 -27
  91. data/lib/watobo/gui/html_viewer.rb +295 -307
  92. data/lib/watobo/gui/intercept_filter_dialog.rb +196 -208
  93. data/lib/watobo/gui/interceptor_gui.rb +1046 -1041
  94. data/lib/watobo/gui/interceptor_settings_dialog.rb +8 -20
  95. data/lib/watobo/gui/list_box.rb +109 -121
  96. data/lib/watobo/gui/log_file_viewer.rb +40 -52
  97. data/lib/watobo/gui/log_viewer.rb +87 -99
  98. data/lib/watobo/gui/login_wizzard.rb +8 -20
  99. data/lib/watobo/gui/main_window.rb +34 -33
  100. data/lib/watobo/gui/manual_request_editor.rb +25 -35
  101. data/lib/watobo/gui/master_pw_dialog.rb +8 -20
  102. data/lib/watobo/gui/mixins/gui_settings.rb +37 -49
  103. data/lib/watobo/gui/page_tree.rb +225 -237
  104. data/lib/watobo/gui/password_policy_dialog.rb +8 -20
  105. data/lib/watobo/gui/plugin_board.rb +8 -20
  106. data/lib/watobo/gui/preferences_dialog.rb +8 -20
  107. data/lib/watobo/gui/progress_window.rb +8 -20
  108. data/lib/watobo/gui/project_wizzard.rb +8 -20
  109. data/lib/watobo/gui/proxy_dialog.rb +117 -85
  110. data/lib/watobo/gui/quick_scan_dialog.rb +8 -20
  111. data/lib/watobo/gui/request_builder_frame.rb +125 -122
  112. data/lib/watobo/gui/request_editor.rb +53 -28
  113. data/lib/watobo/gui/rewrite_filters_dialog.rb +402 -414
  114. data/lib/watobo/gui/rewrite_rules_dialog.rb +380 -392
  115. data/lib/watobo/gui/save_chat_dialog.rb +148 -160
  116. data/lib/watobo/gui/scanner_settings_dialog.rb +8 -20
  117. data/lib/watobo/gui/select_chat_dialog.rb +8 -20
  118. data/lib/watobo/gui/session_management_dialog.rb +8 -20
  119. data/lib/watobo/gui/sites_tree.rb +118 -22
  120. data/lib/watobo/gui/status_bar.rb +8 -20
  121. data/lib/watobo/gui/table_editor.rb +76 -53
  122. data/lib/watobo/gui/tagless_viewer.rb +10 -21
  123. data/lib/watobo/gui/templates/plugin.rb +8 -20
  124. data/lib/watobo/gui/templates/plugin2.rb +99 -111
  125. data/lib/watobo/gui/templates/plugin_base.rb +152 -164
  126. data/lib/watobo/gui/text_viewer.rb +8 -20
  127. data/lib/watobo/gui/transcoder_window.rb +15 -22
  128. data/lib/watobo/gui/utils/gui_utils.rb +8 -20
  129. data/lib/watobo/gui/utils/init_icons.rb +94 -106
  130. data/lib/watobo/gui/utils/load_icons.rb +41 -53
  131. data/lib/watobo/gui/utils/load_plugins.rb +118 -130
  132. data/lib/watobo/gui/utils/master_password.rb +76 -88
  133. data/lib/watobo/gui/utils/save_default_settings.rb +121 -133
  134. data/lib/watobo/gui/utils/save_project_settings.rb +8 -20
  135. data/lib/watobo/gui/utils/save_proxy_settings.rb +53 -21
  136. data/lib/watobo/gui/utils/save_scanner_settings.rb +26 -38
  137. data/lib/watobo/gui/utils/session_history.rb +120 -132
  138. data/lib/watobo/gui/workspace_dialog.rb +8 -20
  139. data/lib/watobo/gui/www_auth_dialog.rb +8 -20
  140. data/lib/watobo/gui/xml_viewer_frame.rb +8 -20
  141. data/lib/watobo/http.rb +12 -23
  142. data/lib/watobo/http/cookies/cookies.rb +63 -70
  143. data/lib/watobo/http/data/data.rb +56 -64
  144. data/lib/watobo/http/data/json.rb +51 -0
  145. data/lib/watobo/http/url/url.rb +46 -58
  146. data/lib/watobo/http/xml/xml.rb +129 -141
  147. data/lib/watobo/interceptor.rb +11 -23
  148. data/lib/watobo/interceptor/proxy.rb +624 -625
  149. data/lib/watobo/interceptor/transparent.rb +22 -34
  150. data/lib/watobo/mixins.rb +18 -30
  151. data/lib/watobo/mixins/check_info.rb +35 -47
  152. data/lib/watobo/mixins/httpparser.rb +42 -35
  153. data/lib/watobo/mixins/request_parser.rb +8 -20
  154. data/lib/watobo/mixins/shapers.rb +484 -477
  155. data/lib/watobo/mixins/transcoders.rb +8 -20
  156. data/lib/watobo/parser.rb +9 -21
  157. data/lib/watobo/parser/html.rb +91 -103
  158. data/lib/watobo/sockets.rb +11 -23
  159. data/lib/watobo/sockets/agent.rb +836 -848
  160. data/lib/watobo/sockets/client_socket.rb +283 -277
  161. data/lib/watobo/sockets/connection.rb +409 -421
  162. data/lib/watobo/sockets/http_socket.rb +16 -23
  163. data/lib/watobo/sockets/ntlm_auth.rb +137 -149
  164. data/lib/watobo/utils.rb +18 -30
  165. data/lib/watobo/utils/check_regex.rb +8 -20
  166. data/lib/watobo/utils/copy_object.rb +8 -20
  167. data/lib/watobo/utils/crypto.rb +8 -20
  168. data/lib/watobo/utils/expand_range.rb +31 -43
  169. data/lib/watobo/utils/export_xml.rb +108 -0
  170. data/lib/watobo/utils/file_management.rb +8 -20
  171. data/lib/watobo/utils/hexprint.rb +17 -29
  172. data/lib/watobo/utils/load_chat.rb +8 -20
  173. data/lib/watobo/utils/load_icon.rb +8 -20
  174. data/lib/watobo/{external/ntlm → utils}/ntlm.rb +874 -796
  175. data/lib/watobo/utils/print_debug.rb +20 -32
  176. data/lib/watobo/utils/response_builder.rb +98 -110
  177. data/lib/watobo/utils/response_hash.rb +9 -20
  178. data/lib/watobo/utils/secure_eval.rb +10 -22
  179. data/lib/watobo/utils/strings.rb +18 -30
  180. data/lib/watobo/utils/text2request.rb +12 -20
  181. data/lib/watobo/utils/url.rb +31 -43
  182. data/lib/watobo/utils/utf16.rb +22 -0
  183. data/modules/active/Apache/mod_status.rb +9 -0
  184. data/modules/active/Apache/multiview.rb +161 -0
  185. data/modules/active/Flash/crossdomain.rb +9 -0
  186. data/modules/active/directories/dirwalker.rb +8 -20
  187. data/modules/active/discovery/fileextensions.rb +10 -22
  188. data/modules/active/discovery/http_methods.rb +8 -20
  189. data/modules/active/domino/domino_db.rb +8 -20
  190. data/modules/active/dotNET/custom_errors.rb +110 -122
  191. data/modules/active/dotNET/dotnet_files.rb +98 -110
  192. data/modules/active/fileinclusion/lfi_simple.rb +8 -20
  193. data/modules/active/jboss/jboss_basic.rb +8 -20
  194. data/modules/active/sap/business_objects.rb +63 -0
  195. data/modules/active/sap/its_commands.rb +8 -20
  196. data/modules/active/sap/its_service_parameter.rb +8 -20
  197. data/modules/active/sap/its_services.rb +8 -20
  198. data/modules/active/sap/its_xss.rb +8 -20
  199. data/modules/active/shell_shock/shell_shock.rb +149 -0
  200. data/modules/active/siebel/siebel_apps.rb +168 -180
  201. data/modules/active/sqlinjection/sql_boolean.rb +9 -21
  202. data/modules/active/sqlinjection/sqli_error.rb +10 -22
  203. data/modules/active/sqlinjection/sqli_timing.rb +228 -240
  204. data/modules/active/struts2/default_handler_ognl.rb +114 -126
  205. data/modules/active/struts2/include_params_ognl.rb +113 -125
  206. data/modules/active/xml/xml_xxe.rb +122 -127
  207. data/modules/active/xss/xss_ng.rb +223 -234
  208. data/modules/active/xss/xss_simple.rb +8 -20
  209. data/modules/passive/ajax.rb +76 -84
  210. data/modules/passive/autocomplete.rb +64 -76
  211. data/modules/passive/cookie_options.rb +8 -20
  212. data/modules/passive/cookie_xss.rb +9 -21
  213. data/modules/passive/detect_code.rb +9 -21
  214. data/modules/passive/detect_fileupload.rb +11 -22
  215. data/modules/passive/detect_infrastructure.rb +23 -35
  216. data/modules/passive/detect_one_time_tokens.rb +8 -20
  217. data/modules/passive/dirindexing.rb +9 -21
  218. data/modules/passive/disclosure_domino.rb +66 -79
  219. data/modules/passive/disclosure_emails.rb +9 -21
  220. data/modules/passive/disclosure_ipaddr.rb +15 -23
  221. data/modules/passive/filename_as_parameter.rb +8 -20
  222. data/modules/passive/form_spotter.rb +15 -21
  223. data/modules/passive/hidden_fields.rb +64 -70
  224. data/modules/passive/hotspots.rb +13 -22
  225. data/modules/passive/in_script_parameter.rb +15 -24
  226. data/modules/passive/multiple_server_headers.rb +8 -20
  227. data/modules/passive/possible_login.rb +12 -23
  228. data/modules/passive/redirect_url.rb +10 -22
  229. data/modules/passive/redirectionz.rb +9 -21
  230. data/modules/passive/sap-headers.rb +64 -76
  231. data/modules/passive/xss_dom.rb +10 -21
  232. data/plugins/catalog/catalog.rb +17 -23
  233. data/plugins/crawler/crawler.rb +12 -24
  234. data/plugins/crawler/gui.rb +13 -25
  235. data/plugins/crawler/gui/auth_frame.rb +278 -290
  236. data/plugins/crawler/gui/crawler_gui.rb +302 -320
  237. data/plugins/crawler/gui/general_settings_frame.rb +104 -116
  238. data/plugins/crawler/gui/hooks_frame.rb +88 -100
  239. data/plugins/crawler/gui/scope_frame.rb +58 -70
  240. data/plugins/crawler/gui/settings_tabbook.rb +46 -58
  241. data/plugins/crawler/gui/status_frame.rb +67 -78
  242. data/plugins/crawler/lib/bags.rb +26 -38
  243. data/plugins/crawler/lib/constants.rb +19 -31
  244. data/plugins/crawler/lib/engine.rb +505 -508
  245. data/plugins/crawler/lib/grabber.rb +77 -87
  246. data/plugins/crawler/lib/status.rb +82 -0
  247. data/plugins/crawler/lib/uri_mp.rb +20 -32
  248. data/plugins/filefinder/dbs/siebel_paths.txt +1118 -0
  249. data/plugins/filefinder/dbs/subs-big.lst +31986 -0
  250. data/plugins/filefinder/filefinder.rb +13 -23
  251. data/plugins/sqlmap/bin/test.rb +86 -98
  252. data/plugins/sqlmap/gui.rb +12 -24
  253. data/plugins/sqlmap/gui/main.rb +226 -238
  254. data/plugins/sqlmap/gui/options_frame.rb +105 -117
  255. data/plugins/sqlmap/lib/sqlmap_ctrl.rb +103 -115
  256. data/plugins/sqlmap/sqlmap.rb +10 -22
  257. data/plugins/sslchecker/cli/sslchecker_cli.rb +8 -20
  258. data/plugins/sslchecker/gui/cipher_table.rb +252 -264
  259. data/plugins/sslchecker/gui/gui.rb +267 -276
  260. data/plugins/sslchecker/gui/sslchecker.rb +12 -24
  261. data/plugins/sslchecker/lib/check.rb +172 -80
  262. data/plugins/wshell/gui/main.rb +115 -127
  263. data/plugins/wshell/lib/core.rb +85 -97
  264. data/plugins/wshell/wshell.rb +19 -31
  265. metadata +14 -6
  266. data/.yardopts +0 -24
@@ -1,26 +1,14 @@
1
- # .
1
+ #.
2
2
  # sslchecker.rb
3
- #
4
- # Copyright 2013 by siberas, http://www.siberas.de
5
- #
6
- # This file is part of WATOBO (Web Application Tool Box)
7
- # http://watobo.sourceforge.com
8
- #
9
- # WATOBO is free software; you can redistribute it and/or modify
10
- # it under the terms of the GNU General Public License as published by
11
- # the Free Software Foundation version 2 of the License.
12
- #
13
- # WATOBO is distributed in the hope that it will be useful,
14
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
15
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
- # GNU General Public License for more details.
17
- #
18
- # You should have received a copy of the GNU General Public License
19
- # along with WATOBO; if not, write to the Free Software
20
- # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21
- # .
22
- #path = File.expand_path(File.dirname(__FILE__))
3
+ #.
4
+ # Copyright 2014 by siberas, http://www.siberas.de
5
+ # This file is part of WATOBO (Web Application Tool Box) http://watobo.sourceforge.com
6
+ # WATOBO is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation version 2 of the License.
7
+ # WATOBO is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
8
+ # You should have received a copy of the GNU General Public License along with WATOBO; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
23
9
 
24
- require_relative File.join( "..", "lib", "check")
25
- require_relative "cipher_table"
26
- require_relative "gui"
10
+ #path = File.expand_path(File.dirname(__FILE__))
11
+
12
+ require_relative File.join( "..", "lib", "check")
13
+ require_relative "cipher_table"
14
+ require_relative "gui"
@@ -1,82 +1,118 @@
1
- # .
1
+ #.
2
2
  # check.rb
3
- #
4
- # Copyright 2013 by siberas, http://www.siberas.de
5
- #
6
- # This file is part of WATOBO (Web Application Tool Box)
7
- # http://watobo.sourceforge.com
8
- #
9
- # WATOBO is free software; you can redistribute it and/or modify
10
- # it under the terms of the GNU General Public License as published by
11
- # the Free Software Foundation version 2 of the License.
12
- #
13
- # WATOBO is distributed in the hope that it will be useful,
14
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
15
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
- # GNU General Public License for more details.
17
- #
18
- # You should have received a copy of the GNU General Public License
19
- # along with WATOBO; if not, write to the Free Software
20
- # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21
- # .
3
+ #.
4
+ # Copyright 2014 by siberas, http://www.siberas.de
5
+ # This file is part of WATOBO (Web Application Tool Box) http://watobo.sourceforge.com
6
+ # WATOBO is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation version 2 of the License.
7
+ # WATOBO is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
8
+ # You should have received a copy of the GNU General Public License along with WATOBO; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
9
+
22
10
  # @private
23
- module Watobo#:nodoc: all
24
- module Plugin
25
- module Sslchecker
26
- class Check < Watobo::ActiveCheck
27
- attr :cipherlist
11
+ module Watobo#:nodoc: all
12
+ module Plugin
13
+ module Sslchecker
14
+ class Check < Watobo::ActiveCheck
15
+ attr :cipherlist
16
+
17
+ @info.update(
18
+ :check_name => 'SSL-Checker', # name of check which briefly describes functionality, will be used for tree and progress views
19
+ :description => "Test applikation for supportes SSL Ciphers.", # description of checkfunction
20
+ :author => "Andreas Schmidt", # author of check
21
+ :version => "0.9" # check version
22
+ )
23
+
24
+ @finding.update(
25
+ :threat => 'Attacks on weak encryption ciphers which may lead loss of privacy', # thread of vulnerability, e.g. loss of information
26
+ :class => "SSL Ciphers", # vulnerability class, e.g. Stored XSS, SQL-Injection, ...
27
+ :type => FINDING_TYPE_VULN, # FINDING_TYPE_HINT, FINDING_TYPE_INFO, FINDING_TYPE_VULN
28
+ :rating => VULN_RATING_LOW
29
+ )
30
+
31
+
32
+ def initialize(project)
33
+ super(project)
34
+
35
+ @result = Hash.new
36
+ @cipherlist = Array.new
37
+
38
+
39
+ OpenSSL::SSL::SSLContext::METHODS.each do |method|
40
+ next if method =~ /(client|server)/
41
+ next if method =~ /23/
42
+ #%w( TLSv1_server SSLv2_server SSLv3_server ).each do |method|
43
+ puts ">> #{method}"
44
+ begin
45
+ ctx = OpenSSL::SSL::SSLContext.new(method)
46
+ ctx.ciphers="ALL::COMPLEMENTOFALL::eNull"
47
+ ctx.ciphers.each do |c|
48
+ @cipherlist.push [ method, c[0]]
49
+ end
50
+ #ctx.ciphers="eNULL" # because ALL don't include Null-Ciphers!!!
51
+ #ctx.ciphers.each do |c|
52
+ # @cipherlist.push [ method, c[0]]
53
+ #end
54
+
55
+
56
+ rescue => bang
57
+ puts bang
58
+ end
59
+
60
+ end
61
+ # puts @cipherlist.to_yaml
62
+ end
63
+
64
+ def reset()
65
+ @result.clear
66
+ end
28
67
 
29
- @info.update(
30
- :check_name => 'SSL-Checker', # name of check which briefly describes functionality, will be used for tree and progress views
31
- :description => "Test applikation for supportes SSL Ciphers.", # description of checkfunction
32
- :author => "Andreas Schmidt", # author of check
33
- :version => "0.9" # check version
34
- )
35
-
36
- @finding.update(
37
- :threat => 'Attacks on weak encryption ciphers which may lead loss of privacy', # thread of vulnerability, e.g. loss of information
38
- :class => "SSL Ciphers", # vulnerability class, e.g. Stored XSS, SQL-Injection, ...
39
- :type => FINDING_TYPE_VULN, # FINDING_TYPE_HINT, FINDING_TYPE_INFO, FINDING_TYPE_VULN
40
- :rating => VULN_RATING_LOW
41
- )
42
-
43
-
44
- def initialize(project)
45
- super(project)
46
-
47
- @result = Hash.new
48
- @cipherlist = Array.new
49
-
68
+ def check_cipher(request, method, cipher)
69
+ begin
70
+ @lasterror = nil
71
+ response_header = nil
50
72
 
51
- OpenSSL::SSL::SSLContext::METHODS.each do |method|
52
- next if method =~ /(client|server)/
53
- next if method =~ /23/
54
- #%w( TLSv1_server SSLv2_server SSLv3_server ).each do |method|
55
- puts ">> #{method}"
56
- begin
57
- ctx = OpenSSL::SSL::SSLContext.new(method)
58
- ctx.ciphers="ALL::COMPLEMENTOFALL::eNull"
59
- ctx.ciphers.each do |c|
60
- @cipherlist.push [ method, c[0]]
73
+ site = request.site
74
+
75
+ proxy = Watobo::ForwardingProxy.get(site)
76
+ unless proxy.nil?
77
+ puts "* a proxy is configured for site #{site}"
61
78
  end
62
- #ctx.ciphers="eNULL" # because ALL don't include Null-Ciphers!!!
63
- #ctx.ciphers.each do |c|
64
- # @cipherlist.push [ method, c[0]]
65
- #end
66
79
 
80
+ host = request.host
81
+ port = request.port
67
82
 
68
- rescue => bang
69
- puts bang
70
- end
83
+ # check if hostname is valid and can be resolved
84
+ hostip = IPSocket.getaddress(host)
71
85
 
72
- end
73
- # puts @cipherlist.to_yaml
86
+ rescue SocketError
87
+ puts "!!! unknown hostname #{host}"
88
+ puts request.first
89
+ return false, "WATOBO: Could not resolve hostname #{host}", nil
90
+ rescue => bang
91
+ #puts bang
92
+ puts bang.backtrace if $DEBUG
74
93
  end
94
+
95
+ begin
96
+ tcp_socket = nil
97
+ tcp_socket = TCPSocket.new( host, port )
98
+ tcp_socket.setsockopt(Socket::IPPROTO_TCP, Socket::TCP_NODELAY, 1)
99
+ tcp_socket.setsockopt(Socket::SOL_SOCKET,Socket::SO_REUSEADDR, true)
100
+ tcp_socket.sync = true
101
+ socket = tcp_socket
102
+
103
+ ctx = OpenSSL::SSL::SSLContext.new(method)
104
+ ctx.ciphers = cipher
105
+ socket = OpenSSL::SSL::SSLSocket.new(tcp_socket, ctx)
106
+ socket.sync_close = true
75
107
 
76
- def reset()
77
- @result.clear
108
+ socket.connect
109
+ rescue => bang
110
+ puts bang
111
+ return false
78
112
  end
79
-
113
+ true
114
+ end
115
+
80
116
  def generateChecks(chat)
81
117
  begin
82
118
  @cipherlist.each do |method, c|
@@ -94,8 +130,7 @@ module Watobo#:nodoc: all
94
130
  cypher = ctx.ciphers.first
95
131
  bits = cypher[2].to_i
96
132
  algo = cypher[0]
97
-
98
- test_request, test_response = doRequest( request, :ssl_cipher => c )
133
+
99
134
  result = {
100
135
  :method => method,
101
136
  :algo => algo,
@@ -103,8 +138,7 @@ module Watobo#:nodoc: all
103
138
  :support => true
104
139
  }
105
140
 
106
- unless test_response.status =~ /555/
107
-
141
+ if check_cipher(request, method, c) == true
108
142
 
109
143
  notify( :cipher_checked, result)
110
144
  if bits < 128
@@ -132,11 +166,69 @@ module Watobo#:nodoc: all
132
166
  puts bang
133
167
  end
134
168
  end
135
- end
136
-
137
-
138
- end
139
- end
140
- end
141
-
142
-
169
+
170
+
171
+
172
+ def generateChecks_UNUSED(chat)
173
+ begin
174
+ @cipherlist.each do |method, c|
175
+ checker = proc {
176
+
177
+ test_request = nil
178
+ test_response = nil
179
+ # !!! ATTENTION !!!
180
+ # MAKE COPY BEFORE MODIFIYING REQUEST
181
+ request = chat.copyRequest
182
+
183
+
184
+ ctx = OpenSSL::SSL::SSLContext.new(method)
185
+ ctx.ciphers = c
186
+ cypher = ctx.ciphers.first
187
+ bits = cypher[2].to_i
188
+ algo = cypher[0]
189
+
190
+ test_request, test_response = doRequest( request, :ssl_cipher => c )
191
+ result = {
192
+ :method => method,
193
+ :algo => algo,
194
+ :bits => bits,
195
+ :support => true
196
+ }
197
+
198
+ unless test_response.status =~ /555/
199
+
200
+
201
+ notify( :cipher_checked, result)
202
+ if bits < 128
203
+
204
+ addFinding( test_request, test_response,
205
+ :test_item => "#{algo}#{bits}",
206
+ #:proof_pattern => "#{match}",
207
+ :chat => chat,
208
+ :title => "[#{algo}] - #{bits} Bit"
209
+ )
210
+ end
211
+ else
212
+ result[:support] = false
213
+ notify(:cipher_checked, result)
214
+ # puts "!!! ERROR: #{c}"
215
+ end
216
+
217
+ [ test_request, test_response ]
218
+
219
+ }
220
+ yield checker
221
+ end
222
+ rescue => bang
223
+ puts "!error in module #{Module.nesting[0].name}"
224
+ puts bang
225
+ end
226
+ end
227
+ end
228
+
229
+
230
+ end
231
+ end
232
+ end
233
+
234
+
@@ -1,130 +1,118 @@
1
- # .
1
+ #.
2
2
  # main.rb
3
- #
4
- # Copyright 2013 by siberas, http://www.siberas.de
5
- #
6
- # This file is part of WATOBO (Web Application Tool Box)
7
- # http://watobo.sourceforge.com
8
- #
9
- # WATOBO is free software; you can redistribute it and/or modify
10
- # it under the terms of the GNU General Public License as published by
11
- # the Free Software Foundation version 2 of the License.
12
- #
13
- # WATOBO is distributed in the hope that it will be useful,
14
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
15
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
- # GNU General Public License for more details.
17
- #
18
- # You should have received a copy of the GNU General Public License
19
- # along with WATOBO; if not, write to the Free Software
20
- # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21
- # .
22
- # @private
23
- module Watobo#:nodoc: all
24
- module Plugin
25
- class WShell
26
- class Gui < Watobo::PluginGui
27
-
28
- window_title "WATOBO Shell (experimental)"
29
- icon_file "wsh.ico"
30
- def initialize()
31
- super()
32
-
33
- @history_pos = 0
34
-
35
- hs_green = FXHiliteStyle.new
36
- # hs_green.normalForeColor = FXRGBA(255,255,255,255)
37
- # hs_green.normalForeColor = FXRGBA(0,255,0,1)
38
- #hs_green.normalBackColor = FXRGBA(0,255,0,1)
39
- hs_green.style = FXText::STYLE_BOLD
40
-
41
- hs_red = FXHiliteStyle.new
42
- hs_red.normalForeColor = FXRGBA(255,0,0,1)
43
- #hs_red.normalBackColor = FXRGBA(255,0,0,1)
44
- hs_red.style = FXText::STYLE_BOLD
45
-
46
- frame = FXVerticalFrame.new(self, :opts => LAYOUT_FILL_X|LAYOUT_FILL_Y)
47
- output_frame = FXVerticalFrame.new(frame, :opts => LAYOUT_FILL_X|LAYOUT_FILL_Y|FRAME_SUNKEN|FRAME_THICK, :padding => 0)
48
- @output = FXText.new(output_frame, :opts => LAYOUT_FILL_X|LAYOUT_FILL_Y)
49
- @output.editable = false
50
- @output.styled = true
51
- #@font = FXFont.new(getApp(), "courier", 12, FONTWEIGHT_BOLD)
52
- @output.setFont(FXFont.new(getApp(), "courier", 10, FONTSLANT_ITALIC, FONTENCODING_DEFAULT))
53
- @output.hiliteStyles = [ hs_red, hs_green]
54
-
55
- @output.appendStyledText Watobo::Plugin::WShell::HELP_TEXT, 2
56
-
57
- FXLabel.new(frame, "Enter 'help' for more information.")
58
-
59
- cmd_frame = FXHorizontalFrame.new(frame, :opts => LAYOUT_FILL_X)
60
- @cmd = FXTextField.new(cmd_frame, 25, nil, 0, :opts => TEXTFIELD_NORMAL|LAYOUT_FILL_X|LAYOUT_LEFT)
61
- @cmd.connect(SEL_COMMAND){ run_cmd }
62
-
63
- @cmd.connect(SEL_KEYPRESS) do |sender, sel, event|
64
- fin = false
65
- if event.code == KEY_Up
66
- @history_pos -=1 if @history_pos > 0
67
- set_history_cmd
68
- fin = true
69
- elsif event.code == KEY_Down
70
- @history_pos += 1 if @history_pos < Watobo::Plugin::WShell.history_length-1
71
- set_history_cmd
72
- fin = true
73
- end
74
- fin
75
- end
76
-
77
- @cmd.setFocus()
78
- @cmd.setDefault()
79
-
80
- @cmd_btn = FXButton.new(cmd_frame, "run")
81
- @executions = Watobo::Plugin::WShell.executions
82
-
83
- @cmd_btn.connect(SEL_COMMAND){ run_cmd }
3
+ #.
4
+ # Copyright 2014 by siberas, http://www.siberas.de
5
+ # This file is part of WATOBO (Web Application Tool Box) http://watobo.sourceforge.com
6
+ # WATOBO is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation version 2 of the License.
7
+ # WATOBO is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
8
+ # You should have received a copy of the GNU General Public License along with WATOBO; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
84
9
 
85
- update_timer{
86
- unless @executions.empty?
87
- cmd, result = @executions.pop
88
-
89
- # @output.appendText(">> #{cmd}\n")
90
- @output.appendText("#{result}\n")
91
- @output.appendText("\n---\n")
92
-
93
- @output.makePositionVisible @output.length-1
94
-
95
- @cmd.enabled = true
96
- @cmd.backColor = FXColor::White
97
- @cmd.text = ''
98
- @cmd.setFocus
99
-
100
- end
101
- }
102
- end
103
-
104
- private
105
-
106
- def set_history_cmd()
107
- cmd = Watobo::Plugin::WShell.history_at @history_pos
108
- @cmd.text = cmd
109
- end
110
-
111
- def run_cmd
112
- unless @cmd.text.empty?
113
- if @cmd.text =~ /^help$/i
114
- # @output.appendText(Watobo::Plugin::WShell.help)
115
- @output.appendStyledText Watobo::Plugin::WShell::HELP_TEXT, 2
116
- @cmd.text = ''
117
- return true
118
- end
119
- @output.appendStyledText ">> #{@cmd.text}\n", 1
120
- @history_pos = Watobo::Plugin::WShell.history_length+1
121
- @cmd.enabled = false
122
- @cmd.backColor = @cmd.parent.backColor
123
-
124
- Watobo::Plugin::WShell.execute_cmd @cmd.text
125
- end
126
- end
127
- end
128
- end
129
- end
10
+ # @private
11
+ module Watobo#:nodoc: all
12
+ module Plugin
13
+ class WShell
14
+ class Gui < Watobo::PluginGui
15
+
16
+ window_title "WATOBO Shell (experimental)"
17
+ icon_file "wsh.ico"
18
+ def initialize()
19
+ super()
20
+
21
+ @history_pos = 0
22
+
23
+ hs_green = FXHiliteStyle.new
24
+ # hs_green.normalForeColor = FXRGBA(255,255,255,255)
25
+ # hs_green.normalForeColor = FXRGBA(0,255,0,1)
26
+ #hs_green.normalBackColor = FXRGBA(0,255,0,1)
27
+ hs_green.style = FXText::STYLE_BOLD
28
+
29
+ hs_red = FXHiliteStyle.new
30
+ hs_red.normalForeColor = FXRGBA(255,0,0,1)
31
+ #hs_red.normalBackColor = FXRGBA(255,0,0,1)
32
+ hs_red.style = FXText::STYLE_BOLD
33
+
34
+ frame = FXVerticalFrame.new(self, :opts => LAYOUT_FILL_X|LAYOUT_FILL_Y)
35
+ output_frame = FXVerticalFrame.new(frame, :opts => LAYOUT_FILL_X|LAYOUT_FILL_Y|FRAME_SUNKEN|FRAME_THICK, :padding => 0)
36
+ @output = FXText.new(output_frame, :opts => LAYOUT_FILL_X|LAYOUT_FILL_Y)
37
+ @output.editable = false
38
+ @output.styled = true
39
+ #@font = FXFont.new(getApp(), "courier", 12, FONTWEIGHT_BOLD)
40
+ @output.setFont(FXFont.new(getApp(), "courier", 10, FONTSLANT_ITALIC, FONTENCODING_DEFAULT))
41
+ @output.hiliteStyles = [ hs_red, hs_green]
42
+
43
+ @output.appendStyledText Watobo::Plugin::WShell::HELP_TEXT, 2
44
+
45
+ FXLabel.new(frame, "Enter 'help' for more information.")
46
+
47
+ cmd_frame = FXHorizontalFrame.new(frame, :opts => LAYOUT_FILL_X)
48
+ @cmd = FXTextField.new(cmd_frame, 25, nil, 0, :opts => TEXTFIELD_NORMAL|LAYOUT_FILL_X|LAYOUT_LEFT)
49
+ @cmd.connect(SEL_COMMAND){ run_cmd }
50
+
51
+ @cmd.connect(SEL_KEYPRESS) do |sender, sel, event|
52
+ fin = false
53
+ if event.code == KEY_Up
54
+ @history_pos -=1 if @history_pos > 0
55
+ set_history_cmd
56
+ fin = true
57
+ elsif event.code == KEY_Down
58
+ @history_pos += 1 if @history_pos < Watobo::Plugin::WShell.history_length-1
59
+ set_history_cmd
60
+ fin = true
61
+ end
62
+ fin
63
+ end
64
+
65
+ @cmd.setFocus()
66
+ @cmd.setDefault()
67
+
68
+ @cmd_btn = FXButton.new(cmd_frame, "run")
69
+ @executions = Watobo::Plugin::WShell.executions
70
+
71
+ @cmd_btn.connect(SEL_COMMAND){ run_cmd }
72
+
73
+ update_timer{
74
+ unless @executions.empty?
75
+ cmd, result = @executions.pop
76
+
77
+ # @output.appendText(">> #{cmd}\n")
78
+ @output.appendText("#{result}\n")
79
+ @output.appendText("\n---\n")
80
+
81
+ @output.makePositionVisible @output.length-1
82
+
83
+ @cmd.enabled = true
84
+ @cmd.backColor = FXColor::White
85
+ @cmd.text = ''
86
+ @cmd.setFocus
87
+
88
+ end
89
+ }
90
+ end
91
+
92
+ private
93
+
94
+ def set_history_cmd()
95
+ cmd = Watobo::Plugin::WShell.history_at @history_pos
96
+ @cmd.text = cmd
97
+ end
98
+
99
+ def run_cmd
100
+ unless @cmd.text.empty?
101
+ if @cmd.text =~ /^help$/i
102
+ # @output.appendText(Watobo::Plugin::WShell.help)
103
+ @output.appendStyledText Watobo::Plugin::WShell::HELP_TEXT, 2
104
+ @cmd.text = ''
105
+ return true
106
+ end
107
+ @output.appendStyledText ">> #{@cmd.text}\n", 1
108
+ @history_pos = Watobo::Plugin::WShell.history_length+1
109
+ @cmd.enabled = false
110
+ @cmd.backColor = @cmd.parent.backColor
111
+
112
+ Watobo::Plugin::WShell.execute_cmd @cmd.text
113
+ end
114
+ end
115
+ end
116
+ end
117
+ end
130
118
  end