|  | // 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_BROWSER_EXTENSION_WEB_CONTENTS_OBSERVER_H_ | 
|  | #define EXTENSIONS_BROWSER_EXTENSION_WEB_CONTENTS_OBSERVER_H_ | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | #include "base/compiler_specific.h" | 
|  | #include "base/macros.h" | 
|  | #include "content/public/browser/web_contents_observer.h" | 
|  | #include "extensions/browser/extension_function_dispatcher.h" | 
|  | #include "services/service_manager/public/cpp/binder_registry.h" | 
|  |  | 
|  | namespace content { | 
|  | class BrowserContext; | 
|  | class RenderFrameHost; | 
|  | class WebContents; | 
|  | } | 
|  |  | 
|  | namespace extensions { | 
|  | class Extension; | 
|  |  | 
|  | // A web contents observer used for renderer and extension processes. Grants the | 
|  | // renderer access to certain URL scheme patterns for extensions and notifies | 
|  | // the renderer that the extension was loaded. | 
|  | // | 
|  | // Extension system embedders must create an instance for every extension | 
|  | // WebContents. It must be a subclass so that creating an instance via | 
|  | // content::WebContentsUserData::CreateForWebContents() provides an object of | 
|  | // the correct type. For an example, see ChromeExtensionWebContentsObserver. | 
|  | // | 
|  | // This class is responsible for maintaining the registrations of extension | 
|  | // frames with the ProcessManager. Only frames in an extension process are | 
|  | // registered. If out-of-process frames are enabled, every frame hosts a | 
|  | // chrome-extension: page. Otherwise non-extension frames may erroneously be | 
|  | // registered, but only briefly until they are correctly classified. This is | 
|  | // achieved using the following notifications: | 
|  | // 1. RenderFrameCreated - registers all new frames in extension processes. | 
|  | // 2. DidCommitProvisionalLoadForFrame - unregisters non-extension frames. | 
|  | // 3. DidNavigateAnyFrame - registers extension frames if they had been | 
|  | //    unregistered. | 
|  | // | 
|  | // Without OOPIF, non-extension frames created by the Chrome extension are also | 
|  | // registered at RenderFrameCreated. When the non-extension page is committed, | 
|  | // we detect that the unexpected URL and unregister the frame. | 
|  | // With OOPIF only the first notification is sufficient in most cases, except | 
|  | // for sandboxed frames with a unique origin. | 
|  | class ExtensionWebContentsObserver | 
|  | : public content::WebContentsObserver, | 
|  | public ExtensionFunctionDispatcher::Delegate { | 
|  | public: | 
|  | // Returns the ExtensionWebContentsObserver for the given |web_contents|. | 
|  | static ExtensionWebContentsObserver* GetForWebContents( | 
|  | content::WebContents* web_contents); | 
|  |  | 
|  | ExtensionFunctionDispatcher* dispatcher() { return &dispatcher_; } | 
|  |  | 
|  | // Returns the extension associated with the given |render_frame_host|, or | 
|  | // null if there is none. | 
|  | // If |verify_url| is false, only the SiteInstance is taken into account. | 
|  | // If |verify_url| is true, the frame's last committed URL is also used to | 
|  | // improve the classification of the frame. | 
|  | const Extension* GetExtensionFromFrame( | 
|  | content::RenderFrameHost* render_frame_host, | 
|  | bool verify_url) const; | 
|  |  | 
|  | protected: | 
|  | explicit ExtensionWebContentsObserver(content::WebContents* web_contents); | 
|  | ~ExtensionWebContentsObserver() override; | 
|  |  | 
|  | content::BrowserContext* browser_context() { return browser_context_; } | 
|  |  | 
|  | // Initializes a new render frame. Subclasses should invoke this | 
|  | // implementation if extending. | 
|  | virtual void InitializeRenderFrame( | 
|  | content::RenderFrameHost* render_frame_host); | 
|  |  | 
|  | // ExtensionFunctionDispatcher::Delegate overrides. | 
|  | content::WebContents* GetAssociatedWebContents() const override; | 
|  |  | 
|  | // content::WebContentsObserver overrides. | 
|  | void RenderFrameCreated(content::RenderFrameHost* render_frame_host) override; | 
|  | void RenderFrameDeleted(content::RenderFrameHost* render_frame_host) override; | 
|  | void DidFinishNavigation( | 
|  | content::NavigationHandle* navigation_handle) override; | 
|  |  | 
|  | void OnInterfaceRequestFromFrame( | 
|  | content::RenderFrameHost* render_frame_host, | 
|  | const std::string& interface_name, | 
|  | mojo::ScopedMessagePipeHandle* interface_pipe) override; | 
|  |  | 
|  | // Subclasses should call this first before doing their own message handling. | 
|  | bool OnMessageReceived(const IPC::Message& message, | 
|  | content::RenderFrameHost* render_frame_host) override; | 
|  |  | 
|  | // Per the documentation in WebContentsObserver, these two methods are invoked | 
|  | // when a Pepper plugin instance is attached/detached in the page DOM. | 
|  | void PepperInstanceCreated() override; | 
|  | void PepperInstanceDeleted() override; | 
|  |  | 
|  | // Returns the extension id associated with the given |render_frame_host|, or | 
|  | // the empty string if there is none. | 
|  | std::string GetExtensionIdFromFrame( | 
|  | content::RenderFrameHost* render_frame_host) const; | 
|  |  | 
|  | private: | 
|  | void OnRequest(content::RenderFrameHost* render_frame_host, | 
|  | const ExtensionHostMsg_Request_Params& params); | 
|  |  | 
|  | // A helper function for initializing render frames at the creation of the | 
|  | // observer. | 
|  | void InitializeFrameHelper(content::RenderFrameHost* render_frame_host); | 
|  |  | 
|  | // The BrowserContext associated with the WebContents being observed. | 
|  | content::BrowserContext* browser_context_; | 
|  |  | 
|  | ExtensionFunctionDispatcher dispatcher_; | 
|  |  | 
|  | service_manager::BinderRegistryWithArgs<content::RenderFrameHost*> registry_; | 
|  |  | 
|  | DISALLOW_COPY_AND_ASSIGN(ExtensionWebContentsObserver); | 
|  | }; | 
|  |  | 
|  | }  // namespace extensions | 
|  |  | 
|  | #endif  // EXTENSIONS_BROWSER_EXTENSION_WEB_CONTENTS_OBSERVER_H_ |