| 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 |