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 #include "chrome/browser/extensions/api/content_settings/content_settings_api.h" | 5 #include "chrome/browser/extensions/api/content_settings/content_settings_api.h" |
| 6 | 6 |
| 7 #include <set> | 7 #include <set> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| 11 #include "base/command_line.h" | 11 #include "base/command_line.h" |
| 12 #include "base/memory/scoped_ptr.h" | 12 #include "base/memory/scoped_ptr.h" |
| 13 #include "base/strings/stringprintf.h" | 13 #include "base/strings/stringprintf.h" |
| 14 #include "base/values.h" | 14 #include "base/values.h" |
| 15 #include "chrome/browser/content_settings/cookie_settings_factory.h" | 15 #include "chrome/browser/content_settings/cookie_settings_factory.h" |
| 16 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" | 16 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" |
| 17 #include "chrome/browser/extensions/api/content_settings/content_settings_api_co nstants.h" | 17 #include "chrome/browser/extensions/api/content_settings/content_settings_api_co nstants.h" |
| 18 #include "chrome/browser/extensions/api/content_settings/content_settings_helper s.h" | 18 #include "chrome/browser/extensions/api/content_settings/content_settings_helper s.h" |
| 19 #include "chrome/browser/extensions/api/content_settings/content_settings_servic e.h" | 19 #include "chrome/browser/extensions/api/content_settings/content_settings_servic e.h" |
| 20 #include "chrome/browser/extensions/api/content_settings/content_settings_store. h" | 20 #include "chrome/browser/extensions/api/content_settings/content_settings_store. h" |
| 21 #include "chrome/browser/extensions/api/preference/preference_api_constants.h" | 21 #include "chrome/browser/extensions/api/preference/preference_api_constants.h" |
| 22 #include "chrome/browser/extensions/api/preference/preference_helpers.h" | 22 #include "chrome/browser/extensions/api/preference/preference_helpers.h" |
| 23 #include "chrome/browser/plugins/plugin_finder.h" | 23 #include "chrome/browser/plugins/plugin_finder.h" |
| 24 #include "chrome/browser/plugins/plugin_installer.h" | 24 #include "chrome/browser/plugins/plugin_installer.h" |
| 25 #include "chrome/browser/profiles/profile.h" | 25 #include "chrome/browser/profiles/profile.h" |
| 26 #include "chrome/common/chrome_switches.h" | 26 #include "chrome/common/chrome_switches.h" |
| 27 #include "chrome/common/extensions/api/content_settings.h" | 27 #include "chrome/common/extensions/api/content_settings.h" |
| 28 #include "components/content_settings/core/browser/content_settings_utils.h" | |
| 28 #include "components/content_settings/core/browser/cookie_settings.h" | 29 #include "components/content_settings/core/browser/cookie_settings.h" |
| 29 #include "components/content_settings/core/browser/host_content_settings_map.h" | 30 #include "components/content_settings/core/browser/host_content_settings_map.h" |
| 30 #include "content/public/browser/plugin_service.h" | 31 #include "content/public/browser/plugin_service.h" |
| 31 #include "extensions/browser/extension_prefs_scope.h" | 32 #include "extensions/browser/extension_prefs_scope.h" |
| 32 #include "extensions/common/error_utils.h" | 33 #include "extensions/common/error_utils.h" |
| 33 | 34 |
| 34 using content::BrowserThread; | 35 using content::BrowserThread; |
| 35 using content::PluginService; | 36 using content::PluginService; |
| 36 | 37 |
| 37 namespace Clear = extensions::api::content_settings::ContentSetting::Clear; | 38 namespace Clear = extensions::api::content_settings::ContentSetting::Clear; |
| (...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 157 bool setting_cookie = false; | 158 bool setting_cookie = false; |
| 158 setting = cookie_settings->GetCookieSetting(primary_url, secondary_url, | 159 setting = cookie_settings->GetCookieSetting(primary_url, secondary_url, |
| 159 setting_cookie, NULL); | 160 setting_cookie, NULL); |
| 160 } else { | 161 } else { |
| 161 setting = map->GetContentSetting(primary_url, secondary_url, content_type, | 162 setting = map->GetContentSetting(primary_url, secondary_url, content_type, |
| 162 resource_identifier); | 163 resource_identifier); |
| 163 } | 164 } |
| 164 | 165 |
| 165 base::DictionaryValue* result = new base::DictionaryValue(); | 166 base::DictionaryValue* result = new base::DictionaryValue(); |
| 166 result->SetString(keys::kContentSettingKey, | 167 result->SetString(keys::kContentSettingKey, |
| 167 helpers::ContentSettingToString(setting)); | 168 content_settings::ContentSettingToString(setting)); |
| 168 | 169 |
| 169 SetResult(result); | 170 SetResult(result); |
| 170 | 171 |
| 171 return true; | 172 return true; |
| 172 } | 173 } |
| 173 | 174 |
| 174 bool ContentSettingsContentSettingSetFunction::RunSync() { | 175 bool ContentSettingsContentSettingSetFunction::RunSync() { |
| 175 ContentSettingsType content_type; | 176 ContentSettingsType content_type; |
| 176 EXTENSION_FUNCTION_VALIDATE(RemoveContentType(args_.get(), &content_type)); | 177 EXTENSION_FUNCTION_VALIDATE(RemoveContentType(args_.get(), &content_type)); |
| 177 | 178 |
| (...skipping 21 matching lines...) Expand all Loading... | |
| 199 } | 200 } |
| 200 } | 201 } |
| 201 | 202 |
| 202 std::string resource_identifier; | 203 std::string resource_identifier; |
| 203 if (params->details.resource_identifier.get()) | 204 if (params->details.resource_identifier.get()) |
| 204 resource_identifier = params->details.resource_identifier->id; | 205 resource_identifier = params->details.resource_identifier->id; |
| 205 | 206 |
| 206 std::string setting_str; | 207 std::string setting_str; |
| 207 EXTENSION_FUNCTION_VALIDATE( | 208 EXTENSION_FUNCTION_VALIDATE( |
| 208 params->details.setting->GetAsString(&setting_str)); | 209 params->details.setting->GetAsString(&setting_str)); |
| 209 ContentSetting setting; | 210 ContentSetting setting = |
| 210 EXTENSION_FUNCTION_VALIDATE( | 211 content_settings::ContentSettingFromString(setting_str); |
| 211 helpers::StringToContentSetting(setting_str, &setting)); | 212 DCHECK_NE(CONTENT_SETTING_DEFAULT, setting); |
|
Bernhard Bauer
2015/10/05 14:31:48
Sorry, this is the wrong way around (and a DCHECK
Deepak
2015/10/06 15:18:41
Done.
| |
| 212 EXTENSION_FUNCTION_VALIDATE(HostContentSettingsMap::IsSettingAllowedForType( | 213 EXTENSION_FUNCTION_VALIDATE(HostContentSettingsMap::IsSettingAllowedForType( |
| 213 GetProfile()->GetPrefs(), setting, content_type)); | 214 GetProfile()->GetPrefs(), setting, content_type)); |
| 214 | 215 |
| 215 // Some content setting types support the full set of values listed in | 216 // Some content setting types support the full set of values listed in |
| 216 // content_settings.json only for exceptions. For the default setting, | 217 // content_settings.json only for exceptions. For the default setting, |
| 217 // some values might not be supported. | 218 // some values might not be supported. |
| 218 // For example, camera supports [allow, ask, block] for exceptions, but only | 219 // For example, camera supports [allow, ask, block] for exceptions, but only |
| 219 // [ask, block] for the default setting. | 220 // [ask, block] for the default setting. |
| 220 if (primary_pattern == ContentSettingsPattern::Wildcard() && | 221 if (primary_pattern == ContentSettingsPattern::Wildcard() && |
| 221 secondary_pattern == ContentSettingsPattern::Wildcard() && | 222 secondary_pattern == ContentSettingsPattern::Wildcard() && |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 233 break; | 234 break; |
| 234 case CONTENT_SETTINGS_TYPE_MEDIASTREAM_CAMERA: | 235 case CONTENT_SETTINGS_TYPE_MEDIASTREAM_CAMERA: |
| 235 readable_type_name = "camera"; | 236 readable_type_name = "camera"; |
| 236 break; | 237 break; |
| 237 default: | 238 default: |
| 238 DCHECK(false) << "No human-readable type name defined for this type."; | 239 DCHECK(false) << "No human-readable type name defined for this type."; |
| 239 } | 240 } |
| 240 | 241 |
| 241 error_ = base::StringPrintf( | 242 error_ = base::StringPrintf( |
| 242 kUnsupportedDefaultSettingError, | 243 kUnsupportedDefaultSettingError, |
| 243 content_settings_helpers::ContentSettingToString(setting), | 244 content_settings::ContentSettingToString(setting).c_str(), |
| 244 readable_type_name.c_str()); | 245 readable_type_name.c_str()); |
| 245 return false; | 246 return false; |
| 246 } | 247 } |
| 247 | 248 |
| 248 ExtensionPrefsScope scope = kExtensionPrefsScopeRegular; | 249 ExtensionPrefsScope scope = kExtensionPrefsScopeRegular; |
| 249 bool incognito = false; | 250 bool incognito = false; |
| 250 if (params->details.scope == | 251 if (params->details.scope == |
| 251 api::content_settings::SCOPE_INCOGNITO_SESSION_ONLY) { | 252 api::content_settings::SCOPE_INCOGNITO_SESSION_ONLY) { |
| 252 scope = kExtensionPrefsScopeIncognitoSessionOnly; | 253 scope = kExtensionPrefsScopeIncognitoSessionOnly; |
| 253 incognito = true; | 254 incognito = true; |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 319 SetResult(list); | 320 SetResult(list); |
| 320 BrowserThread::PostTask( | 321 BrowserThread::PostTask( |
| 321 BrowserThread::UI, FROM_HERE, base::Bind( | 322 BrowserThread::UI, FROM_HERE, base::Bind( |
| 322 &ContentSettingsContentSettingGetResourceIdentifiersFunction:: | 323 &ContentSettingsContentSettingGetResourceIdentifiersFunction:: |
| 323 SendResponse, | 324 SendResponse, |
| 324 this, | 325 this, |
| 325 true)); | 326 true)); |
| 326 } | 327 } |
| 327 | 328 |
| 328 } // namespace extensions | 329 } // namespace extensions |
| OLD | NEW |