Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #include "chrome/browser/supervised_user/supervised_user_interstitial.h" | 5 #include "chrome/browser/supervised_user/supervised_user_interstitial.h" |
| 6 | 6 |
| 7 #include "base/memory/weak_ptr.h" | 7 #include "base/memory/weak_ptr.h" |
| 8 #include "base/metrics/histogram.h" | 8 #include "base/metrics/histogram.h" |
| 9 #include "base/prefs/pref_service.h" | 9 #include "base/prefs/pref_service.h" |
| 10 #include "base/strings/string_number_conversions.h" | 10 #include "base/strings/string_number_conversions.h" |
| (...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 108 | 108 |
| 109 SupervisedUserInterstitial::SupervisedUserInterstitial( | 109 SupervisedUserInterstitial::SupervisedUserInterstitial( |
| 110 WebContents* web_contents, | 110 WebContents* web_contents, |
| 111 const GURL& url, | 111 const GURL& url, |
| 112 const base::Callback<void(bool)>& callback) | 112 const base::Callback<void(bool)>& callback) |
| 113 : web_contents_(web_contents), | 113 : web_contents_(web_contents), |
| 114 interstitial_page_(NULL), | 114 interstitial_page_(NULL), |
| 115 url_(url), | 115 url_(url), |
| 116 callback_(callback) {} | 116 callback_(callback) {} |
| 117 | 117 |
| 118 SupervisedUserInterstitial::~SupervisedUserInterstitial() {} | 118 SupervisedUserInterstitial::~SupervisedUserInterstitial() { |
| 119 DCHECK(!web_contents_); | |
| 120 } | |
| 119 | 121 |
| 120 bool SupervisedUserInterstitial::Init() { | 122 bool SupervisedUserInterstitial::Init() { |
| 121 if (ShouldProceed()) { | 123 if (ShouldProceed()) { |
| 122 // It can happen that the site was only allowed very recently and the URL | 124 // It can happen that the site was only allowed very recently and the URL |
| 123 // filter on the IO thread had not been updated yet. Proceed with the | 125 // filter on the IO thread had not been updated yet. Proceed with the |
| 124 // request without showing the interstitial. | 126 // request without showing the interstitial. |
| 125 DispatchContinueRequest(true); | 127 DispatchContinueRequest(true); |
| 126 return false; | 128 return false; |
| 127 } | 129 } |
| 128 | 130 |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 145 details.type = content::NAVIGATION_TYPE_NEW_PAGE; | 147 details.type = content::NAVIGATION_TYPE_NEW_PAGE; |
| 146 for (int i = service->infobar_count() - 1; i >= 0; --i) { | 148 for (int i = service->infobar_count() - 1; i >= 0; --i) { |
| 147 infobars::InfoBar* infobar = service->infobar_at(i); | 149 infobars::InfoBar* infobar = service->infobar_at(i); |
| 148 if (infobar->delegate()->ShouldExpire( | 150 if (infobar->delegate()->ShouldExpire( |
| 149 InfoBarService::NavigationDetailsFromLoadCommittedDetails( | 151 InfoBarService::NavigationDetailsFromLoadCommittedDetails( |
| 150 details))) | 152 details))) |
| 151 service->RemoveInfoBar(infobar); | 153 service->RemoveInfoBar(infobar); |
| 152 } | 154 } |
| 153 } | 155 } |
| 154 | 156 |
| 155 // TODO(bauerb): Extract an observer callback on SupervisedUserService for | |
| 156 // this. | |
| 157 Profile* profile = | 157 Profile* profile = |
| 158 Profile::FromBrowserContext(web_contents_->GetBrowserContext()); | 158 Profile::FromBrowserContext(web_contents_->GetBrowserContext()); |
| 159 PrefService* prefs = profile->GetPrefs(); | 159 SupervisedUserService* supervised_user_service = |
| 160 pref_change_registrar_.Init(prefs); | 160 SupervisedUserServiceFactory::GetForProfile(profile); |
| 161 pref_change_registrar_.Add( | 161 supervised_user_service->AddObserver(this); |
| 162 prefs::kDefaultSupervisedUserFilteringBehavior, | |
| 163 base::Bind(&SupervisedUserInterstitial::OnFilteringPrefsChanged, | |
| 164 base::Unretained(this))); | |
| 165 pref_change_registrar_.Add( | |
| 166 prefs::kSupervisedUserManualHosts, | |
| 167 base::Bind(&SupervisedUserInterstitial::OnFilteringPrefsChanged, | |
| 168 base::Unretained(this))); | |
| 169 pref_change_registrar_.Add( | |
| 170 prefs::kSupervisedUserManualURLs, | |
| 171 base::Bind(&SupervisedUserInterstitial::OnFilteringPrefsChanged, | |
| 172 base::Unretained(this))); | |
| 173 | 162 |
| 174 interstitial_page_ = | 163 interstitial_page_ = |
| 175 content::InterstitialPage::Create(web_contents_, true, url_, this); | 164 content::InterstitialPage::Create(web_contents_, true, url_, this); |
| 176 interstitial_page_->Show(); | 165 interstitial_page_->Show(); |
| 177 | 166 |
| 178 return true; | 167 return true; |
| 179 } | 168 } |
| 180 | 169 |
| 181 std::string SupervisedUserInterstitial::GetHTMLContents() { | 170 std::string SupervisedUserInterstitial::GetHTMLContents() { |
| 182 base::DictionaryValue strings; | 171 base::DictionaryValue strings; |
| (...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 280 // CHECK instead of DCHECK as defense in depth in case we'd accidentally | 269 // CHECK instead of DCHECK as defense in depth in case we'd accidentally |
| 281 // proceed on a blocked page. | 270 // proceed on a blocked page. |
| 282 CHECK(ShouldProceed()); | 271 CHECK(ShouldProceed()); |
| 283 DispatchContinueRequest(true); | 272 DispatchContinueRequest(true); |
| 284 } | 273 } |
| 285 | 274 |
| 286 void SupervisedUserInterstitial::OnDontProceed() { | 275 void SupervisedUserInterstitial::OnDontProceed() { |
| 287 DispatchContinueRequest(false); | 276 DispatchContinueRequest(false); |
| 288 } | 277 } |
| 289 | 278 |
| 279 void SupervisedUserInterstitial::OnURLFilterChanged() { | |
| 280 if (web_contents_ && ShouldProceed()) | |
|
Bernhard Bauer
2014/09/24 11:51:59
Why do we need the |web_contents_| check now? Just
Marc Treib
2014/09/24 12:02:27
Because ShouldProceed uses the WebContents to get
| |
| 281 interstitial_page_->Proceed(); | |
| 282 } | |
| 283 | |
| 290 bool SupervisedUserInterstitial::ShouldProceed() { | 284 bool SupervisedUserInterstitial::ShouldProceed() { |
| 285 DCHECK(web_contents_); | |
| 291 Profile* profile = | 286 Profile* profile = |
| 292 Profile::FromBrowserContext(web_contents_->GetBrowserContext()); | 287 Profile::FromBrowserContext(web_contents_->GetBrowserContext()); |
| 293 SupervisedUserService* supervised_user_service = | 288 SupervisedUserService* supervised_user_service = |
| 294 SupervisedUserServiceFactory::GetForProfile(profile); | 289 SupervisedUserServiceFactory::GetForProfile(profile); |
| 295 SupervisedUserURLFilter* url_filter = | 290 SupervisedUserURLFilter* url_filter = |
| 296 supervised_user_service->GetURLFilterForUIThread(); | 291 supervised_user_service->GetURLFilterForUIThread(); |
| 297 return url_filter->GetFilteringBehaviorForURL(url_) != | 292 return url_filter->GetFilteringBehaviorForURL(url_) != |
| 298 SupervisedUserURLFilter::BLOCK; | 293 SupervisedUserURLFilter::BLOCK; |
| 299 } | 294 } |
| 300 | 295 |
| 301 void SupervisedUserInterstitial::OnFilteringPrefsChanged() { | |
| 302 if (ShouldProceed()) | |
| 303 interstitial_page_->Proceed(); | |
| 304 } | |
| 305 | |
| 306 void SupervisedUserInterstitial::DispatchContinueRequest( | 296 void SupervisedUserInterstitial::DispatchContinueRequest( |
| 307 bool continue_request) { | 297 bool continue_request) { |
| 298 DCHECK(web_contents_); | |
| 299 Profile* profile = | |
| 300 Profile::FromBrowserContext(web_contents_->GetBrowserContext()); | |
| 301 SupervisedUserService* supervised_user_service = | |
| 302 SupervisedUserServiceFactory::GetForProfile(profile); | |
| 303 supervised_user_service->RemoveObserver(this); | |
| 304 | |
| 308 BrowserThread::PostTask( | 305 BrowserThread::PostTask( |
| 309 BrowserThread::IO, FROM_HERE, base::Bind(callback_, continue_request)); | 306 BrowserThread::IO, FROM_HERE, base::Bind(callback_, continue_request)); |
| 307 | |
| 308 // After this, the WebContents may be destroyed. Make sure we don't try to use | |
| 309 // it again. | |
| 310 web_contents_ = NULL; | |
|
Bernhard Bauer
2014/09/24 11:51:59
Is it guaranteed that this will be called, even if
Marc Treib
2014/09/24 12:02:27
Yes, InterstitialPageImpl calls OnDontProceed when
Bernhard Bauer
2014/09/24 12:58:43
Hm, accessing |web_contents_| above already worrie
Marc Treib
2014/09/24 13:25:25
That's a good point.
| |
| 310 } | 311 } |
| OLD | NEW |