mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	- Remove |accept_lang| parameter from CefJSDialogHandler::OnJSDialog and CefFormatUrlForSecurityDisplay (see https://crbug.com/336973#c36). - Remove remaining NPAPI-related code including functions from cef_web_plugin.h (see https://crbug.com/493212#c55). - Mac: 10.7+ deployment target is now required for client applications. - Mac: Remove CefBrowserHost::SetWindowVisibility (issue #1375). No replacement is required for windowed rendering. Use WasHidden for off-screen rendering. - Windows: Visual Studio 2015 Update 2 is now required when building CEF/Chromium.
		
			
				
	
	
		
			153 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			153 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // Copyright (c) 2012 The Chromium Embedded Framework 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/web_plugin_impl.h"
 | |
| #include "libcef/browser/context.h"
 | |
| #include "libcef/browser/thread_util.h"
 | |
| 
 | |
| #include "base/bind.h"
 | |
| #include "base/files/file_path.h"
 | |
| #include "content/browser/plugin_service_impl.h"
 | |
| 
 | |
| namespace {
 | |
| 
 | |
| void PluginsCallbackImpl(
 | |
|     CefRefPtr<CefWebPluginInfoVisitor> visitor,
 | |
|     const std::vector<content::WebPluginInfo>& all_plugins) {
 | |
|   CEF_REQUIRE_UIT();
 | |
| 
 | |
|   int count = 0;
 | |
|   int total = static_cast<int>(all_plugins.size());
 | |
| 
 | |
|   std::vector<content::WebPluginInfo>::const_iterator it = all_plugins.begin();
 | |
|   for (; it != all_plugins.end(); ++it, ++count) {
 | |
|     CefRefPtr<CefWebPluginInfoImpl> info(new CefWebPluginInfoImpl(*it));
 | |
|     if (!visitor->Visit(info.get(), count, total))
 | |
|       break;
 | |
|   }
 | |
| }
 | |
| 
 | |
| }  // namespace
 | |
| 
 | |
| 
 | |
| // CefWebPluginInfoImpl
 | |
| 
 | |
| CefWebPluginInfoImpl::CefWebPluginInfoImpl(
 | |
|     const content::WebPluginInfo& plugin_info)
 | |
|     : plugin_info_(plugin_info) {
 | |
| }
 | |
| 
 | |
| CefString CefWebPluginInfoImpl::GetName() {
 | |
|   return plugin_info_.name;
 | |
| }
 | |
| 
 | |
| CefString CefWebPluginInfoImpl::GetPath() {
 | |
|   return plugin_info_.path.value();
 | |
| }
 | |
| 
 | |
| CefString CefWebPluginInfoImpl::GetVersion() {
 | |
|   return plugin_info_.version;
 | |
| }
 | |
| 
 | |
| CefString CefWebPluginInfoImpl::GetDescription() {
 | |
|   return plugin_info_.desc;
 | |
| }
 | |
| 
 | |
| 
 | |
| // Global functions.
 | |
| 
 | |
| void CefVisitWebPluginInfo(CefRefPtr<CefWebPluginInfoVisitor> visitor) {
 | |
|   // Verify that the context is in a valid state.
 | |
|   if (!CONTEXT_STATE_VALID()) {
 | |
|     NOTREACHED() << "context not valid";
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   if (!visitor.get()) {
 | |
|     NOTREACHED() << "invalid parameter";
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   if (CEF_CURRENTLY_ON_UIT()) {
 | |
|     content::PluginServiceImpl::GetInstance()->GetPlugins(
 | |
|         base::Bind(PluginsCallbackImpl, visitor));
 | |
|   } else {
 | |
|     // Execute on the UI thread.
 | |
|     CEF_POST_TASK(CEF_UIT, base::Bind(CefVisitWebPluginInfo, visitor));
 | |
|   }
 | |
| }
 | |
| 
 | |
| void CefRefreshWebPlugins() {
 | |
|   // Verify that the context is in a valid state.
 | |
|   if (!CONTEXT_STATE_VALID()) {
 | |
|     NOTREACHED() << "context not valid";
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   // No thread affinity.
 | |
|   content::PluginServiceImpl::GetInstance()->RefreshPlugins();
 | |
| }
 | |
| 
 | |
| void CefUnregisterInternalWebPlugin(const CefString& path) {
 | |
|   // Verify that the context is in a valid state.
 | |
|   if (!CONTEXT_STATE_VALID()) {
 | |
|     NOTREACHED() << "context not valid";
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   if (path.empty()) {
 | |
|     NOTREACHED() << "invalid parameter";
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   // No thread affinity.
 | |
|   content::PluginServiceImpl::GetInstance()->UnregisterInternalPlugin(
 | |
|       base::FilePath(path));
 | |
| }
 | |
| 
 | |
| void CefRegisterWebPluginCrash(const CefString& path) {
 | |
|   // Verify that the context is in a valid state.
 | |
|   if (!CONTEXT_STATE_VALID()) {
 | |
|     NOTREACHED() << "context not valid";
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   if (path.empty()) {
 | |
|     NOTREACHED() << "invalid parameter";
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   if (CEF_CURRENTLY_ON_IOT()) {
 | |
|     content::PluginServiceImpl::GetInstance()->RegisterPluginCrash(
 | |
|         base::FilePath(path));
 | |
|   } else {
 | |
|     // Execute on the IO thread.
 | |
|     CEF_POST_TASK(CEF_IOT, base::Bind(CefRegisterWebPluginCrash, path));
 | |
|   }
 | |
| }
 | |
| 
 | |
| void CefIsWebPluginUnstable(
 | |
|     const CefString& path,
 | |
|     CefRefPtr<CefWebPluginUnstableCallback> callback) {
 | |
|   // Verify that the context is in a valid state.
 | |
|   if (!CONTEXT_STATE_VALID()) {
 | |
|     NOTREACHED() << "context not valid";
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   if (path.empty() || !callback.get()) {
 | |
|     NOTREACHED() << "invalid parameter";
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   if (CEF_CURRENTLY_ON_IOT()) {
 | |
|     callback->IsUnstable(path,
 | |
|         content::PluginServiceImpl::GetInstance()->IsPluginUnstable(
 | |
|             base::FilePath(path)));
 | |
|   } else {
 | |
|     // Execute on the IO thread.
 | |
|     CEF_POST_TASK(CEF_IOT, base::Bind(CefIsWebPluginUnstable, path, callback));
 | |
|   }
 | |
| }
 |