OLD | NEW |
---|---|
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 Loading... | |
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 |
OLD | NEW |