Index: chrome/browser/chrome_content_browser_client.cc |
diff --git a/chrome/browser/chrome_content_browser_client.cc b/chrome/browser/chrome_content_browser_client.cc |
index a2eb4645b5167a7b0ccff1064c5879c5052bd3be..a997e4f2f1940424a6ee9d855c441dfa1afbf95b 100644 |
--- a/chrome/browser/chrome_content_browser_client.cc |
+++ b/chrome/browser/chrome_content_browser_client.cc |
@@ -2294,48 +2294,8 @@ bool ChromeContentBrowserClient::AllowPepperSocketAPI( |
bool private_api, |
const content::SocketPermissionRequest* params) { |
#if defined(ENABLE_EXTENSIONS) |
- Profile* profile = Profile::FromBrowserContext(browser_context); |
- const extensions::ExtensionSet* extension_set = NULL; |
- if (profile) { |
- const ExtensionService* ext_service = |
- extensions::ExtensionSystem::Get(profile)->extension_service(); |
- if (ext_service) { |
- extension_set = ext_service->extensions(); |
- } |
- } |
- |
- if (private_api) { |
- // Access to private socket APIs is controlled by the whitelist. |
- if (IsExtensionOrSharedModuleWhitelisted(url, extension_set, |
Lei Zhang
2014/09/23 01:15:11
BTW, this is only declared if defined(ENABLE_PLUGI
|
- allowed_socket_origins_)) { |
- return true; |
- } |
- } else { |
- // Access to public socket APIs is controlled by extension permissions. |
- if (url.is_valid() && url.SchemeIs(extensions::kExtensionScheme) && |
- extension_set) { |
- const Extension* extension = extension_set->GetByID(url.host()); |
- if (extension) { |
- const extensions::PermissionsData* permissions_data = |
- extension->permissions_data(); |
- if (params) { |
- extensions::SocketPermission::CheckParam check_params( |
- params->type, params->host, params->port); |
- if (permissions_data->CheckAPIPermissionWithParam( |
- extensions::APIPermission::kSocket, &check_params)) { |
- return true; |
- } |
- } else if (permissions_data->HasAPIPermission( |
- extensions::APIPermission::kSocket)) { |
- return true; |
- } |
- } |
- } |
- } |
- |
- // Allow both public and private APIs if the command line says so. |
- return IsHostAllowedByCommandLine(url, extension_set, |
- switches::kAllowNaClSocketAPI); |
+ return ChromeContentBrowserClientExtensionsPart::AllowPepperSocketAPI( |
+ browser_context, url, private_api, params, allowed_socket_origins_); |
#else |
return false; |
#endif |
@@ -2509,19 +2469,9 @@ bool ChromeContentBrowserClient::IsPluginAllowedToCallRequestOSFileHandle( |
content::BrowserContext* browser_context, |
const GURL& url) { |
#if defined(ENABLE_EXTENSIONS) |
- Profile* profile = Profile::FromBrowserContext(browser_context); |
- const extensions::ExtensionSet* extension_set = NULL; |
- if (profile) { |
- const ExtensionService* ext_service = |
- extensions::ExtensionSystem::Get(profile)->extension_service(); |
- if (ext_service) { |
- extension_set = ext_service->extensions(); |
- } |
- } |
- return IsExtensionOrSharedModuleWhitelisted(url, extension_set, |
- allowed_file_handle_origins_) || |
- IsHostAllowedByCommandLine(url, extension_set, |
- switches::kAllowNaClFileHandleAPI); |
+ return ChromeContentBrowserClientExtensionsPart:: |
+ IsPluginAllowedToCallRequestOSFileHandle( |
+ browser_context, url, allowed_file_handle_origins_); |
#else |
return false; |
#endif |
@@ -2536,29 +2486,9 @@ bool ChromeContentBrowserClient::IsPluginAllowedToUseDevChannelAPIs( |
switches::kEnablePepperTesting)) { |
return true; |
} |
- |
- Profile* profile = Profile::FromBrowserContext(browser_context); |
- const extensions::ExtensionSet* extension_set = NULL; |
- if (profile) { |
- const ExtensionService* ext_service = |
- extensions::ExtensionSystem::Get(profile)->extension_service(); |
- if (ext_service) { |
- extension_set = ext_service->extensions(); |
- } |
- } |
- |
- // Allow access for whitelisted applications. |
- if (IsExtensionOrSharedModuleWhitelisted(url, |
- extension_set, |
- allowed_dev_channel_origins_)) { |
- return true; |
- } |
- |
- chrome::VersionInfo::Channel channel = chrome::VersionInfo::GetChannel(); |
- // Allow dev channel APIs to be used on "Canary", "Dev", and "Unknown" |
- // releases of Chrome. Permitting "Unknown" allows these APIs to be used on |
- // Chromium builds as well. |
- return channel <= chrome::VersionInfo::CHANNEL_DEV; |
+ return ChromeContentBrowserClientExtensionsPart:: |
+ IsPluginAllowedToUseDevChannelAPIs( |
+ browser_context, url, allowed_dev_channel_origins_); |
#else |
return false; |
#endif |