Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1390)

Side by Side Diff: chrome/browser/google/google_url_tracker.h

Issue 303233006: Abstract GoogleURLTracker & google_util Profile dependencies (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Update comments Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 16 matching lines...) Expand all
27 class Profile; 27 class Profile;
28 28
29 namespace infobars { 29 namespace infobars {
30 class InfoBar; 30 class InfoBar;
31 } 31 }
32 32
33 // This object is responsible for checking the Google URL once per network 33 // This object is responsible for checking the Google URL once per network
34 // change, and if necessary prompting the user to see if they want to change to 34 // change, and if necessary prompting the user to see if they want to change to
35 // using it. The current and last prompted values are saved to prefs. 35 // using it. The current and last prompted values are saved to prefs.
36 // 36 //
37 // Most consumers should only call GoogleURL(), which is guaranteed to 37 // Most consumers should only call
38 // synchronously return a value at all times (even during startup or in unittest 38 // google_profile_helper::GetGoogleHomePageURL(), which is guaranteed to
Peter Kasting 2014/05/30 20:50:39 Nit: Maybe "Most consumers should not use this cla
blundell 2014/06/02 15:42:26 Yep, you're right re: the layering violation. Chan
39 // mode). Consumers who need to be notified when things change should register 39 // synchronously return a value at all times (even during startup or in
40 // a callback that provides the original and updated values via 40 // unittest mode). Consumers who need to be notified when things change should
41 // register a callback that provides the original and updated values via
41 // RegisterCallback(). 42 // RegisterCallback().
42 // 43 //
43 // To protect users' privacy and reduce server load, no updates will be 44 // To protect users' privacy and reduce server load, no updates will be
44 // performed (ever) unless at least one consumer registers interest by calling 45 // performed (ever) unless at least one consumer registers interest by calling
45 // RequestServerCheck(). 46 // RequestServerCheck().
46 class GoogleURLTracker : public net::URLFetcherDelegate, 47 class GoogleURLTracker : public net::URLFetcherDelegate,
47 public net::NetworkChangeNotifier::IPAddressObserver, 48 public net::NetworkChangeNotifier::IPAddressObserver,
48 public KeyedService { 49 public KeyedService {
49 public: 50 public:
50 // Callback that is called when the Google URL is updated. The arguments are 51 // Callback that is called when the Google URL is updated. The arguments are
51 // the old and new URLs. 52 // the old and new URLs.
52 typedef base::Callback<void(GURL, GURL)> OnGoogleURLUpdatedCallback; 53 typedef base::Callback<void(GURL, GURL)> OnGoogleURLUpdatedCallback;
53 typedef base::CallbackList<void(GURL, GURL)> CallbackList; 54 typedef base::CallbackList<void(GURL, GURL)> CallbackList;
54 typedef CallbackList::Subscription Subscription; 55 typedef CallbackList::Subscription Subscription;
55 56
56 // The constructor does different things depending on which of these values 57 // The constructor does different things depending on which of these values
57 // you pass it. Hopefully these are self-explanatory. 58 // you pass it. Hopefully these are self-explanatory.
58 enum Mode { 59 enum Mode {
59 NORMAL_MODE, 60 NORMAL_MODE,
60 UNIT_TEST_MODE, 61 UNIT_TEST_MODE,
61 }; 62 };
62 63
63 static const char kDefaultGoogleHomepage[]; 64 static const char kDefaultGoogleHomepage[];
Peter Kasting 2014/05/30 20:50:39 Now that you have DefaultGogoleHomepage(), I think
blundell 2014/06/02 15:42:26 Oops, I hadn't noticed that this was already publi
64 static const char kSearchDomainCheckURL[]; 65 static const char kSearchDomainCheckURL[];
Peter Kasting 2014/05/30 20:50:39 It looks like this is only exposed for tests, so p
blundell 2014/06/02 15:42:26 Done.
65 66
66 // Only the GoogleURLTrackerFactory and tests should call this. No code other 67 // Only the GoogleURLTrackerFactory and tests should call this.
67 // than the GoogleURLTracker itself should actually use
68 // GoogleURLTrackerFactory::GetForProfile().
69 GoogleURLTracker(Profile* profile, 68 GoogleURLTracker(Profile* profile,
70 scoped_ptr<GoogleURLTrackerClient> client, 69 scoped_ptr<GoogleURLTrackerClient> client,
71 Mode mode); 70 Mode mode);
72 71
73 virtual ~GoogleURLTracker(); 72 virtual ~GoogleURLTracker();
74 73
75 // Returns the current Google URL. This will return a valid URL even if 74 // Returns the URL corresponding to the default Google homepage.
76 // |profile| is NULL or a testing profile. 75 static GURL DefaultGoogleHomepage();
77 //
78 // This is the only function most code should ever call.
79 static GURL GoogleURL(Profile* profile);
80 76
81 // Requests that the tracker perform a server check to update the Google URL 77 // Requests that the tracker perform a server check to update the Google URL
82 // as necessary. If |force| is false, this will happen at most once per 78 // as necessary. If |force| is false, this will happen at most once per
83 // network change, not sooner than five seconds after startup (checks 79 // network change, not sooner than five seconds after startup (checks
84 // requested before that time will occur then; checks requested afterwards 80 // requested before that time will occur then; checks requested afterwards
85 // will occur immediately, if no other checks have been made during this run). 81 // will occur immediately, if no other checks have been made during this run).
86 // If |force| is true, and the tracker has already performed any requested 82 // If |force| is true, and the tracker has already performed any requested
87 // check, it will check again. 83 // check, it will check again.
88 // 84 void RequestServerCheck(bool force);
89 // When |profile| is NULL or a testing profile, this function does nothing.
90 static void RequestServerCheck(Profile* profile, bool force);
91 85
92 // Notifies the tracker that the user has started a Google search. 86 // Notifies the tracker that the user has started a Google search.
93 // If prompting is necessary, we then listen for the subsequent pending 87 // If prompting is necessary, we then listen for the subsequent pending
94 // navigation to get the appropriate NavigationController. When the load 88 // navigation to get the appropriate NavigationHelper. When the load
95 // commits, we'll show the infobar. 89 // commits, we'll show the infobar.
96 // 90 void GoogleURLSearchCommitted();
Peter Kasting 2014/05/30 20:50:39 Nit: Now that there isn't a private SearchCommitte
blundell 2014/06/02 15:42:26 Done.
97 // When |profile| is NULL or a testing profile, this function does nothing.
98 static void GoogleURLSearchCommitted(Profile* profile);
99 91
100 // No one but GoogleURLTrackerInfoBarDelegate or test code should call these. 92 // No one but GoogleURLTrackerInfoBarDelegate or test code should call these.
Peter Kasting 2014/05/30 20:50:39 This comment is now incorrect for google_url() (si
blundell 2014/06/02 15:42:26 Done.
101 void AcceptGoogleURL(bool redo_searches); 93 void AcceptGoogleURL(bool redo_searches);
102 void CancelGoogleURL(); 94 void CancelGoogleURL();
103 const GURL& google_url() const { return google_url_; } 95 const GURL& google_url() const { return google_url_; }
104 const GURL& fetched_google_url() const { return fetched_google_url_; } 96 const GURL& fetched_google_url() const { return fetched_google_url_; }
105 97
106 // No one but GoogleURLTrackerMapEntry should call this. 98 // No one but GoogleURLTrackerMapEntry should call this.
107 void DeleteMapEntryForService(const InfoBarService* infobar_service); 99 void DeleteMapEntryForService(const InfoBarService* infobar_service);
108 100
109 // Called by the client after SearchCommitted() registers listeners, to 101 // Called by the client after GoogleURLSearchCommitted() registers listeners,
110 // indicate that we've received the "load now pending" notification. 102 // to indicate that we've received the "load now pending" notification.
111 // |nav_helper| is the GoogleURLTrackerNavigationHelper associated with this 103 // |nav_helper| is the GoogleURLTrackerNavigationHelper associated with this
112 // navigation; |infobar_service| is the InfoBarService of the associated tab; 104 // navigation; |infobar_service| is the InfoBarService of the associated tab;
113 // and |pending_id| is the unique ID of the newly pending NavigationEntry. 105 // and |pending_id| is the unique ID of the newly pending NavigationEntry.
114 // If there is already a visible GoogleURLTracker infobar for this tab, this 106 // If there is already a visible GoogleURLTracker infobar for this tab, this
115 // function resets its associated pending entry ID to the new ID. Otherwise 107 // function resets its associated pending entry ID to the new ID. Otherwise
116 // this function creates a map entry for the associated tab. 108 // this function creates a map entry for the associated tab.
117 virtual void OnNavigationPending( 109 virtual void OnNavigationPending(
118 scoped_ptr<GoogleURLTrackerNavigationHelper> nav_helper, 110 scoped_ptr<GoogleURLTrackerNavigationHelper> nav_helper,
119 InfoBarService* infobar_service, 111 InfoBarService* infobar_service,
120 int pending_id); 112 int pending_id);
(...skipping 30 matching lines...) Expand all
151 void SetNeedToFetch(); 143 void SetNeedToFetch();
152 144
153 // Called when the five second startup sleep has finished. Runs any pending 145 // Called when the five second startup sleep has finished. Runs any pending
154 // fetch. 146 // fetch.
155 void FinishSleep(); 147 void FinishSleep();
156 148
157 // Starts the fetch of the up-to-date Google URL if we actually want to fetch 149 // Starts the fetch of the up-to-date Google URL if we actually want to fetch
158 // it and can currently do so. 150 // it and can currently do so.
159 void StartFetchIfDesirable(); 151 void StartFetchIfDesirable();
160 152
161 // Called each time the user performs a search. This checks whether we need
162 // to prompt the user about a domain change, and if so, starts listening for
163 // the notifications sent when the actual load is triggered.
164 void SearchCommitted();
165
166 // Closes all map entries. If |redo_searches| is true, this also triggers 153 // Closes all map entries. If |redo_searches| is true, this also triggers
167 // each tab with an infobar to re-perform the user's search, but on the new 154 // each tab with an infobar to re-perform the user's search, but on the new
168 // Google TLD. 155 // Google TLD.
169 void CloseAllEntries(bool redo_searches); 156 void CloseAllEntries(bool redo_searches);
170 157
171 // Unregisters any listeners for the navigation helper in |map_entry|. 158 // Unregisters any listeners for the navigation helper in |map_entry|.
172 // This sanity-DCHECKs that these are registered (or not) in the specific 159 // This sanity-DCHECKs that these are registered (or not) in the specific
173 // cases we expect. (|must_be_listening_for_commit| is used purely for this 160 // cases we expect. (|must_be_listening_for_commit| is used purely for this
174 // sanity-checking.) This also unregisters the global navigation pending 161 // sanity-checking.) This also unregisters the global navigation pending
175 // listener if there are no remaining listeners for navigation commits, as we 162 // listener if there are no remaining listeners for navigation commits, as we
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
211 // nor the last prompted Google URL. 198 // nor the last prompted Google URL.
212 bool search_committed_; // True when we're expecting a notification of a new 199 bool search_committed_; // True when we're expecting a notification of a new
213 // pending search navigation. 200 // pending search navigation.
214 EntryMap entry_map_; 201 EntryMap entry_map_;
215 base::WeakPtrFactory<GoogleURLTracker> weak_ptr_factory_; 202 base::WeakPtrFactory<GoogleURLTracker> weak_ptr_factory_;
216 203
217 DISALLOW_COPY_AND_ASSIGN(GoogleURLTracker); 204 DISALLOW_COPY_AND_ASSIGN(GoogleURLTracker);
218 }; 205 };
219 206
220 #endif // CHROME_BROWSER_GOOGLE_GOOGLE_URL_TRACKER_H_ 207 #endif // CHROME_BROWSER_GOOGLE_GOOGLE_URL_TRACKER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698