 Chromium Code Reviews
 Chromium Code Reviews Issue 2925053003:
  [NTP::Push] Adding BreakingNewsSuggestionsProvider  (Closed)
    
  
    Issue 2925053003:
  [NTP::Push] Adding BreakingNewsSuggestionsProvider  (Closed) 
  | Index: components/ntp_snippets/breaking_news/breaking_news_suggestions_provider.h | 
| diff --git a/components/ntp_snippets/breaking_news/breaking_news_suggestions_provider.h b/components/ntp_snippets/breaking_news/breaking_news_suggestions_provider.h | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..671803f01770a290168539470aa03d16b576f169 | 
| --- /dev/null | 
| +++ b/components/ntp_snippets/breaking_news/breaking_news_suggestions_provider.h | 
| @@ -0,0 +1,62 @@ | 
| +// Copyright 2017 The Chromium Authors. All rights reserved. | 
| +// Use of this source code is governed by a BSD-style license that can be | 
| +// found in the LICENSE file. | 
| + | 
| +#ifndef COMPONENTS_NTP_SNIPPETS_BREAKING_NEWS_BREAKING_NEWS_SUGGESTIONS_PROVIDER_H_ | 
| +#define COMPONENTS_NTP_SNIPPETS_BREAKING_NEWS_BREAKING_NEWS_SUGGESTIONS_PROVIDER_H_ | 
| + | 
| +#include "components/ntp_snippets/category.h" | 
| +#include "components/ntp_snippets/content_suggestions_provider.h" | 
| +#include "components/prefs/pref_registry_simple.h" | 
| + | 
| +namespace ntp_snippets { | 
| +class ContentSuggestionsGCMAppHandler; | 
| +} | 
| + | 
| +namespace ntp_snippets { | 
| + | 
| +// Receives breaking news suggestions via GCM push messages, stores them and | 
| +// provides them as content suggestions. | 
| +class BreakingNewsSuggestionsProvider : public ContentSuggestionsProvider { | 
| + public: | 
| + BreakingNewsSuggestionsProvider( | 
| + ContentSuggestionsProvider::Observer* observer, | 
| + std::unique_ptr<ContentSuggestionsGCMAppHandler> gcm_app_handler); | 
| + virtual ~BreakingNewsSuggestionsProvider(); | 
| + | 
| + // Starts the underlying GCM handler and registers the callback when GCM | 
| + // receives a message. | 
| + void Start(); | 
| + | 
| + // Callback called from the GCM handler when new content has been pushed from | 
| + // the server. | 
| + void OnNewContentSuggestion(const std::string& content); | 
| 
sfiera
2017/06/08 13:37:15
Could be private?
Could take a base::Value (JSON,
 
mamir
2017/06/08 15:20:06
Done.
 | 
| + | 
| + private: | 
| + // ContentSuggestionsProvider implementation. | 
| + CategoryStatus GetCategoryStatus(Category category) override; | 
| + CategoryInfo GetCategoryInfo(Category category) override; | 
| + void DismissSuggestion(const ContentSuggestion::ID& suggestion_id) override; | 
| + void FetchSuggestionImage(const ContentSuggestion::ID& suggestion_id, | 
| + const ImageFetchedCallback& callback) override; | 
| + void Fetch(const Category& category, | 
| + const std::set<std::string>& known_suggestion_ids, | 
| + const FetchDoneCallback& callback) override; | 
| + void ClearHistory( | 
| + base::Time begin, | 
| + base::Time end, | 
| + const base::Callback<bool(const GURL& url)>& filter) override; | 
| + void ClearCachedSuggestions(Category category) override; | 
| + void GetDismissedSuggestionsForDebugging( | 
| + Category category, | 
| + const DismissedSuggestionsCallback& callback) override; | 
| + void ClearDismissedSuggestionsForDebugging(Category category) override; | 
| + | 
| + std::unique_ptr<ContentSuggestionsGCMAppHandler> gcm_app_handler_; | 
| + const Category provided_category_; | 
| + CategoryStatus category_status_; | 
| +}; | 
| 
sfiera
2017/06/08 13:37:15
Oh, should probably have a DISALLOW_COPY_AND_ASSIG
 
mamir
2017/06/08 15:20:06
Done.
 | 
| + | 
| +} // namespace ntp_snippets | 
| + | 
| +#endif // COMPONENTS_NTP_SNIPPETS_BREAKING_NEWS_BREAKING_NEWS_SUGGESTIONS_PROVIDER_H_ |