| 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 #ifndef CHROME_BROWSER_SYNC_GLUE_SYNC_BACKEND_HOST_H_ | 5 #ifndef CHROME_BROWSER_SYNC_GLUE_SYNC_BACKEND_HOST_H_ |
| 6 #define CHROME_BROWSER_SYNC_GLUE_SYNC_BACKEND_HOST_H_ | 6 #define CHROME_BROWSER_SYNC_GLUE_SYNC_BACKEND_HOST_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| 11 #include "base/callback.h" | 11 #include "base/callback.h" |
| 12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
| 13 #include "base/memory/ref_counted.h" | 13 #include "base/memory/ref_counted.h" |
| 14 #include "base/memory/scoped_ptr.h" | 14 #include "base/memory/scoped_ptr.h" |
| 15 #include "base/memory/weak_ptr.h" | 15 #include "base/memory/weak_ptr.h" |
| 16 #include "base/threading/thread.h" | 16 #include "base/threading/thread.h" |
| 17 #include "chrome/browser/sync/glue/backend_data_type_configurer.h" | 17 #include "chrome/browser/sync/glue/backend_data_type_configurer.h" |
| 18 #include "chrome/browser/sync/glue/chrome_extensions_activity_monitor.h" | 18 #include "chrome/browser/sync/glue/chrome_extensions_activity_monitor.h" |
| 19 #include "chrome/common/net/gaia/google_service_auth_error.h" | 19 #include "chrome/common/net/gaia/google_service_auth_error.h" |
| 20 #include "googleurl/src/gurl.h" | 20 #include "googleurl/src/gurl.h" |
| 21 #include "sync/internal_api/public/base/model_type.h" | 21 #include "sync/internal_api/public/base/model_type.h" |
| 22 #include "sync/internal_api/public/configure_reason.h" | 22 #include "sync/internal_api/public/configure_reason.h" |
| 23 #include "sync/internal_api/public/engine/model_safe_worker.h" | 23 #include "sync/internal_api/public/engine/model_safe_worker.h" |
| 24 #include "sync/internal_api/public/sessions/sync_session_snapshot.h" | 24 #include "sync/internal_api/public/sessions/sync_session_snapshot.h" |
| 25 #include "sync/internal_api/public/sync_encryption_handler.h" |
| 25 #include "sync/internal_api/public/sync_manager.h" | 26 #include "sync/internal_api/public/sync_manager.h" |
| 26 #include "sync/internal_api/public/util/report_unrecoverable_error_function.h" | 27 #include "sync/internal_api/public/util/report_unrecoverable_error_function.h" |
| 27 #include "sync/internal_api/public/util/unrecoverable_error_handler.h" | 28 #include "sync/internal_api/public/util/unrecoverable_error_handler.h" |
| 28 #include "sync/internal_api/public/util/weak_handle.h" | 29 #include "sync/internal_api/public/util/weak_handle.h" |
| 29 #include "sync/notifier/sync_notifier_factory.h" | 30 #include "sync/notifier/sync_notifier_factory.h" |
| 30 #include "sync/notifier/sync_notifier_observer.h" | 31 #include "sync/notifier/sync_notifier_observer.h" |
| 31 #include "sync/protocol/encryption.pb.h" | 32 #include "sync/protocol/encryption.pb.h" |
| 32 #include "sync/protocol/sync_protocol_error.h" | 33 #include "sync/protocol/sync_protocol_error.h" |
| 33 | 34 |
| 34 class MessageLoop; | 35 class MessageLoop; |
| (...skipping 309 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 344 const base::Callback<void(syncer::ModelTypeSet)>& ready_task, | 345 const base::Callback<void(syncer::ModelTypeSet)>& ready_task, |
| 345 const base::Closure& retry_callback); | 346 const base::Closure& retry_callback); |
| 346 | 347 |
| 347 // Called when the syncer has finished performing a configuration. | 348 // Called when the syncer has finished performing a configuration. |
| 348 void FinishConfigureDataTypesOnFrontendLoop( | 349 void FinishConfigureDataTypesOnFrontendLoop( |
| 349 const syncer::ModelTypeSet failed_configuration_types, | 350 const syncer::ModelTypeSet failed_configuration_types, |
| 350 const base::Callback<void(syncer::ModelTypeSet)>& ready_task); | 351 const base::Callback<void(syncer::ModelTypeSet)>& ready_task); |
| 351 | 352 |
| 352 // Called when the SyncManager has been constructed and initialized. | 353 // Called when the SyncManager has been constructed and initialized. |
| 353 virtual void HandleSyncManagerInitializationOnFrontendLoop( | 354 virtual void HandleSyncManagerInitializationOnFrontendLoop( |
| 354 const syncer::WeakHandle<syncer::JsBackend>& js_backend, bool success, | 355 const syncer::WeakHandle<syncer::JsBackend>& js_backend, |
| 356 bool success, |
| 355 syncer::ModelTypeSet restored_types); | 357 syncer::ModelTypeSet restored_types); |
| 356 | 358 |
| 357 SyncFrontend* frontend() { return frontend_; } | 359 SyncFrontend* frontend() { return frontend_; } |
| 358 | 360 |
| 359 private: | 361 private: |
| 360 // The real guts of SyncBackendHost, to keep the public client API clean. | 362 // The real guts of SyncBackendHost, to keep the public client API clean. |
| 361 class Core; | 363 class Core; |
| 362 | 364 |
| 363 // An enum representing the steps to initializing the SyncBackendHost. | 365 // An enum representing the steps to initializing the SyncBackendHost. |
| 364 enum InitializationState { | 366 enum InitializationState { |
| 365 NOT_ATTEMPTED, | 367 NOT_ATTEMPTED, |
| 366 CREATING_SYNC_MANAGER, // We're waiting for the first callback from the | 368 CREATING_SYNC_MANAGER, // We're waiting for the first callback from the |
| 367 // sync thread to inform us that the sync manager | 369 // sync thread to inform us that the sync manager |
| 368 // has been created. | 370 // has been created. |
| 369 NOT_INITIALIZED, // Initialization hasn't completed, but we've | 371 NOT_INITIALIZED, // Initialization hasn't completed, but we've |
| 370 // constructed a SyncManager. | 372 // constructed a SyncManager. |
| 371 DOWNLOADING_NIGORI, // The SyncManager is initialized, but | 373 DOWNLOADING_NIGORI, // The SyncManager is initialized, but |
| 372 // we're fetching encryption information. | 374 // we're fetching sync encryption information. |
| 373 REFRESHING_NIGORI, // The SyncManager is initialized, and we | 375 ASSOCIATING_NIGORI, // The SyncManager is initialized, and we |
| 374 // have the encryption information, but we | 376 // have the sync encryption information, but we |
| 375 // still need to refresh encryption. Also, we need | 377 // have to update the local encryption state. |
| 376 // to update the device information in the nigori. | |
| 377 INITIALIZED, // Initialization is complete. | 378 INITIALIZED, // Initialization is complete. |
| 378 }; | 379 }; |
| 379 | 380 |
| 380 // Enum used to distinguish which bootstrap encryption token is being updated. | 381 // Enum used to distinguish which bootstrap encryption token is being updated. |
| 381 enum BootstrapTokenType { | 382 enum BootstrapTokenType { |
| 382 PASSPHRASE_BOOTSTRAP_TOKEN, | 383 PASSPHRASE_BOOTSTRAP_TOKEN, |
| 383 KEYSTORE_BOOTSTRAP_TOKEN | 384 KEYSTORE_BOOTSTRAP_TOKEN |
| 384 }; | 385 }; |
| 385 | 386 |
| 386 // Checks if we have received a notice to turn on experimental datatypes | 387 // Checks if we have received a notice to turn on experimental datatypes |
| 387 // (via the nigori node) and informs the frontend if that is the case. | 388 // (via the nigori node) and informs the frontend if that is the case. |
| 388 // Note: it is illegal to call this before the backend is initialized. | 389 // Note: it is illegal to call this before the backend is initialized. |
| 389 void AddExperimentalTypes(); | 390 void AddExperimentalTypes(); |
| 390 | 391 |
| 391 // Downloading of nigori failed and will be retried. | 392 // Downloading of nigori failed and will be retried. |
| 392 void OnNigoriDownloadRetry(); | 393 void OnNigoriDownloadRetry(); |
| 393 | 394 |
| 394 // InitializationComplete passes through the SyncBackendHost to forward | 395 // InitializationComplete passes through the SyncBackendHost to forward |
| 395 // on to |frontend_|, and so that tests can intercept here if they need to | 396 // on to |frontend_|, and so that tests can intercept here if they need to |
| 396 // set up initial conditions. | 397 // set up initial conditions. |
| 397 void HandleInitializationCompletedOnFrontendLoop( | 398 void HandleInitializationCompletedOnFrontendLoop( |
| 398 const syncer::WeakHandle<syncer::JsBackend>& js_backend, | |
| 399 bool success); | 399 bool success); |
| 400 | 400 |
| 401 // Called from Core::OnSyncCycleCompleted to handle updating frontend | 401 // Called from Core::OnSyncCycleCompleted to handle updating frontend |
| 402 // thread components. | 402 // thread components. |
| 403 void HandleSyncCycleCompletedOnFrontendLoop( | 403 void HandleSyncCycleCompletedOnFrontendLoop( |
| 404 const syncer::sessions::SyncSessionSnapshot& snapshot); | 404 const syncer::sessions::SyncSessionSnapshot& snapshot); |
| 405 | 405 |
| 406 // Called when the syncer failed to perform a configuration and will | 406 // Called when the syncer failed to perform a configuration and will |
| 407 // eventually retry. FinishingConfigurationOnFrontendLoop(..) will be called | 407 // eventually retry. FinishingConfigurationOnFrontendLoop(..) will be called |
| 408 // on successful completion. | 408 // on successful completion. |
| (...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 457 void HandleStopSyncingPermanentlyOnFrontendLoop(); | 457 void HandleStopSyncingPermanentlyOnFrontendLoop(); |
| 458 | 458 |
| 459 // Dispatched to from OnConnectionStatusChange to handle updating | 459 // Dispatched to from OnConnectionStatusChange to handle updating |
| 460 // frontend UI components. | 460 // frontend UI components. |
| 461 void HandleConnectionStatusChangeOnFrontendLoop( | 461 void HandleConnectionStatusChangeOnFrontendLoop( |
| 462 syncer::ConnectionStatus status); | 462 syncer::ConnectionStatus status); |
| 463 | 463 |
| 464 // Called when configuration of the Nigori node has completed as | 464 // Called when configuration of the Nigori node has completed as |
| 465 // part of the initialization process. | 465 // part of the initialization process. |
| 466 void HandleNigoriConfigurationCompletedOnFrontendLoop( | 466 void HandleNigoriConfigurationCompletedOnFrontendLoop( |
| 467 const syncer::WeakHandle<syncer::JsBackend>& js_backend, | |
| 468 syncer::ModelTypeSet failed_configuration_types); | 467 syncer::ModelTypeSet failed_configuration_types); |
| 469 | 468 |
| 470 // syncer::SyncNotifierObserver-like functions. | 469 // syncer::SyncNotifierObserver-like functions. |
| 471 void HandleNotificationsEnabledOnFrontendLoop(); | 470 void HandleNotificationsEnabledOnFrontendLoop(); |
| 472 void HandleNotificationsDisabledOnFrontendLoop( | 471 void HandleNotificationsDisabledOnFrontendLoop( |
| 473 syncer::NotificationsDisabledReason reason); | 472 syncer::NotificationsDisabledReason reason); |
| 474 void HandleIncomingNotificationOnFrontendLoop( | 473 void HandleIncomingNotificationOnFrontendLoop( |
| 475 const syncer::ObjectIdPayloadMap& id_payloads, | 474 const syncer::ObjectIdPayloadMap& id_payloads, |
| 476 syncer::IncomingNotificationSource source); | 475 syncer::IncomingNotificationSource source); |
| 477 | 476 |
| 478 // Must be called on |frontend_loop_|. |done_callback| is called on | |
| 479 // |frontend_loop_|. | |
| 480 void RefreshNigori(const base::Closure& done_callback); | |
| 481 | |
| 482 // Handles stopping the core's SyncManager, accounting for whether | 477 // Handles stopping the core's SyncManager, accounting for whether |
| 483 // initialization is done yet. | 478 // initialization is done yet. |
| 484 void StopSyncManagerForShutdown(const base::Closure& closure); | 479 void StopSyncManagerForShutdown(const base::Closure& closure); |
| 485 | 480 |
| 486 base::WeakPtrFactory<SyncBackendHost> weak_ptr_factory_; | 481 base::WeakPtrFactory<SyncBackendHost> weak_ptr_factory_; |
| 487 | 482 |
| 488 // A thread where all the sync operations happen. | 483 // A thread where all the sync operations happen. |
| 489 base::Thread sync_thread_; | 484 base::Thread sync_thread_; |
| 490 | 485 |
| 491 // A reference to the MessageLoop used to construct |this|, so we know how | 486 // A reference to the MessageLoop used to construct |this|, so we know how |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 523 // give the user immediate feedback about the passphrase entered by first | 518 // give the user immediate feedback about the passphrase entered by first |
| 524 // trying to decrypt the cached pending keys on the UI thread. Note that | 519 // trying to decrypt the cached pending keys on the UI thread. Note that |
| 525 // SetDecryptionPassphrase can still fail after the cached pending keys are | 520 // SetDecryptionPassphrase can still fail after the cached pending keys are |
| 526 // successfully decrypted if the pending keys have changed since the time they | 521 // successfully decrypted if the pending keys have changed since the time they |
| 527 // were cached. | 522 // were cached. |
| 528 sync_pb::EncryptedData cached_pending_keys_; | 523 sync_pb::EncryptedData cached_pending_keys_; |
| 529 | 524 |
| 530 // UI-thread cache of the last SyncSessionSnapshot received from syncapi. | 525 // UI-thread cache of the last SyncSessionSnapshot received from syncapi. |
| 531 syncer::sessions::SyncSessionSnapshot last_snapshot_; | 526 syncer::sessions::SyncSessionSnapshot last_snapshot_; |
| 532 | 527 |
| 528 // Temporary holder for the javascript backend. Set by |
| 529 // HandleSyncManagerInitializationOnFrontendLoop, and consumed when we pass |
| 530 // it via OnBackendInitialized in the final state of |
| 531 // HandleInitializationCompletedOnFrontendLoop. |
| 532 syncer::WeakHandle<syncer::JsBackend> js_backend_; |
| 533 |
| 533 DISALLOW_COPY_AND_ASSIGN(SyncBackendHost); | 534 DISALLOW_COPY_AND_ASSIGN(SyncBackendHost); |
| 534 }; | 535 }; |
| 535 | 536 |
| 536 } // namespace browser_sync | 537 } // namespace browser_sync |
| 537 | 538 |
| 538 #endif // CHROME_BROWSER_SYNC_GLUE_SYNC_BACKEND_HOST_H_ | 539 #endif // CHROME_BROWSER_SYNC_GLUE_SYNC_BACKEND_HOST_H_ |
| OLD | NEW |