OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CHROME_BROWSER_GOOGLE_GOOGLE_URL_TRACKER_H_ | 5 #ifndef CHROME_BROWSER_GOOGLE_GOOGLE_URL_TRACKER_H_ |
6 #define CHROME_BROWSER_GOOGLE_GOOGLE_URL_TRACKER_H_ | 6 #define CHROME_BROWSER_GOOGLE_GOOGLE_URL_TRACKER_H_ |
7 | 7 |
8 #include <map> | 8 #include <map> |
9 #include <string> | 9 #include <string> |
10 #include <utility> | 10 #include <utility> |
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
86 // NAV_ENTRY_PENDING notification to get the appropriate NavigationController. | 86 // NAV_ENTRY_PENDING notification to get the appropriate NavigationController. |
87 // When the load commits, we'll show the infobar. | 87 // When the load commits, we'll show the infobar. |
88 // | 88 // |
89 // When |profile| is NULL or a testing profile, this function does nothing. | 89 // When |profile| is NULL or a testing profile, this function does nothing. |
90 static void GoogleURLSearchCommitted(Profile* profile); | 90 static void GoogleURLSearchCommitted(Profile* profile); |
91 | 91 |
92 static const char kDefaultGoogleHomepage[]; | 92 static const char kDefaultGoogleHomepage[]; |
93 static const char kSearchDomainCheckURL[]; | 93 static const char kSearchDomainCheckURL[]; |
94 | 94 |
95 private: | 95 private: |
96 friend class GoogleURLTrackerInfoBarDelegate; | 96 friend class GoogleURLTrackerInfoBarDelegate; |
Ilya Sherman
2012/10/16 20:16:24
Whoa, I just noticed this. How 'bout we expose pu
Peter Kasting
2012/10/16 23:29:35
OK. I hadn't done this so far because the current
| |
97 friend class GoogleURLTrackerTest; | 97 friend class GoogleURLTrackerTest; |
98 | 98 |
99 struct MapEntry { | 99 class MapEntry; |
Ilya Sherman
2012/10/16 20:16:24
How about defining this in a separate header file?
Peter Kasting
2012/10/16 23:29:35
:/ I'm less convinced of the benefits of this, but
| |
100 MapEntry(); // Required by STL. | |
101 MapEntry(GoogleURLTrackerInfoBarDelegate* infobar, | |
102 const content::NotificationSource& navigation_controller_source, | |
103 const content::NotificationSource& web_contents_source); | |
104 ~MapEntry(); | |
105 | 100 |
106 GoogleURLTrackerInfoBarDelegate* infobar; | 101 typedef std::map<const InfoBarTabHelper*, MapEntry*> InfoBarMap; |
107 content::NotificationSource navigation_controller_source; | |
108 content::NotificationSource web_contents_source; | |
109 }; | |
110 | 102 |
111 typedef std::map<const InfoBarTabHelper*, MapEntry> InfoBarMap; | 103 // Creates an infobar delegate and adds it to |infobar_helper|. Returns the |
104 // delegate pointer on success or NULL on failure. The caller does not own | |
105 // the returned object, the InfoBarTabHelper does. | |
112 typedef GoogleURLTrackerInfoBarDelegate* (*InfoBarCreator)( | 106 typedef GoogleURLTrackerInfoBarDelegate* (*InfoBarCreator)( |
113 InfoBarTabHelper* infobar_helper, | 107 InfoBarTabHelper* infobar_helper, |
114 GoogleURLTracker* google_url_tracker, | 108 GoogleURLTracker* google_url_tracker, |
115 const GURL& new_google_url); | 109 const GURL& new_google_url); |
116 | 110 |
117 // net::URLFetcherDelegate: | 111 // net::URLFetcherDelegate: |
118 virtual void OnURLFetchComplete(const net::URLFetcher* source) OVERRIDE; | 112 virtual void OnURLFetchComplete(const net::URLFetcher* source) OVERRIDE; |
119 | 113 |
120 // content::NotificationObserver: | 114 // content::NotificationObserver: |
121 virtual void Observe(int type, | 115 virtual void Observe(int type, |
122 const content::NotificationSource& source, | 116 const content::NotificationSource& source, |
123 const content::NotificationDetails& details) OVERRIDE; | 117 const content::NotificationDetails& details) OVERRIDE; |
124 | 118 |
125 // NetworkChangeNotifier::IPAddressObserver: | 119 // NetworkChangeNotifier::IPAddressObserver: |
126 virtual void OnIPAddressChanged() OVERRIDE; | 120 virtual void OnIPAddressChanged() OVERRIDE; |
127 | 121 |
128 // ProfileKeyedService: | 122 // ProfileKeyedService: |
129 virtual void Shutdown() OVERRIDE; | 123 virtual void Shutdown() OVERRIDE; |
130 | 124 |
131 // Callbacks from GoogleURLTrackerInfoBarDelegate: | 125 // Callbacks from GoogleURLTrackerInfoBarDelegate: |
132 void AcceptGoogleURL(const GURL& google_url, bool redo_searches); | 126 void AcceptGoogleURL(bool redo_searches); |
133 void CancelGoogleURL(const GURL& google_url); | 127 void CancelGoogleURL(); |
134 void InfoBarClosed(const InfoBarTabHelper* infobar_helper); | 128 |
129 // Callback from MapEntry: | |
130 void DeleteMapEntryForHelper(const InfoBarTabHelper* infobar_helper); | |
135 | 131 |
136 // Registers consumer interest in getting an updated URL from the server. | 132 // Registers consumer interest in getting an updated URL from the server. |
137 // Observe chrome::NOTIFICATION_GOOGLE_URL_UPDATED to be notified when the URL | 133 // Observe chrome::NOTIFICATION_GOOGLE_URL_UPDATED to be notified when the URL |
138 // changes. | 134 // changes. |
139 void SetNeedToFetch(); | 135 void SetNeedToFetch(); |
140 | 136 |
141 // Called when the five second startup sleep has finished. Runs any pending | 137 // Called when the five second startup sleep has finished. Runs any pending |
142 // fetch. | 138 // fetch. |
143 void FinishSleep(); | 139 void FinishSleep(); |
144 | 140 |
(...skipping 20 matching lines...) Expand all Loading... | |
165 const content::NotificationSource& navigation_controller_source, | 161 const content::NotificationSource& navigation_controller_source, |
166 const content::NotificationSource& web_contents_source, | 162 const content::NotificationSource& web_contents_source, |
167 InfoBarTabHelper* infobar_helper, | 163 InfoBarTabHelper* infobar_helper, |
168 int pending_id); | 164 int pending_id); |
169 | 165 |
170 // Called by Observe() once a load we're watching commits, or the associated | 166 // Called by Observe() once a load we're watching commits, or the associated |
171 // tab is closed. |infobar_helper| is the same as for OnNavigationPending(); | 167 // tab is closed. |infobar_helper| is the same as for OnNavigationPending(); |
172 // |search_url| is valid when this call is due to a successful navigation | 168 // |search_url| is valid when this call is due to a successful navigation |
173 // (indicating that we should show or update the relevant infobar) as opposed | 169 // (indicating that we should show or update the relevant infobar) as opposed |
174 // to tab closure (which means we should delete the infobar). | 170 // to tab closure (which means we should delete the infobar). |
175 void OnNavigationCommittedOrTabClosed(const InfoBarTabHelper* infobar_helper, | 171 void OnNavigationCommittedOrTabClosed(InfoBarTabHelper* infobar_helper, |
176 const GURL& search_url); | 172 const GURL& search_url); |
177 | 173 |
178 // Called by Observe() when an instant navigation occurs. This will call | 174 // Called by Observe() when an instant navigation occurs. This will call |
179 // OnNavigationPending(), and, depending on whether this is a search we were | 175 // OnNavigationPending(), and, depending on whether this is a search we were |
180 // listening for, may then also call OnNavigationCommittedOrTabClosed(). | 176 // listening for, may then also call OnNavigationCommittedOrTabClosed(). |
181 void OnInstantCommitted( | 177 void OnInstantCommitted( |
182 const content::NotificationSource& navigation_controller_source, | 178 const content::NotificationSource& navigation_controller_source, |
183 const content::NotificationSource& web_contents_source, | 179 const content::NotificationSource& web_contents_source, |
184 InfoBarTabHelper* infobar_helper, | 180 InfoBarTabHelper* infobar_helper, |
185 const GURL& search_url); | 181 const GURL& search_url); |
186 | 182 |
187 // Closes all open infobars. If |redo_searches| is true, this also triggers | 183 // Closes all open infobars. If |redo_searches| is true, this also triggers |
188 // each tab to re-perform the user's search, but on the new Google TLD. | 184 // each tab to re-perform the user's search, but on the new Google TLD. |
189 void CloseAllInfoBars(bool redo_searches); | 185 void CloseAllInfoBars(bool redo_searches); |
190 | 186 |
191 // Unregisters any listeners for the notification sources in |map_entry|. | 187 // Unregisters any listeners for the notification sources in |map_entry|. |
192 // This sanity-DCHECKs that these are registered (or not) in the specific | 188 // This sanity-DCHECKs that these are registered (or not) in the specific |
193 // cases we expect. (|must_be_listening_for_commit| is used purely for this | 189 // cases we expect. (|must_be_listening_for_commit| is used purely for this |
194 // sanity-checking.) This also unregisters our global NAV_ENTRY_PENDING/ | 190 // sanity-checking.) This also unregisters our global NAV_ENTRY_PENDING/ |
195 // INSTANT_COMMITTED listeners if there are no remaining listeners for | 191 // INSTANT_COMMITTED listeners if there are no remaining listeners for |
196 // NAV_ENTRY_COMMITTED, as we no longer need them until another search is | 192 // NAV_ENTRY_COMMITTED, as we no longer need them until another search is |
197 // committed. | 193 // committed. |
198 void UnregisterForEntrySpecificNotifications( | 194 void UnregisterForEntrySpecificNotifications( |
199 const MapEntry& map_entry, | 195 const MapEntry& map_entry, |
200 bool must_be_listening_for_commit); | 196 bool must_be_listening_for_commit); |
201 | 197 |
202 Profile* profile_; | 198 Profile* profile_; |
203 content::NotificationRegistrar registrar_; | 199 content::NotificationRegistrar registrar_; |
204 InfoBarCreator infobar_creator_; | 200 InfoBarCreator infobar_creator_; |
205 // TODO(ukai): GoogleURLTracker should track google domain (e.g. google.co.uk) | |
206 // rather than URL (e.g. http://www.google.co.uk/), so that user could | |
207 // configure to use https in search engine templates. | |
Ilya Sherman
2012/10/16 20:16:24
Is this being removed because it's no longer appro
Peter Kasting
2012/10/16 23:29:35
We solved this problem in a different way by suppo
| |
208 GURL google_url_; | 201 GURL google_url_; |
209 GURL fetched_google_url_; | 202 GURL fetched_google_url_; |
210 base::WeakPtrFactory<GoogleURLTracker> weak_ptr_factory_; | 203 base::WeakPtrFactory<GoogleURLTracker> weak_ptr_factory_; |
211 scoped_ptr<net::URLFetcher> fetcher_; | 204 scoped_ptr<net::URLFetcher> fetcher_; |
212 int fetcher_id_; | 205 int fetcher_id_; |
213 bool in_startup_sleep_; // True if we're in the five-second "no fetching" | 206 bool in_startup_sleep_; // True if we're in the five-second "no fetching" |
214 // period that begins at browser start. | 207 // period that begins at browser start. |
215 bool already_fetched_; // True if we've already fetched a URL once this run; | 208 bool already_fetched_; // True if we've already fetched a URL once this run; |
216 // we won't fetch again until after a restart. | 209 // we won't fetch again until after a restart. |
217 bool need_to_fetch_; // True if a consumer actually wants us to fetch an | 210 bool need_to_fetch_; // True if a consumer actually wants us to fetch an |
218 // updated URL. If this is never set, we won't | 211 // updated URL. If this is never set, we won't |
219 // bother to fetch anything. | 212 // bother to fetch anything. |
220 // Consumers should observe | 213 // Consumers should observe |
221 // chrome::NOTIFICATION_GOOGLE_URL_UPDATED. | 214 // chrome::NOTIFICATION_GOOGLE_URL_UPDATED. |
222 bool need_to_prompt_; // True if the last fetched Google URL is not | 215 bool need_to_prompt_; // True if the last fetched Google URL is not |
223 // matched with current user's default Google URL | 216 // matched with current user's default Google URL |
224 // nor the last prompted Google URL. | 217 // nor the last prompted Google URL. |
225 bool search_committed_; // True when we're expecting a notification of a new | 218 bool search_committed_; // True when we're expecting a notification of a new |
226 // pending search navigation. | 219 // pending search navigation. |
227 InfoBarMap infobar_map_; | 220 InfoBarMap infobar_map_; |
228 | 221 |
229 DISALLOW_COPY_AND_ASSIGN(GoogleURLTracker); | 222 DISALLOW_COPY_AND_ASSIGN(GoogleURLTracker); |
230 }; | 223 }; |
231 | 224 |
225 class GoogleURLTracker::MapEntry : public content::NotificationObserver { | |
226 public: | |
227 MapEntry(GoogleURLTracker* google_url_tracker, | |
228 InfoBarTabHelper* infobar_helper, | |
229 const content::NotificationSource& navigation_controller_source, | |
230 const content::NotificationSource& web_contents_source); | |
231 virtual ~MapEntry(); | |
232 | |
233 bool has_infobar() const { return !!infobar_; } | |
234 GoogleURLTrackerInfoBarDelegate* infobar() { return infobar_; } | |
235 void SetInfoBar(GoogleURLTrackerInfoBarDelegate* infobar); | |
236 | |
237 const content::NotificationSource& navigation_controller_source() const { | |
238 return navigation_controller_source_; | |
239 } | |
240 const content::NotificationSource& web_contents_source() const { | |
241 return web_contents_source_; | |
242 } | |
243 | |
244 void Close(bool redo_search); | |
245 | |
246 private: | |
247 friend class GoogleURLTrackerTest; | |
248 | |
249 // content::NotificationObserver: | |
250 virtual void Observe(int type, | |
251 const content::NotificationSource& source, | |
252 const content::NotificationDetails& details) OVERRIDE; | |
253 | |
254 content::NotificationRegistrar registrar_; | |
255 GoogleURLTracker* google_url_tracker_; | |
256 InfoBarTabHelper* infobar_helper_; | |
Ilya Sherman
2012/10/16 20:16:24
nit: Can these be const members?
Peter Kasting
2012/10/16 23:29:35
Added as much const as possible.
| |
257 GoogleURLTrackerInfoBarDelegate* infobar_; | |
258 content::NotificationSource navigation_controller_source_; | |
259 content::NotificationSource web_contents_source_; | |
Ilya Sherman
2012/10/16 20:16:24
nit: Can these be const members?
Peter Kasting
2012/10/16 23:29:35
Yes.
| |
260 | |
261 DISALLOW_COPY_AND_ASSIGN(MapEntry); | |
262 }; | |
263 | |
232 #endif // CHROME_BROWSER_GOOGLE_GOOGLE_URL_TRACKER_H_ | 264 #endif // CHROME_BROWSER_GOOGLE_GOOGLE_URL_TRACKER_H_ |
OLD | NEW |