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

Side by Side Diff: components/ntp_snippets/ntp_snippets_service.h

Issue 2131943002: Change NTPSnippetsService to implement ContentSuggestionsProvider (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@neuerservice2
Patch Set: Insert the default-case again because some compilers need it Created 4 years, 5 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
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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_NTP_SNIPPETS_SERVICE_H_ 5 #ifndef COMPONENTS_NTP_SNIPPETS_NTP_SNIPPETS_SERVICE_H_
6 #define COMPONENTS_NTP_SNIPPETS_NTP_SNIPPETS_SERVICE_H_ 6 #define COMPONENTS_NTP_SNIPPETS_NTP_SNIPPETS_SERVICE_H_
7 7
8 #include <stddef.h> 8 #include <stddef.h>
9 9
10 #include <memory> 10 #include <memory>
11 #include <set> 11 #include <set>
12 #include <string> 12 #include <string>
13 #include <vector> 13 #include <vector>
14 14
15 #include "base/callback_forward.h" 15 #include "base/callback_forward.h"
16 #include "base/gtest_prod_util.h" 16 #include "base/gtest_prod_util.h"
17 #include "base/macros.h" 17 #include "base/macros.h"
18 #include "base/observer_list.h" 18 #include "base/observer_list.h"
19 #include "base/timer/timer.h" 19 #include "base/timer/timer.h"
20 #include "components/image_fetcher/image_fetcher_delegate.h" 20 #include "components/image_fetcher/image_fetcher_delegate.h"
21 #include "components/keyed_service/core/keyed_service.h" 21 #include "components/keyed_service/core/keyed_service.h"
22 #include "components/ntp_snippets/content_suggestion.h"
23 #include "components/ntp_snippets/content_suggestions_category.h"
24 #include "components/ntp_snippets/content_suggestions_category_status.h"
25 #include "components/ntp_snippets/content_suggestions_provider.h"
22 #include "components/ntp_snippets/ntp_snippet.h" 26 #include "components/ntp_snippets/ntp_snippet.h"
23 #include "components/ntp_snippets/ntp_snippets_fetcher.h" 27 #include "components/ntp_snippets/ntp_snippets_fetcher.h"
24 #include "components/ntp_snippets/ntp_snippets_scheduler.h" 28 #include "components/ntp_snippets/ntp_snippets_scheduler.h"
25 #include "components/ntp_snippets/ntp_snippets_status_service.h" 29 #include "components/ntp_snippets/ntp_snippets_status_service.h"
26 #include "components/suggestions/suggestions_service.h" 30 #include "components/suggestions/suggestions_service.h"
27 #include "components/sync_driver/sync_service_observer.h" 31 #include "components/sync_driver/sync_service_observer.h"
28 32
29 class PrefRegistrySimple; 33 class PrefRegistrySimple;
30 class PrefService; 34 class PrefService;
31 class SigninManagerBase; 35 class SigninManagerBase;
(...skipping 19 matching lines...) Expand all
51 namespace sync_driver { 55 namespace sync_driver {
52 class SyncService; 56 class SyncService;
53 } 57 }
54 58
55 namespace ntp_snippets { 59 namespace ntp_snippets {
56 60
57 class NTPSnippetsDatabase; 61 class NTPSnippetsDatabase;
58 class NTPSnippetsServiceObserver; 62 class NTPSnippetsServiceObserver;
59 63
60 // Stores and vends fresh content data for the NTP. 64 // Stores and vends fresh content data for the NTP.
65 // TODO(pke): Rename this service to ArticleSuggestionsService and move to
66 // a subdirectory.
61 class NTPSnippetsService : public KeyedService, 67 class NTPSnippetsService : public KeyedService,
62 public image_fetcher::ImageFetcherDelegate { 68 public image_fetcher::ImageFetcherDelegate,
69 public ContentSuggestionsProvider {
63 public: 70 public:
64 using ImageFetchedCallback = 71 using ImageFetchedCallback =
65 base::Callback<void(const std::string& snippet_id, const gfx::Image&)>; 72 base::Callback<void(const std::string& suggestion_id, const gfx::Image&)>;
66 73
67 // |application_language_code| should be a ISO 639-1 compliant string, e.g. 74 // |application_language_code| should be a ISO 639-1 compliant string, e.g.
68 // 'en' or 'en-US'. Note that this code should only specify the language, not 75 // 'en' or 'en-US'. Note that this code should only specify the language, not
69 // the locale, so 'en_US' (English language with US locale) and 'en-GB_US' 76 // the locale, so 'en_US' (English language with US locale) and 'en-GB_US'
70 // (British English person in the US) are not language codes. 77 // (British English person in the US) are not language codes.
71 NTPSnippetsService(bool enabled, 78 NTPSnippetsService(bool enabled,
72 PrefService* pref_service, 79 PrefService* pref_service,
73 suggestions::SuggestionsService* suggestions_service, 80 suggestions::SuggestionsService* suggestions_service,
74 const std::string& application_language_code, 81 const std::string& application_language_code,
75 NTPSnippetsScheduler* scheduler, 82 NTPSnippetsScheduler* scheduler,
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after
119 // Returns a reason why the service is disabled, or DisabledReason::NONE 126 // Returns a reason why the service is disabled, or DisabledReason::NONE
120 // if it's not. 127 // if it's not.
121 DisabledReason disabled_reason() const { 128 DisabledReason disabled_reason() const {
122 return snippets_status_service_->disabled_reason(); 129 return snippets_status_service_->disabled_reason();
123 } 130 }
124 131
125 // (Re)schedules the periodic fetching of snippets. This is necessary because 132 // (Re)schedules the periodic fetching of snippets. This is necessary because
126 // the schedule depends on the time of day. 133 // the schedule depends on the time of day.
127 void RescheduleFetching(); 134 void RescheduleFetching();
128 135
129 // Fetches the image for the snippet with the given |snippet_id| and runs the 136 // ContentSuggestionsProvider implementation
130 // |callback|. If that snippet doesn't exist or the fetch fails, the callback 137 // TODO(pke): At some point reorder the implementations in the .cc file
131 // gets a null image. 138 // accordingly.
132 void FetchSnippetImage(const std::string& snippet_id, 139 void SetObserver(Observer* observer) override;
133 const ImageFetchedCallback& callback); 140 ContentSuggestionsCategoryStatus GetCategoryStatus(
134 141 ContentSuggestionsCategory category) override;
135 // Deletes all currently stored snippets. 142 void DiscardSuggestion(const std::string& suggestion_id) override;
136 void ClearSnippets(); 143 void FetchSuggestionImage(const std::string& suggestion_id,
137 144 const ImageFetchedCallback& callback) override;
138 // Discards the snippet with the given |snippet_id|, if it exists. Returns 145 void ClearCachedSuggestionsForDebugging() override;
139 // true iff a snippet was discarded. 146 void ClearDiscardedSuggestionsForDebugging() override;
140 bool DiscardSnippet(const std::string& snippet_id);
141
142 // Clears the lists of snippets previously discarded by the user.
143 void ClearDiscardedSnippets();
144 147
145 // Returns the lists of suggestion hosts the snippets are restricted to. 148 // Returns the lists of suggestion hosts the snippets are restricted to.
146 std::set<std::string> GetSuggestionsHosts() const; 149 std::set<std::string> GetSuggestionsHosts() const;
147 150
148 // Observer accessors. 151 // Observer accessors.
149 void AddObserver(NTPSnippetsServiceObserver* observer); 152 void AddObserver(NTPSnippetsServiceObserver* observer);
150 void RemoveObserver(NTPSnippetsServiceObserver* observer); 153 void RemoveObserver(NTPSnippetsServiceObserver* observer);
151 154
152 // Returns the maximum number of snippets that will be shown at once. 155 // Returns the maximum number of snippets that will be shown at once.
153 static int GetMaxSnippetCountForTesting(); 156 static int GetMaxSnippetCountForTesting();
154 157
155 private: 158 private:
156 FRIEND_TEST_ALL_PREFIXES(NTPSnippetsServiceTest, HistorySyncStateChanges); 159 FRIEND_TEST_ALL_PREFIXES(NTPSnippetsServiceTest, HistorySyncStateChanges);
157 160
161 // TODO(pke): As soon as the DisabledReason is replaced with the new status,
162 // also remove the old State enum and replace it with
163 // ContentSuggestionsCategoryStatus and a similar status diagram.
158 // Possible state transitions: 164 // Possible state transitions:
159 // +------- NOT_INITED ------+ 165 // +------- NOT_INITED ------+
160 // | / \ | 166 // | / \ |
161 // | READY <--> DISABLED <-+ 167 // | READY <--> DISABLED <-+
162 // | \ / 168 // | \ /
163 // +-----> SHUT_DOWN 169 // +-----> SHUT_DOWN
164 enum class State { 170 enum class State {
165 // The service has just been created. Can change to states: 171 // The service has just been created. Can change to states:
166 // - DISABLED: if the constructor was called with |enabled == false| . In 172 // - DISABLED: if the constructor was called with |enabled == false| . In
167 // that case the service will stay disabled until it is shut 173 // that case the service will stay disabled until it is shut
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
231 237
232 void FetchSnippetImageFromNetwork(const std::string& snippet_id, 238 void FetchSnippetImageFromNetwork(const std::string& snippet_id,
233 const ImageFetchedCallback& callback); 239 const ImageFetchedCallback& callback);
234 240
235 // Triggers a state transition depending on the provided reason to be 241 // Triggers a state transition depending on the provided reason to be
236 // disabled (or lack thereof). This method is called when a change is detected 242 // disabled (or lack thereof). This method is called when a change is detected
237 // by |snippets_status_service_| 243 // by |snippets_status_service_|
238 void UpdateStateForStatus(DisabledReason disabled_reason); 244 void UpdateStateForStatus(DisabledReason disabled_reason);
239 245
240 // Verifies state transitions (see |State|'s documentation) and applies them. 246 // Verifies state transitions (see |State|'s documentation) and applies them.
241 // Does nothing if called with the current state. 247 // Also updates the provider status. Does nothing except updating the provider
242 void EnterState(State state); 248 // status if called with the current state.
249 void EnterState(State state, ContentSuggestionsCategoryStatus status);
243 250
244 // Enables the service and triggers a fetch if required. Do not call directly, 251 // Enables the service and triggers a fetch if required. Do not call directly,
245 // use |EnterState| instead. 252 // use |EnterState| instead.
246 void EnterStateEnabled(bool fetch_snippets); 253 void EnterStateEnabled(bool fetch_snippets);
247 254
248 // Disables the service. Do not call directly, use |EnterState| instead. 255 // Disables the service. Do not call directly, use |EnterState| instead.
249 void EnterStateDisabled(); 256 void EnterStateDisabled();
250 257
251 // Applies the effects of the transition to the SHUT_DOWN state. Do not call 258 // Applies the effects of the transition to the SHUT_DOWN state. Do not call
252 // directly, use |EnterState| instead. 259 // directly, use |EnterState| instead.
253 void EnterStateShutdown(); 260 void EnterStateShutdown();
254 261
262 // Converts the cached snippets to article content suggestions and notifies
263 // the observers.
264 void NotifyNewSuggestions();
265
266 // Notifies the content suggestions observer about a change in the
267 // |category_status_|.
268 void NotifyCategoryStatusChanged();
269
255 State state_; 270 State state_;
256 271
272 ContentSuggestionsCategoryStatus category_status_;
273
257 PrefService* pref_service_; 274 PrefService* pref_service_;
258 275
259 suggestions::SuggestionsService* suggestions_service_; 276 suggestions::SuggestionsService* suggestions_service_;
260 277
261 // All current suggestions (i.e. not discarded ones). 278 // All current suggestions (i.e. not discarded ones).
262 NTPSnippet::PtrVector snippets_; 279 NTPSnippet::PtrVector snippets_;
263 280
264 // Suggestions that the user discarded. We keep these around until they expire 281 // Suggestions that the user discarded. We keep these around until they expire
265 // so we won't re-add them on the next fetch. 282 // so we won't re-add them on the next fetch.
266 NTPSnippet::PtrVector discarded_snippets_; 283 NTPSnippet::PtrVector discarded_snippets_;
267 284
268 // The ISO 639-1 code of the language used by the application. 285 // The ISO 639-1 code of the language used by the application.
269 const std::string application_language_code_; 286 const std::string application_language_code_;
270 287
271 // The observers. 288 // The observers.
289 // TODO(pke): This is an old kind of observers that will be removed.
272 base::ObserverList<NTPSnippetsServiceObserver> observers_; 290 base::ObserverList<NTPSnippetsServiceObserver> observers_;
273 291
292 // The observer to deliver data to.
293 Observer* observer_;
294
274 // Scheduler for fetching snippets. Not owned. 295 // Scheduler for fetching snippets. Not owned.
275 NTPSnippetsScheduler* scheduler_; 296 NTPSnippetsScheduler* scheduler_;
276 297
277 // The subscription to the SuggestionsService. When the suggestions change, 298 // The subscription to the SuggestionsService. When the suggestions change,
278 // SuggestionsService will call |OnSuggestionsChanged|, which triggers an 299 // SuggestionsService will call |OnSuggestionsChanged|, which triggers an
279 // update to the set of snippets. 300 // update to the set of snippets.
280 using SuggestionsSubscription = 301 using SuggestionsSubscription =
281 suggestions::SuggestionsService::ResponseCallbackList::Subscription; 302 suggestions::SuggestionsService::ResponseCallbackList::Subscription;
282 std::unique_ptr<SuggestionsSubscription> suggestions_service_subscription_; 303 std::unique_ptr<SuggestionsSubscription> suggestions_service_subscription_;
283 304
(...skipping 12 matching lines...) Expand all
296 // The service that provides events and data about the signin and sync state. 317 // The service that provides events and data about the signin and sync state.
297 std::unique_ptr<NTPSnippetsStatusService> snippets_status_service_; 318 std::unique_ptr<NTPSnippetsStatusService> snippets_status_service_;
298 319
299 // Set to true if FetchSnippets is called before the database has been loaded. 320 // Set to true if FetchSnippets is called before the database has been loaded.
300 // The fetch will be executed after the database load finishes. 321 // The fetch will be executed after the database load finishes.
301 bool fetch_after_load_; 322 bool fetch_after_load_;
302 323
303 DISALLOW_COPY_AND_ASSIGN(NTPSnippetsService); 324 DISALLOW_COPY_AND_ASSIGN(NTPSnippetsService);
304 }; 325 };
305 326
327 // TODO(pke): Remove this when snippets internals don't access this service
328 // directly anymore.
306 class NTPSnippetsServiceObserver { 329 class NTPSnippetsServiceObserver {
307 public: 330 public:
308 // Sent every time the service loads a new set of data. 331 // Sent every time the service loads a new set of data.
309 virtual void NTPSnippetsServiceLoaded() = 0; 332 virtual void NTPSnippetsServiceLoaded() = 0;
310 333
311 // Sent when the service is shutting down. 334 // Sent when the service is shutting down.
312 virtual void NTPSnippetsServiceShutdown() = 0; 335 virtual void NTPSnippetsServiceShutdown() = 0;
313 336
314 // Sent when the state of the service is changing. Something changed in its 337 // Sent when the state of the service is changing. Something changed in its
315 // dependencies so it's notifying observers about incoming data changes. 338 // dependencies so it's notifying observers about incoming data changes.
316 // If the service might be enabled, DisabledReason::NONE will be provided. 339 // If the service might be enabled, DisabledReason::NONE will be provided.
317 virtual void NTPSnippetsServiceDisabledReasonChanged(DisabledReason) = 0; 340 virtual void NTPSnippetsServiceDisabledReasonChanged(DisabledReason) = 0;
318 341
319 protected: 342 protected:
320 virtual ~NTPSnippetsServiceObserver() {} 343 virtual ~NTPSnippetsServiceObserver() {}
321 }; 344 };
322 345
323 } // namespace ntp_snippets 346 } // namespace ntp_snippets
324 347
325 #endif // COMPONENTS_NTP_SNIPPETS_NTP_SNIPPETS_SERVICE_H_ 348 #endif // COMPONENTS_NTP_SNIPPETS_NTP_SNIPPETS_SERVICE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698