summaryrefslogtreecommitdiffstats
path: root/content/browser/browser_plugin/browser_plugin_host.h
blob: 5ed58f79bc93ae5513bcdad41b1135d4caed1ac2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// 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.

#ifndef CONTENT_BROWSER_BROWSER_PLUGIN_BROWSER_PLUGIN_HOST_H__
#define CONTENT_BROWSER_BROWSER_PLUGIN_BROWSER_PLUGIN_HOST_H__
#pragma once

#include <map>

#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
#include "content/public/browser/web_contents_delegate.h"
#include "content/public/browser/web_contents_observer.h"
#include "ppapi/c/pp_instance.h"
#include "ui/gfx/size.h"

class WebContentsImpl;

namespace content {

class RenderProcessHost;

// A BrowserPluginHost object is used by both embedders and guests.
// The primary purpose of BrowserPluginHost is to allow an embedder
// to manage the lifetime of its guests. It cleans up its guests
// on navigation, crashes, and "hides" guests when it hides.
// For the guest, BrowserPluginHost keeps track of its embedder,
// and its BrowserPlugin instance ID.
class BrowserPluginHost : public WebContentsObserver,
                          public NotificationObserver,
                          public WebContentsDelegate {
 public:
  // BrowserPluginHost is owned by a WebContentsImpl. Here it takes in its
  // owner. The owner can be either a guest or embedder WebContents.
  explicit BrowserPluginHost(WebContentsImpl* web_contents);

  virtual ~BrowserPluginHost();

  void ConnectEmbedderToChannel(RenderViewHost* render_view_host,
                                const IPC::ChannelHandle& handle);

  // This is called on the first navigation of the browser plugin. It creates
  // a new WebContentsImpl for the guest, associates it with its embedder, sets
  // its size and navigates it to the src URL.
  void NavigateGuestFromEmbedder(RenderViewHost* render_view_host,
                                 int container_instance_id,
                                 long long frame_id,
                                 const std::string& src);

  RenderProcessHost* embedder_render_process_host() const {
    return embedder_render_process_host_;
  }
  int instance_id() const { return instance_id_; }

 private:
  typedef std::map<WebContentsImpl*, int64> GuestMap;
  typedef std::map<int, BrowserPluginHost*> ContainerInstanceMap;

  // Get a guest BrowserPluginHost by its container ID specified
  // in BrowserPlugin.
  BrowserPluginHost* GetGuestByContainerID(int container_id);

  // Associate a guest with its container instance ID.
  void RegisterContainerInstance(
      int container_id,
      BrowserPluginHost* observer);

  // An embedder BrowserPluginHost keeps track of
  // its guests so that if it navigates away, its associated RenderView
  // crashes or it is hidden, it takes appropriate action on the guest.
  void AddGuest(WebContentsImpl* guest, int64 frame_id);

  // This removes a guest from an embedder's guest list.
  // TODO(fsamuel): Use this when deleting guest after they crash.
  // ToT plugin crash handling seems to be broken in this case and so I can't
  // test this scenario at the moment. Delete this comment once fixed.
  void RemoveGuest(WebContentsImpl* guest);

  void set_embedder_render_process_host(
      RenderProcessHost* embedder_render_process_host) {
    embedder_render_process_host_ = embedder_render_process_host;
  }
  void set_instance_id(int instance_id) { instance_id_ = instance_id; }

  void OnNavigateFromGuest(PP_Instance instance,
                           const std::string& src);

  void DestroyGuests();

  // WebContentObserver implementation.
  virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE;
  // Used to monitor frame navigation to cleanup guests when a frame navigates
  // away from the browser plugin it's hosting.
  virtual void DidCommitProvisionalLoadForFrame(
      int64 frame_id,
      bool is_main_frame,
      const GURL& url,
      PageTransition transition_type,
      RenderViewHost* render_view_host) OVERRIDE;
  virtual void RenderViewDeleted(RenderViewHost* render_view_host) OVERRIDE;
  virtual void RenderViewGone(base::TerminationStatus status) OVERRIDE;
  virtual void WebContentsDestroyed(WebContents* web_contents) OVERRIDE;

  // NotificationObserver method override.
  virtual void Observe(int type,
                       const NotificationSource& source,
                       const NotificationDetails& details) OVERRIDE;

  // A scoped container for notification registries.
  NotificationRegistrar registrar_;
  RenderProcessHost* embedder_render_process_host_;
  std::string embedder_channel_name_;
  // An identifier that uniquely identifies a browser plugin container
  // within an embedder.
  int instance_id_;
  gfx::Size initial_size_;
  GuestMap guests_;
  ContainerInstanceMap guests_by_container_id_;
};

}  // namespace content

#endif  // CONTENT_BROWSER_BROWSER_PLUGIN_BROWSER_PLUGIN_HOST_H_