| Index: chrome/browser/managed_mode/managed_mode.cc
|
| diff --git a/chrome/browser/managed_mode/managed_mode.cc b/chrome/browser/managed_mode/managed_mode.cc
|
| index 0f0014f32ebc5ee6a8794c540226e26f596f4ac8..bfa61037ee44bf5e95dc2d0f0b37a2f6ebfed611 100644
|
| --- a/chrome/browser/managed_mode/managed_mode.cc
|
| +++ b/chrome/browser/managed_mode/managed_mode.cc
|
| @@ -14,6 +14,7 @@
|
| #include "chrome/browser/managed_mode/managed_mode_url_filter.h"
|
| #include "chrome/browser/policy/url_blacklist_manager.h"
|
| #include "chrome/browser/prefs/pref_service.h"
|
| +#include "chrome/browser/prefs/scoped_user_pref_update.h"
|
| #include "chrome/browser/profiles/profile.h"
|
| #include "chrome/browser/ui/browser.h"
|
| #include "chrome/browser/ui/browser_list.h"
|
| @@ -75,24 +76,22 @@ class ManagedMode::URLFilterContext {
|
| base::Bind(&base::DoNothing)));
|
| }
|
|
|
| - void AddStringToManualWhitelist(const std::string& url) {
|
| + void AddURLPatternToManualWhitelist(const std::string& url) {
|
| DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
|
| task_runner_->PostTask(FROM_HERE,
|
| - base::Bind(
|
| - &ManagedModeURLFilter::AddStringToManualWhitelist,
|
| - base::Unretained(&url_filter_),
|
| - url,
|
| - base::Bind(&base::DoNothing)));
|
| + base::Bind(&ManagedModeURLFilter::AddURLPatternToManualWhitelist,
|
| + base::Unretained(&url_filter_),
|
| + url,
|
| + base::Bind(&base::DoNothing)));
|
| }
|
|
|
| - void AddStringToManualBlacklist(const std::string& url) {
|
| + void AddURLPatternToManualBlacklist(const std::string& url) {
|
| DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
|
| task_runner_->PostTask(FROM_HERE,
|
| - base::Bind(
|
| - &ManagedModeURLFilter::AddStringToManualBlacklist,
|
| - base::Unretained(&url_filter_),
|
| - url,
|
| - base::Bind(&base::DoNothing)));
|
| + base::Bind(&ManagedModeURLFilter::AddURLPatternToManualBlacklist,
|
| + base::Unretained(&url_filter_),
|
| + url,
|
| + base::Bind(&base::DoNothing)));
|
| }
|
|
|
| void ShutdownOnUIThread() {
|
| @@ -262,17 +261,36 @@ void ManagedMode::GetCategoryNames(CategoryList* list) {
|
| };
|
|
|
| // static
|
| -scoped_ptr<base::ListValue> ManagedMode::GetWhitelist() {
|
| - // XXX Is this ok? GetList returns a const and we need non-const
|
| - return scoped_ptr<base::ListValue>(
|
| - GetInstance()->managed_profile_->GetPrefs()->GetList(
|
| - prefs::kManagedModeWhitelist)->DeepCopy()).Pass();
|
| +void ManagedMode::AddToManualWhitelist(const base::ListValue& whitelist) {
|
| + GetInstance()->AddToManualWhitelistImpl(whitelist);
|
| +}
|
| +
|
| +void ManagedMode::AddToManualWhitelistImpl(const base::ListValue& whitelist) {
|
| + ListPrefUpdate pref_update(managed_profile_->GetPrefs(),
|
| + prefs::kManagedModeWhitelist);
|
| + ListValue* pref_whitelist = pref_update.Get();
|
| +
|
| + for (size_t i = 0; i < whitelist.GetSize(); ++i) {
|
| + std::string url_pattern;
|
| + whitelist.GetString(i, &url_pattern);
|
| +
|
| + if (!IsInManualWhitelist(url_pattern)) {
|
| + pref_whitelist->AppendString(url_pattern);
|
| + AddURLPatternToManualWhitelist(url_pattern);
|
| + }
|
| + }
|
| }
|
|
|
| // static
|
| -void ManagedMode::SetWhitelist(base::ListValue* whitelist) {
|
| - GetInstance()->managed_profile_->GetPrefs()->Set(
|
| - prefs::kManagedModeWhitelist, *whitelist);
|
| +bool ManagedMode::IsInManualWhitelist(const std::string& url_pattern) {
|
| + return GetInstance()->IsInManualWhitelistImpl(url_pattern);
|
| +}
|
| +
|
| +bool ManagedMode::IsInManualWhitelistImpl(const std::string& url_pattern) {
|
| + StringValue pattern(url_pattern);
|
| + const ListValue* list = managed_profile_->GetPrefs()->GetList(
|
| + prefs::kManagedModeWhitelist);
|
| + return list->Find(pattern) != list->end();
|
| }
|
|
|
| // static
|
| @@ -519,12 +537,25 @@ void ManagedMode::UpdateWhitelist() {
|
| ui_url_filter_context_->LoadManualLists(GetWhitelist(), GetBlacklist());
|
| }
|
|
|
| -void ManagedMode::AddStringToManualWhitelist(const std::string& url) {
|
| - GetInstance()->io_url_filter_context_->AddStringToManualWhitelist(url);
|
| - GetInstance()->ui_url_filter_context_->AddStringToManualWhitelist(url);
|
| +scoped_ptr<base::ListValue> ManagedMode::GetWhitelist() {
|
| + return make_scoped_ptr(
|
| + managed_profile_->GetPrefs()->GetList(
|
| + prefs::kManagedModeWhitelist)->DeepCopy());
|
| +}
|
| +
|
| +
|
| +void ManagedMode::AddURLPatternToManualWhitelist(
|
| + const std::string& url_pattern) {
|
| + GetInstance()->io_url_filter_context_->AddURLPatternToManualWhitelist(
|
| + url_pattern);
|
| + GetInstance()->ui_url_filter_context_->AddURLPatternToManualWhitelist(
|
| + url_pattern);
|
| }
|
|
|
| -void ManagedMode::AddStringToManualBlacklist(const std::string& url) {
|
| - GetInstance()->io_url_filter_context_->AddStringToManualBlacklist(url);
|
| - GetInstance()->ui_url_filter_context_->AddStringToManualBlacklist(url);
|
| +void ManagedMode::AddURLPatternToManualBlacklist(
|
| + const std::string& url_pattern) {
|
| + GetInstance()->io_url_filter_context_->AddURLPatternToManualBlacklist(
|
| + url_pattern);
|
| + GetInstance()->ui_url_filter_context_->AddURLPatternToManualBlacklist(
|
| + url_pattern);
|
| }
|
|
|