OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 COMPONENTS_NTP_SNIPPETS_REMOTE_NTP_SNIPPETS_FETCHER_H_ | 5 #ifndef COMPONENTS_NTP_SNIPPETS_REMOTE_NTP_SNIPPETS_FETCHER_H_ |
6 #define COMPONENTS_NTP_SNIPPETS_REMOTE_NTP_SNIPPETS_FETCHER_H_ | 6 #define COMPONENTS_NTP_SNIPPETS_REMOTE_NTP_SNIPPETS_FETCHER_H_ |
7 | 7 |
8 #include <memory> | 8 #include <memory> |
9 #include <set> | 9 #include <set> |
10 #include <string> | 10 #include <string> |
(...skipping 13 matching lines...) Expand all Loading... |
24 | 24 |
25 class PrefService; | 25 class PrefService; |
26 class SigninManagerBase; | 26 class SigninManagerBase; |
27 | 27 |
28 namespace base { | 28 namespace base { |
29 class Value; | 29 class Value; |
30 } // namespace base | 30 } // namespace base |
31 | 31 |
32 namespace ntp_snippets { | 32 namespace ntp_snippets { |
33 | 33 |
| 34 class UserClassifier; |
| 35 |
34 // Fetches snippet data for the NTP from the server. | 36 // Fetches snippet data for the NTP from the server. |
35 class NTPSnippetsFetcher : public OAuth2TokenService::Consumer, | 37 class NTPSnippetsFetcher : public OAuth2TokenService::Consumer, |
36 public OAuth2TokenService::Observer, | 38 public OAuth2TokenService::Observer, |
37 public net::URLFetcherDelegate { | 39 public net::URLFetcherDelegate { |
38 public: | 40 public: |
39 // Callbacks for JSON parsing, needed because the parsing is platform- | 41 // Callbacks for JSON parsing, needed because the parsing is platform- |
40 // dependent. | 42 // dependent. |
41 using SuccessCallback = base::Callback<void(std::unique_ptr<base::Value>)>; | 43 using SuccessCallback = base::Callback<void(std::unique_ptr<base::Value>)>; |
42 using ErrorCallback = base::Callback<void(const std::string&)>; | 44 using ErrorCallback = base::Callback<void(const std::string&)>; |
43 using ParseJSONCallback = base::Callback< | 45 using ParseJSONCallback = base::Callback< |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
85 kBoth | 87 kBoth |
86 }; | 88 }; |
87 | 89 |
88 NTPSnippetsFetcher( | 90 NTPSnippetsFetcher( |
89 SigninManagerBase* signin_manager, | 91 SigninManagerBase* signin_manager, |
90 OAuth2TokenService* token_service, | 92 OAuth2TokenService* token_service, |
91 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter, | 93 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter, |
92 PrefService* pref_service, | 94 PrefService* pref_service, |
93 CategoryFactory* category_factory, | 95 CategoryFactory* category_factory, |
94 const ParseJSONCallback& parse_json_callback, | 96 const ParseJSONCallback& parse_json_callback, |
95 const std::string& api_key); | 97 const std::string& api_key, |
| 98 const UserClassifier* user_classifier); |
96 ~NTPSnippetsFetcher() override; | 99 ~NTPSnippetsFetcher() override; |
97 | 100 |
98 // Set a callback that is called when a new set of snippets are downloaded, | 101 // Set a callback that is called when a new set of snippets are downloaded, |
99 // overriding any previously set callback. | 102 // overriding any previously set callback. |
100 void SetCallback(const SnippetsAvailableCallback& callback); | 103 void SetCallback(const SnippetsAvailableCallback& callback); |
101 | 104 |
102 // Fetches snippets from the server. |hosts| restricts the results to a set of | 105 // Fetches snippets from the server. |hosts| restricts the results to a set of |
103 // hosts, e.g. "www.google.com". If host restrictions are enabled, an empty | 106 // hosts, e.g. "www.google.com". If host restrictions are enabled, an empty |
104 // host set produces an error without issuing a fetch. | 107 // host set produces an error without issuing a fetch. |
105 // | 108 // |
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
158 | 161 |
159 struct RequestParams { | 162 struct RequestParams { |
160 FetchAPI fetch_api; | 163 FetchAPI fetch_api; |
161 std::string obfuscated_gaia_id; | 164 std::string obfuscated_gaia_id; |
162 bool only_return_personalized_results; | 165 bool only_return_personalized_results; |
163 std::string user_locale; | 166 std::string user_locale; |
164 std::set<std::string> host_restricts; | 167 std::set<std::string> host_restricts; |
165 std::set<std::string> excluded_ids; | 168 std::set<std::string> excluded_ids; |
166 int count_to_fetch; | 169 int count_to_fetch; |
167 bool interactive_request; | 170 bool interactive_request; |
| 171 std::string user_class; |
168 | 172 |
169 RequestParams(); | 173 RequestParams(); |
170 ~RequestParams(); | 174 ~RequestParams(); |
171 | 175 |
172 std::string BuildRequest(); | 176 std::string BuildRequest(); |
173 }; | 177 }; |
174 | 178 |
175 void FetchSnippetsImpl(const GURL& url, | 179 void FetchSnippetsImpl(const GURL& url, |
176 const std::string& auth_header, | 180 const std::string& auth_header, |
177 const std::string& request); | 181 const std::string& request); |
(...skipping 16 matching lines...) Expand all Loading... |
194 void OnURLFetchComplete(const net::URLFetcher* source) override; | 198 void OnURLFetchComplete(const net::URLFetcher* source) override; |
195 | 199 |
196 bool JsonToSnippets(const base::Value& parsed, | 200 bool JsonToSnippets(const base::Value& parsed, |
197 FetchedCategoriesVector* categories); | 201 FetchedCategoriesVector* categories); |
198 void OnJsonParsed(std::unique_ptr<base::Value> parsed); | 202 void OnJsonParsed(std::unique_ptr<base::Value> parsed); |
199 void OnJsonError(const std::string& error); | 203 void OnJsonError(const std::string& error); |
200 void FetchFinished(OptionalSnippets snippets, | 204 void FetchFinished(OptionalSnippets snippets, |
201 FetchResult result, | 205 FetchResult result, |
202 const std::string& extra_message); | 206 const std::string& extra_message); |
203 | 207 |
| 208 bool DemandQuotaForRequest(bool interactive_request); |
| 209 |
204 // Authorization for signed-in users. | 210 // Authorization for signed-in users. |
205 SigninManagerBase* signin_manager_; | 211 SigninManagerBase* signin_manager_; |
206 OAuth2TokenService* token_service_; | 212 OAuth2TokenService* token_service_; |
207 std::unique_ptr<OAuth2TokenService::Request> oauth_request_; | 213 std::unique_ptr<OAuth2TokenService::Request> oauth_request_; |
208 bool waiting_for_refresh_token_; | 214 bool waiting_for_refresh_token_; |
209 | 215 |
210 // Holds the URL request context. | 216 // Holds the URL request context. |
211 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter_; | 217 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter_; |
212 | 218 |
213 CategoryFactory* const category_factory_; | 219 CategoryFactory* const category_factory_; |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
246 Personalization personalization_; | 252 Personalization personalization_; |
247 // Should we apply host restriction? It is loaded from variation parameters. | 253 // Should we apply host restriction? It is loaded from variation parameters. |
248 bool use_host_restriction_; | 254 bool use_host_restriction_; |
249 | 255 |
250 // Is the request user initiated? | 256 // Is the request user initiated? |
251 bool interactive_request_; | 257 bool interactive_request_; |
252 | 258 |
253 // Allow for an injectable tick clock for testing. | 259 // Allow for an injectable tick clock for testing. |
254 std::unique_ptr<base::TickClock> tick_clock_; | 260 std::unique_ptr<base::TickClock> tick_clock_; |
255 | 261 |
256 // Request throttler for limiting requests. | 262 // Classifier that tells us how active the user is. Not owned. |
257 RequestThrottler request_throttler_; | 263 const UserClassifier* user_classifier_; |
| 264 |
| 265 // Request throttlers for limiting requests for different classes of users. |
| 266 RequestThrottler request_throttler_rare_ntp_user_; |
| 267 RequestThrottler request_throttler_active_ntp_user_; |
| 268 RequestThrottler request_throttler_active_suggestions_consumer_; |
258 | 269 |
259 // When a token request gets canceled, we want to retry once. | 270 // When a token request gets canceled, we want to retry once. |
260 bool oauth_token_retried_; | 271 bool oauth_token_retried_; |
261 | 272 |
262 base::WeakPtrFactory<NTPSnippetsFetcher> weak_ptr_factory_; | 273 base::WeakPtrFactory<NTPSnippetsFetcher> weak_ptr_factory_; |
263 | 274 |
264 DISALLOW_COPY_AND_ASSIGN(NTPSnippetsFetcher); | 275 DISALLOW_COPY_AND_ASSIGN(NTPSnippetsFetcher); |
265 }; | 276 }; |
266 } // namespace ntp_snippets | 277 } // namespace ntp_snippets |
267 | 278 |
268 #endif // COMPONENTS_NTP_SNIPPETS_REMOTE_NTP_SNIPPETS_FETCHER_H_ | 279 #endif // COMPONENTS_NTP_SNIPPETS_REMOTE_NTP_SNIPPETS_FETCHER_H_ |
OLD | NEW |