| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/chromeos/login/easy_unlock/easy_unlock_create_keys_oper
ation.h" | 5 #include "chrome/browser/chromeos/login/easy_unlock/easy_unlock_create_keys_oper
ation.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 328 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 339 key_def.provider_data.push_back(cryptohome::KeyDefinition::ProviderData( | 339 key_def.provider_data.push_back(cryptohome::KeyDefinition::ProviderData( |
| 340 kEasyUnlockKeyMetaNamePsk, device->psk)); | 340 kEasyUnlockKeyMetaNamePsk, device->psk)); |
| 341 key_def.provider_data.push_back(cryptohome::KeyDefinition::ProviderData( | 341 key_def.provider_data.push_back(cryptohome::KeyDefinition::ProviderData( |
| 342 kEasyUnlockKeyMetaNamePubKey, device->public_key)); | 342 kEasyUnlockKeyMetaNamePubKey, device->public_key)); |
| 343 key_def.provider_data.push_back(cryptohome::KeyDefinition::ProviderData( | 343 key_def.provider_data.push_back(cryptohome::KeyDefinition::ProviderData( |
| 344 kEasyUnlockKeyMetaNameChallenge, device->challenge)); | 344 kEasyUnlockKeyMetaNameChallenge, device->challenge)); |
| 345 key_def.provider_data.push_back(cryptohome::KeyDefinition::ProviderData( | 345 key_def.provider_data.push_back(cryptohome::KeyDefinition::ProviderData( |
| 346 kEasyUnlockKeyMetaNameWrappedSecret, device->wrapped_secret)); | 346 kEasyUnlockKeyMetaNameWrappedSecret, device->wrapped_secret)); |
| 347 | 347 |
| 348 // Add cryptohome key. | 348 // Add cryptohome key. |
| 349 std::string canonicalized = | 349 cryptohome::Identification id(user_context_.GetUserID()); |
| 350 gaia::CanonicalizeEmail(user_context_.GetUserID()); | |
| 351 cryptohome::Identification id(canonicalized); | |
| 352 | 350 |
| 353 scoped_ptr<Key> auth_key(new Key(*user_context_.GetKey())); | 351 scoped_ptr<Key> auth_key(new Key(*user_context_.GetKey())); |
| 354 if (auth_key->GetKeyType() == Key::KEY_TYPE_PASSWORD_PLAIN) | 352 if (auth_key->GetKeyType() == Key::KEY_TYPE_PASSWORD_PLAIN) |
| 355 auth_key->Transform(Key::KEY_TYPE_SALTED_SHA256_TOP_HALF, system_salt); | 353 auth_key->Transform(Key::KEY_TYPE_SALTED_SHA256_TOP_HALF, system_salt); |
| 356 | 354 |
| 357 cryptohome::Authorization auth(auth_key->GetSecret(), auth_key->GetLabel()); | 355 cryptohome::Authorization auth(auth_key->GetSecret(), auth_key->GetLabel()); |
| 358 cryptohome::HomedirMethods::GetInstance()->AddKeyEx( | 356 cryptohome::HomedirMethods::GetInstance()->AddKeyEx( |
| 359 id, | 357 id, |
| 360 auth, | 358 auth, |
| 361 key_def, | 359 key_def, |
| (...skipping 23 matching lines...) Expand all Loading... |
| 385 user_context_.GetKey()->GetLabel() == | 383 user_context_.GetKey()->GetLabel() == |
| 386 EasyUnlockKeyManager::GetKeyLabel(key_creation_index_)) { | 384 EasyUnlockKeyManager::GetKeyLabel(key_creation_index_)) { |
| 387 user_context_.SetKey(user_key); | 385 user_context_.SetKey(user_key); |
| 388 } | 386 } |
| 389 | 387 |
| 390 ++key_creation_index_; | 388 ++key_creation_index_; |
| 391 CreateKeyForDeviceAtIndex(key_creation_index_); | 389 CreateKeyForDeviceAtIndex(key_creation_index_); |
| 392 } | 390 } |
| 393 | 391 |
| 394 } // namespace chromeos | 392 } // namespace chromeos |
| OLD | NEW |