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

Side by Side Diff: sync/notifier/invalidation_notifier.cc

Issue 12847003: Separate invalidator and sync client ID (part 2/2) (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix sync_listen_notifications utility Created 7 years, 9 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
« no previous file with comments | « sync/notifier/invalidation_notifier.h ('k') | sync/notifier/invalidation_notifier_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "sync/notifier/invalidation_notifier.h" 5 #include "sync/notifier/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_proxy.h" 9 #include "base/message_loop_proxy.h"
10 #include "base/metrics/histogram.h" 10 #include "base/metrics/histogram.h"
11 #include "google/cacheinvalidation/include/invalidation-client-factory.h" 11 #include "google/cacheinvalidation/include/invalidation-client-factory.h"
12 #include "jingle/notifier/listener/push_client.h" 12 #include "jingle/notifier/listener/push_client.h"
13 #include "net/url_request/url_request_context.h" 13 #include "net/url_request/url_request_context.h"
14 #include "sync/notifier/invalidation_handler.h" 14 #include "sync/notifier/invalidation_handler.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<notifier::PushClient> push_client, 21 scoped_ptr<notifier::PushClient> push_client,
22 const std::string& invalidator_client_id,
22 const InvalidationStateMap& initial_invalidation_state_map, 23 const InvalidationStateMap& initial_invalidation_state_map,
23 const std::string& invalidation_bootstrap_data, 24 const std::string& invalidation_bootstrap_data,
24 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker, 25 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker,
25 const std::string& client_info) 26 const std::string& client_info)
26 : state_(STOPPED), 27 : state_(STOPPED),
27 initial_invalidation_state_map_(initial_invalidation_state_map), 28 initial_invalidation_state_map_(initial_invalidation_state_map),
28 invalidation_state_tracker_(invalidation_state_tracker), 29 invalidation_state_tracker_(invalidation_state_tracker),
29 client_info_(client_info), 30 client_info_(client_info),
31 invalidator_client_id_(invalidator_client_id),
30 invalidation_bootstrap_data_(invalidation_bootstrap_data), 32 invalidation_bootstrap_data_(invalidation_bootstrap_data),
31 invalidation_listener_(&tick_clock_, push_client.Pass()) { 33 invalidation_listener_(&tick_clock_, push_client.Pass()) {
32 } 34 }
33 35
34 InvalidationNotifier::~InvalidationNotifier() { 36 InvalidationNotifier::~InvalidationNotifier() {
35 DCHECK(CalledOnValidThread()); 37 DCHECK(CalledOnValidThread());
36 } 38 }
37 39
38 void InvalidationNotifier::RegisterHandler(InvalidationHandler* handler) { 40 void InvalidationNotifier::RegisterHandler(InvalidationHandler* handler) {
39 DCHECK(CalledOnValidThread()); 41 DCHECK(CalledOnValidThread());
(...skipping 16 matching lines...) Expand all
56 const AckHandle& ack_handle) { 58 const AckHandle& ack_handle) {
57 DCHECK(CalledOnValidThread()); 59 DCHECK(CalledOnValidThread());
58 invalidation_listener_.Acknowledge(id, ack_handle); 60 invalidation_listener_.Acknowledge(id, ack_handle);
59 } 61 }
60 62
61 InvalidatorState InvalidationNotifier::GetInvalidatorState() const { 63 InvalidatorState InvalidationNotifier::GetInvalidatorState() const {
62 DCHECK(CalledOnValidThread()); 64 DCHECK(CalledOnValidThread());
63 return registrar_.GetInvalidatorState(); 65 return registrar_.GetInvalidatorState();
64 } 66 }
65 67
66 void InvalidationNotifier::SetUniqueId(const std::string& unique_id) {
67 DCHECK(CalledOnValidThread());
68 client_id_ = unique_id;
69 DVLOG(1) << "Setting unique ID to " << unique_id;
70 CHECK(!client_id_.empty());
71 }
72
73 void InvalidationNotifier::UpdateCredentials( 68 void InvalidationNotifier::UpdateCredentials(
74 const std::string& email, const std::string& token) { 69 const std::string& email, const std::string& token) {
75 if (state_ == STOPPED) { 70 if (state_ == STOPPED) {
76 invalidation_listener_.Start( 71 invalidation_listener_.Start(
77 base::Bind(&invalidation::CreateInvalidationClient), 72 base::Bind(&invalidation::CreateInvalidationClient),
78 client_id_, client_info_, invalidation_bootstrap_data_, 73 invalidator_client_id_, client_info_, invalidation_bootstrap_data_,
79 initial_invalidation_state_map_, 74 initial_invalidation_state_map_,
80 invalidation_state_tracker_, 75 invalidation_state_tracker_,
81 this); 76 this);
82 state_ = STARTED; 77 state_ = STARTED;
83 } 78 }
84 invalidation_listener_.UpdateCredentials(email, token); 79 invalidation_listener_.UpdateCredentials(email, token);
85 } 80 }
86 81
87 void InvalidationNotifier::SendInvalidation( 82 void InvalidationNotifier::SendInvalidation(
88 const ObjectIdInvalidationMap& invalidation_map) { 83 const ObjectIdInvalidationMap& invalidation_map) {
89 DCHECK(CalledOnValidThread()); 84 DCHECK(CalledOnValidThread());
90 // Do nothing. 85 // Do nothing.
91 } 86 }
92 87
93 void InvalidationNotifier::OnInvalidate( 88 void InvalidationNotifier::OnInvalidate(
94 const ObjectIdInvalidationMap& invalidation_map) { 89 const ObjectIdInvalidationMap& invalidation_map) {
95 DCHECK(CalledOnValidThread()); 90 DCHECK(CalledOnValidThread());
96 registrar_.DispatchInvalidationsToHandlers(invalidation_map); 91 registrar_.DispatchInvalidationsToHandlers(invalidation_map);
97 } 92 }
98 93
99 void InvalidationNotifier::OnInvalidatorStateChange(InvalidatorState state) { 94 void InvalidationNotifier::OnInvalidatorStateChange(InvalidatorState state) {
100 DCHECK(CalledOnValidThread()); 95 DCHECK(CalledOnValidThread());
101 registrar_.UpdateInvalidatorState(state); 96 registrar_.UpdateInvalidatorState(state);
102 } 97 }
103 98
104 } // namespace syncer 99 } // namespace syncer
OLDNEW
« no previous file with comments | « sync/notifier/invalidation_notifier.h ('k') | sync/notifier/invalidation_notifier_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698