OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 "chrome/browser/invalidation/ticl_invalidation_service.h" | 5 #include "chrome/browser/invalidation/ticl_invalidation_service.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/metrics/histogram.h" | 8 #include "base/metrics/histogram.h" |
9 #include "chrome/browser/invalidation/gcm_network_channel_delegate_impl.h" | 9 #include "chrome/browser/invalidation/gcm_invalidation_bridge.h" |
10 #include "chrome/browser/invalidation/invalidation_logger.h" | 10 #include "chrome/browser/invalidation/invalidation_logger.h" |
11 #include "chrome/browser/invalidation/invalidation_service_util.h" | 11 #include "chrome/browser/invalidation/invalidation_service_util.h" |
12 #include "chrome/browser/profiles/profile.h" | 12 #include "chrome/browser/profiles/profile.h" |
13 #include "chrome/browser/signin/about_signin_internals.h" | 13 #include "chrome/browser/signin/about_signin_internals.h" |
14 #include "chrome/browser/signin/about_signin_internals_factory.h" | 14 #include "chrome/browser/signin/about_signin_internals_factory.h" |
15 #include "chrome/browser/signin/profile_oauth2_token_service.h" | 15 #include "chrome/browser/signin/profile_oauth2_token_service.h" |
16 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h" | 16 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h" |
17 #include "google_apis/gaia/gaia_constants.h" | 17 #include "google_apis/gaia/gaia_constants.h" |
18 #include "sync/notifier/gcm_network_channel_delegate.h" | 18 #include "sync/notifier/gcm_network_channel_delegate.h" |
19 #include "sync/notifier/invalidation_util.h" | 19 #include "sync/notifier/invalidation_util.h" |
(...skipping 329 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
349 notifier::NotifierOptions options = | 349 notifier::NotifierOptions options = |
350 ParseNotifierOptions(*CommandLine::ForCurrentProcess()); | 350 ParseNotifierOptions(*CommandLine::ForCurrentProcess()); |
351 options.request_context_getter = profile_->GetRequestContext(); | 351 options.request_context_getter = profile_->GetRequestContext(); |
352 options.auth_mechanism = "X-OAUTH2"; | 352 options.auth_mechanism = "X-OAUTH2"; |
353 DCHECK_EQ(notifier::NOTIFICATION_SERVER, options.notification_method); | 353 DCHECK_EQ(notifier::NOTIFICATION_SERVER, options.notification_method); |
354 network_channel_creator = | 354 network_channel_creator = |
355 syncer::NonBlockingInvalidator::MakePushClientChannelCreator(options); | 355 syncer::NonBlockingInvalidator::MakePushClientChannelCreator(options); |
356 break; | 356 break; |
357 } | 357 } |
358 case GCM_NETWORK_CHANNEL: { | 358 case GCM_NETWORK_CHANNEL: { |
359 scoped_ptr<syncer::GCMNetworkChannelDelegate> delegate; | 359 gcm_invalidation_bridge_.reset(new GCMInvalidationBridge(profile_)); |
360 delegate.reset(new GCMNetworkChannelDelegateImpl(profile_)); | |
361 network_channel_creator = | 360 network_channel_creator = |
362 syncer::NonBlockingInvalidator::MakeGCMNetworkChannelCreator( | 361 syncer::NonBlockingInvalidator::MakeGCMNetworkChannelCreator( |
363 profile_->GetRequestContext(), | 362 profile_->GetRequestContext(), |
364 delegate.Pass()); | 363 gcm_invalidation_bridge_->CreateDelegate().Pass()); |
365 break; | 364 break; |
366 } | 365 } |
367 default: { | 366 default: { |
368 NOTREACHED(); | 367 NOTREACHED(); |
369 return; | 368 return; |
370 } | 369 } |
371 } | 370 } |
372 invalidator_.reset(new syncer::NonBlockingInvalidator( | 371 invalidator_.reset(new syncer::NonBlockingInvalidator( |
373 network_channel_creator, | 372 network_channel_creator, |
374 invalidator_storage_->GetInvalidatorClientId(), | 373 invalidator_storage_->GetInvalidatorClientId(), |
(...skipping 16 matching lines...) Expand all Loading... |
391 std::string email = signin_manager_->GetAuthenticatedUsername(); | 390 std::string email = signin_manager_->GetAuthenticatedUsername(); |
392 | 391 |
393 DCHECK(!email.empty()) << "Expected user to be signed in."; | 392 DCHECK(!email.empty()) << "Expected user to be signed in."; |
394 | 393 |
395 DVLOG(2) << "UpdateCredentials: " << email; | 394 DVLOG(2) << "UpdateCredentials: " << email; |
396 invalidator_->UpdateCredentials(email, access_token_); | 395 invalidator_->UpdateCredentials(email, access_token_); |
397 } | 396 } |
398 | 397 |
399 void TiclInvalidationService::StopInvalidator() { | 398 void TiclInvalidationService::StopInvalidator() { |
400 DCHECK(invalidator_); | 399 DCHECK(invalidator_); |
| 400 gcm_invalidation_bridge_.reset(); |
401 invalidator_->UnregisterHandler(this); | 401 invalidator_->UnregisterHandler(this); |
402 invalidator_.reset(); | 402 invalidator_.reset(); |
403 } | 403 } |
404 | 404 |
405 void TiclInvalidationService::Logout() { | 405 void TiclInvalidationService::Logout() { |
406 access_token_request_.reset(); | 406 access_token_request_.reset(); |
407 request_access_token_retry_timer_.Stop(); | 407 request_access_token_retry_timer_.Stop(); |
408 | 408 |
409 if (IsStarted()) { | 409 if (IsStarted()) { |
410 StopInvalidator(); | 410 StopInvalidator(); |
411 } | 411 } |
412 | 412 |
413 // This service always expects to have a valid invalidator storage. | 413 // This service always expects to have a valid invalidator storage. |
414 // So we must not only clear the old one, but also start a new one. | 414 // So we must not only clear the old one, but also start a new one. |
415 invalidator_storage_->Clear(); | 415 invalidator_storage_->Clear(); |
416 invalidator_storage_.reset(new InvalidatorStorage(profile_->GetPrefs())); | 416 invalidator_storage_.reset(new InvalidatorStorage(profile_->GetPrefs())); |
417 invalidator_storage_->SetInvalidatorClientId(GenerateInvalidatorClientId()); | 417 invalidator_storage_->SetInvalidatorClientId(GenerateInvalidatorClientId()); |
418 } | 418 } |
419 | 419 |
420 } // namespace invalidation | 420 } // namespace invalidation |
OLD | NEW |