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,395 +1,383 @@
1
- # .
1
+ #.
2
2
  # rewrite_rules_dialog.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 Gui
25
- class RulesTableCtrl < FXHorizontalFrame
26
- attr_accessor :target
27
-
28
- def initialize(owner,target = nil, opts)
29
- @target = target
30
- super owner, opts
31
- matrix = FXMatrix.new(self, 4, :opts => MATRIX_BY_COLUMNS|LAYOUT_FILL_X|LAYOUT_FILL_Y)
32
-
33
- %w( Action Location Pattern Content).each do |l|
34
- FXLabel.new(matrix, l)
35
- end
36
-
37
- @actions_combo = FXComboBox.new(matrix, 10, nil, 0, COMBOBOX_STATIC|FRAME_SUNKEN|FRAME_THICK)
38
- #@filterCombo.width =200
39
-
40
- @actions_combo.numVisible = 0
41
- @actions_combo.numColumns = 10
42
- @actions_combo.editable = false
43
- @actions_combo.connect(SEL_COMMAND){}
44
-
45
- @locations_combo = FXComboBox.new(matrix, 10, nil, 0, COMBOBOX_STATIC|FRAME_SUNKEN|FRAME_THICK)
46
- #@filterCombo.width =200
47
-
48
- @locations_combo.numVisible = 0
49
- @locations_combo.numColumns = 10
50
- @locations_combo.editable = false
51
- @locations_combo.connect(SEL_COMMAND){}
52
-
53
- @pattern_txt = FXTextField.new(matrix, 20, nil, 0, :opts => TEXTFIELD_NORMAL|LAYOUT_FILL_COLUMN)
54
- @content_txt = FXTextField.new(matrix, 20, nil, 0, :opts => TEXTFIELD_NORMAL|LAYOUT_FILL_COLUMN)
55
-
56
- frame = FXVerticalFrame.new(self, :opts => LAYOUT_FILL_X|LAYOUT_FILL_Y, :padding => 0)
57
- top_btn_frame = FXHorizontalFrame.new(frame,:opts => LAYOUT_FILL_X|LAYOUT_FILL_Y, :padding => 0)
58
-
59
- @del_btn = FXButton.new(top_btn_frame, "Del" , nil, nil)
60
- @del_btn.enable
61
- @del_btn.connect(SEL_COMMAND){ delete_rule }
62
-
63
- # @edit_btn = FXButton.new(top_btn_frame, "Edit ..." , nil, nil)
64
- # @edit_btn.enable
65
- # @edit_btn.connect(SEL_COMMAND){ delete_rule }
66
-
67
- @up_btn = FXButton.new(top_btn_frame, "Up" , nil, nil)
68
- @up_btn.enable
69
-
70
- @down_btn = FXButton.new(top_btn_frame, "Down" , nil, nil)
71
- @down_btn.enable
72
-
73
- @filter_btn = FXButton.new(top_btn_frame, "Filter" , nil, nil)
74
- @filter_btn.enable
75
- @filter_btn.connect(SEL_COMMAND){ open_filter_dialog }
76
-
77
-
78
- add_btn_frame = FXHorizontalFrame.new(frame,:opts => LAYOUT_FILL_X|LAYOUT_FILL_Y, :padding => 0)
79
- @add_btn = FXButton.new(add_btn_frame, "Add ..." , nil, nil, )
80
- @add_btn.enable
81
- @add_btn.connect(SEL_COMMAND){ add_rule }
82
-
83
- end
84
-
85
- private
86
-
87
- def init_handlers()
88
-
89
- end
90
-
91
- def clear_actions
92
- @actions_combo.clearItems()
93
- end
94
-
95
- def add_action(a)
96
- @actions_combo.appendItem(a.to_s, a)
97
- @actions_combo.numVisible = @actions_combo.numItems
98
- end
99
-
100
- def add_location(l)
101
- @locations_combo.appendItem(l.to_s, l)
102
- @locations_combo.numVisible = @locations_combo.numItems
103
- end
104
-
105
- def delete_rule
106
- @target.delete_current_row if @target.respond_to? :delete_current_row
107
-
108
- end
109
-
110
- def add_rule
111
- return false if @target.nil?
112
- #TODO: Add some checks if rule is ok
113
- @target.add_rule Watobo::Interceptor::CarverRule.new(:action => @actions_combo.getItemData(@actions_combo.currentItem),
114
- :location => @locations_combo.getItemData(@locations_combo.currentItem),
115
- :pattern => @pattern_txt.text,
116
- :content => @content_txt.text,
117
- :filter => nil
118
- )
119
- end
120
-
121
- def open_filter_dialog
122
-
123
- end
124
-
125
- end
126
-
127
- class RequestRulesCtrl < RulesTableCtrl
128
- def initialize(owner, target, opts)
129
- super owner, target, opts
130
- add_action :rewrite
131
- add_action :flag
132
- add_location :url
133
- add_location :body
134
- add_location :header
135
- add_location :cookie
136
- add_location :http_parm
137
-
138
- end
139
-
140
- def open_filter_dialog
141
- rule = @target.current_rule
142
- return false if rule.nil?
143
- dlg = Watobo::Gui::RequestFilterDialog.new( self, rule )
144
- if dlg.execute != 0 then
145
- # TODO: Apply interceptor settings
146
- rule.set_filter dlg.filter
147
- @target.reset_table
148
-
149
- end
150
- end
151
- end
152
-
153
- class ResponseRulesCtrl < RulesTableCtrl
154
- def initialize(owner, target, opts)
155
- super owner, target, opts
156
- add_action :rewrite
157
- add_location :body
158
- add_location :header
159
- add_location :replace_all
160
- end
161
-
162
- def open_filter_dialog
163
- rule = @target.current_rule
164
- return false if rule.nil?
165
- dlg = Watobo::Gui::ResponseFilterDialog.new( self, rule )
166
- if dlg.execute != 0 then
167
- # TODO: Apply interceptor settings
168
- rule.set_filter dlg.filter
169
- @target.reset_table
170
- end
171
- end
172
- end
173
-
174
- class RulesTable < FXTable
175
- attr :rules
176
- def add_rule(rule)
177
- @rules << rule
178
- add_rule_row(rule)
179
- end
180
-
181
- def current_rule
182
- return nil if self.currentRow < 0
183
- return @rules[self.currentRow]
184
- end
185
-
186
- def delete_row_by_index(index)
187
- return false if index < 0
188
- return false if index > self.numRows-1
189
- @rules.delete_at index
190
- self.clearItems
191
- reset_table
192
- true
193
- end
194
-
195
- def reset_table
196
- init_columns
197
-
198
- @rules.each do |r|
199
- add_rule_row r
200
- end
201
- adjust_cell_width
202
- self.selectRow self.currentRow if self.currentRow >= 0
203
- end
204
-
205
- def delete_current_row
206
- i = self.currentRow
207
- return false if i < 0
208
- delete_row_by_index i
209
- end
210
-
211
- def initialize( owner, rules=[], opts={} )
212
- @event_dispatcher_listeners = Hash.new
213
- parms = { :opts => TABLE_COL_SIZABLE|TABLE_ROW_SIZABLE|LAYOUT_FILL_X|LAYOUT_FILL_Y|TABLE_READONLY|LAYOUT_SIDE_TOP,
214
- :padding => 2
215
- }
216
- parms.update opts
217
-
218
- super(owner, parms)
219
-
220
- self.extend Watobo::Subscriber
221
- self.setBackColor(FXRGB(255, 255, 255))
222
- self.setCellColor(0, 0, FXRGB(255, 255, 255))
223
- self.setCellColor(0, 1, FXRGB(255, 240, 240))
224
- self.setCellColor(1, 0, FXRGB(240, 255, 240))
225
- self.setCellColor(1, 1, FXRGB(240, 240, 255))
226
-
227
- @columns=Hash.new
228
-
229
- @rules = []
230
- @rules.concat rules
231
-
232
- add_column "Action", 50
233
- add_column "Location", 80
234
- add_column "Pattern", 80
235
- add_column "Content", 80
236
- add_column "Filter", 80
237
-
238
- init_columns
239
-
240
- @rules.each do |r|
241
- add_rule_row r
242
- end
243
- adjust_cell_width
244
-
245
- self.connect(SEL_SELECTED){|sender,sel,pos|
246
- self.selectRow pos.row
247
- # notify(:rule_selected, @rules[pos.row])
248
- }
249
- end
250
-
251
- private
252
-
253
- def add_rule_row(rule)
254
- row_index = self.getNumRows
255
- self.appendRows(1)
256
-
257
- self.rowHeader.setItemJustify(row_index, FXHeaderItem::RIGHT)
258
- self.setRowText(row_index, (row_index+1).to_s)
259
-
260
- index = @columns[:action][:order]
261
- self.setItemText(row_index, index, rule.action_name)
262
- self.getItem(row_index, index).justify = FXTableItem::LEFT
263
-
264
- index = @columns[:location][:order]
265
- self.setItemText(row_index, index, rule.location_name)
266
- self.getItem(row_index, index).justify = FXTableItem::LEFT
267
-
268
- index = @columns[:pattern][:order]
269
- self.setItemText(row_index, index, rule.pattern_name)
270
- self.getItem(row_index, index).justify = FXTableItem::LEFT
271
-
272
- index = @columns[:content][:order]
273
- self.setItemText(row_index, index, rule.content_name)
274
- self.getItem(row_index, index).justify = FXTableItem::LEFT
275
-
276
- index = @columns[:filter][:order]
277
- self.setItemText(row_index, index, rule.filter_name)
278
- self.getItem(row_index, index).justify = FXTableItem::LEFT
279
-
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
280
9
 
281
- end
282
- def add_column(name, width, order=0)
283
- o = ( order == 0 ) ? @columns.length : order
284
- @columns[name.downcase.to_sym] = { :name => name,
285
- :width => width,
286
- :order => o
287
- }
288
-
289
- end
290
-
291
- def adjust_cell_width()
292
- begin
293
- self.rowHeader.width = 30
294
- #self.fitColumnsToContents(0)
295
- @columns.each_with_index do |v,i|
296
-
297
- self.setColumnWidth(i, v[1][:width])
298
- end
299
- rescue => bang
300
- puts "!!!ERROR: adjustCellWidth"
301
- puts bang
302
- puts bang.backtrace
303
- end
304
-
305
- end
306
-
307
- def init_columns
308
- self.setTableSize(0, @columns.length)
309
- self.visibleRows = 5
310
- self.visibleColumns = @columns.length
311
-
312
- @columns.sort_by{|k,v| v[:order] }.each_with_index do |v,i|
313
- self.setColumnText( i, v[1][:name] )
314
- end
315
-
316
- end
317
-
318
- end
319
-
320
- class RequestRulesTable < RulesTable
321
- def initialize(owner, opts={})
322
- super owner, opts
323
- add_column "Action", 50
324
- add_column "Location", 80
325
- add_column "Pattern", 80
326
- add_column "Content", 80
327
- add_column "Filter", 80
328
-
329
- init_columns
330
- adjust_cell_width
331
-
332
- end
333
- end
334
-
335
- class RewriteRulesDialog < FXDialogBox
336
-
337
- include Responder
338
- def request_rules
339
- @request_rules_table.rules
340
- end
341
-
342
- def response_rules
343
- @response_rules_table.rules
344
- end
345
-
346
- def initialize(owner, settings = {} )
347
- super(owner, "Rewrite Rules", DECOR_TITLE|DECOR_BORDER|DECOR_CLOSE, :width => 650, :height => 610)
348
-
349
- FXMAPFUNC(SEL_COMMAND, ID_ACCEPT, :onAccept)
350
-
351
- @main_frame = FXVerticalFrame.new(self, :opts => LAYOUT_FILL_X|LAYOUT_FILL_Y, :padding => 0)
352
- init_request_rules(@main_frame)
353
- init_response_rules(@main_frame)
354
-
355
- buttons_frame = FXHorizontalFrame.new(@main_frame, :opts => LAYOUT_FILL_X|LAYOUT_BOTTOM)
356
- @finishButton = FXButton.new(buttons_frame, "Accept" , nil, nil, :opts => BUTTON_NORMAL|LAYOUT_RIGHT)
357
- @finishButton.enable
358
- @finishButton.connect(SEL_COMMAND) do |sender, sel, item|
359
- #self.handle(self, FXSEL(SEL_COMMAND, ID_CANCEL), nil)
360
- self.handle(self, FXSEL(SEL_COMMAND, ID_ACCEPT), nil)
361
- end
362
-
363
- @cancelButton = FXButton.new(buttons_frame, "Cancel" ,
364
- :target => self, :selector => FXDialogBox::ID_CANCEL,
365
- :opts => BUTTON_NORMAL|LAYOUT_RIGHT)
366
- end
367
-
368
- private
369
-
370
- def onAccept(sender, sel, event)
371
-
372
- getApp().stopModal(self, 1)
373
- self.hide()
374
- return 1
375
- end
376
-
377
- def init_request_rules(owner)
378
-
379
- gbframe = FXGroupBox.new(owner, "Request Rules", LAYOUT_SIDE_RIGHT|FRAME_GROOVE|LAYOUT_FILL_X, 0, 0, 0, 0)
380
- frame = FXVerticalFrame.new(gbframe, :opts => LAYOUT_FILL_X, :padding => 0)
381
-
382
- @request_rules_table = RulesTable.new(frame, Interceptor::RequestCarver.rules)
383
- @request_rules_ctrl = RequestRulesCtrl.new(gbframe, @request_rules_table, :opts => LAYOUT_FILL_X|FRAME_SUNKEN|FRAME_THICK)
384
- end
385
-
386
- def init_response_rules(owner)
387
- gbframe = FXGroupBox.new(owner, "Response Rules", LAYOUT_SIDE_RIGHT|FRAME_GROOVE|LAYOUT_FILL_X, 0, 0, 0, 0)
388
- frame = FXVerticalFrame.new(gbframe, :opts => LAYOUT_FILL_X, :padding => 0)
389
-
390
- @response_rules_table = RulesTable.new(frame, Interceptor::ResponseCarver.rules)
391
- @response_rules_ctrl = ResponseRulesCtrl.new(gbframe, @response_rules_table, :opts => LAYOUT_FILL_X|FRAME_SUNKEN|FRAME_THICK)
392
- end
393
- end
394
- end
10
+ # @private
11
+ module Watobo#:nodoc: all
12
+ module Gui
13
+ class RulesTableCtrl < FXHorizontalFrame
14
+ attr_accessor :target
15
+
16
+ def initialize(owner,target = nil, opts)
17
+ @target = target
18
+ super owner, opts
19
+ matrix = FXMatrix.new(self, 4, :opts => MATRIX_BY_COLUMNS|LAYOUT_FILL_X|LAYOUT_FILL_Y)
20
+
21
+ %w( Action Location Pattern Content).each do |l|
22
+ FXLabel.new(matrix, l)
23
+ end
24
+
25
+ @actions_combo = FXComboBox.new(matrix, 10, nil, 0, COMBOBOX_STATIC|FRAME_SUNKEN|FRAME_THICK)
26
+ #@filterCombo.width =200
27
+
28
+ @actions_combo.numVisible = 0
29
+ @actions_combo.numColumns = 10
30
+ @actions_combo.editable = false
31
+ @actions_combo.connect(SEL_COMMAND){}
32
+
33
+ @locations_combo = FXComboBox.new(matrix, 10, nil, 0, COMBOBOX_STATIC|FRAME_SUNKEN|FRAME_THICK)
34
+ #@filterCombo.width =200
35
+
36
+ @locations_combo.numVisible = 0
37
+ @locations_combo.numColumns = 10
38
+ @locations_combo.editable = false
39
+ @locations_combo.connect(SEL_COMMAND){}
40
+
41
+ @pattern_txt = FXTextField.new(matrix, 20, nil, 0, :opts => TEXTFIELD_NORMAL|LAYOUT_FILL_COLUMN)
42
+ @content_txt = FXTextField.new(matrix, 20, nil, 0, :opts => TEXTFIELD_NORMAL|LAYOUT_FILL_COLUMN)
43
+
44
+ frame = FXVerticalFrame.new(self, :opts => LAYOUT_FILL_X|LAYOUT_FILL_Y, :padding => 0)
45
+ top_btn_frame = FXHorizontalFrame.new(frame,:opts => LAYOUT_FILL_X|LAYOUT_FILL_Y, :padding => 0)
46
+
47
+ @del_btn = FXButton.new(top_btn_frame, "Del" , nil, nil)
48
+ @del_btn.enable
49
+ @del_btn.connect(SEL_COMMAND){ delete_rule }
50
+
51
+ # @edit_btn = FXButton.new(top_btn_frame, "Edit ..." , nil, nil)
52
+ # @edit_btn.enable
53
+ # @edit_btn.connect(SEL_COMMAND){ delete_rule }
54
+
55
+ @up_btn = FXButton.new(top_btn_frame, "Up" , nil, nil)
56
+ @up_btn.enable
57
+
58
+ @down_btn = FXButton.new(top_btn_frame, "Down" , nil, nil)
59
+ @down_btn.enable
60
+
61
+ @filter_btn = FXButton.new(top_btn_frame, "Filter" , nil, nil)
62
+ @filter_btn.enable
63
+ @filter_btn.connect(SEL_COMMAND){ open_filter_dialog }
64
+
65
+
66
+ add_btn_frame = FXHorizontalFrame.new(frame,:opts => LAYOUT_FILL_X|LAYOUT_FILL_Y, :padding => 0)
67
+ @add_btn = FXButton.new(add_btn_frame, "Add ..." , nil, nil, )
68
+ @add_btn.enable
69
+ @add_btn.connect(SEL_COMMAND){ add_rule }
70
+
71
+ end
72
+
73
+ private
74
+
75
+ def init_handlers()
76
+
77
+ end
78
+
79
+ def clear_actions
80
+ @actions_combo.clearItems()
81
+ end
82
+
83
+ def add_action(a)
84
+ @actions_combo.appendItem(a.to_s, a)
85
+ @actions_combo.numVisible = @actions_combo.numItems
86
+ end
87
+
88
+ def add_location(l)
89
+ @locations_combo.appendItem(l.to_s, l)
90
+ @locations_combo.numVisible = @locations_combo.numItems
91
+ end
92
+
93
+ def delete_rule
94
+ @target.delete_current_row if @target.respond_to? :delete_current_row
95
+
96
+ end
97
+
98
+ def add_rule
99
+ return false if @target.nil?
100
+ #TODO: Add some checks if rule is ok
101
+ @target.add_rule Watobo::Interceptor::CarverRule.new(:action => @actions_combo.getItemData(@actions_combo.currentItem),
102
+ :location => @locations_combo.getItemData(@locations_combo.currentItem),
103
+ :pattern => @pattern_txt.text,
104
+ :content => @content_txt.text,
105
+ :filter => nil
106
+ )
107
+ end
108
+
109
+ def open_filter_dialog
110
+
111
+ end
112
+
113
+ end
114
+
115
+ class RequestRulesCtrl < RulesTableCtrl
116
+ def initialize(owner, target, opts)
117
+ super owner, target, opts
118
+ add_action :rewrite
119
+ add_action :flag
120
+ add_location :url
121
+ add_location :body
122
+ add_location :header
123
+ add_location :cookie
124
+ add_location :http_parm
125
+
126
+ end
127
+
128
+ def open_filter_dialog
129
+ rule = @target.current_rule
130
+ return false if rule.nil?
131
+ dlg = Watobo::Gui::RequestFilterDialog.new( self, rule )
132
+ if dlg.execute != 0 then
133
+ # TODO: Apply interceptor settings
134
+ rule.set_filter dlg.filter
135
+ @target.reset_table
136
+
137
+ end
138
+ end
139
+ end
140
+
141
+ class ResponseRulesCtrl < RulesTableCtrl
142
+ def initialize(owner, target, opts)
143
+ super owner, target, opts
144
+ add_action :rewrite
145
+ add_location :body
146
+ add_location :header
147
+ add_location :replace_all
148
+ end
149
+
150
+ def open_filter_dialog
151
+ rule = @target.current_rule
152
+ return false if rule.nil?
153
+ dlg = Watobo::Gui::ResponseFilterDialog.new( self, rule )
154
+ if dlg.execute != 0 then
155
+ # TODO: Apply interceptor settings
156
+ rule.set_filter dlg.filter
157
+ @target.reset_table
158
+ end
159
+ end
160
+ end
161
+
162
+ class RulesTable < FXTable
163
+ attr :rules
164
+ def add_rule(rule)
165
+ @rules << rule
166
+ add_rule_row(rule)
167
+ end
168
+
169
+ def current_rule
170
+ return nil if self.currentRow < 0
171
+ return @rules[self.currentRow]
172
+ end
173
+
174
+ def delete_row_by_index(index)
175
+ return false if index < 0
176
+ return false if index > self.numRows-1
177
+ @rules.delete_at index
178
+ self.clearItems
179
+ reset_table
180
+ true
181
+ end
182
+
183
+ def reset_table
184
+ init_columns
185
+
186
+ @rules.each do |r|
187
+ add_rule_row r
188
+ end
189
+ adjust_cell_width
190
+ self.selectRow self.currentRow if self.currentRow >= 0
191
+ end
192
+
193
+ def delete_current_row
194
+ i = self.currentRow
195
+ return false if i < 0
196
+ delete_row_by_index i
197
+ end
198
+
199
+ def initialize( owner, rules=[], opts={} )
200
+ @event_dispatcher_listeners = Hash.new
201
+ parms = { :opts => TABLE_COL_SIZABLE|TABLE_ROW_SIZABLE|LAYOUT_FILL_X|LAYOUT_FILL_Y|TABLE_READONLY|LAYOUT_SIDE_TOP,
202
+ :padding => 2
203
+ }
204
+ parms.update opts
205
+
206
+ super(owner, parms)
207
+
208
+ self.extend Watobo::Subscriber
209
+ self.setBackColor(FXRGB(255, 255, 255))
210
+ self.setCellColor(0, 0, FXRGB(255, 255, 255))
211
+ self.setCellColor(0, 1, FXRGB(255, 240, 240))
212
+ self.setCellColor(1, 0, FXRGB(240, 255, 240))
213
+ self.setCellColor(1, 1, FXRGB(240, 240, 255))
214
+
215
+ @columns=Hash.new
216
+
217
+ @rules = []
218
+ @rules.concat rules
219
+
220
+ add_column "Action", 50
221
+ add_column "Location", 80
222
+ add_column "Pattern", 80
223
+ add_column "Content", 80
224
+ add_column "Filter", 80
225
+
226
+ init_columns
227
+
228
+ @rules.each do |r|
229
+ add_rule_row r
230
+ end
231
+ adjust_cell_width
232
+
233
+ self.connect(SEL_SELECTED){|sender,sel,pos|
234
+ self.selectRow pos.row
235
+ # notify(:rule_selected, @rules[pos.row])
236
+ }
237
+ end
238
+
239
+ private
240
+
241
+ def add_rule_row(rule)
242
+ row_index = self.getNumRows
243
+ self.appendRows(1)
244
+
245
+ self.rowHeader.setItemJustify(row_index, FXHeaderItem::RIGHT)
246
+ self.setRowText(row_index, (row_index+1).to_s)
247
+
248
+ index = @columns[:action][:order]
249
+ self.setItemText(row_index, index, rule.action_name)
250
+ self.getItem(row_index, index).justify = FXTableItem::LEFT
251
+
252
+ index = @columns[:location][:order]
253
+ self.setItemText(row_index, index, rule.location_name)
254
+ self.getItem(row_index, index).justify = FXTableItem::LEFT
255
+
256
+ index = @columns[:pattern][:order]
257
+ self.setItemText(row_index, index, rule.pattern_name)
258
+ self.getItem(row_index, index).justify = FXTableItem::LEFT
259
+
260
+ index = @columns[:content][:order]
261
+ self.setItemText(row_index, index, rule.content_name)
262
+ self.getItem(row_index, index).justify = FXTableItem::LEFT
263
+
264
+ index = @columns[:filter][:order]
265
+ self.setItemText(row_index, index, rule.filter_name)
266
+ self.getItem(row_index, index).justify = FXTableItem::LEFT
267
+
268
+
269
+ end
270
+ def add_column(name, width, order=0)
271
+ o = ( order == 0 ) ? @columns.length : order
272
+ @columns[name.downcase.to_sym] = { :name => name,
273
+ :width => width,
274
+ :order => o
275
+ }
276
+
277
+ end
278
+
279
+ def adjust_cell_width()
280
+ begin
281
+ self.rowHeader.width = 30
282
+ #self.fitColumnsToContents(0)
283
+ @columns.each_with_index do |v,i|
284
+
285
+ self.setColumnWidth(i, v[1][:width])
286
+ end
287
+ rescue => bang
288
+ puts "!!!ERROR: adjustCellWidth"
289
+ puts bang
290
+ puts bang.backtrace
291
+ end
292
+
293
+ end
294
+
295
+ def init_columns
296
+ self.setTableSize(0, @columns.length)
297
+ self.visibleRows = 5
298
+ self.visibleColumns = @columns.length
299
+
300
+ @columns.sort_by{|k,v| v[:order] }.each_with_index do |v,i|
301
+ self.setColumnText( i, v[1][:name] )
302
+ end
303
+
304
+ end
305
+
306
+ end
307
+
308
+ class RequestRulesTable < RulesTable
309
+ def initialize(owner, opts={})
310
+ super owner, opts
311
+ add_column "Action", 50
312
+ add_column "Location", 80
313
+ add_column "Pattern", 80
314
+ add_column "Content", 80
315
+ add_column "Filter", 80
316
+
317
+ init_columns
318
+ adjust_cell_width
319
+
320
+ end
321
+ end
322
+
323
+ class RewriteRulesDialog < FXDialogBox
324
+
325
+ include Responder
326
+ def request_rules
327
+ @request_rules_table.rules
328
+ end
329
+
330
+ def response_rules
331
+ @response_rules_table.rules
332
+ end
333
+
334
+ def initialize(owner, settings = {} )
335
+ super(owner, "Rewrite Rules", DECOR_TITLE|DECOR_BORDER|DECOR_CLOSE, :width => 650, :height => 610)
336
+
337
+ FXMAPFUNC(SEL_COMMAND, ID_ACCEPT, :onAccept)
338
+
339
+ @main_frame = FXVerticalFrame.new(self, :opts => LAYOUT_FILL_X|LAYOUT_FILL_Y, :padding => 0)
340
+ init_request_rules(@main_frame)
341
+ init_response_rules(@main_frame)
342
+
343
+ buttons_frame = FXHorizontalFrame.new(@main_frame, :opts => LAYOUT_FILL_X|LAYOUT_BOTTOM)
344
+ @finishButton = FXButton.new(buttons_frame, "Accept" , nil, nil, :opts => BUTTON_NORMAL|LAYOUT_RIGHT)
345
+ @finishButton.enable
346
+ @finishButton.connect(SEL_COMMAND) do |sender, sel, item|
347
+ #self.handle(self, FXSEL(SEL_COMMAND, ID_CANCEL), nil)
348
+ self.handle(self, FXSEL(SEL_COMMAND, ID_ACCEPT), nil)
349
+ end
350
+
351
+ @cancelButton = FXButton.new(buttons_frame, "Cancel" ,
352
+ :target => self, :selector => FXDialogBox::ID_CANCEL,
353
+ :opts => BUTTON_NORMAL|LAYOUT_RIGHT)
354
+ end
355
+
356
+ private
357
+
358
+ def onAccept(sender, sel, event)
359
+
360
+ getApp().stopModal(self, 1)
361
+ self.hide()
362
+ return 1
363
+ end
364
+
365
+ def init_request_rules(owner)
366
+
367
+ gbframe = FXGroupBox.new(owner, "Request Rules", LAYOUT_SIDE_RIGHT|FRAME_GROOVE|LAYOUT_FILL_X, 0, 0, 0, 0)
368
+ frame = FXVerticalFrame.new(gbframe, :opts => LAYOUT_FILL_X, :padding => 0)
369
+
370
+ @request_rules_table = RulesTable.new(frame, Interceptor::RequestCarver.rules)
371
+ @request_rules_ctrl = RequestRulesCtrl.new(gbframe, @request_rules_table, :opts => LAYOUT_FILL_X|FRAME_SUNKEN|FRAME_THICK)
372
+ end
373
+
374
+ def init_response_rules(owner)
375
+ gbframe = FXGroupBox.new(owner, "Response Rules", LAYOUT_SIDE_RIGHT|FRAME_GROOVE|LAYOUT_FILL_X, 0, 0, 0, 0)
376
+ frame = FXVerticalFrame.new(gbframe, :opts => LAYOUT_FILL_X, :padding => 0)
377
+
378
+ @response_rules_table = RulesTable.new(frame, Interceptor::ResponseCarver.rules)
379
+ @response_rules_ctrl = ResponseRulesCtrl.new(gbframe, @response_rules_table, :opts => LAYOUT_FILL_X|FRAME_SUNKEN|FRAME_THICK)
380
+ end
381
+ end
382
+ end
395
383
  end