• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright 2014 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 EXTENSIONS_BROWSER_EXTENSION_WEB_CONTENTS_OBSERVER_H_
6 #define EXTENSIONS_BROWSER_EXTENSION_WEB_CONTENTS_OBSERVER_H_
7 
8 #include <string>
9 
10 #include "base/compiler_specific.h"
11 #include "base/macros.h"
12 #include "content/public/browser/web_contents_observer.h"
13 
14 namespace content {
15 class BrowserContext;
16 class RenderViewHost;
17 class WebContents;
18 }
19 
20 namespace extensions {
21 class Extension;
22 
23 // A web contents observer used for renderer and extension processes. Grants the
24 // renderer access to certain URL scheme patterns for extensions and notifies
25 // the renderer that the extension was loaded.
26 //
27 // Extension system embedders must create an instance for every extension
28 // WebContents. It must be a subclass so that creating an instance via
29 // content::WebContentsUserData::CreateForWebContents() provides an object of
30 // the correct type. For an example, see ChromeExtensionWebContentsObserver.
31 class ExtensionWebContentsObserver : public content::WebContentsObserver {
32  protected:
33   explicit ExtensionWebContentsObserver(content::WebContents* web_contents);
34   virtual ~ExtensionWebContentsObserver();
35 
browser_context()36   content::BrowserContext* browser_context() { return browser_context_; }
37 
38   // content::WebContentsObserver overrides.
39 
40   // A subclass should invoke this method to finish extension process setup.
41   virtual void RenderViewCreated(content::RenderViewHost* render_view_host)
42       OVERRIDE;
43 
44   // Returns the extension or app associated with a render view host. Returns
45   // NULL if the render view host is not for a valid extension.
46   const Extension* GetExtension(content::RenderViewHost* render_view_host);
47 
48   // Updates ViewType for RenderViewHost based on GetViewType(web_contents()).
49   void NotifyRenderViewType(content::RenderViewHost* render_view_host);
50 
51   // Returns the extension or app ID associated with a render view host. Returns
52   // the empty string if the render view host is not for a valid extension.
53   static std::string GetExtensionId(content::RenderViewHost* render_view_host);
54 
55  private:
56   // The BrowserContext associated with the WebContents being observed.
57   content::BrowserContext* browser_context_;
58 
59   DISALLOW_COPY_AND_ASSIGN(ExtensionWebContentsObserver);
60 };
61 
62 }  // namespace extensions
63 
64 #endif  // EXTENSIONS_BROWSER_EXTENSION_WEB_CONTENTS_OBSERVER_H_
65