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

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

Issue 12092091: Separate sync and invalidation client IDs (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 10 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_(push_client.Pass()) { 33 invalidation_listener_(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 10 matching lines...) Expand all
50 void InvalidationNotifier::UnregisterHandler(InvalidationHandler* handler) { 52 void InvalidationNotifier::UnregisterHandler(InvalidationHandler* handler) {
51 DCHECK(CalledOnValidThread()); 53 DCHECK(CalledOnValidThread());
52 registrar_.UnregisterHandler(handler); 54 registrar_.UnregisterHandler(handler);
53 } 55 }
54 56
55 InvalidatorState InvalidationNotifier::GetInvalidatorState() const { 57 InvalidatorState InvalidationNotifier::GetInvalidatorState() const {
56 DCHECK(CalledOnValidThread()); 58 DCHECK(CalledOnValidThread());
57 return registrar_.GetInvalidatorState(); 59 return registrar_.GetInvalidatorState();
58 } 60 }
59 61
60 void InvalidationNotifier::SetUniqueId(const std::string& unique_id) {
61 DCHECK(CalledOnValidThread());
62 client_id_ = unique_id;
63 DVLOG(1) << "Setting unique ID to " << unique_id;
64 CHECK(!client_id_.empty());
65 }
66
67 void InvalidationNotifier::UpdateCredentials( 62 void InvalidationNotifier::UpdateCredentials(
68 const std::string& email, const std::string& token) { 63 const std::string& email, const std::string& token) {
69 if (state_ == STOPPED) { 64 if (state_ == STOPPED) {
70 invalidation_listener_.Start( 65 invalidation_listener_.Start(
71 base::Bind(&invalidation::CreateInvalidationClient), 66 base::Bind(&invalidation::CreateInvalidationClient),
72 client_id_, client_info_, invalidation_bootstrap_data_, 67 invalidator_client_id_, client_info_, invalidation_bootstrap_data_,
73 initial_invalidation_state_map_, 68 initial_invalidation_state_map_,
74 invalidation_state_tracker_, 69 invalidation_state_tracker_,
75 this); 70 this);
76 state_ = STARTED; 71 state_ = STARTED;
77 } 72 }
78 invalidation_listener_.UpdateCredentials(email, token); 73 invalidation_listener_.UpdateCredentials(email, token);
79 } 74 }
80 75
81 void InvalidationNotifier::SendInvalidation( 76 void InvalidationNotifier::SendInvalidation(
82 const ObjectIdInvalidationMap& invalidation_map) { 77 const ObjectIdInvalidationMap& invalidation_map) {
83 DCHECK(CalledOnValidThread()); 78 DCHECK(CalledOnValidThread());
84 // Do nothing. 79 // Do nothing.
85 } 80 }
86 81
87 void InvalidationNotifier::OnInvalidate( 82 void InvalidationNotifier::OnInvalidate(
88 const ObjectIdInvalidationMap& invalidation_map) { 83 const ObjectIdInvalidationMap& invalidation_map) {
89 DCHECK(CalledOnValidThread()); 84 DCHECK(CalledOnValidThread());
90 registrar_.DispatchInvalidationsToHandlers(invalidation_map, 85 registrar_.DispatchInvalidationsToHandlers(invalidation_map,
91 REMOTE_INVALIDATION); 86 REMOTE_INVALIDATION);
92 } 87 }
93 88
94 void InvalidationNotifier::OnInvalidatorStateChange(InvalidatorState state) { 89 void InvalidationNotifier::OnInvalidatorStateChange(InvalidatorState state) {
95 DCHECK(CalledOnValidThread()); 90 DCHECK(CalledOnValidThread());
96 registrar_.UpdateInvalidatorState(state); 91 registrar_.UpdateInvalidatorState(state);
97 } 92 }
98 93
99 } // namespace syncer 94 } // 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