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 InvalidationVersionMap& initial_max_invalidation_versions, | 22 const InvalidationStateMap& initial_invalidation_state_map, |
23 const std::string& initial_invalidation_state, | 23 const std::string& initial_invalidation_state, |
24 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker, | 24 const WeakHandle<InvalidationStateTracker>& invalidation_state_tracker, |
25 const std::string& client_info) | 25 const std::string& client_info) |
26 : state_(STOPPED), | 26 : state_(STOPPED), |
27 initial_max_invalidation_versions_(initial_max_invalidation_versions), | 27 initial_invalidation_state_map_(initial_invalidation_state_map), |
28 invalidation_state_tracker_(invalidation_state_tracker), | 28 invalidation_state_tracker_(invalidation_state_tracker), |
29 client_info_(client_info), | 29 client_info_(client_info), |
30 invalidation_state_(initial_invalidation_state), | 30 invalidation_state_(initial_invalidation_state), |
31 invalidation_listener_(push_client.Pass()) { | 31 invalidation_listener_(push_client.Pass()) { |
32 } | 32 } |
33 | 33 |
34 InvalidationNotifier::~InvalidationNotifier() { | 34 InvalidationNotifier::~InvalidationNotifier() { |
35 DCHECK(CalledOnValidThread()); | 35 DCHECK(CalledOnValidThread()); |
36 } | 36 } |
37 | 37 |
38 void InvalidationNotifier::RegisterHandler(InvalidationHandler* handler) { | 38 void InvalidationNotifier::RegisterHandler(InvalidationHandler* handler) { |
39 DCHECK(CalledOnValidThread()); | 39 DCHECK(CalledOnValidThread()); |
40 registrar_.RegisterHandler(handler); | 40 registrar_.RegisterHandler(handler); |
41 } | 41 } |
42 | 42 |
43 void InvalidationNotifier::UpdateRegisteredIds(InvalidationHandler* handler, | 43 void InvalidationNotifier::UpdateRegisteredIds(InvalidationHandler* handler, |
44 const ObjectIdSet& ids) { | 44 const ObjectIdSet& ids) { |
45 DCHECK(CalledOnValidThread()); | 45 DCHECK(CalledOnValidThread()); |
46 registrar_.UpdateRegisteredIds(handler, ids); | 46 registrar_.UpdateRegisteredIds(handler, ids); |
47 invalidation_listener_.UpdateRegisteredIds(registrar_.GetAllRegisteredIds()); | 47 invalidation_listener_.UpdateRegisteredIds(registrar_.GetAllRegisteredIds()); |
48 } | 48 } |
49 | 49 |
50 void InvalidationNotifier::UnregisterHandler(InvalidationHandler* handler) { | 50 void InvalidationNotifier::UnregisterHandler(InvalidationHandler* handler) { |
51 DCHECK(CalledOnValidThread()); | 51 DCHECK(CalledOnValidThread()); |
52 registrar_.UnregisterHandler(handler); | 52 registrar_.UnregisterHandler(handler); |
53 } | 53 } |
54 | 54 |
| 55 void InvalidationNotifier::Acknowledge(const invalidation::ObjectId& id, |
| 56 const AckHandle& ack_handle) { |
| 57 DCHECK(CalledOnValidThread()); |
| 58 invalidation_listener_.Acknowledge(id, ack_handle); |
| 59 } |
| 60 |
55 InvalidatorState InvalidationNotifier::GetInvalidatorState() const { | 61 InvalidatorState InvalidationNotifier::GetInvalidatorState() const { |
56 DCHECK(CalledOnValidThread()); | 62 DCHECK(CalledOnValidThread()); |
57 return registrar_.GetInvalidatorState(); | 63 return registrar_.GetInvalidatorState(); |
58 } | 64 } |
59 | 65 |
60 void InvalidationNotifier::SetUniqueId(const std::string& unique_id) { | 66 void InvalidationNotifier::SetUniqueId(const std::string& unique_id) { |
61 DCHECK(CalledOnValidThread()); | 67 DCHECK(CalledOnValidThread()); |
62 client_id_ = unique_id; | 68 client_id_ = unique_id; |
63 DVLOG(1) << "Setting unique ID to " << unique_id; | 69 DVLOG(1) << "Setting unique ID to " << unique_id; |
64 CHECK(!client_id_.empty()); | 70 CHECK(!client_id_.empty()); |
(...skipping 18 matching lines...) Expand all Loading... |
83 UMA_HISTOGRAM_BOOLEAN("InvalidationNotifier.UsefulSetState", false); | 89 UMA_HISTOGRAM_BOOLEAN("InvalidationNotifier.UsefulSetState", false); |
84 } | 90 } |
85 } | 91 } |
86 | 92 |
87 void InvalidationNotifier::UpdateCredentials( | 93 void InvalidationNotifier::UpdateCredentials( |
88 const std::string& email, const std::string& token) { | 94 const std::string& email, const std::string& token) { |
89 if (state_ == STOPPED) { | 95 if (state_ == STOPPED) { |
90 invalidation_listener_.Start( | 96 invalidation_listener_.Start( |
91 base::Bind(&invalidation::CreateInvalidationClient), | 97 base::Bind(&invalidation::CreateInvalidationClient), |
92 client_id_, client_info_, invalidation_state_, | 98 client_id_, client_info_, invalidation_state_, |
93 initial_max_invalidation_versions_, | 99 initial_invalidation_state_map_, |
94 invalidation_state_tracker_, | 100 invalidation_state_tracker_, |
95 this); | 101 this); |
96 invalidation_state_.clear(); | 102 invalidation_state_.clear(); |
97 state_ = STARTED; | 103 state_ = STARTED; |
98 } | 104 } |
99 invalidation_listener_.UpdateCredentials(email, token); | 105 invalidation_listener_.UpdateCredentials(email, token); |
100 } | 106 } |
101 | 107 |
102 void InvalidationNotifier::SendInvalidation( | 108 void InvalidationNotifier::SendInvalidation( |
103 const ObjectIdStateMap& id_state_map) { | 109 const ObjectIdStateMap& id_state_map) { |
104 DCHECK(CalledOnValidThread()); | 110 DCHECK(CalledOnValidThread()); |
105 // Do nothing. | 111 // Do nothing. |
106 } | 112 } |
107 | 113 |
108 void InvalidationNotifier::OnInvalidate(const ObjectIdStateMap& id_state_map) { | 114 void InvalidationNotifier::OnInvalidate(const ObjectIdStateMap& id_state_map) { |
109 DCHECK(CalledOnValidThread()); | 115 DCHECK(CalledOnValidThread()); |
110 registrar_.DispatchInvalidationsToHandlers(id_state_map, REMOTE_INVALIDATION); | 116 registrar_.DispatchInvalidationsToHandlers(id_state_map, REMOTE_INVALIDATION); |
111 } | 117 } |
112 | 118 |
113 void InvalidationNotifier::OnInvalidatorStateChange(InvalidatorState state) { | 119 void InvalidationNotifier::OnInvalidatorStateChange(InvalidatorState state) { |
114 DCHECK(CalledOnValidThread()); | 120 DCHECK(CalledOnValidThread()); |
115 registrar_.UpdateInvalidatorState(state); | 121 registrar_.UpdateInvalidatorState(state); |
116 } | 122 } |
117 | 123 |
118 } // namespace syncer | 124 } // namespace syncer |
OLD | NEW |