Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 // | 4 // |
| 5 // Classes for managing the SafeBrowsing interstitial pages. | 5 // Classes for managing the SafeBrowsing interstitial pages. |
| 6 // | 6 // |
| 7 // When a user is about to visit a page the SafeBrowsing system has deemed to | 7 // When a user is about to visit a page the SafeBrowsing system has deemed to |
| 8 // be malicious, either as malware or a phishing page, we show an interstitial | 8 // be malicious, either as malware or a phishing page, we show an interstitial |
| 9 // page with some options (go back, continue) to give the user a chance to avoid | 9 // page with some options (go back, continue) to give the user a chance to avoid |
| 10 // the harmful page. | 10 // the harmful page. |
| (...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 69 const UnsafeResource& unsafe_resource); | 69 const UnsafeResource& unsafe_resource); |
| 70 | 70 |
| 71 // Shows a blocking page warning the user about phishing/malware for a | 71 // Shows a blocking page warning the user about phishing/malware for a |
| 72 // specific resource. | 72 // specific resource. |
| 73 // You can call this method several times, if an interstitial is already | 73 // You can call this method several times, if an interstitial is already |
| 74 // showing, the new one will be queued and displayed if the user decides | 74 // showing, the new one will be queued and displayed if the user decides |
| 75 // to proceed on the currently showing interstitial. | 75 // to proceed on the currently showing interstitial. |
| 76 static void ShowBlockingPage( | 76 static void ShowBlockingPage( |
| 77 SafeBrowsingUIManager* ui_manager, const UnsafeResource& resource); | 77 SafeBrowsingUIManager* ui_manager, const UnsafeResource& resource); |
| 78 | 78 |
| 79 // InterstitialPageDelegate method: | |
|
Dan Beam
2014/08/08 02:34:33
combine with other methods
felt
2014/08/08 02:37:38
Done, and reordered to be in same order as Interst
| |
| 80 virtual std::string GetHTMLContents() OVERRIDE; | |
| 81 | |
| 79 // Makes the passed |factory| the factory used to instantiate | 82 // Makes the passed |factory| the factory used to instantiate |
| 80 // SafeBrowsingBlockingPage objects. Useful for tests. | 83 // SafeBrowsingBlockingPage objects. Useful for tests. |
| 81 static void RegisterFactory(SafeBrowsingBlockingPageFactory* factory) { | 84 static void RegisterFactory(SafeBrowsingBlockingPageFactory* factory) { |
| 82 factory_ = factory; | 85 factory_ = factory; |
| 83 } | 86 } |
| 84 | 87 |
| 85 // InterstitialPageDelegate method: | 88 // InterstitialPageDelegate method: |
|
Dan Beam
2014/08/08 02:34:33
^
felt
2014/08/08 02:37:38
Acknowledged.
| |
| 86 virtual void CommandReceived(const std::string& command) OVERRIDE; | 89 virtual void CommandReceived(const std::string& command) OVERRIDE; |
| 87 virtual void OverrideRendererPrefs( | 90 virtual void OverrideRendererPrefs( |
| 88 content::RendererPreferences* prefs) OVERRIDE; | 91 content::RendererPreferences* prefs) OVERRIDE; |
| 89 virtual void OnProceed() OVERRIDE; | 92 virtual void OnProceed() OVERRIDE; |
| 90 virtual void OnDontProceed() OVERRIDE; | 93 virtual void OnDontProceed() OVERRIDE; |
| 91 | 94 |
| 92 protected: | 95 protected: |
| 93 template <class TestSBInterstitialPage> | |
| 94 friend class SafeBrowsingBlockingPageTest; | 96 friend class SafeBrowsingBlockingPageTest; |
| 95 template <class TestSBInterstitialPage> | |
| 96 FRIEND_TEST_ALL_PREFIXES(SafeBrowsingBlockingPageTest, | 97 FRIEND_TEST_ALL_PREFIXES(SafeBrowsingBlockingPageTest, |
| 97 ProceedThenDontProceed); | 98 ProceedThenDontProceed); |
| 98 | 99 |
| 99 void DontCreateViewForTesting(); | 100 void DontCreateViewForTesting(); |
| 100 void Show(); | 101 void Show(); |
| 101 void SetReportingPreference(bool report); | 102 void SetReportingPreference(bool report); |
| 102 void UpdateReportingPref(); // Used for the transition from old to new pref. | 103 void UpdateReportingPref(); // Used for the transition from old to new pref. |
| 103 | 104 |
| 104 // Don't instantiate this class directly, use ShowBlockingPage instead. | 105 // Don't instantiate this class directly, use ShowBlockingPage instead. |
| 105 SafeBrowsingBlockingPage(SafeBrowsingUIManager* ui_manager, | 106 SafeBrowsingBlockingPage(SafeBrowsingUIManager* ui_manager, |
| 106 content::WebContents* web_contents, | 107 content::WebContents* web_contents, |
| 107 const UnsafeResourceList& unsafe_resources); | 108 const UnsafeResourceList& unsafe_resources); |
| 108 | 109 |
| 109 // After a malware interstitial where the user opted-in to the | 110 // After a malware interstitial where the user opted-in to the |
| 110 // report but clicked "proceed anyway", we delay the call to | 111 // report but clicked "proceed anyway", we delay the call to |
| 111 // MalwareDetails::FinishCollection() by this much time (in | 112 // MalwareDetails::FinishCollection() by this much time (in |
| 112 // milliseconds), in order to get data from the blocked resource itself. | 113 // milliseconds), in order to get data from the blocked resource itself. |
| 113 int64 malware_details_proceed_delay_ms_; | 114 int64 malware_details_proceed_delay_ms_; |
| 114 content::InterstitialPage* interstitial_page() const { | 115 content::InterstitialPage* interstitial_page() const { |
| 115 return interstitial_page_; | 116 return interstitial_page_; |
| 116 } | 117 } |
| 117 | 118 |
| 118 template <class TestSBInterstitialPage> | |
| 119 FRIEND_TEST_ALL_PREFIXES(SafeBrowsingBlockingPageTest, | 119 FRIEND_TEST_ALL_PREFIXES(SafeBrowsingBlockingPageTest, |
| 120 MalwareReportsTransitionDisabled); | 120 MalwareReportsTransitionDisabled); |
| 121 template <class TestSBInterstitialPage> | |
| 122 FRIEND_TEST_ALL_PREFIXES(SafeBrowsingBlockingPageTest, | 121 FRIEND_TEST_ALL_PREFIXES(SafeBrowsingBlockingPageTest, |
| 123 MalwareReportsToggling); | 122 MalwareReportsToggling); |
| 124 | 123 |
| 125 enum BlockingPageEvent { | 124 enum BlockingPageEvent { |
| 126 SHOW, | 125 SHOW, |
| 127 PROCEED, | 126 PROCEED, |
| 128 DONT_PROCEED, | 127 DONT_PROCEED, |
| 129 SHOW_ADVANCED, | 128 SHOW_ADVANCED, |
| 130 }; | 129 }; |
| 131 | 130 |
| (...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 226 | 225 |
| 227 // The factory used to instantiate SafeBrowsingBlockingPage objects. | 226 // The factory used to instantiate SafeBrowsingBlockingPage objects. |
| 228 // Usefull for tests, so they can provide their own implementation of | 227 // Usefull for tests, so they can provide their own implementation of |
| 229 // SafeBrowsingBlockingPage. | 228 // SafeBrowsingBlockingPage. |
| 230 static SafeBrowsingBlockingPageFactory* factory_; | 229 static SafeBrowsingBlockingPageFactory* factory_; |
| 231 | 230 |
| 232 // How many times is this same URL in history? Used for histogramming. | 231 // How many times is this same URL in history? Used for histogramming. |
| 233 int num_visits_; | 232 int num_visits_; |
| 234 base::CancelableTaskTracker request_tracker_; | 233 base::CancelableTaskTracker request_tracker_; |
| 235 | 234 |
| 236 DISALLOW_COPY_AND_ASSIGN(SafeBrowsingBlockingPage); | |
| 237 }; | |
| 238 | |
| 239 class SafeBrowsingBlockingPageV1 : public SafeBrowsingBlockingPage { | |
| 240 public: | |
| 241 // Don't instantiate this class directly, use ShowBlockingPage instead. | |
| 242 SafeBrowsingBlockingPageV1(SafeBrowsingUIManager* ui_manager, | |
| 243 content::WebContents* web_contents, | |
| 244 const UnsafeResourceList& unsafe_resources); | |
| 245 | |
| 246 // InterstitialPageDelegate method: | |
| 247 virtual std::string GetHTMLContents() OVERRIDE; | |
| 248 | |
| 249 private: | |
| 250 // Fills the passed dictionary with the strings passed to JS Template when | |
| 251 // creating the HTML. | |
| 252 void PopulateMultipleThreatStringDictionary(base::DictionaryValue* strings); | |
| 253 void PopulateMalwareStringDictionary(base::DictionaryValue* strings); | |
| 254 void PopulatePhishingStringDictionary(base::DictionaryValue* strings); | |
| 255 | |
| 256 // A helper method used by the Populate methods above used to populate common | |
| 257 // fields. | |
| 258 void PopulateStringDictionary(base::DictionaryValue* strings, | |
| 259 const base::string16& title, | |
| 260 const base::string16& headline, | |
| 261 const base::string16& description1, | |
| 262 const base::string16& description2, | |
| 263 const base::string16& description3); | |
| 264 | |
| 265 DISALLOW_COPY_AND_ASSIGN(SafeBrowsingBlockingPageV1); | |
| 266 }; | |
| 267 | |
| 268 class SafeBrowsingBlockingPageV2 : public SafeBrowsingBlockingPage { | |
| 269 public: | |
| 270 // Don't instantiate this class directly, use ShowBlockingPage instead. | |
| 271 SafeBrowsingBlockingPageV2(SafeBrowsingUIManager* ui_manager, | |
| 272 content::WebContents* web_contents, | |
| 273 const UnsafeResourceList& unsafe_resources); | |
| 274 | |
| 275 // InterstitialPageDelegate method: | |
| 276 virtual std::string GetHTMLContents() OVERRIDE; | |
| 277 | |
| 278 private: | |
| 279 // Fills the passed dictionary with the strings passed to JS Template when | |
| 280 // creating the HTML. | |
| 281 void PopulateMultipleThreatStringDictionary(base::DictionaryValue* strings); | |
| 282 void PopulateMalwareStringDictionary(base::DictionaryValue* strings); | |
| 283 void PopulatePhishingStringDictionary(base::DictionaryValue* strings); | |
| 284 | |
| 285 // A helper method used by the Populate methods above used to populate common | |
| 286 // fields. | |
| 287 void PopulateStringDictionary(base::DictionaryValue* strings, | |
| 288 const base::string16& title, | |
| 289 const base::string16& headline, | |
| 290 const base::string16& description1, | |
| 291 const base::string16& description2, | |
| 292 const base::string16& description3); | |
| 293 | |
| 294 DISALLOW_COPY_AND_ASSIGN(SafeBrowsingBlockingPageV2); | |
| 295 }; | |
| 296 | |
| 297 class SafeBrowsingBlockingPageV3 : public SafeBrowsingBlockingPage { | |
| 298 public: | |
| 299 SafeBrowsingBlockingPageV3(SafeBrowsingUIManager* ui_manager, | |
| 300 content::WebContents* web_contents, | |
| 301 const UnsafeResourceList& unsafe_resources); | |
| 302 | |
| 303 // InterstitialPageDelegate method: | |
| 304 virtual std::string GetHTMLContents() OVERRIDE; | |
| 305 | |
| 306 private: | 235 private: |
| 307 // Fills the passed dictionary with the values to be passed to the template | 236 // Fills the passed dictionary with the values to be passed to the template |
| 308 // when creating the HTML. | 237 // when creating the HTML. |
| 309 void PopulateMalwareLoadTimeData(base::DictionaryValue* load_time_data); | 238 void PopulateMalwareLoadTimeData(base::DictionaryValue* load_time_data); |
| 310 void PopulatePhishingLoadTimeData(base::DictionaryValue* load_time_data); | 239 void PopulatePhishingLoadTimeData(base::DictionaryValue* load_time_data); |
| 311 | 240 |
| 312 // For the M37 FieldTrial: this contains the name of the condition. | 241 DISALLOW_COPY_AND_ASSIGN(SafeBrowsingBlockingPage); |
| 313 std::string trial_condition_; | |
| 314 | |
| 315 DISALLOW_COPY_AND_ASSIGN(SafeBrowsingBlockingPageV3); | |
| 316 }; | 242 }; |
| 317 | 243 |
| 318 // Factory for creating SafeBrowsingBlockingPage. Useful for tests. | 244 // Factory for creating SafeBrowsingBlockingPage. Useful for tests. |
| 319 class SafeBrowsingBlockingPageFactory { | 245 class SafeBrowsingBlockingPageFactory { |
| 320 public: | 246 public: |
| 321 virtual ~SafeBrowsingBlockingPageFactory() { } | 247 virtual ~SafeBrowsingBlockingPageFactory() { } |
| 322 | 248 |
| 323 virtual SafeBrowsingBlockingPage* CreateSafeBrowsingPage( | 249 virtual SafeBrowsingBlockingPage* CreateSafeBrowsingPage( |
| 324 SafeBrowsingUIManager* ui_manager, | 250 SafeBrowsingUIManager* ui_manager, |
| 325 content::WebContents* web_contents, | 251 content::WebContents* web_contents, |
| 326 const SafeBrowsingBlockingPage::UnsafeResourceList& unsafe_resources) = 0; | 252 const SafeBrowsingBlockingPage::UnsafeResourceList& unsafe_resources) = 0; |
| 327 }; | 253 }; |
| 328 | 254 |
| 329 #endif // CHROME_BROWSER_SAFE_BROWSING_SAFE_BROWSING_BLOCKING_PAGE_H_ | 255 #endif // CHROME_BROWSER_SAFE_BROWSING_SAFE_BROWSING_BLOCKING_PAGE_H_ |
| OLD | NEW |