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

Side by Side Diff: components/ntp_snippets/breaking_news/subscription_manager.cc

Issue 2922543002: [NTP::Push] Add Content Suggestions GCM App Handler (Closed)
Patch Set: peter@ comments. Created 3 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
OLDNEW
1 // Copyright 2017 The Chromium Authors. All rights reserved. 1 // Copyright 2017 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 #include "components/ntp_snippets/breaking_news/subscription_manager.h" 5 #include "components/ntp_snippets/breaking_news/subscription_manager.h"
6 #include "base/bind.h" 6 #include "base/bind.h"
7 #include "components/ntp_snippets/breaking_news/subscription_json_request.h" 7 #include "components/ntp_snippets/breaking_news/subscription_json_request.h"
8 #include "components/ntp_snippets/pref_names.h" 8 #include "components/ntp_snippets/pref_names.h"
9 #include "components/prefs/pref_service.h" 9 #include "components/prefs/pref_service.h"
10 10
11 namespace ntp_snippets { 11 namespace ntp_snippets {
12 12
13 using internal::SubscriptionJsonRequest; 13 using internal::SubscriptionJsonRequest;
14 14
15 SubscriptionManager::SubscriptionManager( 15 SubscriptionManager::SubscriptionManager(
16 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter, 16 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter,
17 PrefService* pref_service, 17 PrefService* pref_service,
18 const GURL& subscribe_url) 18 const GURL& subscribe_url,
19 const GURL& unsubscribe_url)
19 : url_request_context_getter_(std::move(url_request_context_getter)), 20 : url_request_context_getter_(std::move(url_request_context_getter)),
20 pref_service_(pref_service), 21 pref_service_(pref_service),
21 subscribe_url_(subscribe_url) {} 22 subscribe_url_(subscribe_url),
23 unsubscribe_url_(unsubscribe_url) {}
22 24
23 SubscriptionManager::~SubscriptionManager() = default; 25 SubscriptionManager::~SubscriptionManager() = default;
24 26
25 void SubscriptionManager::Subscribe(const std::string& token) { 27 void SubscriptionManager::Subscribe(const std::string& token) {
26 DCHECK(!subscription_request_); 28 DCHECK(!subscription_request_);
27 subscription_token_ = token; 29 subscription_token_ = token;
28 SubscriptionJsonRequest::Builder builder; 30 SubscriptionJsonRequest::Builder builder;
29 builder.SetToken(token) 31 builder.SetToken(token)
30 .SetUrlRequestContextGetter(url_request_context_getter_) 32 .SetUrlRequestContextGetter(url_request_context_getter_)
31 .SetUrl(subscribe_url_); 33 .SetUrl(subscribe_url_);
(...skipping 16 matching lines...) Expand all
48 ntp_snippets::prefs::kContentSuggestionsSubscriptionDataToken, 50 ntp_snippets::prefs::kContentSuggestionsSubscriptionDataToken,
49 subscription_token_); 51 subscription_token_);
50 break; 52 break;
51 default: 53 default:
52 // TODO(mamir): handle failure. 54 // TODO(mamir): handle failure.
53 break; 55 break;
54 } 56 }
55 } 57 }
56 58
57 void SubscriptionManager::Unsubscribe(const std::string& token) { 59 void SubscriptionManager::Unsubscribe(const std::string& token) {
58 // TODO(mamir): Implement. 60 DCHECK(!unsubscription_request_);
jkrcal 2017/06/09 09:10:10 I find this (and above) a bit subtle to use: It is
mamir 2017/06/09 13:52:58 As discussed off-review, I have added 3 methods Ca
61 unsubscription_token_ = token;
62 SubscriptionJsonRequest::Builder builder;
63 builder.SetToken(token)
64 .SetUrlRequestContextGetter(url_request_context_getter_)
65 .SetUrl(unsubscribe_url_);
66
67 unsubscription_request_ = builder.Build();
68 unsubscription_request_->Start(base::BindOnce(
69 &SubscriptionManager::DidUnsubscribe, base::Unretained(this)));
70 }
71
72 void SubscriptionManager::DidUnsubscribe(const ntp_snippets::Status& status) {
73 unsubscription_request_.reset();
74
75 switch (status.code) {
76 case ntp_snippets::StatusCode::SUCCESS:
77 // In case of successful unsubscription, clear the previously stored data.
78 // TODO(mamir): clear stored region and language.
79 pref_service_->ClearPref(
80 ntp_snippets::prefs::kContentSuggestionsSubscriptionDataToken);
81 break;
82 default:
83 // TODO(mamir): handle failure.
84 break;
85 }
59 } 86 }
60 87
61 void SubscriptionManager::RegisterProfilePrefs(PrefRegistrySimple* registry) { 88 void SubscriptionManager::RegisterProfilePrefs(PrefRegistrySimple* registry) {
62 registry->RegisterStringPref(prefs::kContentSuggestionsSubscriptionDataToken, 89 registry->RegisterStringPref(prefs::kContentSuggestionsSubscriptionDataToken,
63 std::string()); 90 std::string());
64 } 91 }
65 } // namespace ntp_snippets 92 } // namespace ntp_snippets
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698