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

Side by Side Diff: chrome/browser/chrome_to_mobile_service.h

Issue 10834203: Integrate invalidation API into ChromeToMobileService. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Update comment; sync and rebase. Created 8 years, 4 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
« no previous file with comments | « chrome/browser/DEPS ('k') | chrome/browser/chrome_to_mobile_service.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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_CHROME_TO_MOBILE_SERVICE_H_ 5 #ifndef CHROME_BROWSER_CHROME_TO_MOBILE_SERVICE_H_
6 #define CHROME_BROWSER_CHROME_TO_MOBILE_SERVICE_H_ 6 #define CHROME_BROWSER_CHROME_TO_MOBILE_SERVICE_H_
7 7
8 #include <map> 8 #include <map>
9 #include <queue>
9 #include <set> 10 #include <set>
10 #include <string> 11 #include <string>
11 #include <vector> 12 #include <vector>
12 13
14 #include "base/compiler_specific.h"
13 #include "base/file_path.h" 15 #include "base/file_path.h"
14 #include "base/memory/weak_ptr.h" 16 #include "base/memory/weak_ptr.h"
15 #include "base/string16.h" 17 #include "base/string16.h"
16 #include "base/timer.h" 18 #include "base/timer.h"
17 #include "base/values.h" 19 #include "base/values.h"
18 #include "chrome/browser/profiles/profile_keyed_service.h" 20 #include "chrome/browser/profiles/profile_keyed_service.h"
19 #include "chrome/browser/sessions/session_id.h" 21 #include "chrome/browser/sessions/session_id.h"
20 #include "chrome/common/net/gaia/oauth2_access_token_consumer.h" 22 #include "chrome/common/net/gaia/oauth2_access_token_consumer.h"
21 #include "content/public/browser/notification_observer.h" 23 #include "content/public/browser/notification_observer.h"
22 #include "content/public/browser/notification_registrar.h" 24 #include "content/public/browser/notification_registrar.h"
23 #include "googleurl/src/gurl.h" 25 #include "googleurl/src/gurl.h"
24 #include "net/url_request/url_fetcher_delegate.h" 26 #include "net/url_request/url_fetcher_delegate.h"
27 #include "sync/notifier/sync_notifier_observer.h"
25 28
26 class OAuth2AccessTokenFetcher; 29 class OAuth2AccessTokenFetcher;
27 class Browser; 30 class Browser;
28 class CloudPrintURL; 31 class CloudPrintURL;
29 class MockChromeToMobileService; 32 class MockChromeToMobileService;
30 class PrefService; 33 class PrefService;
31 class Profile; 34 class Profile;
32 35
33 namespace net { 36 namespace net {
34 class URLFetcher; 37 class URLFetcher;
35 } 38 }
36 39
37 // ChromeToMobileService connects to the cloud print service to enumerate 40 // ChromeToMobileService connects to the cloud print service to enumerate
38 // compatible mobiles owned by its profile and send URLs and MHTML snapshots. 41 // compatible mobiles owned by its profile and send URLs and MHTML snapshots.
39 class ChromeToMobileService : public ProfileKeyedService, 42 class ChromeToMobileService : public ProfileKeyedService,
40 public net::URLFetcherDelegate, 43 public net::URLFetcherDelegate,
41 public content::NotificationObserver, 44 public content::NotificationObserver,
42 public OAuth2AccessTokenConsumer { 45 public OAuth2AccessTokenConsumer,
46 public syncer::SyncNotifierObserver {
43 public: 47 public:
44 class Observer { 48 class Observer {
45 public: 49 public:
46 virtual ~Observer(); 50 virtual ~Observer();
47 51
48 // Called on generation of the page's MHTML snapshot. 52 // Called on generation of the page's MHTML snapshot.
49 virtual void SnapshotGenerated(const FilePath& path, int64 bytes) = 0; 53 virtual void SnapshotGenerated(const FilePath& path, int64 bytes) = 0;
50 54
51 // Called after URLFetcher responses from sending the URL (and snapshot). 55 // Called after URLFetcher responses from sending the URL (and snapshot).
52 virtual void OnSendComplete(bool success) = 0; 56 virtual void OnSendComplete(bool success) = 0;
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after
105 109
106 // Returns true if the service has found any registered mobile devices. 110 // Returns true if the service has found any registered mobile devices.
107 bool HasMobiles() const; 111 bool HasMobiles() const;
108 112
109 // Get the non-NULL ListValue of mobile devices from the cloud print service. 113 // Get the non-NULL ListValue of mobile devices from the cloud print service.
110 // The list is owned by PrefService, which outlives ChromeToMobileService. 114 // The list is owned by PrefService, which outlives ChromeToMobileService.
111 // Each device DictionaryValue contains strings "type", "name", and "id". 115 // Each device DictionaryValue contains strings "type", "name", and "id".
112 // Virtual for unit test mocking. 116 // Virtual for unit test mocking.
113 virtual const base::ListValue* GetMobiles() const; 117 virtual const base::ListValue* GetMobiles() const;
114 118
115 // Request an updated mobile device list, request auth first if needed.
116 // Virtual for unit test mocking.
117 virtual void RequestMobileListUpdate();
118
119 // Callback with an MHTML snapshot of the browser's selected WebContents. 119 // Callback with an MHTML snapshot of the browser's selected WebContents.
120 // Virtual for unit test mocking. 120 // Virtual for unit test mocking.
121 virtual void GenerateSnapshot(Browser* browser, 121 virtual void GenerateSnapshot(Browser* browser,
122 base::WeakPtr<Observer> observer); 122 base::WeakPtr<Observer> observer);
123 123
124 // Send the browser's selected WebContents to the specified mobile device. 124 // Send the browser's selected WebContents to the specified mobile device.
125 // Virtual for unit test mocking. 125 // Virtual for unit test mocking.
126 virtual void SendToMobile(const base::DictionaryValue& mobile, 126 virtual void SendToMobile(const base::DictionaryValue* mobile,
127 const FilePath& snapshot, 127 const FilePath& snapshot,
128 Browser* browser, 128 Browser* browser,
129 base::WeakPtr<Observer> observer); 129 base::WeakPtr<Observer> observer);
130 130
131 // Delete the snapshot file (should be called on observer destruction). 131 // Delete the snapshot file (should be called on observer destruction).
132 // Virtual for unit test mocking. 132 // Virtual for unit test mocking.
133 virtual void DeleteSnapshot(const FilePath& snapshot); 133 virtual void DeleteSnapshot(const FilePath& snapshot);
134 134
135 // Log a metric for the "ChromeToMobile.Service" histogram. 135 // Log a metric for the "ChromeToMobile.Service" histogram.
136 // Virtual for unit test mocking. 136 // Virtual for unit test mocking.
137 virtual void LogMetric(Metric metric) const; 137 virtual void LogMetric(Metric metric) const;
138 138
139 // Opens the "Learn More" help article link in the supplied |browser|. 139 // Opens the "Learn More" help article link in the supplied |browser|.
140 void LearnMore(Browser* browser) const; 140 void LearnMore(Browser* browser) const;
141 141
142 // net::URLFetcherDelegate method. 142 // net::URLFetcherDelegate method.
143 virtual void OnURLFetchComplete(const net::URLFetcher* source) OVERRIDE; 143 virtual void OnURLFetchComplete(const net::URLFetcher* source) OVERRIDE;
144 144
145 // content::NotificationObserver method. 145 // content::NotificationObserver method.
146 virtual void Observe(int type, 146 virtual void Observe(int type,
147 const content::NotificationSource& source, 147 const content::NotificationSource& source,
148 const content::NotificationDetails& details) OVERRIDE; 148 const content::NotificationDetails& details) OVERRIDE;
149 149
150 // OAuth2AccessTokenConsumer methods. 150 // OAuth2AccessTokenConsumer methods.
151 virtual void OnGetTokenSuccess(const std::string& access_token, 151 virtual void OnGetTokenSuccess(const std::string& access_token,
152 const base::Time& expiration_time) OVERRIDE; 152 const base::Time& expiration_time) OVERRIDE;
153 virtual void OnGetTokenFailure(const GoogleServiceAuthError& error) OVERRIDE; 153 virtual void OnGetTokenFailure(const GoogleServiceAuthError& error) OVERRIDE;
154 154
155 // syncer::SyncNotifierObserver implementation.
156 virtual void OnNotificationsEnabled() OVERRIDE;
157 virtual void OnNotificationsDisabled(
158 syncer::NotificationsDisabledReason reason) OVERRIDE;
159 virtual void OnIncomingNotification(
160 const syncer::ObjectIdPayloadMap& id_payloads,
161 syncer::IncomingNotificationSource source) OVERRIDE;
162
163 // Expose access token accessors for test purposes.
164 const std::string& GetAccessTokenForTest() const;
165 void SetAccessTokenForTest(const std::string& access_token);
166
155 private: 167 private:
156 friend class MockChromeToMobileService; 168 friend class MockChromeToMobileService;
157 169
158 // Enable or disable Chrome To Mobile with the browsers' command controllers. 170 // Enable or disable Chrome To Mobile with the browsers' command controllers.
159 // The feature state is automatically derived from internal conditions. 171 // The feature state is automatically derived from internal conditions.
160 void UpdateCommandState() const; 172 void UpdateCommandState() const;
161 173
162 // Handle the attempted creation of a temporary file for snapshot generation. 174 // Handle the attempted creation of a temporary file for snapshot generation.
163 // Alert the observer of failure or generate MHTML with an observer callback. 175 // Alert the observer of failure or generate MHTML with an observer callback.
164 void SnapshotFileCreated(base::WeakPtr<Observer> observer, 176 void SnapshotFileCreated(base::WeakPtr<Observer> observer,
165 SessionID::id_type browser_id, 177 SessionID::id_type browser_id,
166 const FilePath& path, 178 const FilePath& path,
167 bool success); 179 bool success);
168 180
169 // Create a cloud print job submission request for a URL or snapshot. 181 // Create a cloud print job submission request for a URL or snapshot.
170 net::URLFetcher* CreateRequest(const JobData& data); 182 net::URLFetcher* CreateRequest(const JobData& data);
171 183
172 // Initialize cloud print URLFetcher requests. 184 // Initialize cloud print URLFetcher requests.
173 void InitRequest(net::URLFetcher* request); 185 void InitRequest(net::URLFetcher* request);
174 186
175 // Submit a cloud print job request with the requisite data. 187 // Submit a cloud print job request with the requisite data.
176 void SendRequest(net::URLFetcher* request, const JobData& data); 188 void SendRequest(net::URLFetcher* request, const JobData& data);
177 189
178 // Send the OAuth2AccessTokenFetcher request. 190 // Send the OAuth2AccessTokenFetcher request.
179 // Virtual for unit test mocking. 191 // Virtual for unit test mocking.
180 virtual void RequestAccessToken(); 192 virtual void RequestAccessToken();
181 193
182 // Request account information to limit cloud print access to existing users. 194 // Send the cloud print URLFetcher device search request.
183 void RequestAccountInfo(); 195 // Virtual for unit test mocking.
196 virtual void RequestDeviceSearch();
184 197
185 // Send the cloud print URLFetcher device search request. 198 void HandleSearchResponse(const net::URLFetcher* source);
186 void RequestDeviceSearch();
187
188 void HandleAccountInfoResponse();
189 void HandleSearchResponse();
190 void HandleSubmitResponse(const net::URLFetcher* source); 199 void HandleSubmitResponse(const net::URLFetcher* source);
191 200
192 base::WeakPtrFactory<ChromeToMobileService> weak_ptr_factory_; 201 base::WeakPtrFactory<ChromeToMobileService> weak_ptr_factory_;
193 202
194 Profile* profile_; 203 Profile* profile_;
195 204
205 // Sync invalidation service state. Chrome To Mobile requires this service to
206 // to keep the mobile device list up to date and prevent page send failures.
207 bool sync_invalidation_enabled_;
208
196 // Used to recieve TokenService notifications for GaiaOAuth2LoginRefreshToken. 209 // Used to recieve TokenService notifications for GaiaOAuth2LoginRefreshToken.
197 content::NotificationRegistrar registrar_; 210 content::NotificationRegistrar registrar_;
198 211
199 // Cloud print helper class and auth token. 212 // The cloud print service URL and auth access token.
200 scoped_ptr<CloudPrintURL> cloud_print_url_; 213 GURL cloud_print_url_;
201 std::string access_token_; 214 std::string access_token_;
202 215
203 // The set of snapshots currently available. 216 // The set of snapshots currently available.
204 std::set<FilePath> snapshots_; 217 std::set<FilePath> snapshots_;
205 218
206 // Map URLFetchers to observers for reporting OnSendComplete. 219 // Map URLFetchers to observers for reporting OnSendComplete.
207 typedef std::map<const net::URLFetcher*, base::WeakPtr<Observer> > 220 typedef std::map<const net::URLFetcher*, base::WeakPtr<Observer> >
208 RequestObserverMap; 221 RequestObserverMap;
209 RequestObserverMap request_observer_map_; 222 RequestObserverMap request_observer_map_;
210 223
211 // The pending OAuth access token request and a timer for retrying on failure. 224 // The pending OAuth access token request and a timer for retrying on failure.
212 scoped_ptr<OAuth2AccessTokenFetcher> access_token_fetcher_; 225 scoped_ptr<OAuth2AccessTokenFetcher> access_token_fetcher_;
213 base::OneShotTimer<ChromeToMobileService> auth_retry_timer_; 226 base::OneShotTimer<ChromeToMobileService> auth_retry_timer_;
214 227
215 // The pending account information request and the cloud print access flag. 228 // A queue of tasks to perform after an access token is lazily initialized.
216 scoped_ptr<net::URLFetcher> account_info_request_; 229 std::queue<base::Closure> task_queue_;
217 bool cloud_print_accessible_;
218
219 // The pending mobile device search request.
220 scoped_ptr<net::URLFetcher> search_request_;
221 230
222 DISALLOW_COPY_AND_ASSIGN(ChromeToMobileService); 231 DISALLOW_COPY_AND_ASSIGN(ChromeToMobileService);
223 }; 232 };
224 233
225 #endif // CHROME_BROWSER_CHROME_TO_MOBILE_SERVICE_H_ 234 #endif // CHROME_BROWSER_CHROME_TO_MOBILE_SERVICE_H_
OLDNEW
« no previous file with comments | « chrome/browser/DEPS ('k') | chrome/browser/chrome_to_mobile_service.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698