Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2930)

Unified Diff: chrome/browser/chrome_content_browser_client.cc

Issue 591063003: Split ChromeContentBrowserClient into smaller parts. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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

Powered by Google App Engine
This is Rietveld 408576698