mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-01-23 07:50:44 +01:00
240b869db5
Widevine CDM binaries will be downloaded on supported platforms shortly after application startup. Widevine support will then become available within a few seconds after successful installation on Windows or after the next application restart on other platforms. The CDM files will be downloaded to a "WidevineCdm" directory inside the `CefSettings.user_data_path` directory. Pass the `--disable-component-update` command-line flag to disable Widevine download and installation. Pass the `--component-updater=fast-update` command- line flag to force Widevine download immediately after application startup. See the related issue for additional usage details.
151 lines
3.8 KiB
C++
151 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::BindOnce(PluginsCallbackImpl, visitor));
|
|
} else {
|
|
// Execute on the UI thread.
|
|
CEF_POST_TASK(CEF_UIT, base::BindOnce(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::BindOnce(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::BindOnce(CefIsWebPluginUnstable, path, callback));
|
|
}
|
|
}
|