mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2024-12-12 09:37:37 +01:00
e7ddc933c9
- 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.
137 lines
4.6 KiB
C++
137 lines
4.6 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/extensions/event_router_forwarder.h"
|
|
|
|
#include <stddef.h>
|
|
#include <utility>
|
|
|
|
#include "libcef/browser/browser_context_impl.h"
|
|
|
|
#include "base/bind.h"
|
|
#include "base/values.h"
|
|
#include "build/build_config.h"
|
|
#include "content/public/browser/browser_thread.h"
|
|
#include "extensions/browser/event_router.h"
|
|
#include "url/gurl.h"
|
|
|
|
using content::BrowserThread;
|
|
|
|
namespace extensions {
|
|
|
|
EventRouterForwarder::EventRouterForwarder() {
|
|
}
|
|
|
|
EventRouterForwarder::~EventRouterForwarder() {
|
|
}
|
|
|
|
void EventRouterForwarder::BroadcastEventToRenderers(
|
|
events::HistogramValue histogram_value,
|
|
const std::string& event_name,
|
|
std::unique_ptr<base::ListValue> event_args,
|
|
const GURL& event_url) {
|
|
HandleEvent(std::string(), histogram_value, event_name, std::move(event_args),
|
|
0, true, event_url);
|
|
}
|
|
|
|
void EventRouterForwarder::DispatchEventToRenderers(
|
|
events::HistogramValue histogram_value,
|
|
const std::string& event_name,
|
|
std::unique_ptr<base::ListValue> event_args,
|
|
void* profile,
|
|
bool use_profile_to_restrict_events,
|
|
const GURL& event_url) {
|
|
if (!profile)
|
|
return;
|
|
HandleEvent(std::string(), histogram_value, event_name, std::move(event_args),
|
|
profile, use_profile_to_restrict_events, event_url);
|
|
}
|
|
|
|
void EventRouterForwarder::BroadcastEventToExtension(
|
|
const std::string& extension_id,
|
|
events::HistogramValue histogram_value,
|
|
const std::string& event_name,
|
|
std::unique_ptr<base::ListValue> event_args,
|
|
const GURL& event_url) {
|
|
HandleEvent(extension_id, histogram_value, event_name, std::move(event_args),
|
|
0, true, event_url);
|
|
}
|
|
|
|
void EventRouterForwarder::DispatchEventToExtension(
|
|
const std::string& extension_id,
|
|
events::HistogramValue histogram_value,
|
|
const std::string& event_name,
|
|
std::unique_ptr<base::ListValue> event_args,
|
|
void* profile,
|
|
bool use_profile_to_restrict_events,
|
|
const GURL& event_url) {
|
|
if (!profile)
|
|
return;
|
|
HandleEvent(extension_id, histogram_value, event_name, std::move(event_args),
|
|
profile, use_profile_to_restrict_events, event_url);
|
|
}
|
|
|
|
void EventRouterForwarder::HandleEvent(
|
|
const std::string& extension_id,
|
|
events::HistogramValue histogram_value,
|
|
const std::string& event_name,
|
|
std::unique_ptr<base::ListValue> event_args,
|
|
void* profile_ptr,
|
|
bool use_profile_to_restrict_events,
|
|
const GURL& event_url) {
|
|
if (!BrowserThread::CurrentlyOn(BrowserThread::UI)) {
|
|
BrowserThread::PostTask(
|
|
BrowserThread::UI, FROM_HERE,
|
|
base::Bind(&EventRouterForwarder::HandleEvent, this, extension_id,
|
|
histogram_value, event_name, base::Passed(&event_args),
|
|
profile_ptr, use_profile_to_restrict_events, event_url));
|
|
return;
|
|
}
|
|
|
|
content::BrowserContext* profile = NULL;
|
|
if (profile_ptr) {
|
|
profile = reinterpret_cast<content::BrowserContext*>(profile_ptr);
|
|
if (CefBrowserContextImpl::GetForContext(profile) == NULL)
|
|
return;
|
|
}
|
|
if (profile) {
|
|
CallEventRouter(profile, extension_id, histogram_value, event_name,
|
|
std::move(event_args),
|
|
use_profile_to_restrict_events ? profile : NULL, event_url);
|
|
} else {
|
|
std::vector<CefBrowserContextImpl*> profiles(
|
|
CefBrowserContextImpl::GetAll());
|
|
for (size_t i = 0; i < profiles.size(); ++i) {
|
|
std::unique_ptr<base::ListValue> per_profile_event_args(
|
|
event_args->DeepCopy());
|
|
CallEventRouter(profiles[i], extension_id, histogram_value, event_name,
|
|
std::move(per_profile_event_args),
|
|
use_profile_to_restrict_events ? profiles[i] : NULL,
|
|
event_url);
|
|
}
|
|
}
|
|
}
|
|
|
|
void EventRouterForwarder::CallEventRouter(
|
|
content::BrowserContext* profile,
|
|
const std::string& extension_id,
|
|
events::HistogramValue histogram_value,
|
|
const std::string& event_name,
|
|
std::unique_ptr<base::ListValue> event_args,
|
|
content::BrowserContext* restrict_to_profile,
|
|
const GURL& event_url) {
|
|
std::unique_ptr<Event> event(
|
|
new Event(histogram_value, event_name, std::move(event_args)));
|
|
event->restrict_to_browser_context = restrict_to_profile;
|
|
event->event_url = event_url;
|
|
if (extension_id.empty()) {
|
|
extensions::EventRouter::Get(profile)->BroadcastEvent(std::move(event));
|
|
} else {
|
|
extensions::EventRouter::Get(profile)
|
|
->DispatchEventToExtension(extension_id, std::move(event));
|
|
}
|
|
}
|
|
|
|
} // namespace extensions
|