Home | History | Annotate | Download | only in pepper
      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 #ifndef CONTENT_RENDERER_PEPPER_RENDERER_PPAPI_HOST_IMPL_H_
      6 #define CONTENT_RENDERER_PEPPER_RENDERER_PPAPI_HOST_IMPL_H_
      7 
      8 #include "base/basictypes.h"
      9 #include "base/memory/scoped_ptr.h"
     10 #include "content/public/renderer/renderer_ppapi_host.h"
     11 #include "content/renderer/pepper/content_renderer_pepper_host_factory.h"
     12 #include "ppapi/host/ppapi_host.h"
     13 
     14 namespace IPC {
     15 class Sender;
     16 }
     17 
     18 namespace ppapi {
     19 
     20 namespace proxy {
     21 class HostDispatcher;
     22 }
     23 
     24 namespace thunk {
     25 class ResourceCreationAPI;
     26 }
     27 
     28 }  // namespace ppapi
     29 
     30 namespace content {
     31 
     32 class PepperInProcessRouter;
     33 class PepperPluginInstanceImpl;
     34 class PluginModule;
     35 
     36 // This class is attached to a PluginModule which manages our lifetime.
     37 class RendererPpapiHostImpl : public RendererPpapiHost {
     38  public:
     39   virtual ~RendererPpapiHostImpl();
     40 
     41   // Factory functions to create in process or out-of-process host impls. The
     42   // host will be created and associated with the given module, which must not
     43   // already have embedder state on it.
     44   //
     45   // The module will take ownership of the new host impl. The returned value
     46   // does not pass ownership, it's just for the information of the caller.
     47   static RendererPpapiHostImpl* CreateOnModuleForOutOfProcess(
     48       PluginModule* module,
     49       ppapi::proxy::HostDispatcher* dispatcher,
     50       const ppapi::PpapiPermissions& permissions);
     51   static RendererPpapiHostImpl* CreateOnModuleForInProcess(
     52       PluginModule* module,
     53       const ppapi::PpapiPermissions& permissions);
     54 
     55   // Returns the RendererPpapiHostImpl associated with the given PP_Instance,
     56   // or NULL if the instance is invalid.
     57   static RendererPpapiHostImpl* GetForPPInstance(PP_Instance pp_instance);
     58 
     59   // Returns the router that we use for in-process IPC emulation (see the
     60   // pepper_in_process_router.h for more). This will be NULL when the plugin
     61   // is running out-of-process.
     62   PepperInProcessRouter* in_process_router() {
     63     return in_process_router_.get();
     64   }
     65 
     66   // Creates the in-process resource creation API wrapper for the given
     67   // plugin instance. This object will reference the host impl, so the
     68   // host impl should outlive the returned pointer. Since the resource
     69   // creation object is associated with the instance, this will generally
     70   // happen automatically.
     71   scoped_ptr<ppapi::thunk::ResourceCreationAPI>
     72       CreateInProcessResourceCreationAPI(PepperPluginInstanceImpl* instance);
     73 
     74   PepperPluginInstanceImpl* GetPluginInstanceImpl(PP_Instance instance) const;
     75 
     76   // RendererPpapiHost implementation.
     77   virtual ppapi::host::PpapiHost* GetPpapiHost() OVERRIDE;
     78   virtual bool IsValidInstance(PP_Instance instance) const OVERRIDE;
     79   virtual PepperPluginInstance* GetPluginInstance(
     80       PP_Instance instance) const OVERRIDE;
     81   virtual RenderFrame* GetRenderFrameForInstance(
     82       PP_Instance instance) const OVERRIDE;
     83   virtual RenderView* GetRenderViewForInstance(
     84       PP_Instance instance) const OVERRIDE;
     85   virtual blink::WebPluginContainer* GetContainerForInstance(
     86       PP_Instance instance) const OVERRIDE;
     87   virtual base::ProcessId GetPluginPID() const OVERRIDE;
     88   virtual bool HasUserGesture(PP_Instance instance) const OVERRIDE;
     89   virtual int GetRoutingIDForWidget(PP_Instance instance) const OVERRIDE;
     90   virtual gfx::Point PluginPointToRenderFrame(
     91       PP_Instance instance,
     92       const gfx::Point& pt) const OVERRIDE;
     93   virtual IPC::PlatformFileForTransit ShareHandleWithRemote(
     94       base::PlatformFile handle,
     95       bool should_close_source) OVERRIDE;
     96   virtual bool IsRunningInProcess() const OVERRIDE;
     97   virtual void CreateBrowserResourceHosts(
     98       PP_Instance instance,
     99       const std::vector<IPC::Message>& nested_msgs,
    100       const base::Callback<void(
    101           const std::vector<int>&)>& callback) const OVERRIDE;
    102   virtual GURL GetDocumentURL(PP_Instance instance) const OVERRIDE;
    103 
    104  private:
    105   RendererPpapiHostImpl(PluginModule* module,
    106                         ppapi::proxy::HostDispatcher* dispatcher,
    107                         const ppapi::PpapiPermissions& permissions);
    108   RendererPpapiHostImpl(PluginModule* module,
    109                         const ppapi::PpapiPermissions& permissions);
    110 
    111   // Retrieves the plugin instance object associated with the given PP_Instance
    112   // and validates that it is one of the instances associated with our module.
    113   // Returns NULL on failure.
    114   //
    115   // We use this to security check the PP_Instance values sent from a plugin to
    116   // make sure it's not trying to spoof another instance.
    117   PepperPluginInstanceImpl* GetAndValidateInstance(PP_Instance instance) const;
    118 
    119   PluginModule* module_;  // Non-owning pointer.
    120 
    121   // The dispatcher we use to send messagse when the plugin is out-of-process.
    122   // Will be null when running in-process. Non-owning pointer.
    123   ppapi::proxy::HostDispatcher* dispatcher_;
    124 
    125   scoped_ptr<ppapi::host::PpapiHost> ppapi_host_;
    126 
    127   // Null when running out-of-process.
    128   scoped_ptr<PepperInProcessRouter> in_process_router_;
    129 
    130   // Whether the plugin is running in process.
    131   bool is_running_in_process_;
    132 
    133   DISALLOW_COPY_AND_ASSIGN(RendererPpapiHostImpl);
    134 };
    135 
    136 }  // namespace content
    137 
    138 #endif  // CONTENT_RENDERER_PEPPER_RENDERER_PPAPI_HOST_IMPL_H_
    139