Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/ui/app_list/arc/arc_package_sync_data_type_controller.h " | 5 #include "chrome/browser/ui/app_list/arc/arc_package_sync_data_type_controller.h " |
| 6 | 6 |
| 7 #include "chrome/browser/chromeos/arc/arc_auth_service.h" | |
| 7 #include "chrome/browser/profiles/profile.h" | 8 #include "chrome/browser/profiles/profile.h" |
| 8 #include "chrome/browser/ui/app_list/arc/arc_app_list_prefs.h" | 9 #include "chrome/browser/ui/app_list/arc/arc_app_list_prefs.h" |
| 9 #include "chrome/common/pref_names.h" | 10 #include "chrome/common/pref_names.h" |
| 10 #include "components/arc/common/app.mojom.h" | 11 #include "components/arc/arc_bridge_service.h" |
| 11 #include "components/arc/instance_holder.h" | |
| 12 #include "components/prefs/pref_service.h" | 12 #include "components/prefs/pref_service.h" |
| 13 #include "components/sync/driver/pref_names.h" | |
| 13 #include "components/sync/driver/sync_client.h" | 14 #include "components/sync/driver/sync_client.h" |
| 14 #include "components/sync/driver/sync_prefs.h" | 15 #include "components/sync/driver/sync_prefs.h" |
| 15 #include "components/sync/driver/sync_service.h" | 16 #include "components/sync/driver/sync_service.h" |
| 16 | 17 |
| 17 // ArcPackage sync service is controlled by apps checkbox in sync settings. Arc | 18 // ArcPackage sync service is controlled by apps checkbox in sync settings. Arc |
| 18 // apps and regular Chrome apps have same user control. | 19 // apps and regular Chrome apps have same user control. |
| 20 namespace { | |
| 21 | |
| 22 bool ValidateEnableArcPackageSyncPref(Profile* profile) { | |
| 23 PrefService* pref_service = profile->GetPrefs(); | |
| 24 // If device is set to sync everything, Arc package should be synced. | |
| 25 if (pref_service->GetBoolean(sync_driver::prefs::kSyncKeepEverythingSynced)) | |
| 26 return true; | |
| 27 | |
| 28 const bool apps_sync_enable = pref_service->GetBoolean( | |
| 29 sync_driver::SyncPrefs::GetPrefNameForDataType(syncer::APPS)); | |
| 30 // ArcPackage sync service is controlled by apps checkbox in sync settings. | |
| 31 // Update ArcPackage sync setting pref if it is different from apps sync | |
| 32 // setting pref. | |
| 33 const char* arc_sync_path = | |
| 34 sync_driver::SyncPrefs::GetPrefNameForDataType(syncer::ARC_PACKAGE); | |
| 35 if (apps_sync_enable != pref_service->GetBoolean(arc_sync_path)) { | |
| 36 pref_service->SetBoolean(arc_sync_path, apps_sync_enable); | |
| 37 } | |
| 38 | |
| 39 return apps_sync_enable; | |
| 40 } | |
| 41 | |
| 42 // Indicates whether ARC is enabled on this machine. | |
| 43 bool IsArcEnabled(Profile* profile) { | |
| 44 return arc::ArcAuthService::IsAllowedForProfile(profile) && | |
| 45 profile->GetPrefs()->GetBoolean(prefs::kArcEnabled); | |
| 46 } | |
| 47 | |
| 48 } // namespace | |
| 49 | |
| 19 ArcPackageSyncDataTypeController::ArcPackageSyncDataTypeController( | 50 ArcPackageSyncDataTypeController::ArcPackageSyncDataTypeController( |
| 20 syncer::ModelType type, | 51 syncer::ModelType type, |
| 21 const base::Closure& dump_stack, | 52 const base::Closure& dump_stack, |
| 22 sync_driver::SyncClient* sync_client, | 53 sync_driver::SyncClient* sync_client, |
| 23 Profile* profile) | 54 Profile* profile) |
| 24 : sync_driver::UIDataTypeController(type, dump_stack, sync_client), | 55 : sync_driver::UIDataTypeController(type, dump_stack, sync_client), |
| 56 model_normal_start_(true), | |
|
khmel
2016/09/28 17:25:49
nit: move init of model_normal_start_ to header. I
lgcheng
2016/09/28 17:28:50
Done. Sorry I miss the remove.
| |
| 25 profile_(profile), | 57 profile_(profile), |
| 26 sync_client_(sync_client) { | 58 sync_client_(sync_client) { |
| 27 pref_registrar_.Init(profile_->GetPrefs()); | 59 pref_registrar_.Init(profile_->GetPrefs()); |
| 28 pref_registrar_.Add( | 60 pref_registrar_.Add( |
| 29 sync_driver::SyncPrefs::GetPrefNameForDataType(type), | 61 sync_driver::SyncPrefs::GetPrefNameForDataType(type), |
| 30 base::Bind(&ArcPackageSyncDataTypeController::OnArcAppsSyncPrefChanged, | 62 base::Bind(&ArcPackageSyncDataTypeController::OnArcAppsSyncPrefChanged, |
| 31 base::Unretained(this))); | 63 base::Unretained(this))); |
| 32 pref_registrar_.Add( | 64 pref_registrar_.Add( |
| 33 prefs::kArcEnabled, | 65 prefs::kArcEnabled, |
| 34 base::Bind(&ArcPackageSyncDataTypeController::OnArcEnabledPrefChanged, | 66 base::Bind(&ArcPackageSyncDataTypeController::OnArcEnabledPrefChanged, |
| 35 base::Unretained(this))); | 67 base::Unretained(this))); |
| 68 | |
| 69 arc::ArcBridgeService* arc_bridge_service = arc::ArcBridgeService::Get(); | |
| 70 if (arc_bridge_service) | |
| 71 arc_bridge_service->app()->AddObserver(this); | |
| 36 } | 72 } |
| 37 | 73 |
| 38 ArcPackageSyncDataTypeController::~ArcPackageSyncDataTypeController() {} | 74 ArcPackageSyncDataTypeController::~ArcPackageSyncDataTypeController() { |
| 75 arc::ArcBridgeService* arc_bridge_service = arc::ArcBridgeService::Get(); | |
| 76 if (arc_bridge_service) | |
| 77 arc_bridge_service->app()->RemoveObserver(this); | |
| 78 } | |
| 39 | 79 |
| 40 bool ArcPackageSyncDataTypeController::ReadyForStart() const { | 80 bool ArcPackageSyncDataTypeController::ReadyForStart() const { |
| 41 DCHECK(CalledOnValidThread()); | 81 DCHECK(CalledOnValidThread()); |
| 82 return IsArcEnabled(profile_) && ValidateEnableArcPackageSyncPref(profile_); | |
| 83 } | |
| 84 | |
| 85 void ArcPackageSyncDataTypeController::OnInstanceReady() { | |
| 86 // model_normal_start_ is true by default. Normally, | |
| 87 // ArcPackageSyncDataTypeController::StartModels() gets called before Arc is | |
| 88 // ready. But in integration test, the order can be either way. If | |
| 89 // OnInstanceReady comes before ArcPackageSyncDataTypeController | |
| 90 // ::StartModels(), this function is no-op and waits for StartModels() to be | |
| 91 // called. | |
| 92 if (model_normal_start_) | |
| 93 return; | |
| 94 | |
| 95 model_normal_start_ = true; | |
| 96 OnModelLoaded(); | |
| 97 } | |
| 98 | |
| 99 bool ArcPackageSyncDataTypeController::StartModels() { | |
| 100 DCHECK_EQ(state(), MODEL_STARTING); | |
| 42 ArcAppListPrefs* prefs = ArcAppListPrefs::Get(profile_); | 101 ArcAppListPrefs* prefs = ArcAppListPrefs::Get(profile_); |
| 43 return profile_->GetPrefs()->GetBoolean( | 102 model_normal_start_ = prefs && prefs->app_instance_holder()->has_instance(); |
| 44 sync_driver::SyncPrefs::GetPrefNameForDataType(type())) && | 103 return model_normal_start_; |
| 45 prefs && prefs->app_instance_holder()->has_instance(); | |
| 46 } | 104 } |
| 47 | 105 |
| 48 void ArcPackageSyncDataTypeController::OnArcAppsSyncPrefChanged() { | 106 void ArcPackageSyncDataTypeController::OnArcAppsSyncPrefChanged() { |
| 49 DCHECK(CalledOnValidThread()); | 107 DCHECK(CalledOnValidThread()); |
| 50 | 108 |
| 51 if (!ReadyForStart()) { | 109 if (!ReadyForStart()) { |
| 52 // If apps sync in advanced sync settings is turned off then generate an | 110 // If apps sync in advanced sync settings is turned off then generate an |
| 53 // unrecoverable error. | 111 // unrecoverable error. |
| 54 if (state() != NOT_RUNNING && state() != STOPPING) { | 112 if (state() != NOT_RUNNING && state() != STOPPING) { |
| 55 syncer::SyncError error( | 113 syncer::SyncError error( |
| 56 FROM_HERE, syncer::SyncError::DATATYPE_POLICY_ERROR, | 114 FROM_HERE, syncer::SyncError::DATATYPE_POLICY_ERROR, |
| 57 "Arc package sync is now disabled by user.", type()); | 115 "Arc package sync is now disabled by user.", type()); |
| 58 CreateErrorHandler()->OnUnrecoverableError(error); | 116 CreateErrorHandler()->OnUnrecoverableError(error); |
| 59 } | 117 } |
| 60 return; | 118 return; |
| 61 } | 119 } |
| 62 sync_driver::SyncService* sync_service = sync_client_->GetSyncService(); | 120 EnableDataType(); |
| 63 DCHECK(sync_service); | |
| 64 sync_service->ReenableDatatype(type()); | |
| 65 } | 121 } |
| 66 | 122 |
| 67 void ArcPackageSyncDataTypeController::OnArcEnabledPrefChanged() { | 123 void ArcPackageSyncDataTypeController::OnArcEnabledPrefChanged() { |
| 68 DCHECK(CalledOnValidThread()); | 124 DCHECK(CalledOnValidThread()); |
| 69 if (!profile_->GetPrefs()->GetBoolean(prefs::kArcEnabled)) { | 125 |
| 126 if (!ReadyForStart()) { | |
| 70 // If enable Arc in settings is turned off then generate an unrecoverable | 127 // If enable Arc in settings is turned off then generate an unrecoverable |
| 71 // error. | 128 // error. |
| 72 if (state() != NOT_RUNNING && state() != STOPPING) { | 129 if (state() != NOT_RUNNING && state() != STOPPING) { |
| 73 syncer::SyncError error( | 130 syncer::SyncError error( |
| 74 FROM_HERE, syncer::SyncError::DATATYPE_POLICY_ERROR, | 131 FROM_HERE, syncer::SyncError::DATATYPE_POLICY_ERROR, |
| 75 "Arc package sync is now disabled because user disables Arc.", | 132 "Arc package sync is now disabled because user disables Arc.", |
| 76 type()); | 133 type()); |
| 77 CreateErrorHandler()->OnUnrecoverableError(error); | 134 CreateErrorHandler()->OnUnrecoverableError(error); |
| 78 } | 135 } |
| 136 return; | |
| 79 } | 137 } |
| 138 EnableDataType(); | |
| 80 } | 139 } |
| 140 | |
| 141 void ArcPackageSyncDataTypeController::EnableDataType() { | |
| 142 sync_driver::SyncService* sync_service = sync_client_->GetSyncService(); | |
| 143 DCHECK(sync_service); | |
| 144 sync_service->ReenableDatatype(type()); | |
| 145 } | |
| OLD | NEW |