| 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 "chromeos/login/auth/extended_authenticator_impl.h" | 5 #include "chromeos/login/auth/extended_authenticator_impl.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/strings/string_number_conversions.h" | 10 #include "base/strings/string_number_conversions.h" |
| (...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 75 const UserContext& context, | 75 const UserContext& context, |
| 76 const base::Closure& success_callback) { | 76 const base::Closure& success_callback) { |
| 77 TransformKeyIfNeeded( | 77 TransformKeyIfNeeded( |
| 78 context, | 78 context, |
| 79 base::Bind(&ExtendedAuthenticatorImpl::DoAuthenticateToCheck, | 79 base::Bind(&ExtendedAuthenticatorImpl::DoAuthenticateToCheck, |
| 80 this, | 80 this, |
| 81 success_callback)); | 81 success_callback)); |
| 82 } | 82 } |
| 83 | 83 |
| 84 void ExtendedAuthenticatorImpl::CreateMount( | 84 void ExtendedAuthenticatorImpl::CreateMount( |
| 85 const std::string& user_id, | 85 const AccountId& account_id, |
| 86 const std::vector<cryptohome::KeyDefinition>& keys, | 86 const std::vector<cryptohome::KeyDefinition>& keys, |
| 87 const ResultCallback& success_callback) { | 87 const ResultCallback& success_callback) { |
| 88 RecordStartMarker("MountEx"); | 88 RecordStartMarker("MountEx"); |
| 89 | 89 |
| 90 std::string canonicalized = gaia::CanonicalizeEmail(user_id); | 90 cryptohome::Identification id(account_id); |
| 91 cryptohome::Identification id(canonicalized); | |
| 92 cryptohome::Authorization auth(keys.front()); | 91 cryptohome::Authorization auth(keys.front()); |
| 93 cryptohome::MountParameters mount(false); | 92 cryptohome::MountParameters mount(false); |
| 94 for (size_t i = 0; i < keys.size(); i++) { | 93 for (size_t i = 0; i < keys.size(); i++) { |
| 95 mount.create_keys.push_back(keys[i]); | 94 mount.create_keys.push_back(keys[i]); |
| 96 } | 95 } |
| 97 UserContext context(AccountId::FromUserEmail(user_id)); | 96 UserContext context(account_id); |
| 98 Key key(keys.front().secret); | 97 Key key(keys.front().secret); |
| 99 key.SetLabel(keys.front().label); | 98 key.SetLabel(keys.front().label); |
| 100 context.SetKey(key); | 99 context.SetKey(key); |
| 101 | 100 |
| 102 cryptohome::HomedirMethods::GetInstance()->MountEx( | 101 cryptohome::HomedirMethods::GetInstance()->MountEx( |
| 103 id, | 102 id, |
| 104 auth, | 103 auth, |
| 105 mount, | 104 mount, |
| 106 base::Bind(&ExtendedAuthenticatorImpl::OnMountComplete, | 105 base::Bind(&ExtendedAuthenticatorImpl::OnMountComplete, |
| 107 this, | 106 this, |
| (...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 182 it->Run(); | 181 it->Run(); |
| 183 } | 182 } |
| 184 system_salt_callbacks_.clear(); | 183 system_salt_callbacks_.clear(); |
| 185 } | 184 } |
| 186 | 185 |
| 187 void ExtendedAuthenticatorImpl::DoAuthenticateToMount( | 186 void ExtendedAuthenticatorImpl::DoAuthenticateToMount( |
| 188 const ResultCallback& success_callback, | 187 const ResultCallback& success_callback, |
| 189 const UserContext& user_context) { | 188 const UserContext& user_context) { |
| 190 RecordStartMarker("MountEx"); | 189 RecordStartMarker("MountEx"); |
| 191 | 190 |
| 192 const std::string canonicalized = | 191 cryptohome::Identification id(user_context.GetAccountId()); |
| 193 gaia::CanonicalizeEmail(user_context.GetAccountId().GetUserEmail()); | |
| 194 cryptohome::Identification id(canonicalized); | |
| 195 const Key* const key = user_context.GetKey(); | 192 const Key* const key = user_context.GetKey(); |
| 196 cryptohome::Authorization auth(key->GetSecret(), key->GetLabel()); | 193 cryptohome::Authorization auth(key->GetSecret(), key->GetLabel()); |
| 197 cryptohome::MountParameters mount(false); | 194 cryptohome::MountParameters mount(false); |
| 198 | 195 |
| 199 cryptohome::HomedirMethods::GetInstance()->MountEx( | 196 cryptohome::HomedirMethods::GetInstance()->MountEx( |
| 200 id, | 197 id, |
| 201 auth, | 198 auth, |
| 202 mount, | 199 mount, |
| 203 base::Bind(&ExtendedAuthenticatorImpl::OnMountComplete, | 200 base::Bind(&ExtendedAuthenticatorImpl::OnMountComplete, |
| 204 this, | 201 this, |
| 205 "MountEx", | 202 "MountEx", |
| 206 user_context, | 203 user_context, |
| 207 success_callback)); | 204 success_callback)); |
| 208 } | 205 } |
| 209 | 206 |
| 210 void ExtendedAuthenticatorImpl::DoAuthenticateToCheck( | 207 void ExtendedAuthenticatorImpl::DoAuthenticateToCheck( |
| 211 const base::Closure& success_callback, | 208 const base::Closure& success_callback, |
| 212 const UserContext& user_context) { | 209 const UserContext& user_context) { |
| 213 RecordStartMarker("CheckKeyEx"); | 210 RecordStartMarker("CheckKeyEx"); |
| 214 | 211 |
| 215 const std::string canonicalized = | 212 cryptohome::Identification id(user_context.GetAccountId()); |
| 216 gaia::CanonicalizeEmail(user_context.GetAccountId().GetUserEmail()); | |
| 217 cryptohome::Identification id(canonicalized); | |
| 218 const Key* const key = user_context.GetKey(); | 213 const Key* const key = user_context.GetKey(); |
| 219 cryptohome::Authorization auth(key->GetSecret(), key->GetLabel()); | 214 cryptohome::Authorization auth(key->GetSecret(), key->GetLabel()); |
| 220 | 215 |
| 221 cryptohome::HomedirMethods::GetInstance()->CheckKeyEx( | 216 cryptohome::HomedirMethods::GetInstance()->CheckKeyEx( |
| 222 id, | 217 id, |
| 223 auth, | 218 auth, |
| 224 base::Bind(&ExtendedAuthenticatorImpl::OnOperationComplete, | 219 base::Bind(&ExtendedAuthenticatorImpl::OnOperationComplete, |
| 225 this, | 220 this, |
| 226 "CheckKeyEx", | 221 "CheckKeyEx", |
| 227 user_context, | 222 user_context, |
| 228 success_callback)); | 223 success_callback)); |
| 229 } | 224 } |
| 230 | 225 |
| 231 void ExtendedAuthenticatorImpl::DoAddKey(const cryptohome::KeyDefinition& key, | 226 void ExtendedAuthenticatorImpl::DoAddKey(const cryptohome::KeyDefinition& key, |
| 232 bool replace_existing, | 227 bool replace_existing, |
| 233 const base::Closure& success_callback, | 228 const base::Closure& success_callback, |
| 234 const UserContext& user_context) { | 229 const UserContext& user_context) { |
| 235 RecordStartMarker("AddKeyEx"); | 230 RecordStartMarker("AddKeyEx"); |
| 236 | 231 |
| 237 const std::string canonicalized = | 232 cryptohome::Identification id(user_context.GetAccountId()); |
| 238 gaia::CanonicalizeEmail(user_context.GetAccountId().GetUserEmail()); | |
| 239 cryptohome::Identification id(canonicalized); | |
| 240 const Key* const auth_key = user_context.GetKey(); | 233 const Key* const auth_key = user_context.GetKey(); |
| 241 cryptohome::Authorization auth(auth_key->GetSecret(), auth_key->GetLabel()); | 234 cryptohome::Authorization auth(auth_key->GetSecret(), auth_key->GetLabel()); |
| 242 | 235 |
| 243 cryptohome::HomedirMethods::GetInstance()->AddKeyEx( | 236 cryptohome::HomedirMethods::GetInstance()->AddKeyEx( |
| 244 id, | 237 id, |
| 245 auth, | 238 auth, |
| 246 key, | 239 key, |
| 247 replace_existing, | 240 replace_existing, |
| 248 base::Bind(&ExtendedAuthenticatorImpl::OnOperationComplete, | 241 base::Bind(&ExtendedAuthenticatorImpl::OnOperationComplete, |
| 249 this, | 242 this, |
| 250 "AddKeyEx", | 243 "AddKeyEx", |
| 251 user_context, | 244 user_context, |
| 252 success_callback)); | 245 success_callback)); |
| 253 } | 246 } |
| 254 | 247 |
| 255 void ExtendedAuthenticatorImpl::DoUpdateKeyAuthorized( | 248 void ExtendedAuthenticatorImpl::DoUpdateKeyAuthorized( |
| 256 const cryptohome::KeyDefinition& key, | 249 const cryptohome::KeyDefinition& key, |
| 257 const std::string& signature, | 250 const std::string& signature, |
| 258 const base::Closure& success_callback, | 251 const base::Closure& success_callback, |
| 259 const UserContext& user_context) { | 252 const UserContext& user_context) { |
| 260 RecordStartMarker("UpdateKeyAuthorized"); | 253 RecordStartMarker("UpdateKeyAuthorized"); |
| 261 | 254 |
| 262 const std::string canonicalized = | 255 cryptohome::Identification id(user_context.GetAccountId()); |
| 263 gaia::CanonicalizeEmail(user_context.GetAccountId().GetUserEmail()); | |
| 264 cryptohome::Identification id(canonicalized); | |
| 265 const Key* const auth_key = user_context.GetKey(); | 256 const Key* const auth_key = user_context.GetKey(); |
| 266 cryptohome::Authorization auth(auth_key->GetSecret(), auth_key->GetLabel()); | 257 cryptohome::Authorization auth(auth_key->GetSecret(), auth_key->GetLabel()); |
| 267 | 258 |
| 268 cryptohome::HomedirMethods::GetInstance()->UpdateKeyEx( | 259 cryptohome::HomedirMethods::GetInstance()->UpdateKeyEx( |
| 269 id, | 260 id, |
| 270 auth, | 261 auth, |
| 271 key, | 262 key, |
| 272 signature, | 263 signature, |
| 273 base::Bind(&ExtendedAuthenticatorImpl::OnOperationComplete, | 264 base::Bind(&ExtendedAuthenticatorImpl::OnOperationComplete, |
| 274 this, | 265 this, |
| 275 "UpdateKeyAuthorized", | 266 "UpdateKeyAuthorized", |
| 276 user_context, | 267 user_context, |
| 277 success_callback)); | 268 success_callback)); |
| 278 } | 269 } |
| 279 | 270 |
| 280 void ExtendedAuthenticatorImpl::DoRemoveKey(const std::string& key_to_remove, | 271 void ExtendedAuthenticatorImpl::DoRemoveKey(const std::string& key_to_remove, |
| 281 const base::Closure& success_callback, | 272 const base::Closure& success_callback, |
| 282 const UserContext& user_context) { | 273 const UserContext& user_context) { |
| 283 RecordStartMarker("RemoveKeyEx"); | 274 RecordStartMarker("RemoveKeyEx"); |
| 284 | 275 |
| 285 const std::string canonicalized = | 276 cryptohome::Identification id(user_context.GetAccountId()); |
| 286 gaia::CanonicalizeEmail(user_context.GetAccountId().GetUserEmail()); | |
| 287 cryptohome::Identification id(canonicalized); | |
| 288 const Key* const auth_key = user_context.GetKey(); | 277 const Key* const auth_key = user_context.GetKey(); |
| 289 cryptohome::Authorization auth(auth_key->GetSecret(), auth_key->GetLabel()); | 278 cryptohome::Authorization auth(auth_key->GetSecret(), auth_key->GetLabel()); |
| 290 | 279 |
| 291 cryptohome::HomedirMethods::GetInstance()->RemoveKeyEx( | 280 cryptohome::HomedirMethods::GetInstance()->RemoveKeyEx( |
| 292 id, | 281 id, |
| 293 auth, | 282 auth, |
| 294 key_to_remove, | 283 key_to_remove, |
| 295 base::Bind(&ExtendedAuthenticatorImpl::OnOperationComplete, | 284 base::Bind(&ExtendedAuthenticatorImpl::OnOperationComplete, |
| 296 this, | 285 this, |
| 297 "RemoveKeyEx", | 286 "RemoveKeyEx", |
| (...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 364 if (consumer_) | 353 if (consumer_) |
| 365 consumer_->OnAuthenticationFailure(state); | 354 consumer_->OnAuthenticationFailure(state); |
| 366 | 355 |
| 367 if (old_consumer_) { | 356 if (old_consumer_) { |
| 368 AuthFailure failure(AuthFailure::UNLOCK_FAILED); | 357 AuthFailure failure(AuthFailure::UNLOCK_FAILED); |
| 369 old_consumer_->OnAuthFailure(failure); | 358 old_consumer_->OnAuthFailure(failure); |
| 370 } | 359 } |
| 371 } | 360 } |
| 372 | 361 |
| 373 } // namespace chromeos | 362 } // namespace chromeos |
| OLD | NEW |