diff options
author | evan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-22 02:02:18 +0000 |
---|---|---|
committer | evan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-05-22 02:02:18 +0000 |
commit | f02e75847af83123902bd465ddd30276306abd49 (patch) | |
tree | e5efba00bc3ca2f9ffc8f354b93ebcf9d8eefc01 /chrome/browser/profile.cc | |
parent | 139ec96dc6f26a24d8812aad4470f00b36ecee52 (diff) | |
download | chromium_src-f02e75847af83123902bd465ddd30276306abd49.zip chromium_src-f02e75847af83123902bd465ddd30276306abd49.tar.gz chromium_src-f02e75847af83123902bd465ddd30276306abd49.tar.bz2 |
Patch to make password patch build.
Review URL: http://codereview.chromium.org/113710
Patch from John Maguire <johnmaguire@google.com>.
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@16708 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/profile.cc')
-rw-r--r-- | chrome/browser/profile.cc | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/chrome/browser/profile.cc b/chrome/browser/profile.cc index 1ef234c..4afea85 100644 --- a/chrome/browser/profile.cc +++ b/chrome/browser/profile.cc @@ -20,6 +20,7 @@ #include "chrome/browser/extensions/user_script_master.h" #include "chrome/browser/history/history.h" #include "chrome/browser/net/chrome_url_request_context.h" +#include "chrome/browser/password_manager/password_store_default.h" #include "chrome/browser/profile_manager.h" #include "chrome/browser/renderer_host/render_process_host.h" #include "chrome/browser/search_engines/template_url_fetcher.h" @@ -88,6 +89,14 @@ URLRequestContext* Profile::GetDefaultRequestContext() { return default_request_context_; } +#if defined(OS_LINUX) +// Temporarily disabled while we figure some stuff out. +// http://code.google.com/p/chromium/issues/detail?id=12351 +// #include "chrome/browser/password_manager/password_store_gnome.h" +// #include "chrome/browser/password_manager/password_store_kwallet.h" +#elif defined(OS_WIN) +#include "chrome/browser/password_manager/password_store_win.h" +#endif //////////////////////////////////////////////////////////////////////////////// // @@ -191,6 +200,15 @@ class OffTheRecordProfileImpl : public Profile, } } + virtual PasswordStore* GetPasswordStore(ServiceAccessType sat) { + if (sat == EXPLICIT_ACCESS) { + return profile_->GetPasswordStore(sat); + } else { + NOTREACHED() << "This profile is OffTheRecord"; + return NULL; + } + } + virtual PrefService* GetPrefs() { return profile_->GetPrefs(); } @@ -412,6 +430,7 @@ ProfileImpl::ProfileImpl(const FilePath& path) extensions_request_context_(NULL), history_service_created_(false), created_web_data_service_(false), + created_password_store_(false), created_download_manager_(false), created_theme_provider_(false), start_time_(Time::Now()), @@ -785,6 +804,41 @@ void ProfileImpl::CreateWebDataService() { web_data_service_.swap(wds); } +PasswordStore* ProfileImpl::GetPasswordStore(ServiceAccessType sat) { + if (!created_password_store_) + CreatePasswordStore(); + return password_store_.get(); +} + +void ProfileImpl::CreatePasswordStore() { + DCHECK(!created_password_store_ && password_store_.get() == NULL); + created_password_store_ = true; + scoped_refptr<PasswordStore> ps; +#if defined(OS_LINUX) +// Temporarily disabled while we figure some stuff out. +// http://code.google.com/p/chromium/issues/detail?id=12351 +// if (getenv("KDE_FULL_SESSION")) { +// ps = new PasswordStoreKWallet(); +// } else { +// ps = new PasswordStoreGnome(); +// } + NOTIMPLEMENTED(); +#elif defined(OS_WIN) + ps = new PasswordStoreWin(GetWebDataService(Profile::IMPLICIT_ACCESS)); +#else + NOTIMPLEMENTED(); +#endif + if (!ps || !ps->Init()) { + // Try falling back to the default password manager + LOG(WARNING) << "Could not initialise native password manager - " + "falling back to default"; + ps = new PasswordStoreDefault(GetWebDataService(Profile::IMPLICIT_ACCESS)); + if (!ps->Init()) + return; + } + password_store_.swap(ps); +} + DownloadManager* ProfileImpl::GetDownloadManager() { if (!created_download_manager_) { scoped_refptr<DownloadManager> dlm(new DownloadManager); |