| 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/sync_setup_flow.h" | 5 #include "chrome/browser/sync/sync_setup_flow.h" |
| 6 | 6 |
| 7 #include "base/callback.h" | 7 #include "base/callback.h" |
| 8 #include "base/command_line.h" |
| 8 #include "base/json/json_reader.h" | 9 #include "base/json/json_reader.h" |
| 9 #include "base/json/json_writer.h" | 10 #include "base/json/json_writer.h" |
| 10 #include "base/metrics/histogram.h" | 11 #include "base/metrics/histogram.h" |
| 11 #include "base/string_util.h" | 12 #include "base/string_util.h" |
| 12 #include "base/utf_string_conversions.h" | 13 #include "base/utf_string_conversions.h" |
| 13 #include "base/values.h" | 14 #include "base/values.h" |
| 14 #include "chrome/browser/platform_util.h" | 15 #include "chrome/browser/platform_util.h" |
| 15 #include "chrome/browser/prefs/pref_service.h" | 16 #include "chrome/browser/prefs/pref_service.h" |
| 16 #include "chrome/browser/profiles/profile.h" | 17 #include "chrome/browser/profiles/profile.h" |
| 17 #include "chrome/browser/sync/profile_sync_service.h" | 18 #include "chrome/browser/sync/profile_sync_service.h" |
| 19 #include "chrome/browser/sync/syncable/model_type.h" |
| 18 #include "chrome/browser/sync/sync_setup_flow_handler.h" | 20 #include "chrome/browser/sync/sync_setup_flow_handler.h" |
| 19 #include "chrome/browser/ui/browser.h" | 21 #include "chrome/browser/ui/browser.h" |
| 20 #include "chrome/browser/ui/browser_dialogs.h" | 22 #include "chrome/browser/ui/browser_dialogs.h" |
| 21 #include "chrome/browser/ui/browser_list.h" | 23 #include "chrome/browser/ui/browser_list.h" |
| 24 #include "chrome/common/chrome_switches.h" |
| 22 #include "chrome/common/net/gaia/google_service_auth_error.h" | 25 #include "chrome/common/net/gaia/google_service_auth_error.h" |
| 23 #include "chrome/common/pref_names.h" | 26 #include "chrome/common/pref_names.h" |
| 24 #include "chrome/common/url_constants.h" | 27 #include "chrome/common/url_constants.h" |
| 25 #include "content/browser/renderer_host/render_view_host.h" | 28 #include "content/browser/renderer_host/render_view_host.h" |
| 26 #include "content/browser/tab_contents/tab_contents.h" | 29 #include "content/browser/tab_contents/tab_contents.h" |
| 27 #include "grit/generated_resources.h" | 30 #include "grit/generated_resources.h" |
| 28 #include "grit/locale_settings.h" | 31 #include "grit/locale_settings.h" |
| 29 #include "ui/base/l10n/l10n_font_util.h" | 32 #include "ui/base/l10n/l10n_font_util.h" |
| 30 #include "ui/gfx/font.h" | 33 #include "ui/gfx/font.h" |
| 31 | 34 |
| (...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 134 args->SetBoolean("syncAutofill", | 137 args->SetBoolean("syncAutofill", |
| 135 service->profile()->GetPrefs()->GetBoolean(prefs::kSyncAutofill)); | 138 service->profile()->GetPrefs()->GetBoolean(prefs::kSyncAutofill)); |
| 136 args->SetBoolean("syncExtensions", | 139 args->SetBoolean("syncExtensions", |
| 137 service->profile()->GetPrefs()->GetBoolean(prefs::kSyncExtensions)); | 140 service->profile()->GetPrefs()->GetBoolean(prefs::kSyncExtensions)); |
| 138 args->SetBoolean("syncSessions", | 141 args->SetBoolean("syncSessions", |
| 139 service->profile()->GetPrefs()->GetBoolean(prefs::kSyncSessions)); | 142 service->profile()->GetPrefs()->GetBoolean(prefs::kSyncSessions)); |
| 140 args->SetBoolean("syncTypedUrls", | 143 args->SetBoolean("syncTypedUrls", |
| 141 service->profile()->GetPrefs()->GetBoolean(prefs::kSyncTypedUrls)); | 144 service->profile()->GetPrefs()->GetBoolean(prefs::kSyncTypedUrls)); |
| 142 args->SetBoolean("syncApps", | 145 args->SetBoolean("syncApps", |
| 143 service->profile()->GetPrefs()->GetBoolean(prefs::kSyncApps)); | 146 service->profile()->GetPrefs()->GetBoolean(prefs::kSyncApps)); |
| 147 args->SetBoolean("encryptionEnabled", |
| 148 CommandLine::ForCurrentProcess()->HasSwitch( |
| 149 switches::kEnableSyncEncryption)); |
| 150 |
| 151 syncable::ModelTypeSet encrypted_types; |
| 152 service->GetEncryptedDataTypes(&encrypted_types); |
| 153 bool encrypt_all = |
| 154 encrypted_types.upper_bound(syncable::PASSWORDS) != encrypted_types.end(); |
| 155 args->SetBoolean("encryptAllData", encrypt_all); |
| 144 | 156 |
| 145 // Load the parameters for the encryption tab. | 157 // Load the parameters for the encryption tab. |
| 146 args->SetBoolean("usePassphrase", service->IsUsingSecondaryPassphrase()); | 158 args->SetBoolean("usePassphrase", service->IsUsingSecondaryPassphrase()); |
| 147 } | 159 } |
| 148 | 160 |
| 149 // static | 161 // static |
| 150 void SyncSetupFlow::GetArgsForEnterPassphrase( | 162 void SyncSetupFlow::GetArgsForEnterPassphrase( |
| 151 bool tried_creating_explicit_passphrase, | 163 bool tried_creating_explicit_passphrase, |
| 152 bool tried_setting_explicit_passphrase, | 164 bool tried_setting_explicit_passphrase, |
| 153 DictionaryValue* args) { | 165 DictionaryValue* args) { |
| (...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 220 const std::string& password, | 232 const std::string& password, |
| 221 const std::string& captcha, | 233 const std::string& captcha, |
| 222 const std::string& access_code) { | 234 const std::string& access_code) { |
| 223 service_->OnUserSubmittedAuth(username, password, captcha, access_code); | 235 service_->OnUserSubmittedAuth(username, password, captcha, access_code); |
| 224 } | 236 } |
| 225 | 237 |
| 226 void SyncSetupFlow::OnUserConfigured(const SyncConfiguration& configuration) { | 238 void SyncSetupFlow::OnUserConfigured(const SyncConfiguration& configuration) { |
| 227 // Go to the "loading..." screen. | 239 // Go to the "loading..." screen. |
| 228 Advance(SyncSetupWizard::SETTING_UP); | 240 Advance(SyncSetupWizard::SETTING_UP); |
| 229 | 241 |
| 242 if (configuration.encrypt_all) { |
| 243 syncable::ModelTypeSet data_types; |
| 244 service_->GetRegisteredDataTypes(&data_types); |
| 245 service_->EncryptDataTypes(data_types); |
| 246 } |
| 247 |
| 230 // If we are activating the passphrase, we need to have one supplied. | 248 // If we are activating the passphrase, we need to have one supplied. |
| 231 DCHECK(service_->IsUsingSecondaryPassphrase() || | 249 DCHECK(service_->IsUsingSecondaryPassphrase() || |
| 232 !configuration.use_secondary_passphrase || | 250 !configuration.use_secondary_passphrase || |
| 233 configuration.secondary_passphrase.length() > 0); | 251 configuration.secondary_passphrase.length() > 0); |
| 234 | 252 |
| 235 if (configuration.use_secondary_passphrase && | 253 if (configuration.use_secondary_passphrase && |
| 236 !service_->IsUsingSecondaryPassphrase()) { | 254 !service_->IsUsingSecondaryPassphrase()) { |
| 237 service_->SetPassphrase(configuration.secondary_passphrase, true, true); | 255 service_->SetPassphrase(configuration.secondary_passphrase, true, true); |
| 238 tried_creating_explicit_passphrase_ = true; | 256 tried_creating_explicit_passphrase_ = true; |
| 239 } | 257 } |
| (...skipping 133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 373 } | 391 } |
| 374 case SyncSetupWizard::DONE: | 392 case SyncSetupWizard::DONE: |
| 375 flow_handler_->ShowSetupDone( | 393 flow_handler_->ShowSetupDone( |
| 376 UTF16ToWide(service_->GetAuthenticatedUsername())); | 394 UTF16ToWide(service_->GetAuthenticatedUsername())); |
| 377 break; | 395 break; |
| 378 default: | 396 default: |
| 379 NOTREACHED() << "Invalid advance state: " << state; | 397 NOTREACHED() << "Invalid advance state: " << state; |
| 380 } | 398 } |
| 381 current_state_ = state; | 399 current_state_ = state; |
| 382 } | 400 } |
| OLD | NEW |