Index: chrome/browser/password_manager/password_store_proxy_mac.h |
diff --git a/chrome/browser/password_manager/password_store_proxy_mac.h b/chrome/browser/password_manager/password_store_proxy_mac.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..7e092ba0f722bea08a9ad475b1a9243a5751f8b2 |
--- /dev/null |
+++ b/chrome/browser/password_manager/password_store_proxy_mac.h |
@@ -0,0 +1,80 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef CHROME_BROWSER_PASSWORD_MANAGER_PASSWORD_STORE_PROXY_MAC_H_ |
+#define CHROME_BROWSER_PASSWORD_MANAGER_PASSWORD_STORE_PROXY_MAC_H_ |
+ |
+#include "components/password_manager/core/browser/password_store.h" |
+ |
+namespace crypto { |
+class AppleKeychain; |
+} |
+ |
+namespace password_manager { |
+class LoginDatabase; |
+} |
+ |
+class PasswordStoreMac; |
+class SimplePasswordStoreMac; |
+ |
+// The class is a proxy for either PasswordStoreMac or SimplePasswordStoreMac. |
+// It is responsible for performing migration from PasswordStoreMac to |
+// SimplePasswordStoreMac and instantiating a correct backend according to the |
+// user's state. |
+class PasswordStoreProxyMac : public password_manager::PasswordStore { |
+ public: |
+ PasswordStoreProxyMac( |
+ scoped_refptr<base::SingleThreadTaskRunner> main_thread_runner, |
+ scoped_ptr<crypto::AppleKeychain> keychain, |
+ scoped_ptr<password_manager::LoginDatabase> login_db); |
+ |
+ bool Init(const syncer::SyncableService::StartSyncFlare& flare) override; |
+ void Shutdown() override; |
+ |
+ protected: |
+ ~PasswordStoreProxyMac() override; |
+ |
+ password_manager::PasswordStore* GetBackend() const; |
+ |
+ // PasswordStore: |
+ scoped_refptr<base::SingleThreadTaskRunner> GetBackgroundTaskRunner() |
+ override; |
+ void ReportMetricsImpl(const std::string& sync_username, |
+ bool custom_passphrase_sync_enabled) override; |
+ password_manager::PasswordStoreChangeList AddLoginImpl( |
+ const autofill::PasswordForm& form) override; |
+ password_manager::PasswordStoreChangeList UpdateLoginImpl( |
+ const autofill::PasswordForm& form) override; |
+ password_manager::PasswordStoreChangeList RemoveLoginImpl( |
+ const autofill::PasswordForm& form) override; |
+ password_manager::PasswordStoreChangeList RemoveLoginsCreatedBetweenImpl( |
+ base::Time delete_begin, |
+ base::Time delete_end) override; |
+ password_manager::PasswordStoreChangeList RemoveLoginsSyncedBetweenImpl( |
+ base::Time delete_begin, |
+ base::Time delete_end) override; |
+ ScopedVector<autofill::PasswordForm> FillMatchingLogins( |
+ const autofill::PasswordForm& form, |
+ AuthorizationPromptPolicy prompt_policy) override; |
+ void GetAutofillableLoginsImpl( |
+ scoped_ptr<PasswordStore::GetLoginsRequest> request) override; |
+ void GetBlacklistLoginsImpl( |
+ scoped_ptr<PasswordStore::GetLoginsRequest> request) override; |
+ bool FillAutofillableLogins( |
+ ScopedVector<autofill::PasswordForm>* forms) override; |
+ bool FillBlacklistLogins( |
+ ScopedVector<autofill::PasswordForm>* forms) override; |
+ void AddSiteStatsImpl( |
+ const password_manager::InteractionsStats& stats) override; |
+ void RemoveSiteStatsImpl(const GURL& origin_domain) override; |
+ scoped_ptr<password_manager::InteractionsStats> GetSiteStatsImpl( |
+ const GURL& origin_domain) override; |
+ |
+ scoped_refptr<PasswordStoreMac> password_store_mac_; |
+ scoped_refptr<SimplePasswordStoreMac> password_store_simple_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(PasswordStoreProxyMac); |
Garrett Casto
2015/06/22 08:24:08
Should this be private?
vasilii
2015/06/22 13:34:17
Done.
|
+}; |
+ |
+#endif // CHROME_BROWSER_PASSWORD_MANAGER_PASSWORD_STORE_PROXY_MAC_H_ |