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

Unified Diff: sync/notifier/invalidation_notifier.cc

Issue 10436013: [Sync] Make InvalidationNotifier use PushClient (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Sync to head Created 8 years, 7 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « sync/notifier/invalidation_notifier.h ('k') | sync/notifier/invalidation_notifier_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sync/notifier/invalidation_notifier.cc
diff --git a/sync/notifier/invalidation_notifier.cc b/sync/notifier/invalidation_notifier.cc
index 60f81cc644b2349a1c6418607bb2ea2193b7c12e..c86a50251244fd4b9239049830281efb30642895 100644
--- a/sync/notifier/invalidation_notifier.cc
+++ b/sync/notifier/invalidation_notifier.cc
@@ -6,8 +6,7 @@
#include "base/logging.h"
#include "base/message_loop_proxy.h"
-#include "jingle/notifier/base/const_communicator.h"
-#include "jingle/notifier/base/notifier_options_util.h"
+#include "jingle/notifier/listener/push_client.h"
#include "net/url_request/url_request_context.h"
#include "sync/notifier/sync_notifier_observer.h"
#include "sync/syncable/model_type_payload_map.h"
@@ -17,22 +16,16 @@
namespace sync_notifier {
InvalidationNotifier::InvalidationNotifier(
- const notifier::NotifierOptions& notifier_options,
+ scoped_ptr<notifier::PushClient> push_client,
const InvalidationVersionMap& initial_max_invalidation_versions,
const browser_sync::WeakHandle<InvalidationStateTracker>&
invalidation_state_tracker,
const std::string& client_info)
: state_(STOPPED),
- notifier_options_(notifier_options),
initial_max_invalidation_versions_(initial_max_invalidation_versions),
invalidation_state_tracker_(invalidation_state_tracker),
- client_info_(client_info) {
- DCHECK_EQ(notifier::NOTIFICATION_SERVER,
- notifier_options.notification_method);
- DCHECK(notifier_options_.request_context_getter);
- // TODO(akalin): Replace NonThreadSafe checks with IO thread checks.
- DCHECK(notifier_options_.request_context_getter->GetIOMessageLoopProxy()->
- BelongsToCurrentThread());
+ client_info_(client_info),
+ invalidation_client_(push_client.Pass()) {
}
InvalidationNotifier::~InvalidationNotifier() {
@@ -64,25 +57,16 @@ void InvalidationNotifier::SetState(const std::string& state) {
void InvalidationNotifier::UpdateCredentials(
const std::string& email, const std::string& token) {
- DCHECK(non_thread_safe_.CalledOnValidThread());
- CHECK(!invalidation_client_id_.empty());
- DVLOG(1) << "Updating credentials for " << email;
- buzz::XmppClientSettings xmpp_client_settings =
- notifier::MakeXmppClientSettings(notifier_options_, email, token);
- if (state_ >= CONNECTING) {
- login_->UpdateXmppSettings(xmpp_client_settings);
- } else {
- DVLOG(1) << "First time updating credentials: connecting";
- login_.reset(
- new notifier::Login(this,
- xmpp_client_settings,
- notifier_options_.request_context_getter,
- notifier::GetServerList(notifier_options_),
- notifier_options_.try_ssltcp_first,
- notifier_options_.auth_mechanism));
- login_->StartConnection();
- state_ = CONNECTING;
+ if (state_ == STOPPED) {
+ invalidation_client_.Start(
+ invalidation_client_id_, client_info_, invalidation_state_,
+ initial_max_invalidation_versions_,
+ invalidation_state_tracker_,
+ this, this);
+ invalidation_state_.clear();
+ state_ = STARTED;
}
+ invalidation_client_.UpdateCredentials(email, token);
}
void InvalidationNotifier::UpdateEnabledTypes(
@@ -98,31 +82,6 @@ void InvalidationNotifier::SendNotification(
// Do nothing.
}
-void InvalidationNotifier::OnConnect(
- base::WeakPtr<buzz::XmppTaskParentInterface> base_task) {
- DCHECK(non_thread_safe_.CalledOnValidThread());
- DVLOG(1) << "OnConnect";
- if (state_ >= STARTED) {
- invalidation_client_.ChangeBaseTask(base_task);
- } else {
- DVLOG(1) << "First time connecting: starting invalidation client with id "
- << invalidation_client_id_ << " and client info "
- << client_info_;
- invalidation_client_.Start(
- invalidation_client_id_, client_info_, invalidation_state_,
- initial_max_invalidation_versions_,
- invalidation_state_tracker_,
- this, this, base_task);
- invalidation_state_.clear();
- state_ = STARTED;
- }
-}
-
-void InvalidationNotifier::OnDisconnect() {
- DCHECK(non_thread_safe_.CalledOnValidThread());
- DVLOG(1) << "OnDisconnect";
-}
-
void InvalidationNotifier::OnInvalidate(
const syncable::ModelTypePayloadMap& type_payloads) {
DCHECK(non_thread_safe_.CalledOnValidThread());
« 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