| 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 "chrome/browser/sync/profile_sync_service.h" | 5 #include "chrome/browser/sync/profile_sync_service.h" |
| 6 | 6 |
| 7 #include <cstddef> | 7 #include <cstddef> |
| 8 #include <map> | 8 #include <map> |
| 9 #include <set> | 9 #include <vector> |
| 10 #include <utility> | |
| 11 | 10 |
| 12 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
| 13 #include "base/bind.h" | 12 #include "base/bind.h" |
| 14 #include "base/bind_helpers.h" | 13 #include "base/bind_helpers.h" |
| 15 #include "base/callback.h" | 14 #include "base/callback.h" |
| 16 #include "base/command_line.h" | 15 #include "base/command_line.h" |
| 17 #include "base/compiler_specific.h" | 16 #include "base/compiler_specific.h" |
| 18 #include "base/file_util.h" | 17 #include "base/file_util.h" |
| 19 #include "base/logging.h" | 18 #include "base/logging.h" |
| 20 #include "base/memory/ref_counted.h" | 19 #include "base/memory/ref_counted.h" |
| (...skipping 27 matching lines...) Expand all Loading... |
| 48 #include "chrome/browser/sync/glue/sync_backend_host.h" | 47 #include "chrome/browser/sync/glue/sync_backend_host.h" |
| 49 #include "chrome/browser/sync/glue/sync_backend_host_impl.h" | 48 #include "chrome/browser/sync/glue/sync_backend_host_impl.h" |
| 50 #include "chrome/browser/sync/glue/sync_start_util.h" | 49 #include "chrome/browser/sync/glue/sync_start_util.h" |
| 51 #include "chrome/browser/sync/glue/synced_device_tracker.h" | 50 #include "chrome/browser/sync/glue/synced_device_tracker.h" |
| 52 #include "chrome/browser/sync/glue/typed_url_data_type_controller.h" | 51 #include "chrome/browser/sync/glue/typed_url_data_type_controller.h" |
| 53 #include "chrome/browser/sync/profile_sync_components_factory_impl.h" | 52 #include "chrome/browser/sync/profile_sync_components_factory_impl.h" |
| 54 #include "chrome/browser/sync/sessions/notification_service_sessions_router.h" | 53 #include "chrome/browser/sync/sessions/notification_service_sessions_router.h" |
| 55 #include "chrome/browser/sync/sessions/sessions_sync_manager.h" | 54 #include "chrome/browser/sync/sessions/sessions_sync_manager.h" |
| 56 #include "chrome/browser/sync/supervised_user_signin_manager_wrapper.h" | 55 #include "chrome/browser/sync/supervised_user_signin_manager_wrapper.h" |
| 57 #include "chrome/browser/sync/sync_error_controller.h" | 56 #include "chrome/browser/sync/sync_error_controller.h" |
| 57 #include "chrome/browser/sync/sync_type_preference_provider.h" |
| 58 #include "chrome/browser/ui/browser.h" | 58 #include "chrome/browser/ui/browser.h" |
| 59 #include "chrome/browser/ui/browser_list.h" | 59 #include "chrome/browser/ui/browser_list.h" |
| 60 #include "chrome/browser/ui/browser_window.h" | 60 #include "chrome/browser/ui/browser_window.h" |
| 61 #include "chrome/browser/ui/global_error/global_error_service.h" | 61 #include "chrome/browser/ui/global_error/global_error_service.h" |
| 62 #include "chrome/browser/ui/global_error/global_error_service_factory.h" | 62 #include "chrome/browser/ui/global_error/global_error_service_factory.h" |
| 63 #include "chrome/common/chrome_switches.h" | 63 #include "chrome/common/chrome_switches.h" |
| 64 #include "chrome/common/chrome_version_info.h" | 64 #include "chrome/common/chrome_version_info.h" |
| 65 #include "chrome/common/pref_names.h" | 65 #include "chrome/common/pref_names.h" |
| 66 #include "chrome/common/url_constants.h" | 66 #include "chrome/common/url_constants.h" |
| 67 #include "components/gcm_driver/gcm_driver.h" | 67 #include "components/gcm_driver/gcm_driver.h" |
| (...skipping 1749 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1817 sync_prefs_.GetPreferredDataTypes(registered_types); | 1817 sync_prefs_.GetPreferredDataTypes(registered_types); |
| 1818 return preferred_types; | 1818 return preferred_types; |
| 1819 } | 1819 } |
| 1820 | 1820 |
| 1821 syncer::ModelTypeSet | 1821 syncer::ModelTypeSet |
| 1822 ProfileSyncService::GetPreferredDirectoryDataTypes() const { | 1822 ProfileSyncService::GetPreferredDirectoryDataTypes() const { |
| 1823 const syncer::ModelTypeSet registered_directory_types = | 1823 const syncer::ModelTypeSet registered_directory_types = |
| 1824 GetRegisteredDirectoryDataTypes(); | 1824 GetRegisteredDirectoryDataTypes(); |
| 1825 const syncer::ModelTypeSet preferred_types = | 1825 const syncer::ModelTypeSet preferred_types = |
| 1826 sync_prefs_.GetPreferredDataTypes(registered_directory_types); | 1826 sync_prefs_.GetPreferredDataTypes(registered_directory_types); |
| 1827 return preferred_types; | 1827 |
| 1828 return Union(preferred_types, GetDataTypesFromPreferenceProviders()); |
| 1828 } | 1829 } |
| 1829 | 1830 |
| 1830 syncer::ModelTypeSet | 1831 syncer::ModelTypeSet |
| 1831 ProfileSyncService::GetPreferredNonBlockingDataTypes() const { | 1832 ProfileSyncService::GetPreferredNonBlockingDataTypes() const { |
| 1832 return sync_prefs_.GetPreferredDataTypes(GetRegisteredNonBlockingDataTypes()); | 1833 return sync_prefs_.GetPreferredDataTypes(GetRegisteredNonBlockingDataTypes()); |
| 1833 } | 1834 } |
| 1834 | 1835 |
| 1835 syncer::ModelTypeSet ProfileSyncService::GetRegisteredDataTypes() const { | 1836 syncer::ModelTypeSet ProfileSyncService::GetRegisteredDataTypes() const { |
| 1836 return Union(GetRegisteredDirectoryDataTypes(), | 1837 return Union(GetRegisteredDirectoryDataTypes(), |
| 1837 GetRegisteredNonBlockingDataTypes()); | 1838 GetRegisteredNonBlockingDataTypes()); |
| (...skipping 435 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2273 | 2274 |
| 2274 void ProfileSyncService::RemoveTypeDebugInfoObserver( | 2275 void ProfileSyncService::RemoveTypeDebugInfoObserver( |
| 2275 syncer::TypeDebugInfoObserver* type_debug_info_observer) { | 2276 syncer::TypeDebugInfoObserver* type_debug_info_observer) { |
| 2276 type_debug_info_observers_.RemoveObserver(type_debug_info_observer); | 2277 type_debug_info_observers_.RemoveObserver(type_debug_info_observer); |
| 2277 if (!type_debug_info_observers_.might_have_observers() && | 2278 if (!type_debug_info_observers_.might_have_observers() && |
| 2278 backend_initialized_) { | 2279 backend_initialized_) { |
| 2279 backend_->DisableDirectoryTypeDebugInfoForwarding(); | 2280 backend_->DisableDirectoryTypeDebugInfoForwarding(); |
| 2280 } | 2281 } |
| 2281 } | 2282 } |
| 2282 | 2283 |
| 2284 void ProfileSyncService::AddPreferenceProvider( |
| 2285 SyncTypePreferenceProvider* provider) { |
| 2286 DCHECK(!HasPreferenceProvider(provider)) |
| 2287 << "Providers may only be added once!"; |
| 2288 preference_providers_.insert(provider); |
| 2289 } |
| 2290 |
| 2291 void ProfileSyncService::RemovePreferenceProvider( |
| 2292 SyncTypePreferenceProvider* provider) { |
| 2293 DCHECK(HasPreferenceProvider(provider)) |
| 2294 << "Only providers that have been added before can be removed!"; |
| 2295 preference_providers_.erase(provider); |
| 2296 } |
| 2297 |
| 2298 bool ProfileSyncService::HasPreferenceProvider( |
| 2299 SyncTypePreferenceProvider* provider) const { |
| 2300 return preference_providers_.count(provider) > 0; |
| 2301 } |
| 2302 |
| 2283 namespace { | 2303 namespace { |
| 2284 | 2304 |
| 2285 class GetAllNodesRequestHelper | 2305 class GetAllNodesRequestHelper |
| 2286 : public base::RefCountedThreadSafe<GetAllNodesRequestHelper> { | 2306 : public base::RefCountedThreadSafe<GetAllNodesRequestHelper> { |
| 2287 public: | 2307 public: |
| 2288 GetAllNodesRequestHelper( | 2308 GetAllNodesRequestHelper( |
| 2289 syncer::ModelTypeSet requested_types, | 2309 syncer::ModelTypeSet requested_types, |
| 2290 const base::Callback<void(scoped_ptr<base::ListValue>)>& callback); | 2310 const base::Callback<void(scoped_ptr<base::ListValue>)>& callback); |
| 2291 | 2311 |
| 2292 void OnReceivedNodesForTypes( | 2312 void OnReceivedNodesForTypes( |
| (...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2461 NotifyObservers(); | 2481 NotifyObservers(); |
| 2462 | 2482 |
| 2463 DVLOG(1) << "ConfigureDataTypeManager not invoked because of an " | 2483 DVLOG(1) << "ConfigureDataTypeManager not invoked because of an " |
| 2464 << "Unrecoverable error."; | 2484 << "Unrecoverable error."; |
| 2465 } else { | 2485 } else { |
| 2466 DVLOG(0) << "ConfigureDataTypeManager not invoked because backend is not " | 2486 DVLOG(0) << "ConfigureDataTypeManager not invoked because backend is not " |
| 2467 << "initialized"; | 2487 << "initialized"; |
| 2468 } | 2488 } |
| 2469 } | 2489 } |
| 2470 | 2490 |
| 2491 syncer::ModelTypeSet ProfileSyncService::GetDataTypesFromPreferenceProviders() |
| 2492 const { |
| 2493 syncer::ModelTypeSet types; |
| 2494 for (std::set<SyncTypePreferenceProvider*>::iterator it = |
| 2495 preference_providers_.begin(); |
| 2496 it != preference_providers_.end(); |
| 2497 ++it) { |
| 2498 types.PutAll((*it)->GetPreferredDataTypes()); |
| 2499 } |
| 2500 return types; |
| 2501 } |
| 2502 |
| 2471 const FailedDataTypesHandler& ProfileSyncService::failed_data_types_handler() | 2503 const FailedDataTypesHandler& ProfileSyncService::failed_data_types_handler() |
| 2472 const { | 2504 const { |
| 2473 return failed_data_types_handler_; | 2505 return failed_data_types_handler_; |
| 2474 } | 2506 } |
| 2475 | 2507 |
| 2476 void ProfileSyncService::OnInternalUnrecoverableError( | 2508 void ProfileSyncService::OnInternalUnrecoverableError( |
| 2477 const tracked_objects::Location& from_here, | 2509 const tracked_objects::Location& from_here, |
| 2478 const std::string& message, | 2510 const std::string& message, |
| 2479 bool delete_sync_database, | 2511 bool delete_sync_database, |
| 2480 UnrecoverableErrorReason reason) { | 2512 UnrecoverableErrorReason reason) { |
| (...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2647 browser_sync::SyncedDeviceTracker* device_tracker = | 2679 browser_sync::SyncedDeviceTracker* device_tracker = |
| 2648 backend_->GetSyncedDeviceTracker(); | 2680 backend_->GetSyncedDeviceTracker(); |
| 2649 if (device_tracker) | 2681 if (device_tracker) |
| 2650 device_tracker->UpdateLocalDeviceBackupTime(*last_backup_time_); | 2682 device_tracker->UpdateLocalDeviceBackupTime(*last_backup_time_); |
| 2651 } | 2683 } |
| 2652 } | 2684 } |
| 2653 | 2685 |
| 2654 base::Time ProfileSyncService::GetDeviceBackupTimeForTesting() const { | 2686 base::Time ProfileSyncService::GetDeviceBackupTimeForTesting() const { |
| 2655 return backend_->GetSyncedDeviceTracker()->GetLocalDeviceBackupTime(); | 2687 return backend_->GetSyncedDeviceTracker()->GetLocalDeviceBackupTime(); |
| 2656 } | 2688 } |
| OLD | NEW |