mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	A system-wide installation of the Pepper Flash plugin is available from Adobe for Windows and Mac OS X platforms as a separate download. To enable automatic detection and loading of the system-wide installation pass the `--enable-system-flash` command-line flag. The Pepper Flash plugin can also be loaded by specifying the file path and version via the `--ppapi-flash-path=<path> --ppapi-flash-version=<version>` command-line flags. The version can be identified by viewing the manifest.json file in the same directory as the Pepper Flash plugin library.
		
			
				
	
	
		
			135 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
 | 
						|
// Use of this source code is governed by a BSD-style license that can be
 | 
						|
// found in the LICENSE file.
 | 
						|
 | 
						|
#include "libcef/browser/pepper/pepper_flash_browser_host.h"
 | 
						|
 | 
						|
#include "base/time/time.h"
 | 
						|
#include "content/public/browser/browser_context.h"
 | 
						|
#include "content/public/browser/browser_ppapi_host.h"
 | 
						|
#include "content/public/browser/browser_thread.h"
 | 
						|
#include "content/public/browser/render_process_host.h"
 | 
						|
#include "ipc/ipc_message_macros.h"
 | 
						|
#include "ppapi/c/pp_errors.h"
 | 
						|
#include "ppapi/c/private/ppb_flash.h"
 | 
						|
#include "ppapi/host/dispatch_host_message.h"
 | 
						|
#include "ppapi/proxy/ppapi_messages.h"
 | 
						|
#include "ppapi/proxy/resource_message_params.h"
 | 
						|
#include "ppapi/shared_impl/time_conversion.h"
 | 
						|
#include "url/gurl.h"
 | 
						|
 | 
						|
#if defined(OS_WIN)
 | 
						|
#include <windows.h>
 | 
						|
#elif defined(OS_MACOSX)
 | 
						|
#include <CoreServices/CoreServices.h>
 | 
						|
#endif
 | 
						|
 | 
						|
using content::BrowserPpapiHost;
 | 
						|
using content::BrowserThread;
 | 
						|
using content::RenderProcessHost;
 | 
						|
 | 
						|
namespace {
 | 
						|
 | 
						|
// Returns true if the page identified by (|url|, |first_party_url|) is allowed
 | 
						|
// to read cookies.
 | 
						|
bool IsReadingCookieAllowed(const GURL& url,
 | 
						|
                            const GURL& first_party_url) {
 | 
						|
  return true;
 | 
						|
}
 | 
						|
 | 
						|
// Returns true if the cookie set by a page identified by |url| should be
 | 
						|
// session only.
 | 
						|
bool IsCookieSessionOnly(const GURL& url) {
 | 
						|
  return false;
 | 
						|
}
 | 
						|
 | 
						|
}  // namespace
 | 
						|
 | 
						|
PepperFlashBrowserHost::PepperFlashBrowserHost(BrowserPpapiHost* host,
 | 
						|
                                               PP_Instance instance,
 | 
						|
                                               PP_Resource resource)
 | 
						|
    : ResourceHost(host->GetPpapiHost(), instance, resource),
 | 
						|
      host_(host) {
 | 
						|
  int unused;
 | 
						|
  host->GetRenderFrameIDsForInstance(instance, &render_process_id_, &unused);
 | 
						|
}
 | 
						|
 | 
						|
PepperFlashBrowserHost::~PepperFlashBrowserHost() {}
 | 
						|
 | 
						|
int32_t PepperFlashBrowserHost::OnResourceMessageReceived(
 | 
						|
    const IPC::Message& msg,
 | 
						|
    ppapi::host::HostMessageContext* context) {
 | 
						|
  PPAPI_BEGIN_MESSAGE_MAP(PepperFlashBrowserHost, msg)
 | 
						|
    PPAPI_DISPATCH_HOST_RESOURCE_CALL_0(PpapiHostMsg_Flash_UpdateActivity,
 | 
						|
                                        OnUpdateActivity)
 | 
						|
    PPAPI_DISPATCH_HOST_RESOURCE_CALL(PpapiHostMsg_Flash_GetLocalTimeZoneOffset,
 | 
						|
                                      OnGetLocalTimeZoneOffset)
 | 
						|
    PPAPI_DISPATCH_HOST_RESOURCE_CALL_0(
 | 
						|
        PpapiHostMsg_Flash_GetLocalDataRestrictions, OnGetLocalDataRestrictions)
 | 
						|
  PPAPI_END_MESSAGE_MAP()
 | 
						|
  return PP_ERROR_FAILED;
 | 
						|
}
 | 
						|
 | 
						|
int32_t PepperFlashBrowserHost::OnUpdateActivity(
 | 
						|
    ppapi::host::HostMessageContext* host_context) {
 | 
						|
#if defined(OS_WIN)
 | 
						|
  // Reading then writing back the same value to the screensaver timeout system
 | 
						|
  // setting resets the countdown which prevents the screensaver from turning
 | 
						|
  // on "for a while". As long as the plugin pings us with this message faster
 | 
						|
  // than the screensaver timeout, it won't go on.
 | 
						|
  int value = 0;
 | 
						|
  if (SystemParametersInfo(SPI_GETSCREENSAVETIMEOUT, 0, &value, 0))
 | 
						|
    SystemParametersInfo(SPI_SETSCREENSAVETIMEOUT, value, NULL, 0);
 | 
						|
#elif defined(OS_MACOSX)
 | 
						|
  UpdateSystemActivity(OverallAct);
 | 
						|
#else
 | 
						|
// TODO(brettw) implement this for other platforms.
 | 
						|
#endif
 | 
						|
  return PP_OK;
 | 
						|
}
 | 
						|
 | 
						|
int32_t PepperFlashBrowserHost::OnGetLocalTimeZoneOffset(
 | 
						|
    ppapi::host::HostMessageContext* host_context,
 | 
						|
    const base::Time& t) {
 | 
						|
  // The reason for this processing being in the browser process is that on
 | 
						|
  // Linux, the localtime calls require filesystem access prohibited by the
 | 
						|
  // sandbox.
 | 
						|
  host_context->reply_msg = PpapiPluginMsg_Flash_GetLocalTimeZoneOffsetReply(
 | 
						|
      ppapi::PPGetLocalTimeZoneOffset(t));
 | 
						|
  return PP_OK;
 | 
						|
}
 | 
						|
 | 
						|
int32_t PepperFlashBrowserHost::OnGetLocalDataRestrictions(
 | 
						|
    ppapi::host::HostMessageContext* context) {
 | 
						|
  // Getting the Flash LSO settings requires using the CookieSettings which
 | 
						|
  // belong to the profile which lives on the UI thread. We lazily initialize
 | 
						|
  // |cookie_settings_| by grabbing the reference from the UI thread and then
 | 
						|
  // call |GetLocalDataRestrictions| with it.
 | 
						|
  GURL document_url = host_->GetDocumentURLForInstance(pp_instance());
 | 
						|
  GURL plugin_url = host_->GetPluginURLForInstance(pp_instance());
 | 
						|
  GetLocalDataRestrictions(context->MakeReplyMessageContext(),
 | 
						|
                           document_url,
 | 
						|
                           plugin_url);
 | 
						|
  return PP_OK_COMPLETIONPENDING;
 | 
						|
}
 | 
						|
 | 
						|
void PepperFlashBrowserHost::GetLocalDataRestrictions(
 | 
						|
    ppapi::host::ReplyMessageContext reply_context,
 | 
						|
    const GURL& document_url,
 | 
						|
    const GURL& plugin_url) {
 | 
						|
  DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
 | 
						|
 | 
						|
  PP_FlashLSORestrictions restrictions = PP_FLASHLSORESTRICTIONS_NONE;
 | 
						|
  if (document_url.is_valid() && plugin_url.is_valid()) {
 | 
						|
    // TODO(cef): Determine how to properly handle these permissions. In Chrome
 | 
						|
    // they're handled via CookieSettings associated with a Profile.
 | 
						|
    if (!IsReadingCookieAllowed(document_url, plugin_url))
 | 
						|
      restrictions = PP_FLASHLSORESTRICTIONS_BLOCK;
 | 
						|
    else if (IsCookieSessionOnly(plugin_url))
 | 
						|
      restrictions = PP_FLASHLSORESTRICTIONS_IN_MEMORY;
 | 
						|
  }
 | 
						|
  SendReply(reply_context,
 | 
						|
            PpapiPluginMsg_Flash_GetLocalDataRestrictionsReply(
 | 
						|
                static_cast<int32_t>(restrictions)));
 | 
						|
}
 |