summaryrefslogtreecommitdiffstats
path: root/extensions/renderer/guest_view
diff options
context:
space:
mode:
Diffstat (limited to 'extensions/renderer/guest_view')
-rw-r--r--extensions/renderer/guest_view/extensions_guest_view_container.h4
-rw-r--r--extensions/renderer/guest_view/guest_view_container.cc150
-rw-r--r--extensions/renderer/guest_view/guest_view_container.h73
-rw-r--r--extensions/renderer/guest_view/guest_view_internal_custom_bindings.cc20
-rw-r--r--extensions/renderer/guest_view/guest_view_request.cc123
-rw-r--r--extensions/renderer/guest_view/guest_view_request.h97
-rw-r--r--extensions/renderer/guest_view/mime_handler_view/mime_handler_view_container.h4
7 files changed, 15 insertions, 456 deletions
diff --git a/extensions/renderer/guest_view/extensions_guest_view_container.h b/extensions/renderer/guest_view/extensions_guest_view_container.h
index 0a29daf..0626da0 100644
--- a/extensions/renderer/guest_view/extensions_guest_view_container.h
+++ b/extensions/renderer/guest_view/extensions_guest_view_container.h
@@ -7,7 +7,7 @@
#include <queue>
-#include "extensions/renderer/guest_view/guest_view_container.h"
+#include "components/guest_view/renderer/guest_view_container.h"
#include "v8/include/v8.h"
namespace gfx {
@@ -16,7 +16,7 @@ class Size;
namespace extensions {
-class ExtensionsGuestViewContainer : public GuestViewContainer {
+class ExtensionsGuestViewContainer : public guest_view::GuestViewContainer {
public:
explicit ExtensionsGuestViewContainer(content::RenderFrame* render_frame);
~ExtensionsGuestViewContainer() override;
diff --git a/extensions/renderer/guest_view/guest_view_container.cc b/extensions/renderer/guest_view/guest_view_container.cc
deleted file mode 100644
index d09fa00..0000000
--- a/extensions/renderer/guest_view/guest_view_container.cc
+++ /dev/null
@@ -1,150 +0,0 @@
-// Copyright 2014 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 "extensions/renderer/guest_view/guest_view_container.h"
-
-#include "components/guest_view/common/guest_view_constants.h"
-#include "components/guest_view/common/guest_view_messages.h"
-#include "content/public/renderer/render_frame.h"
-#include "content/public/renderer/render_frame_observer.h"
-#include "content/public/renderer/render_view.h"
-#include "extensions/common/guest_view/extensions_guest_view_messages.h"
-#include "extensions/renderer/guest_view/guest_view_request.h"
-
-namespace {
-
-using GuestViewContainerMap = std::map<int, extensions::GuestViewContainer*>;
-static base::LazyInstance<GuestViewContainerMap> g_guest_view_container_map =
- LAZY_INSTANCE_INITIALIZER;
-
-} // namespace
-
-namespace extensions {
-
-class GuestViewContainer::RenderFrameLifetimeObserver
- : public content::RenderFrameObserver {
- public:
- RenderFrameLifetimeObserver(GuestViewContainer* container,
- content::RenderFrame* render_frame);
-
- // content::RenderFrameObserver overrides.
- void OnDestruct() override;
-
- private:
- GuestViewContainer* container_;
-
- DISALLOW_COPY_AND_ASSIGN(RenderFrameLifetimeObserver);
-};
-
-GuestViewContainer::RenderFrameLifetimeObserver::RenderFrameLifetimeObserver(
- GuestViewContainer* container,
- content::RenderFrame* render_frame)
- : content::RenderFrameObserver(render_frame),
- container_(container) {}
-
-void GuestViewContainer::RenderFrameLifetimeObserver::OnDestruct() {
- container_->RenderFrameDestroyed();
-}
-
-GuestViewContainer::GuestViewContainer(content::RenderFrame* render_frame)
- : element_instance_id_(guest_view::kInstanceIDNone),
- render_frame_(render_frame),
- ready_(false) {
- render_frame_lifetime_observer_.reset(
- new RenderFrameLifetimeObserver(this, render_frame_));
-}
-
-GuestViewContainer::~GuestViewContainer() {
- if (element_instance_id() != guest_view::kInstanceIDNone)
- g_guest_view_container_map.Get().erase(element_instance_id());
-
- if (pending_response_.get())
- pending_response_->ExecuteCallbackIfAvailable(0 /* argc */, nullptr);
-
- while (pending_requests_.size() > 0) {
- linked_ptr<GuestViewRequest> pending_request = pending_requests_.front();
- pending_requests_.pop_front();
- // Call the JavaScript callbacks with no arguments which implies an error.
- pending_request->ExecuteCallbackIfAvailable(0 /* argc */, nullptr);
- }
-}
-
-// static.
-GuestViewContainer* GuestViewContainer::FromID(int element_instance_id) {
- GuestViewContainerMap* guest_view_containers =
- g_guest_view_container_map.Pointer();
- auto it = guest_view_containers->find(element_instance_id);
- return it == guest_view_containers->end() ? nullptr : it->second;
-}
-
-void GuestViewContainer::RenderFrameDestroyed() {
- OnRenderFrameDestroyed();
- render_frame_ = nullptr;
-}
-
-void GuestViewContainer::IssueRequest(linked_ptr<GuestViewRequest> request) {
- EnqueueRequest(request);
- PerformPendingRequest();
-}
-
-void GuestViewContainer::EnqueueRequest(linked_ptr<GuestViewRequest> request) {
- pending_requests_.push_back(request);
-}
-
-void GuestViewContainer::PerformPendingRequest() {
- if (!ready_ || pending_requests_.empty() || pending_response_.get())
- return;
-
- linked_ptr<GuestViewRequest> pending_request = pending_requests_.front();
- pending_requests_.pop_front();
- pending_request->PerformRequest();
- pending_response_ = pending_request;
-}
-
-void GuestViewContainer::HandlePendingResponseCallback(
- const IPC::Message& message) {
- CHECK(pending_response_.get());
- linked_ptr<GuestViewRequest> pending_response(pending_response_.release());
- pending_response->HandleResponse(message);
-}
-
-void GuestViewContainer::OnHandleCallback(const IPC::Message& message) {
- // Handle the callback for the current request with a pending response.
- HandlePendingResponseCallback(message);
- // Perform the subsequent request if one exists.
- PerformPendingRequest();
-}
-
-bool GuestViewContainer::OnMessage(const IPC::Message& message) {
- return false;
-}
-
-bool GuestViewContainer::OnMessageReceived(const IPC::Message& message) {
- if (OnMessage(message))
- return true;
-
- OnHandleCallback(message);
- return true;
-}
-
-void GuestViewContainer::Ready() {
- ready_ = true;
- CHECK(!pending_response_.get());
- PerformPendingRequest();
-
- // Give the derived type an opportunity to perform some actions when the
- // container acquires a geometry.
- OnReady();
-}
-
-void GuestViewContainer::SetElementInstanceID(int element_instance_id) {
- DCHECK_EQ(element_instance_id_, guest_view::kInstanceIDNone);
- element_instance_id_ = element_instance_id;
-
- DCHECK(!g_guest_view_container_map.Get().count(element_instance_id));
- g_guest_view_container_map.Get().insert(
- std::make_pair(element_instance_id, this));
-}
-
-} // namespace extensions
diff --git a/extensions/renderer/guest_view/guest_view_container.h b/extensions/renderer/guest_view/guest_view_container.h
deleted file mode 100644
index 8855dd7..0000000
--- a/extensions/renderer/guest_view/guest_view_container.h
+++ /dev/null
@@ -1,73 +0,0 @@
-// Copyright 2014 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.
-
-#ifndef EXTENSIONS_RENDERER_GUEST_VIEW_GUEST_VIEW_CONTAINER_H_
-#define EXTENSIONS_RENDERER_GUEST_VIEW_GUEST_VIEW_CONTAINER_H_
-
-#include "base/memory/linked_ptr.h"
-#include "base/memory/scoped_ptr.h"
-#include "content/public/renderer/browser_plugin_delegate.h"
-#include "ipc/ipc_message.h"
-
-namespace extensions {
-
-class GuestViewRequest;
-
-class GuestViewContainer : public content::BrowserPluginDelegate {
- public:
- explicit GuestViewContainer(content::RenderFrame* render_frame);
- ~GuestViewContainer() override;
-
- static GuestViewContainer* FromID(int element_instance_id);
-
- // IssueRequest queues up a |request| until the container is ready and
- // the browser process has responded to the last request if it's still
- // pending.
- void IssueRequest(linked_ptr<GuestViewRequest> request);
-
- int element_instance_id() const { return element_instance_id_; }
- content::RenderFrame* render_frame() const { return render_frame_; }
-
- // Called when the embedding RenderFrame is destroyed.
- virtual void OnRenderFrameDestroyed() {}
-
- // Called to respond to IPCs from the browser process that have not been
- // handled by GuestViewContainer.
- virtual bool OnMessage(const IPC::Message& message);
-
- // Called to perform actions when a GuestViewContainer gets a geometry.
- virtual void OnReady() {}
-
- private:
- class RenderFrameLifetimeObserver;
- friend class RenderFrameLifetimeObserver;
-
- void RenderFrameDestroyed();
-
- void EnqueueRequest(linked_ptr<GuestViewRequest> request);
- void PerformPendingRequest();
- void HandlePendingResponseCallback(const IPC::Message& message);
-
- void OnHandleCallback(const IPC::Message& message);
-
- // BrowserPluginDelegate implementation.
- bool OnMessageReceived(const IPC::Message& message) final;
- void Ready() final;
- void SetElementInstanceID(int element_instance_id) final;
-
- int element_instance_id_;
- content::RenderFrame* render_frame_;
- scoped_ptr<RenderFrameLifetimeObserver> render_frame_lifetime_observer_;
-
- bool ready_;
-
- std::deque<linked_ptr<GuestViewRequest> > pending_requests_;
- linked_ptr<GuestViewRequest> pending_response_;
-
- DISALLOW_COPY_AND_ASSIGN(GuestViewContainer);
-};
-
-} // namespace extensions
-
-#endif // EXTENSIONS_RENDERER_GUEST_VIEW_GUEST_VIEW_CONTAINER_H_
diff --git a/extensions/renderer/guest_view/guest_view_internal_custom_bindings.cc b/extensions/renderer/guest_view/guest_view_internal_custom_bindings.cc
index 902465f..a4b08d2 100644
--- a/extensions/renderer/guest_view/guest_view_internal_custom_bindings.cc
+++ b/extensions/renderer/guest_view/guest_view_internal_custom_bindings.cc
@@ -8,12 +8,12 @@
#include "base/bind.h"
#include "components/guest_view/common/guest_view_constants.h"
+#include "components/guest_view/renderer/guest_view_request.h"
#include "content/public/child/v8_value_converter.h"
#include "content/public/renderer/render_view.h"
#include "extensions/common/extension.h"
#include "extensions/common/extension_messages.h"
#include "extensions/renderer/guest_view/extensions_guest_view_container.h"
-#include "extensions/renderer/guest_view/guest_view_request.h"
#include "extensions/renderer/script_context.h"
#include "third_party/WebKit/public/web/WebFrame.h"
#include "third_party/WebKit/public/web/WebScopedUserGesture.h"
@@ -66,7 +66,8 @@ void GuestViewInternalCustomBindings::AttachGuest(
int element_instance_id = args[0]->Int32Value();
// An element instance ID uniquely identifies a GuestViewContainer.
- auto guest_view_container = GuestViewContainer::FromID(element_instance_id);
+ auto guest_view_container =
+ guest_view::GuestViewContainer::FromID(element_instance_id);
// TODO(fsamuel): Should we be reporting an error if the element instance ID
// is invalid?
@@ -89,8 +90,8 @@ void GuestViewInternalCustomBindings::AttachGuest(
// logical units.
params->SetBoolean(guest_view::kElementSizeIsLogical, true);
- linked_ptr<GuestViewRequest> request(
- new GuestViewAttachRequest(
+ linked_ptr<guest_view::GuestViewRequest> request(
+ new guest_view::GuestViewAttachRequest(
guest_view_container, guest_instance_id, params.Pass(),
args.Length() == 4 ? args[3].As<v8::Function>()
: v8::Local<v8::Function>(),
@@ -111,15 +112,16 @@ void GuestViewInternalCustomBindings::DetachGuest(
int element_instance_id = args[0]->Int32Value();
// An element instance ID uniquely identifies a GuestViewContainer.
- auto guest_view_container = GuestViewContainer::FromID(element_instance_id);
+ auto guest_view_container =
+ guest_view::GuestViewContainer::FromID(element_instance_id);
// TODO(fsamuel): Should we be reporting an error if the element instance ID
// is invalid?
if (!guest_view_container)
return;
- linked_ptr<GuestViewRequest> request(
- new GuestViewDetachRequest(
+ linked_ptr<guest_view::GuestViewRequest> request(
+ new guest_view::GuestViewDetachRequest(
guest_view_container, args.Length() == 2 ? args[1].As<v8::Function>()
: v8::Local<v8::Function>(),
args.GetIsolate()));
@@ -166,7 +168,7 @@ void GuestViewInternalCustomBindings::RegisterDestructionCallback(
// An element instance ID uniquely identifies a ExtensionsGuestViewContainer
// within a RenderView.
auto guest_view_container = static_cast<ExtensionsGuestViewContainer*>(
- GuestViewContainer::FromID(element_instance_id));
+ guest_view::GuestViewContainer::FromID(element_instance_id));
if (!guest_view_container)
return;
@@ -189,7 +191,7 @@ void GuestViewInternalCustomBindings::RegisterElementResizeCallback(
// An element instance ID uniquely identifies a ExtensionsGuestViewContainer
// within a RenderView.
auto guest_view_container = static_cast<ExtensionsGuestViewContainer*>(
- GuestViewContainer::FromID(element_instance_id));
+ guest_view::GuestViewContainer::FromID(element_instance_id));
if (!guest_view_container)
return;
diff --git a/extensions/renderer/guest_view/guest_view_request.cc b/extensions/renderer/guest_view/guest_view_request.cc
deleted file mode 100644
index 78251d9..0000000
--- a/extensions/renderer/guest_view/guest_view_request.cc
+++ /dev/null
@@ -1,123 +0,0 @@
-// Copyright 2015 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 "extensions/renderer/guest_view/guest_view_request.h"
-
-#include "components/guest_view/common/guest_view_messages.h"
-#include "content/public/renderer/render_frame.h"
-#include "content/public/renderer/render_view.h"
-#include "extensions/renderer/guest_view/guest_view_container.h"
-#include "third_party/WebKit/public/web/WebLocalFrame.h"
-#include "third_party/WebKit/public/web/WebScopedMicrotaskSuppression.h"
-#include "third_party/WebKit/public/web/WebView.h"
-
-namespace extensions {
-
-GuestViewRequest::GuestViewRequest(GuestViewContainer* container,
- v8::Local<v8::Function> callback,
- v8::Isolate* isolate)
- : container_(container),
- callback_(isolate, callback),
- isolate_(isolate) {
-}
-
-GuestViewRequest::~GuestViewRequest() {
-}
-
-void GuestViewRequest::ExecuteCallbackIfAvailable(
- int argc,
- scoped_ptr<v8::Local<v8::Value>[]> argv) {
- if (callback_.IsEmpty())
- return;
-
- v8::HandleScope handle_scope(isolate());
- v8::Local<v8::Function> callback =
- v8::Local<v8::Function>::New(isolate_, callback_);
- v8::Local<v8::Context> context = callback->CreationContext();
- if (context.IsEmpty())
- return;
-
- v8::Context::Scope context_scope(context);
- blink::WebScopedMicrotaskSuppression suppression;
-
- callback->Call(context->Global(), argc, argv.get());
-}
-
-GuestViewAttachRequest::GuestViewAttachRequest(
- GuestViewContainer* container,
- int guest_instance_id,
- scoped_ptr<base::DictionaryValue> params,
- v8::Local<v8::Function> callback,
- v8::Isolate* isolate)
- : GuestViewRequest(container, callback, isolate),
- guest_instance_id_(guest_instance_id),
- params_(params.Pass()) {
-}
-
-GuestViewAttachRequest::~GuestViewAttachRequest() {
-}
-
-void GuestViewAttachRequest::PerformRequest() {
- if (!container()->render_frame())
- return;
-
- // Step 1, send the attach params to extensions/.
- container()->render_frame()->Send(
- new GuestViewHostMsg_AttachGuest(container()->element_instance_id(),
- guest_instance_id_,
- *params_));
-
- // Step 2, attach plugin through content/.
- container()->render_frame()->AttachGuest(container()->element_instance_id());
-}
-
-void GuestViewAttachRequest::HandleResponse(const IPC::Message& message) {
- // TODO(fsamuel): Rename this message so that it's apparent that this is a
- // response to GuestViewHostMsg_AttachGuest. Perhaps
- // GuestViewMsg_AttachGuest_ACK?
- GuestViewMsg_GuestAttached::Param param;
- if (!GuestViewMsg_GuestAttached::Read(&message, &param))
- return;
-
- content::RenderView* guest_proxy_render_view =
- content::RenderView::FromRoutingID(get<1>(param));
- // TODO(fsamuel): Should we be reporting an error to JavaScript or DCHECKing?
- if (!guest_proxy_render_view)
- return;
-
- v8::HandleScope handle_scope(isolate());
- blink::WebFrame* frame = guest_proxy_render_view->GetWebView()->mainFrame();
- v8::Local<v8::Value> window = frame->mainWorldScriptContext()->Global();
-
- const int argc = 1;
- scoped_ptr<v8::Local<v8::Value>[]> argv(new v8::Local<v8::Value>[argc]);
- argv[0] = window;
-
- // Call the AttachGuest API's callback with the guest proxy as the first
- // parameter.
- ExecuteCallbackIfAvailable(argc, argv.Pass());
-}
-
-GuestViewDetachRequest::GuestViewDetachRequest(
- GuestViewContainer* container,
- v8::Local<v8::Function> callback,
- v8::Isolate* isolate)
- : GuestViewRequest(container, callback, isolate) {
-}
-
-GuestViewDetachRequest::~GuestViewDetachRequest() {
-}
-
-void GuestViewDetachRequest::PerformRequest() {
- if (!container()->render_frame())
- return;
-
- container()->render_frame()->DetachGuest(container()->element_instance_id());
-}
-
-void GuestViewDetachRequest::HandleResponse(const IPC::Message& message) {
- ExecuteCallbackIfAvailable(0 /* argc */, nullptr);
-}
-
-} // namespace extensions
diff --git a/extensions/renderer/guest_view/guest_view_request.h b/extensions/renderer/guest_view/guest_view_request.h
deleted file mode 100644
index dbb7343..0000000
--- a/extensions/renderer/guest_view/guest_view_request.h
+++ /dev/null
@@ -1,97 +0,0 @@
-// Copyright 2015 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.
-
-#ifndef EXTENSIONS_RENDERER_GUEST_VIEW_EXTENSIONS_GUEST_VIEW_REQUEST_H_
-#define EXTENSIONS_RENDERER_GUEST_VIEW_EXTENSIONS_GUEST_VIEW_REQUEST_H_
-
-#include "ipc/ipc_message.h"
-#include "v8/include/v8.h"
-
-namespace extensions {
-
-class GuestViewContainer;
-
-// A GuestViewRequest is the base class for an asynchronous operation performed
-// on a GuestView or GuestViewContainer from JavaScript. This operation may be
-// queued until the container is ready to be operated upon (it has geometry).
-// A GuestViewRequest may or may not have a callback back into JavaScript.
-// Typically, performing a request involves sending an IPC to the browser
-// process in PerformRequest. Handling a response involves receiving a related
-// IPC from the browser process in HandleResponse.
-class GuestViewRequest {
- public:
- GuestViewRequest(GuestViewContainer* container,
- v8::Local<v8::Function> callback,
- v8::Isolate* isolate);
- virtual ~GuestViewRequest();
-
- // Performs the associated request.
- virtual void PerformRequest() = 0;
-
- // Called by GuestViewContainer when the browser process has responded to the
- // request initiated by PerformRequest.
- virtual void HandleResponse(const IPC::Message& message) = 0;
-
- // Called to call the callback associated with this request if one is
- // available.
- // Note: the callback may be called even if a response has not been heard from
- // the browser process if the GuestViewContainer is being torn down.
- void ExecuteCallbackIfAvailable(int argc,
- scoped_ptr<v8::Local<v8::Value>[]> argv);
-
- GuestViewContainer* container() const { return container_; }
-
- v8::Isolate* isolate() const { return isolate_; }
-
- private:
- GuestViewContainer* const container_;
- v8::Global<v8::Function> callback_;
- v8::Isolate* const isolate_;
-
- DISALLOW_COPY_AND_ASSIGN(GuestViewRequest);
-};
-
-// This class represents an AttachGuest request from Javascript. It includes
-// the input parameters and the callback function. The Attach operation may
-// not execute immediately, if the container is not ready or if there are
-// other GuestViewRequests in flight.
-class GuestViewAttachRequest : public GuestViewRequest {
- public:
- GuestViewAttachRequest(GuestViewContainer* container,
- int guest_instance_id,
- scoped_ptr<base::DictionaryValue> params,
- v8::Local<v8::Function> callback,
- v8::Isolate* isolate);
- ~GuestViewAttachRequest() override;
-
- void PerformRequest() override;
- void HandleResponse(const IPC::Message& message) override;
-
- private:
- const int guest_instance_id_;
- scoped_ptr<base::DictionaryValue> params_;
-
- DISALLOW_COPY_AND_ASSIGN(GuestViewAttachRequest);
-};
-
-// This class represents a DetachGuest request from Javascript. The Detach
-// operation may not execute immediately, if the container is not ready or if
-// there are other GuestViewRequests in flight.
-class GuestViewDetachRequest : public GuestViewRequest {
- public:
- GuestViewDetachRequest(GuestViewContainer* container,
- v8::Local<v8::Function> callback,
- v8::Isolate* isolate);
- ~GuestViewDetachRequest() override;
-
- void PerformRequest() override;
- void HandleResponse(const IPC::Message& message) override;
-
- private:
- DISALLOW_COPY_AND_ASSIGN(GuestViewDetachRequest);
-};
-
-} // namespace extensions
-
-#endif // EXTENSIONS_RENDERER_GUEST_VIEW_EXTENSIONS_GUEST_VIEW_CONTAINER_H_
diff --git a/extensions/renderer/guest_view/mime_handler_view/mime_handler_view_container.h b/extensions/renderer/guest_view/mime_handler_view/mime_handler_view_container.h
index 00f0211..8cc31a1 100644
--- a/extensions/renderer/guest_view/mime_handler_view/mime_handler_view_container.h
+++ b/extensions/renderer/guest_view/mime_handler_view/mime_handler_view_container.h
@@ -10,7 +10,7 @@
#include "base/memory/linked_ptr.h"
#include "base/memory/weak_ptr.h"
-#include "extensions/renderer/guest_view/guest_view_container.h"
+#include "components/guest_view/renderer/guest_view_container.h"
#include "third_party/WebKit/public/platform/WebURLLoader.h"
#include "third_party/WebKit/public/platform/WebURLLoaderClient.h"
#include "ui/gfx/geometry/size.h"
@@ -35,7 +35,7 @@ namespace extensions {
// a WebURLLoader. In this case, the |didReceiveData| and |didFinishLoading|
// (from WebURLLoaderClient) when data is received and when it has finished
// being received.
-class MimeHandlerViewContainer : public GuestViewContainer,
+class MimeHandlerViewContainer : public guest_view::GuestViewContainer,
public blink::WebURLLoaderClient {
public:
MimeHandlerViewContainer(content::RenderFrame* render_frame,