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.
5 // Defines the Chrome Extensions WebNavigation API functions for observing and
6 // intercepting navigation events, as specified in the extension JSON API.
8 #ifndef CHROME_BROWSER_EXTENSIONS_API_WEB_NAVIGATION_WEB_NAVIGATION_API_H_
9 #define CHROME_BROWSER_EXTENSIONS_API_WEB_NAVIGATION_WEB_NAVIGATION_API_H_
14 #include "base/compiler_specific.h"
15 #include "chrome/browser/extensions/api/web_navigation/frame_navigation_state.h"
16 #include "chrome/browser/extensions/chrome_extension_function.h"
17 #include "chrome/browser/profiles/profile.h"
18 #include "chrome/browser/ui/browser_list_observer.h"
19 #include "chrome/browser/ui/tabs/tab_strip_model.h"
20 #include "content/public/browser/notification_observer.h"
21 #include "content/public/browser/notification_registrar.h"
22 #include "content/public/browser/web_contents_observer.h"
23 #include "content/public/browser/web_contents_user_data.h"
24 #include "extensions/browser/browser_context_keyed_api_factory.h"
25 #include "extensions/browser/event_router.h"
28 struct RetargetingDetails
;
30 namespace extensions
{
32 // Tab contents observer that forwards navigation events to the event router.
33 class WebNavigationTabObserver
34 : public content::WebContentsObserver
,
35 public content::WebContentsUserData
<WebNavigationTabObserver
> {
37 ~WebNavigationTabObserver() override
;
39 // Returns the object for the given |web_contents|.
40 static WebNavigationTabObserver
* Get(content::WebContents
* web_contents
);
42 const FrameNavigationState
& frame_navigation_state() const {
43 return navigation_state_
;
46 // content::WebContentsObserver implementation.
47 void RenderFrameDeleted(content::RenderFrameHost
* render_frame_host
) override
;
48 void FrameDeleted(content::RenderFrameHost
* render_frame_host
) override
;
49 void RenderFrameHostChanged(content::RenderFrameHost
* old_host
,
50 content::RenderFrameHost
* new_host
) override
;
51 void DidStartProvisionalLoadForFrame(
52 content::RenderFrameHost
* render_frame_host
,
53 const GURL
& validated_url
,
55 bool is_iframe_srcdoc
) override
;
56 void DidCommitProvisionalLoadForFrame(
57 content::RenderFrameHost
* render_frame_host
,
59 ui::PageTransition transition_type
) override
;
60 void DidFailProvisionalLoad(content::RenderFrameHost
* render_frame_host
,
61 const GURL
& validated_url
,
63 const base::string16
& error_description
,
64 bool was_ignored_by_handler
) override
;
65 void DocumentLoadedInFrame(
66 content::RenderFrameHost
* render_frame_host
) override
;
67 void DidFinishLoad(content::RenderFrameHost
* render_frame_host
,
68 const GURL
& validated_url
) override
;
69 void DidFailLoad(content::RenderFrameHost
* render_frame_host
,
70 const GURL
& validated_url
,
72 const base::string16
& error_description
,
73 bool was_ignored_by_handler
) override
;
74 void DidGetRedirectForResourceRequest(
75 content::RenderFrameHost
* render_frame_host
,
76 const content::ResourceRedirectDetails
& details
) override
;
77 void DidOpenRequestedURL(content::WebContents
* new_contents
,
78 content::RenderFrameHost
* source_render_frame_host
,
80 const content::Referrer
& referrer
,
81 WindowOpenDisposition disposition
,
82 ui::PageTransition transition
) override
;
83 void WebContentsDestroyed() override
;
86 explicit WebNavigationTabObserver(content::WebContents
* web_contents
);
87 friend class content::WebContentsUserData
<WebNavigationTabObserver
>;
89 // True if the transition and target url correspond to a reference fragment
91 bool IsReferenceFragmentNavigation(content::RenderFrameHost
* frame_host
,
94 // Creates and sends onErrorOccurred events for all on-going navigations. If
95 // |render_view_host| is non-NULL, only generates events for frames in this
96 // render view host. If |frame_host_to_skip| is given, no events are sent for
99 void SendErrorEvents(content::WebContents
* web_contents
,
100 content::RenderViewHost
* render_view_host
,
101 content::RenderFrameHost
* frame_host_to_skip
);
103 // Tracks the state of the frames we are sending events for.
104 FrameNavigationState navigation_state_
;
106 // Used for tracking registrations to redirect notifications.
107 content::NotificationRegistrar registrar_
;
109 DISALLOW_COPY_AND_ASSIGN(WebNavigationTabObserver
);
112 // Observes navigation notifications and routes them as events to the extension
114 class WebNavigationEventRouter
: public TabStripModelObserver
,
115 public chrome::BrowserListObserver
,
116 public content::NotificationObserver
{
118 explicit WebNavigationEventRouter(Profile
* profile
);
119 ~WebNavigationEventRouter() override
;
122 // Used to cache the information about newly created WebContents objects.
123 struct PendingWebContents
{
124 PendingWebContents();
125 PendingWebContents(content::WebContents
* source_web_contents
,
126 content::RenderFrameHost
* source_frame_host
,
127 content::WebContents
* target_web_contents
,
128 const GURL
& target_url
);
129 ~PendingWebContents();
131 content::WebContents
* source_web_contents
;
132 content::RenderFrameHost
* source_frame_host
;
133 content::WebContents
* target_web_contents
;
137 // TabStripModelObserver implementation.
138 void TabReplacedAt(TabStripModel
* tab_strip_model
,
139 content::WebContents
* old_contents
,
140 content::WebContents
* new_contents
,
143 // chrome::BrowserListObserver implementation.
144 void OnBrowserAdded(Browser
* browser
) override
;
145 void OnBrowserRemoved(Browser
* browser
) override
;
147 // content::NotificationObserver implementation.
148 void Observe(int type
,
149 const content::NotificationSource
& source
,
150 const content::NotificationDetails
& details
) override
;
152 // Handler for the NOTIFICATION_RETARGETING event. The method takes the
153 // details of such an event and stores them for the later
154 // NOTIFICATION_TAB_ADDED event.
155 void Retargeting(const RetargetingDetails
* details
);
157 // Handler for the NOTIFICATION_TAB_ADDED event. The method takes the details
158 // of such an event and creates a JSON formated extension event from it.
159 void TabAdded(content::WebContents
* tab
);
161 // Handler for NOTIFICATION_WEB_CONTENTS_DESTROYED. If |tab| is in
162 // |pending_web_contents_|, it is removed.
163 void TabDestroyed(content::WebContents
* tab
);
165 // Mapping pointers to WebContents objects to information about how they got
167 std::map
<content::WebContents
*, PendingWebContents
> pending_web_contents_
;
169 // Used for tracking registrations to navigation notifications.
170 content::NotificationRegistrar registrar_
;
172 // The profile that owns us via ExtensionService.
175 DISALLOW_COPY_AND_ASSIGN(WebNavigationEventRouter
);
178 // API function that returns the state of a given frame.
179 class WebNavigationGetFrameFunction
: public ChromeSyncExtensionFunction
{
180 ~WebNavigationGetFrameFunction() override
{}
181 bool RunSync() override
;
182 DECLARE_EXTENSION_FUNCTION("webNavigation.getFrame", WEBNAVIGATION_GETFRAME
)
185 // API function that returns the states of all frames in a given tab.
186 class WebNavigationGetAllFramesFunction
: public ChromeSyncExtensionFunction
{
187 ~WebNavigationGetAllFramesFunction() override
{}
188 bool RunSync() override
;
189 DECLARE_EXTENSION_FUNCTION("webNavigation.getAllFrames",
190 WEBNAVIGATION_GETALLFRAMES
)
193 class WebNavigationAPI
: public BrowserContextKeyedAPI
,
194 public extensions::EventRouter::Observer
{
196 explicit WebNavigationAPI(content::BrowserContext
* context
);
197 ~WebNavigationAPI() override
;
199 // KeyedService implementation.
200 void Shutdown() override
;
202 // BrowserContextKeyedAPI implementation.
203 static BrowserContextKeyedAPIFactory
<WebNavigationAPI
>* GetFactoryInstance();
205 // EventRouter::Observer implementation.
206 void OnListenerAdded(const extensions::EventListenerInfo
& details
) override
;
209 friend class BrowserContextKeyedAPIFactory
<WebNavigationAPI
>;
211 content::BrowserContext
* browser_context_
;
213 // BrowserContextKeyedAPI implementation.
214 static const char* service_name() {
215 return "WebNavigationAPI";
217 static const bool kServiceIsNULLWhileTesting
= true;
219 // Created lazily upon OnListenerAdded.
220 scoped_ptr
<WebNavigationEventRouter
> web_navigation_event_router_
;
222 DISALLOW_COPY_AND_ASSIGN(WebNavigationAPI
);
225 } // namespace extensions
227 #endif // CHROME_BROWSER_EXTENSIONS_API_WEB_NAVIGATION_WEB_NAVIGATION_API_H_