mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			207 lines
		
	
	
		
			9.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			207 lines
		
	
	
		
			9.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| diff --git chrome/browser/background_fetch/background_fetch_permission_context.cc chrome/browser/background_fetch/background_fetch_permission_context.cc
 | |
| index 07a544f4fd8a3..7dfe80b9de4c1 100644
 | |
| --- chrome/browser/background_fetch/background_fetch_permission_context.cc
 | |
| +++ chrome/browser/background_fetch/background_fetch_permission_context.cc
 | |
| @@ -4,6 +4,7 @@
 | |
|  
 | |
|  #include "chrome/browser/background_fetch/background_fetch_permission_context.h"
 | |
|  
 | |
| +#include "cef/libcef/features/runtime.h"
 | |
|  #include "chrome/browser/browser_process.h"
 | |
|  #include "chrome/browser/content_settings/host_content_settings_map_factory.h"
 | |
|  #include "chrome/browser/download/download_request_limiter.h"
 | |
| @@ -29,7 +30,8 @@ ContentSetting BackgroundFetchPermissionContext::GetPermissionStatusInternal(
 | |
|      const GURL& embedding_origin) const {
 | |
|    DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
 | |
|  
 | |
| -  if (render_frame_host && !render_frame_host->GetParent()) {
 | |
| +  if (!cef::IsAlloyRuntimeEnabled() &&
 | |
| +      render_frame_host && !render_frame_host->GetParent()) {
 | |
|      DownloadRequestLimiter* limiter =
 | |
|          g_browser_process->download_request_limiter();
 | |
|      DCHECK(limiter);
 | |
| diff --git chrome/browser/background_sync/periodic_background_sync_permission_context.cc chrome/browser/background_sync/periodic_background_sync_permission_context.cc
 | |
| index cfab9f642611f..cc2c6c1f6e9c9 100644
 | |
| --- chrome/browser/background_sync/periodic_background_sync_permission_context.cc
 | |
| +++ chrome/browser/background_sync/periodic_background_sync_permission_context.cc
 | |
| @@ -6,6 +6,7 @@
 | |
|  
 | |
|  #include "base/feature_list.h"
 | |
|  #include "build/build_config.h"
 | |
| +#include "cef/libcef/features/runtime.h"
 | |
|  #include "chrome/browser/content_settings/host_content_settings_map_factory.h"
 | |
|  #include "chrome/browser/installable/installable_utils.h"
 | |
|  #include "chrome/browser/profiles/profile.h"
 | |
| @@ -94,6 +95,10 @@ PeriodicBackgroundSyncPermissionContext::GetPermissionStatusInternal(
 | |
|      return CONTENT_SETTING_ALLOW;
 | |
|  #endif
 | |
|  
 | |
| +  if (cef::IsAlloyRuntimeEnabled()) {
 | |
| +    return CONTENT_SETTING_BLOCK;
 | |
| +  }
 | |
| +
 | |
|    bool can_bypass_install_requirement =
 | |
|        base::FeatureList::IsEnabled(
 | |
|            features::kPeriodicSyncPermissionForDefaultSearchEngine) &&
 | |
| diff --git chrome/browser/permissions/chrome_permissions_client.cc chrome/browser/permissions/chrome_permissions_client.cc
 | |
| index 644eb40b81297..0715d54f84745 100644
 | |
| --- chrome/browser/permissions/chrome_permissions_client.cc
 | |
| +++ chrome/browser/permissions/chrome_permissions_client.cc
 | |
| @@ -12,6 +12,7 @@
 | |
|  #include "base/strings/string_util.h"
 | |
|  #include "build/build_config.h"
 | |
|  #include "build/chromeos_buildflags.h"
 | |
| +#include "cef/libcef/features/runtime.h"
 | |
|  #include "chrome/browser/bluetooth/bluetooth_chooser_context_factory.h"
 | |
|  #include "chrome/browser/content_settings/cookie_settings_factory.h"
 | |
|  #include "chrome/browser/content_settings/host_content_settings_map_factory.h"
 | |
| @@ -210,6 +211,9 @@ ChromePermissionsClient::GetPermissionDecisionAutoBlocker(
 | |
|  double ChromePermissionsClient::GetSiteEngagementScore(
 | |
|      content::BrowserContext* browser_context,
 | |
|      const GURL& origin) {
 | |
| +  // No SiteEngagementService with the Alloy runtime.
 | |
| +  if (cef::IsAlloyRuntimeEnabled())
 | |
| +    return 0.0;
 | |
|    return site_engagement::SiteEngagementService::Get(
 | |
|               Profile::FromBrowserContext(browser_context))
 | |
|        ->GetScore(origin);
 | |
| @@ -300,8 +304,10 @@ ChromePermissionsClient::CreatePermissionUiSelectors(
 | |
|        std::make_unique<ContextualNotificationPermissionUiSelector>());
 | |
|    selectors.emplace_back(std::make_unique<PrefNotificationPermissionUiSelector>(
 | |
|        Profile::FromBrowserContext(browser_context)));
 | |
| +  if (!cef::IsAlloyRuntimeEnabled()) {
 | |
|    selectors.emplace_back(std::make_unique<PredictionBasedPermissionUiSelector>(
 | |
|        Profile::FromBrowserContext(browser_context)));
 | |
| +  }
 | |
|    return selectors;
 | |
|  }
 | |
|  
 | |
| diff --git chrome/browser/permissions/permission_manager_factory.cc chrome/browser/permissions/permission_manager_factory.cc
 | |
| index ad86b42a1698e..74f046951383d 100644
 | |
| --- chrome/browser/permissions/permission_manager_factory.cc
 | |
| +++ chrome/browser/permissions/permission_manager_factory.cc
 | |
| @@ -6,6 +6,7 @@
 | |
|  
 | |
|  #include "build/build_config.h"
 | |
|  #include "build/chromeos_buildflags.h"
 | |
| +#include "cef/libcef/features/runtime.h"
 | |
|  #include "chrome/browser/background_fetch/background_fetch_permission_context.h"
 | |
|  #include "chrome/browser/background_sync/periodic_background_sync_permission_context.h"
 | |
|  #include "chrome/browser/content_settings/host_content_settings_map_factory.h"
 | |
| @@ -59,8 +60,10 @@ permissions::PermissionManager::PermissionContextMap CreatePermissionContexts(
 | |
|        std::make_unique<GeolocationPermissionContextDelegate>(profile);
 | |
|  #endif  // BUILDFLAG(IS_ANDROID)
 | |
|  #if BUILDFLAG(IS_MAC)
 | |
| +  if (!cef::IsAlloyRuntimeEnabled()) {
 | |
|    delegates.geolocation_manager =
 | |
|        g_browser_process->platform_part()->geolocation_manager();
 | |
| +  }
 | |
|  #endif  // BUILDFLAG(IS_MAC)
 | |
|    delegates.media_stream_device_enumerator =
 | |
|        MediaCaptureDevicesDispatcher::GetInstance();
 | |
| diff --git chrome/browser/storage/durable_storage_permission_context.cc chrome/browser/storage/durable_storage_permission_context.cc
 | |
| index b60603e7843eb..9051a490f0b44 100644
 | |
| --- chrome/browser/storage/durable_storage_permission_context.cc
 | |
| +++ chrome/browser/storage/durable_storage_permission_context.cc
 | |
| @@ -8,6 +8,7 @@
 | |
|  
 | |
|  #include "base/check_op.h"
 | |
|  #include "base/containers/contains.h"
 | |
| +#include "cef/libcef/features/runtime.h"
 | |
|  #include "chrome/browser/bookmarks/bookmark_model_factory.h"
 | |
|  #include "chrome/browser/content_settings/cookie_settings_factory.h"
 | |
|  #include "chrome/browser/content_settings/host_content_settings_map_factory.h"
 | |
| @@ -52,7 +53,9 @@ void DurableStoragePermissionContext::DecidePermission(
 | |
|  
 | |
|    // Durable is only allowed to be granted to the top-level origin. Embedding
 | |
|    // origin is the last committed navigation origin to the web contents.
 | |
| -  if (requesting_origin != embedding_origin) {
 | |
| +  // Permission depends on PWA and site engagement subsystems which are not
 | |
| +  // supported by the Alloy runtime (see issue #3379).
 | |
| +  if (cef::IsAlloyRuntimeEnabled() || requesting_origin != embedding_origin) {
 | |
|      NotifyPermissionSet(id, requesting_origin, embedding_origin,
 | |
|                          std::move(callback), /*persist=*/false,
 | |
|                          CONTENT_SETTING_DEFAULT, /*is_one_time=*/false);
 | |
| diff --git chrome/browser/ui/permission_bubble/permission_prompt.h chrome/browser/ui/permission_bubble/permission_prompt.h
 | |
| index fbce13c16ad10..0512b2f09937e 100644
 | |
| --- chrome/browser/ui/permission_bubble/permission_prompt.h
 | |
| +++ chrome/browser/ui/permission_bubble/permission_prompt.h
 | |
| @@ -11,6 +11,13 @@ namespace content {
 | |
|  class WebContents;
 | |
|  }
 | |
|  
 | |
| +using CreatePermissionPromptFunctionPtr =
 | |
| +    std::unique_ptr<permissions::PermissionPrompt> (*)(
 | |
| +        content::WebContents* web_contents,
 | |
| +        permissions::PermissionPrompt::Delegate* delegate,
 | |
| +        bool* default_handling);
 | |
| +void SetCreatePermissionPromptFunction(CreatePermissionPromptFunctionPtr);
 | |
| +
 | |
|  // Factory function to create permission prompts for chrome.
 | |
|  std::unique_ptr<permissions::PermissionPrompt> CreatePermissionPrompt(
 | |
|      content::WebContents* web_contents,
 | |
| diff --git chrome/browser/ui/views/permissions/permission_prompt_factory.cc chrome/browser/ui/views/permissions/permission_prompt_factory.cc
 | |
| index 4584985a62cfa..3e894a8c8ca9d 100644
 | |
| --- chrome/browser/ui/views/permissions/permission_prompt_factory.cc
 | |
| +++ chrome/browser/ui/views/permissions/permission_prompt_factory.cc
 | |
| @@ -142,11 +142,28 @@ std::unique_ptr<permissions::PermissionPrompt> CreateQuietPrompt(
 | |
|    }
 | |
|  }
 | |
|  
 | |
| +CreatePermissionPromptFunctionPtr g_create_permission_prompt_ptr = nullptr;
 | |
| +
 | |
|  }  // namespace
 | |
|  
 | |
| +void SetCreatePermissionPromptFunction(
 | |
| +    CreatePermissionPromptFunctionPtr ptr) {
 | |
| +  g_create_permission_prompt_ptr = ptr;
 | |
| +}
 | |
| +
 | |
|  std::unique_ptr<permissions::PermissionPrompt> CreatePermissionPrompt(
 | |
|      content::WebContents* web_contents,
 | |
|      permissions::PermissionPrompt::Delegate* delegate) {
 | |
| +  if (g_create_permission_prompt_ptr) {
 | |
| +    bool default_handling = true;
 | |
| +    auto prompt = g_create_permission_prompt_ptr(web_contents, delegate,
 | |
| +                                                 &default_handling);
 | |
| +    if (prompt)
 | |
| +      return prompt;
 | |
| +    if (!default_handling)
 | |
| +      return nullptr;
 | |
| +  }
 | |
| +
 | |
|    Browser* browser = chrome::FindBrowserWithWebContents(web_contents);
 | |
|    if (!browser) {
 | |
|      DLOG(WARNING) << "Permission prompt suppressed because the WebContents is "
 | |
| diff --git components/embedder_support/permission_context_utils.cc components/embedder_support/permission_context_utils.cc
 | |
| index c3b99f8e21b1c..8abca05c7c482 100644
 | |
| --- components/embedder_support/permission_context_utils.cc
 | |
| +++ components/embedder_support/permission_context_utils.cc
 | |
| @@ -5,6 +5,7 @@
 | |
|  #include "components/embedder_support/permission_context_utils.h"
 | |
|  
 | |
|  #include "build/build_config.h"
 | |
| +#include "cef/libcef/features/runtime.h"
 | |
|  #include "components/background_sync/background_sync_permission_context.h"
 | |
|  #include "components/permissions/contexts/accessibility_permission_context.h"
 | |
|  #include "components/permissions/contexts/camera_pan_tilt_zoom_permission_context.h"
 | |
| @@ -78,11 +79,18 @@ CreateDefaultPermissionContexts(content::BrowserContext* browser_context,
 | |
|            browser_context,
 | |
|            std::move(delegates.geolocation_permission_context_delegate));
 | |
|  #elif BUILDFLAG(IS_MAC)
 | |
| +  if (cef::IsAlloyRuntimeEnabled()) {
 | |
| +    permission_contexts[ContentSettingsType::GEOLOCATION] =
 | |
| +        std::make_unique<permissions::GeolocationPermissionContext>(
 | |
| +            browser_context,
 | |
| +            std::move(delegates.geolocation_permission_context_delegate));
 | |
| +  } else {
 | |
|    permission_contexts[ContentSettingsType::GEOLOCATION] =
 | |
|        std::make_unique<permissions::GeolocationPermissionContextMac>(
 | |
|            browser_context,
 | |
|            std::move(delegates.geolocation_permission_context_delegate),
 | |
|            delegates.geolocation_manager);
 | |
| +  }
 | |
|  #else
 | |
|    permission_contexts[ContentSettingsType::GEOLOCATION] =
 | |
|        std::make_unique<permissions::GeolocationPermissionContext>(
 |