Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(73)

Side by Side Diff: chrome/browser/chromeos/login/supervised_user_manager_impl.cc

Issue 132803012: Attempt to recover sync token for managed user once we detected that sync auth fails. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix usage of metrics Created 6 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « chrome/browser/chromeos/login/supervised_user_manager_impl.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/supervised_user_manager_impl.h" 5 #include "chrome/browser/chromeos/login/supervised_user_manager_impl.h"
6 6
7 #include "base/file_util.h"
8 #include "base/files/file_path.h"
7 #include "base/prefs/pref_registry_simple.h" 9 #include "base/prefs/pref_registry_simple.h"
8 #include "base/prefs/pref_service.h" 10 #include "base/prefs/pref_service.h"
9 #include "base/prefs/scoped_user_pref_update.h" 11 #include "base/prefs/scoped_user_pref_update.h"
10 #include "base/strings/string_util.h" 12 #include "base/strings/string_util.h"
11 #include "base/strings/stringprintf.h" 13 #include "base/strings/stringprintf.h"
12 #include "base/strings/utf_string_conversions.h" 14 #include "base/strings/utf_string_conversions.h"
15 #include "base/threading/sequenced_worker_pool.h"
13 #include "base/values.h" 16 #include "base/values.h"
14 #include "chrome/browser/browser_process.h" 17 #include "chrome/browser/browser_process.h"
18 #include "chrome/browser/chromeos/login/managed/locally_managed_user_constants.h "
15 #include "chrome/browser/chromeos/login/managed/supervised_user_authentication.h " 19 #include "chrome/browser/chromeos/login/managed/supervised_user_authentication.h "
16 #include "chrome/browser/chromeos/login/user_manager_impl.h" 20 #include "chrome/browser/chromeos/login/user_manager_impl.h"
21 #include "chrome/browser/chromeos/profiles/profile_helper.h"
22 #include "chrome/browser/managed_mode/managed_user_service.h"
23 #include "chrome/browser/managed_mode/managed_user_service_factory.h"
17 #include "chromeos/settings/cros_settings_names.h" 24 #include "chromeos/settings/cros_settings_names.h"
18 #include "content/public/browser/browser_thread.h" 25 #include "content/public/browser/browser_thread.h"
19 #include "google_apis/gaia/gaia_auth_util.h" 26 #include "google_apis/gaia/gaia_auth_util.h"
20 27
21 using content::BrowserThread; 28 using content::BrowserThread;
22 29
23 namespace { 30 namespace {
24 31
25 // Names for pref keys in Local State. 32 // Names for pref keys in Local State.
26 // A map from locally managed user local user id to sync user id. 33 // A map from locally managed user local user id to sync user id.
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after
60 "SupervisedUserPasswordSchema"; 67 "SupervisedUserPasswordSchema";
61 68
62 // A map from user id to password salt. 69 // A map from user id to password salt.
63 const char kSupervisedUserPasswordSalt[] = 70 const char kSupervisedUserPasswordSalt[] =
64 "SupervisedUserPasswordSalt"; 71 "SupervisedUserPasswordSalt";
65 72
66 // A map from user id to password revision. 73 // A map from user id to password revision.
67 const char kSupervisedUserPasswordRevision[] = 74 const char kSupervisedUserPasswordRevision[] =
68 "SupervisedUserPasswordRevision"; 75 "SupervisedUserPasswordRevision";
69 76
77 std::string LoadSyncToken(base::FilePath profile_dir) {
78 std::string token;
79 base::FilePath token_file =
80 profile_dir.Append(chromeos::kManagedUserTokenFilename);
81 VLOG(1) << "Loading" << token_file.value();
82 if (!base::ReadFileToString(token_file, &token))
83 return std::string();
84 return token;
85 }
86
70 } // namespace 87 } // namespace
71 88
72 namespace chromeos { 89 namespace chromeos {
73 90
74 const char kSchemaVersion[] = "SchemaVersion"; 91 const char kSchemaVersion[] = "SchemaVersion";
75 const char kPasswordRevision[] = "PasswordRevision"; 92 const char kPasswordRevision[] = "PasswordRevision";
76 const char kSalt[] = "PasswordSalt"; 93 const char kSalt[] = "PasswordSalt";
77 const char kEncryptedPassword[] = "EncryptedPassword"; 94 const char kEncryptedPassword[] = "EncryptedPassword";
78 const int kMinPasswordRevision = 1; 95 const int kMinPasswordRevision = 1;
79 96
(...skipping 330 matching lines...) Expand 10 before | Expand all | Expand 10 after
410 it.key(), 427 it.key(),
411 new base::StringValue(new_display_name)); 428 new base::StringValue(new_display_name));
412 } 429 }
413 } 430 }
414 } 431 }
415 432
416 SupervisedUserAuthentication* SupervisedUserManagerImpl::GetAuthentication() { 433 SupervisedUserAuthentication* SupervisedUserManagerImpl::GetAuthentication() {
417 return authentication_.get(); 434 return authentication_.get();
418 } 435 }
419 436
437 void SupervisedUserManagerImpl::LoadSupervisedUserToken(
438 Profile* profile,
439 const LoadTokenCallback& callback) {
440 // TODO(antrim): use profile->GetPath() once we sure it is safe.
441 base::FilePath profile_dir = ProfileHelper::GetProfilePathByUserIdHash(
442 UserManager::Get()->GetUserByProfile(profile)->username_hash());
443 PostTaskAndReplyWithResult(
444 content::BrowserThread::GetBlockingPool(),
445 FROM_HERE,
446 base::Bind(&LoadSyncToken, profile_dir),
447 callback);
448 }
449
450 void SupervisedUserManagerImpl::ConfigureSyncWithToken(
451 Profile* profile,
452 const std::string& token) {
453 if (!token.empty())
454 ManagedUserServiceFactory::GetForProfile(profile)->InitSync(token);
455 }
456
420 } // namespace chromeos 457 } // namespace chromeos
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/login/supervised_user_manager_impl.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698