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

Side by Side Diff: components/invalidation/invalidation_notifier.cc

Issue 446223002: Remove WeakHandle from components/invalidation (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Review fixes Created 6 years, 4 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 | Annotate | Revision Log
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/invalidation/invalidation_notifier.h" 5 #include "components/invalidation/invalidation_notifier.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/message_loop/message_loop_proxy.h" 9 #include "base/message_loop/message_loop_proxy.h"
10 #include "base/metrics/histogram.h" 10 #include "base/metrics/histogram.h"
11 #include "components/invalidation/invalidation_handler.h" 11 #include "components/invalidation/invalidation_handler.h"
12 #include "google/cacheinvalidation/include/invalidation-client-factory.h" 12 #include "google/cacheinvalidation/include/invalidation-client-factory.h"
13 #include "jingle/notifier/listener/push_client.h" 13 #include "jingle/notifier/listener/push_client.h"
14 #include "net/url_request/url_request_context.h" 14 #include "net/url_request/url_request_context.h"
15 #include "talk/xmpp/jid.h" 15 #include "talk/xmpp/jid.h"
16 #include "talk/xmpp/xmppclientsettings.h" 16 #include "talk/xmpp/xmppclientsettings.h"
17 17
18 namespace syncer { 18 namespace syncer {
19 19
20 InvalidationNotifier::InvalidationNotifier( 20 InvalidationNotifier::InvalidationNotifier(
21 scoped_ptr<SyncNetworkChannel> network_channel, 21 scoped_ptr<SyncNetworkChannel> network_channel,
22 const std::string& invalidator_client_id, 22 const std::string& invalidator_client_id,
23 const UnackedInvalidationsMap& saved_invalidations, 23 const UnackedInvalidationsMap& saved_invalidations,
24 const std::string& invalidation_bootstrap_data, 24 const std::string& invalidation_bootstrap_data,
25 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker, 25 const base::WeakPtr<InvalidationStateTracker>& invalidation_state_tracker,
26 scoped_refptr<base::SingleThreadTaskRunner>
27 invalidation_state_tracker_task_runner,
26 const std::string& client_info) 28 const std::string& client_info)
27 : state_(STOPPED), 29 : state_(STOPPED),
28 saved_invalidations_(saved_invalidations), 30 saved_invalidations_(saved_invalidations),
29 invalidation_state_tracker_(invalidation_state_tracker), 31 invalidation_state_tracker_(invalidation_state_tracker),
32 invalidation_state_tracker_task_runner_(
33 invalidation_state_tracker_task_runner),
30 client_info_(client_info), 34 client_info_(client_info),
31 invalidator_client_id_(invalidator_client_id), 35 invalidator_client_id_(invalidator_client_id),
32 invalidation_bootstrap_data_(invalidation_bootstrap_data), 36 invalidation_bootstrap_data_(invalidation_bootstrap_data),
33 invalidation_listener_(network_channel.Pass()) { 37 invalidation_listener_(network_channel.Pass()) {
34 } 38 }
35 39
36 InvalidationNotifier::~InvalidationNotifier() { 40 InvalidationNotifier::~InvalidationNotifier() {
37 DCHECK(CalledOnValidThread()); 41 DCHECK(CalledOnValidThread());
38 } 42 }
39 43
(...skipping 17 matching lines...) Expand all
57 InvalidatorState InvalidationNotifier::GetInvalidatorState() const { 61 InvalidatorState InvalidationNotifier::GetInvalidatorState() const {
58 DCHECK(CalledOnValidThread()); 62 DCHECK(CalledOnValidThread());
59 return registrar_.GetInvalidatorState(); 63 return registrar_.GetInvalidatorState();
60 } 64 }
61 65
62 void InvalidationNotifier::UpdateCredentials( 66 void InvalidationNotifier::UpdateCredentials(
63 const std::string& email, const std::string& token) { 67 const std::string& email, const std::string& token) {
64 if (state_ == STOPPED) { 68 if (state_ == STOPPED) {
65 invalidation_listener_.Start( 69 invalidation_listener_.Start(
66 base::Bind(&invalidation::CreateInvalidationClient), 70 base::Bind(&invalidation::CreateInvalidationClient),
67 invalidator_client_id_, client_info_, invalidation_bootstrap_data_, 71 invalidator_client_id_,
72 client_info_,
73 invalidation_bootstrap_data_,
68 saved_invalidations_, 74 saved_invalidations_,
69 invalidation_state_tracker_, 75 invalidation_state_tracker_,
76 invalidation_state_tracker_task_runner_,
70 this); 77 this);
71 state_ = STARTED; 78 state_ = STARTED;
72 } 79 }
73 invalidation_listener_.UpdateCredentials(email, token); 80 invalidation_listener_.UpdateCredentials(email, token);
74 } 81 }
75 82
76 void InvalidationNotifier::RequestDetailedStatus( 83 void InvalidationNotifier::RequestDetailedStatus(
77 base::Callback<void(const base::DictionaryValue&)> callback) const { 84 base::Callback<void(const base::DictionaryValue&)> callback) const {
78 DCHECK(CalledOnValidThread()); 85 DCHECK(CalledOnValidThread());
79 invalidation_listener_.RequestDetailedStatus(callback); 86 invalidation_listener_.RequestDetailedStatus(callback);
80 } 87 }
81 88
82 void InvalidationNotifier::OnInvalidate( 89 void InvalidationNotifier::OnInvalidate(
83 const ObjectIdInvalidationMap& invalidation_map) { 90 const ObjectIdInvalidationMap& invalidation_map) {
84 DCHECK(CalledOnValidThread()); 91 DCHECK(CalledOnValidThread());
85 registrar_.DispatchInvalidationsToHandlers(invalidation_map); 92 registrar_.DispatchInvalidationsToHandlers(invalidation_map);
86 } 93 }
87 94
88 void InvalidationNotifier::OnInvalidatorStateChange(InvalidatorState state) { 95 void InvalidationNotifier::OnInvalidatorStateChange(InvalidatorState state) {
89 DCHECK(CalledOnValidThread()); 96 DCHECK(CalledOnValidThread());
90 registrar_.UpdateInvalidatorState(state); 97 registrar_.UpdateInvalidatorState(state);
91 } 98 }
92 99
93 } // namespace syncer 100 } // namespace syncer
OLDNEW
« no previous file with comments | « components/invalidation/invalidation_notifier.h ('k') | components/invalidation/invalidation_notifier_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698