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