• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 // A BrowserPluginEmbedder handles messages coming from a BrowserPlugin's
6 // embedder that are not directed at any particular existing guest process.
7 // In the beginning, when a BrowserPlugin instance in the embedder renderer
8 // process requests an initial navigation, the WebContents for that renderer
9 // renderer creates a BrowserPluginEmbedder for itself. The
10 // BrowserPluginEmbedder, in turn, forwards the requests to a
11 // BrowserPluginGuestManager, which creates and manages the lifetime of the new
12 // guest.
13 
14 #ifndef CONTENT_BROWSER_BROWSER_PLUGIN_BROWSER_PLUGIN_EMBEDDER_H_
15 #define CONTENT_BROWSER_BROWSER_PLUGIN_BROWSER_PLUGIN_EMBEDDER_H_
16 
17 #include <map>
18 
19 #include "base/memory/weak_ptr.h"
20 #include "base/values.h"
21 #include "content/public/browser/web_contents.h"
22 #include "content/public/browser/web_contents_observer.h"
23 #include "third_party/WebKit/public/web/WebDragOperation.h"
24 
25 struct BrowserPluginHostMsg_Attach_Params;
26 struct BrowserPluginHostMsg_ResizeGuest_Params;
27 
28 namespace gfx {
29 class Point;
30 }
31 
32 namespace content {
33 
34 class BrowserPluginGuest;
35 class BrowserPluginGuestManager;
36 class BrowserPluginHostFactory;
37 class RenderWidgetHostImpl;
38 class WebContentsImpl;
39 struct NativeWebKeyboardEvent;
40 
41 class CONTENT_EXPORT BrowserPluginEmbedder : public WebContentsObserver {
42  public:
43   virtual ~BrowserPluginEmbedder();
44 
45   static BrowserPluginEmbedder* Create(WebContentsImpl* web_contents);
46 
47   // Returns the RenderViewHost at a point (|x|, |y|) asynchronously via
48   // |callback|. We need a roundtrip to renderer process to get this
49   // information.
50   void GetRenderViewHostAtPosition(
51       int x,
52       int y,
53       const WebContents::GetRenderViewHostCallback& callback);
54 
55   // Called when embedder's |rwh| has sent screen rects to renderer.
56   void DidSendScreenRects();
57 
58   // Called when embedder's WebContentsImpl has unhandled keyboard input.
59   // Returns whether the BrowserPlugin has handled the keyboard event.
60   // Currently we are only interested in checking for the escape key to
61   // unlock hte guest's pointer lock.
62   bool HandleKeyboardEvent(const NativeWebKeyboardEvent& event);
63 
64   // Overrides factory for testing. Default (NULL) value indicates regular
65   // (non-test) environment.
set_factory_for_testing(BrowserPluginHostFactory * factory)66   static void set_factory_for_testing(BrowserPluginHostFactory* factory) {
67     factory_ = factory;
68   }
69 
70   // Sets the zoom level for all guests within this embedder.
71   void SetZoomLevel(double level);
72 
73   // WebContentsObserver implementation.
74   virtual void RenderProcessGone(base::TerminationStatus status) OVERRIDE;
75   virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE;
76 
77   void DragSourceEndedAt(int client_x, int client_y, int screen_x,
78       int screen_y, blink::WebDragOperation operation);
79 
80   void DragSourceMovedTo(int client_x, int client_y,
81                          int screen_x, int screen_y);
82 
83   void OnUpdateDragCursor(bool* handled);
84 
85   void DragEnteredGuest(BrowserPluginGuest* guest);
86 
87   void DragLeftGuest(BrowserPluginGuest* guest);
88 
89   void StartDrag(BrowserPluginGuest* guest);
90 
91   void StopDrag(BrowserPluginGuest* guest);
92 
93   void SystemDragEnded();
94 
95  private:
96   friend class TestBrowserPluginEmbedder;
97 
98   BrowserPluginEmbedder(WebContentsImpl* web_contents);
99 
100   void CleanUp();
101 
102   BrowserPluginGuestManager* GetBrowserPluginGuestManager();
103 
104   bool DidSendScreenRectsCallback(BrowserPluginGuest* guest);
105 
106   bool SetZoomLevelCallback(double level, BrowserPluginGuest* guest);
107 
108   bool UnlockMouseIfNecessaryCallback(const NativeWebKeyboardEvent& event,
109                                       BrowserPluginGuest* guest);
110 
111   // Message handlers.
112 
113   void OnAllocateInstanceID(int request_id);
114   void OnAttach(int instance_id,
115                 const BrowserPluginHostMsg_Attach_Params& params,
116                 const base::DictionaryValue& extra_params);
117   void OnPluginAtPositionResponse(int instance_id,
118                                   int request_id,
119                                   const gfx::Point& position);
120 
121   // Static factory instance (always NULL for non-test).
122   static BrowserPluginHostFactory* factory_;
123 
124   // Map that contains outstanding queries to |GetRenderViewHostAtPosition|.
125   // We need a roundtrip to the renderer process to retrieve the answer,
126   // so we store these callbacks until we hear back from the renderer.
127   typedef std::map<int, WebContents::GetRenderViewHostCallback>
128       GetRenderViewHostCallbackMap;
129   GetRenderViewHostCallbackMap pending_get_render_view_callbacks_;
130   // Next request id for BrowserPluginMsg_PluginAtPositionRequest query.
131   int next_get_render_view_request_id_;
132 
133   // Used to correctly update the cursor when dragging over a guest, and to
134   // handle a race condition when dropping onto the guest that started the drag
135   // (the race is that the dragend message arrives before the drop message so
136   // the drop never takes place).
137   // crbug.com/233571
138   base::WeakPtr<BrowserPluginGuest> guest_dragging_over_;
139 
140   // Pointer to the guest that started the drag, used to forward necessary drag
141   // status messages to the correct guest.
142   base::WeakPtr<BrowserPluginGuest> guest_started_drag_;
143 
144   DISALLOW_COPY_AND_ASSIGN(BrowserPluginEmbedder);
145 };
146 
147 }  // namespace content
148 
149 #endif  // CONTENT_BROWSER_BROWSER_PLUGIN_BROWSER_PLUGIN_EMBEDDER_H_
150