Index: net/ssl/client_key_store.cc |
diff --git a/net/ssl/client_key_store.cc b/net/ssl/client_key_store.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..3cc4acc5df6e5ab16308fdf8e3995f800f610792 |
--- /dev/null |
+++ b/net/ssl/client_key_store.cc |
@@ -0,0 +1,49 @@ |
+// 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. |
+ |
+#include "net/ssl/client_key_store.h" |
+ |
+#include <algorithm> |
+ |
+#include "base/memory/singleton.h" |
+#include "net/cert/x509_certificate.h" |
+#include "net/ssl/ssl_private_key.h" |
+ |
+namespace net { |
+ |
+ClientKeyStore::ClientKeyStore() {} |
+ |
+ClientKeyStore::~ClientKeyStore() {} |
+ |
+// static |
+ClientKeyStore* ClientKeyStore::GetInstance() { |
+ return Singleton<ClientKeyStore, LeakySingletonTraits<ClientKeyStore>>::get(); |
+} |
+ |
+void ClientKeyStore::AddProvider(scoped_ptr<CertKeyProvider> provider) { |
+ base::AutoLock auto_lock(lock_); |
+ providers_.push_back(provider.Pass()); |
+} |
+ |
+void ClientKeyStore::RemoveProvider(const CertKeyProvider* provider) { |
+ base::AutoLock auto_lock(lock_); |
+ |
+ const auto& it = std::find(providers_.begin(), providers_.end(), provider); |
+ if (it != providers_.end()) |
+ providers_.erase(it); |
+} |
+ |
+scoped_ptr<SSLPrivateKey> ClientKeyStore::FetchClientCertPrivateKey( |
+ const X509Certificate& certificate) { |
+ base::AutoLock auto_lock(lock_); |
+ |
+ for (const auto& provider : providers_) { |
+ scoped_ptr<SSLPrivateKey> key; |
+ if (provider->GetCertificateKey(certificate, &key)) |
davidben
2015/08/14 22:16:48
Calling a virtual function inside a lock makes me
pneubeck (no reviews)
2015/08/17 14:34:19
I'm not sure what you're nervous about. Is it beca
|
+ return key.Pass(); |
+ } |
+ return nullptr; |
+} |
+ |
+} // namespace net |