| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/password_manager/password_store_factory.h" | 5 #include "chrome/browser/password_manager/password_store_factory.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/environment.h" | 8 #include "base/environment.h" |
| 9 #include "base/metrics/histogram_macros.h" | |
| 10 #include "base/prefs/pref_service.h" | 9 #include "base/prefs/pref_service.h" |
| 11 #include "chrome/browser/password_manager/password_manager_util.h" | |
| 12 #include "chrome/browser/password_manager/sync_metrics.h" | 10 #include "chrome/browser/password_manager/sync_metrics.h" |
| 13 #include "chrome/browser/profiles/incognito_helpers.h" | 11 #include "chrome/browser/profiles/incognito_helpers.h" |
| 14 #include "chrome/browser/sync/glue/sync_start_util.h" | 12 #include "chrome/browser/sync/glue/sync_start_util.h" |
| 15 #include "chrome/browser/webdata/web_data_service_factory.h" | 13 #include "chrome/browser/webdata/web_data_service_factory.h" |
| 16 #include "chrome/common/chrome_constants.h" | 14 #include "chrome/common/chrome_constants.h" |
| 17 #include "chrome/common/chrome_switches.h" | 15 #include "chrome/common/chrome_switches.h" |
| 18 #include "components/keyed_service/content/browser_context_dependency_manager.h" | 16 #include "components/keyed_service/content/browser_context_dependency_manager.h" |
| 19 #include "components/os_crypt/os_crypt_switches.h" | 17 #include "components/os_crypt/os_crypt_switches.h" |
| 20 #include "components/password_manager/core/browser/login_database.h" | 18 #include "components/password_manager/core/browser/login_database.h" |
| 21 #include "components/password_manager/core/browser/password_store.h" | 19 #include "components/password_manager/core/browser/password_store.h" |
| (...skipping 15 matching lines...) Expand all Loading... |
| 37 #include "base/nix/xdg_util.h" | 35 #include "base/nix/xdg_util.h" |
| 38 #if defined(USE_GNOME_KEYRING) | 36 #if defined(USE_GNOME_KEYRING) |
| 39 #include "chrome/browser/password_manager/native_backend_gnome_x.h" | 37 #include "chrome/browser/password_manager/native_backend_gnome_x.h" |
| 40 #endif | 38 #endif |
| 41 #include "chrome/browser/password_manager/native_backend_kwallet_x.h" | 39 #include "chrome/browser/password_manager/native_backend_kwallet_x.h" |
| 42 #include "chrome/browser/password_manager/password_store_x.h" | 40 #include "chrome/browser/password_manager/password_store_x.h" |
| 43 #endif | 41 #endif |
| 44 | 42 |
| 45 using password_manager::PasswordStore; | 43 using password_manager::PasswordStore; |
| 46 | 44 |
| 45 #if !defined(OS_CHROMEOS) && defined(USE_X11) |
| 47 namespace { | 46 namespace { |
| 48 | 47 |
| 49 #if !defined(OS_CHROMEOS) && defined(USE_X11) | |
| 50 const LocalProfileId kInvalidLocalProfileId = | 48 const LocalProfileId kInvalidLocalProfileId = |
| 51 static_cast<LocalProfileId>(0); | 49 static_cast<LocalProfileId>(0); |
| 52 #endif | |
| 53 | |
| 54 void ReportOsPassword() { | |
| 55 password_manager_util::OsPasswordStatus status = | |
| 56 password_manager_util::GetOsPasswordStatus(); | |
| 57 | |
| 58 UMA_HISTOGRAM_ENUMERATION("PasswordManager.OsPasswordStatus", | |
| 59 status, | |
| 60 password_manager_util::MAX_PASSWORD_STATUS); | |
| 61 } | |
| 62 | |
| 63 void DelayReportOsPassword() { | |
| 64 // Avoid checking OS password until later on in browser startup | |
| 65 // since it calls a few Windows APIs. | |
| 66 content::BrowserThread::PostDelayedTask( | |
| 67 content::BrowserThread::FILE, | |
| 68 FROM_HERE, | |
| 69 base::Bind(&ReportOsPassword), | |
| 70 base::TimeDelta::FromSeconds(40)); | |
| 71 } | |
| 72 | 50 |
| 73 } // namespace | 51 } // namespace |
| 74 | 52 #endif |
| 75 | 53 |
| 76 PasswordStoreService::PasswordStoreService( | 54 PasswordStoreService::PasswordStoreService( |
| 77 scoped_refptr<PasswordStore> password_store) | 55 scoped_refptr<PasswordStore> password_store) |
| 78 : password_store_(password_store) {} | 56 : password_store_(password_store) {} |
| 79 | 57 |
| 80 PasswordStoreService::~PasswordStoreService() {} | 58 PasswordStoreService::~PasswordStoreService() {} |
| 81 | 59 |
| 82 scoped_refptr<PasswordStore> PasswordStoreService::GetPasswordStore() { | 60 scoped_refptr<PasswordStore> PasswordStoreService::GetPasswordStore() { |
| 83 return password_store_; | 61 return password_store_; |
| 84 } | 62 } |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 137 // TODO(mdm): scan other profiles to make sure they are not using this id? | 115 // TODO(mdm): scan other profiles to make sure they are not using this id? |
| 138 } while (id == kInvalidLocalProfileId); | 116 } while (id == kInvalidLocalProfileId); |
| 139 prefs->SetInteger(password_manager::prefs::kLocalProfileId, id); | 117 prefs->SetInteger(password_manager::prefs::kLocalProfileId, id); |
| 140 } | 118 } |
| 141 return id; | 119 return id; |
| 142 } | 120 } |
| 143 #endif | 121 #endif |
| 144 | 122 |
| 145 KeyedService* PasswordStoreFactory::BuildServiceInstanceFor( | 123 KeyedService* PasswordStoreFactory::BuildServiceInstanceFor( |
| 146 content::BrowserContext* context) const { | 124 content::BrowserContext* context) const { |
| 147 DelayReportOsPassword(); | |
| 148 Profile* profile = static_cast<Profile*>(context); | 125 Profile* profile = static_cast<Profile*>(context); |
| 149 | 126 |
| 150 base::FilePath login_db_file_path = profile->GetPath(); | 127 base::FilePath login_db_file_path = profile->GetPath(); |
| 151 login_db_file_path = login_db_file_path.Append(chrome::kLoginDataFileName); | 128 login_db_file_path = login_db_file_path.Append(chrome::kLoginDataFileName); |
| 152 scoped_ptr<password_manager::LoginDatabase> login_db( | 129 scoped_ptr<password_manager::LoginDatabase> login_db( |
| 153 new password_manager::LoginDatabase()); | 130 new password_manager::LoginDatabase()); |
| 154 { | 131 { |
| 155 // TODO(paivanof@gmail.com): execution of login_db->Init() should go | 132 // TODO(paivanof@gmail.com): execution of login_db->Init() should go |
| 156 // to DB thread. http://crbug.com/138903 | 133 // to DB thread. http://crbug.com/138903 |
| 157 base::ThreadRestrictions::ScopedAllowIO allow_io; | 134 base::ThreadRestrictions::ScopedAllowIO allow_io; |
| (...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 273 } | 250 } |
| 274 | 251 |
| 275 content::BrowserContext* PasswordStoreFactory::GetBrowserContextToUse( | 252 content::BrowserContext* PasswordStoreFactory::GetBrowserContextToUse( |
| 276 content::BrowserContext* context) const { | 253 content::BrowserContext* context) const { |
| 277 return chrome::GetBrowserContextRedirectedInIncognito(context); | 254 return chrome::GetBrowserContextRedirectedInIncognito(context); |
| 278 } | 255 } |
| 279 | 256 |
| 280 bool PasswordStoreFactory::ServiceIsNULLWhileTesting() const { | 257 bool PasswordStoreFactory::ServiceIsNULLWhileTesting() const { |
| 281 return true; | 258 return true; |
| 282 } | 259 } |
| OLD | NEW |