OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/sync/glue/session_model_associator.h" | 5 #include "chrome/browser/sync/glue/session_model_associator.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <set> | 8 #include <set> |
9 #include <utility> | 9 #include <utility> |
10 | 10 |
11 #include "base/logging.h" | 11 #include "base/logging.h" |
12 #include "base/tracked.h" | 12 #include "base/tracked.h" |
13 #include "chrome/browser/extensions/extension_tab_helper.h" | 13 #include "chrome/browser/extensions/extension_tab_helper.h" |
14 #include "chrome/browser/profiles/profile.h" | 14 #include "chrome/browser/profiles/profile.h" |
15 #include "chrome/browser/sessions/restore_tab_helper.h" | 15 #include "chrome/browser/sessions/restore_tab_helper.h" |
16 #include "chrome/browser/sessions/session_service_factory.h" | 16 #include "chrome/browser/sessions/session_service_factory.h" |
| 17 #include "chrome/browser/sync/api/sync_error.h" |
17 #include "chrome/browser/sync/glue/synced_window_delegate.h" | 18 #include "chrome/browser/sync/glue/synced_window_delegate.h" |
18 #include "chrome/browser/sync/profile_sync_service.h" | 19 #include "chrome/browser/sync/profile_sync_service.h" |
19 #include "chrome/browser/sync/syncable/syncable.h" | 20 #include "chrome/browser/sync/syncable/syncable.h" |
20 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" | 21 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" |
21 #include "chrome/common/chrome_notification_types.h" | 22 #include "chrome/common/chrome_notification_types.h" |
22 #include "chrome/common/extensions/extension.h" | 23 #include "chrome/common/extensions/extension.h" |
23 #include "chrome/common/url_constants.h" | 24 #include "chrome/common/url_constants.h" |
24 #include "content/browser/tab_contents/navigation_controller.h" | 25 #include "content/browser/tab_contents/navigation_controller.h" |
25 #include "content/browser/tab_contents/navigation_entry.h" | 26 #include "content/browser/tab_contents/navigation_entry.h" |
26 #include "content/common/notification_details.h" | 27 #include "content/common/notification_details.h" |
(...skipping 373 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
400 sync_pb::TabNavigation_PageTransition_TYPED); | 401 sync_pb::TabNavigation_PageTransition_TYPED); |
401 } | 402 } |
402 } | 403 } |
403 | 404 |
404 void SessionModelAssociator::Disassociate(int64 sync_id) { | 405 void SessionModelAssociator::Disassociate(int64 sync_id) { |
405 DCHECK(CalledOnValidThread()); | 406 DCHECK(CalledOnValidThread()); |
406 NOTIMPLEMENTED(); | 407 NOTIMPLEMENTED(); |
407 // TODO(zea): we will need this once we support deleting foreign sessions. | 408 // TODO(zea): we will need this once we support deleting foreign sessions. |
408 } | 409 } |
409 | 410 |
410 bool SessionModelAssociator::AssociateModels() { | 411 bool SessionModelAssociator::AssociateModels(SyncError* error) { |
411 DCHECK(CalledOnValidThread()); | 412 DCHECK(CalledOnValidThread()); |
412 | 413 |
413 // Ensure that we disassociated properly, otherwise memory might leak. | 414 // Ensure that we disassociated properly, otherwise memory might leak. |
414 DCHECK(synced_session_tracker_.empty()); | 415 DCHECK(synced_session_tracker_.empty()); |
415 DCHECK_EQ(0U, tab_pool_.capacity()); | 416 DCHECK_EQ(0U, tab_pool_.capacity()); |
416 | 417 |
417 local_session_syncid_ = sync_api::kInvalidId; | 418 local_session_syncid_ = sync_api::kInvalidId; |
418 | 419 |
419 // Read any available foreign sessions and load any session data we may have. | 420 // Read any available foreign sessions and load any session data we may have. |
420 // If we don't have any local session data in the db, create a header node. | 421 // If we don't have any local session data in the db, create a header node. |
421 { | 422 { |
422 sync_api::WriteTransaction trans(FROM_HERE, sync_service_->GetUserShare()); | 423 sync_api::WriteTransaction trans(FROM_HERE, sync_service_->GetUserShare()); |
423 | 424 |
424 sync_api::ReadNode root(&trans); | 425 sync_api::ReadNode root(&trans); |
425 if (!root.InitByTagLookup(kSessionsTag)) { | 426 if (!root.InitByTagLookup(kSessionsTag)) { |
426 LOG(ERROR) << kNoSessionsFolderError; | 427 error->Reset(FROM_HERE, kNoSessionsFolderError, model_type()); |
427 return false; | 428 return false; |
428 } | 429 } |
429 | 430 |
430 // Make sure we have a machine tag. | 431 // Make sure we have a machine tag. |
431 if (current_machine_tag_.empty()) | 432 if (current_machine_tag_.empty()) |
432 InitializeCurrentMachineTag(&trans); | 433 InitializeCurrentMachineTag(&trans); |
433 synced_session_tracker_.SetLocalSessionTag(current_machine_tag_); | 434 synced_session_tracker_.SetLocalSessionTag(current_machine_tag_); |
434 UpdateAssociationsFromSyncModel(root, &trans); | 435 UpdateAssociationsFromSyncModel(root, &trans); |
435 | 436 |
436 if (local_session_syncid_ == sync_api::kInvalidId) { | 437 if (local_session_syncid_ == sync_api::kInvalidId) { |
437 // The sync db didn't have a header node for us, we need to create one. | 438 // The sync db didn't have a header node for us, we need to create one. |
438 sync_api::WriteNode write_node(&trans); | 439 sync_api::WriteNode write_node(&trans); |
439 if (!write_node.InitUniqueByCreation(syncable::SESSIONS, root, | 440 if (!write_node.InitUniqueByCreation(syncable::SESSIONS, root, |
440 current_machine_tag_)) { | 441 current_machine_tag_)) { |
441 LOG(ERROR) << "Failed to create sessions header sync node."; | 442 error->Reset(FROM_HERE, |
| 443 "Failed to create sessions header sync node.", |
| 444 model_type()); |
442 return false; | 445 return false; |
443 } | 446 } |
444 write_node.SetTitle(UTF8ToWide(current_machine_tag_)); | 447 write_node.SetTitle(UTF8ToWide(current_machine_tag_)); |
445 local_session_syncid_ = write_node.GetId(); | 448 local_session_syncid_ = write_node.GetId(); |
446 } | 449 } |
447 } | 450 } |
448 | 451 |
449 // Check if anything has changed on the client side. | 452 // Check if anything has changed on the client side. |
450 UpdateSyncModelDataFromClient(); | 453 UpdateSyncModelDataFromClient(); |
451 | 454 |
452 VLOG(1) << "Session models associated."; | 455 VLOG(1) << "Session models associated."; |
453 | 456 |
454 return true; | 457 return true; |
455 } | 458 } |
456 | 459 |
457 bool SessionModelAssociator::DisassociateModels() { | 460 bool SessionModelAssociator::DisassociateModels(SyncError* error) { |
458 DCHECK(CalledOnValidThread()); | 461 DCHECK(CalledOnValidThread()); |
459 synced_session_tracker_.clear(); | 462 synced_session_tracker_.clear(); |
460 tab_map_.clear(); | 463 tab_map_.clear(); |
461 tab_pool_.clear(); | 464 tab_pool_.clear(); |
462 local_session_syncid_ = sync_api::kInvalidId; | 465 local_session_syncid_ = sync_api::kInvalidId; |
463 | 466 |
464 // There is no local model stored with which to disassociate, just notify | 467 // There is no local model stored with which to disassociate, just notify |
465 // foreign session handlers. | 468 // foreign session handlers. |
466 NotificationService::current()->Notify( | 469 NotificationService::current()->Notify( |
467 chrome::NOTIFICATION_FOREIGN_SESSION_DISABLED, | 470 chrome::NOTIFICATION_FOREIGN_SESSION_DISABLED, |
(...skipping 586 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1054 bool SessionModelAssociator::CryptoReadyIfNecessary() { | 1057 bool SessionModelAssociator::CryptoReadyIfNecessary() { |
1055 // We only access the cryptographer while holding a transaction. | 1058 // We only access the cryptographer while holding a transaction. |
1056 sync_api::ReadTransaction trans(FROM_HERE, sync_service_->GetUserShare()); | 1059 sync_api::ReadTransaction trans(FROM_HERE, sync_service_->GetUserShare()); |
1057 syncable::ModelTypeSet encrypted_types; | 1060 syncable::ModelTypeSet encrypted_types; |
1058 encrypted_types = sync_api::GetEncryptedTypes(&trans); | 1061 encrypted_types = sync_api::GetEncryptedTypes(&trans); |
1059 return encrypted_types.count(syncable::SESSIONS) == 0 || | 1062 return encrypted_types.count(syncable::SESSIONS) == 0 || |
1060 sync_service_->IsCryptographerReady(&trans); | 1063 sync_service_->IsCryptographerReady(&trans); |
1061 } | 1064 } |
1062 | 1065 |
1063 } // namespace browser_sync | 1066 } // namespace browser_sync |
OLD | NEW |