Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "net/ssl/client_key_store.h" | |
| 6 | |
| 7 #include "base/memory/singleton.h" | |
| 8 #include "net/cert/x509_certificate.h" | |
| 9 #include "net/ssl/ssl_private_key.h" | |
| 10 | |
| 11 namespace net { | |
| 12 | |
| 13 ClientKeyStore::CertAndKey::CertAndKey() {} | |
| 14 ClientKeyStore::CertAndKey::~CertAndKey() {} | |
| 15 | |
| 16 ClientKeyStore::ClientKeyStore() {} | |
| 17 | |
| 18 ClientKeyStore::~ClientKeyStore() {} | |
| 19 | |
| 20 // static | |
| 21 ClientKeyStore* ClientKeyStore::GetInstance() { | |
| 22 return Singleton<ClientKeyStore, LeakySingletonTraits<ClientKeyStore>>::get(); | |
| 23 } | |
| 24 | |
| 25 ClientKeyStore::ProviderHandle ClientKeyStore::CreateNewProvider() { | |
| 26 base::AutoLock auto_lock(lock_); | |
| 27 return ProviderHandle(next_free_provider_id_++); | |
| 28 } | |
| 29 | |
| 30 void ClientKeyStore::RemoveProvider(ProviderHandle provider) { | |
| 31 base::AutoLock auto_lock(lock_); | |
| 32 certs_per_provider_.erase(provider.id); | |
| 33 } | |
| 34 | |
| 35 void ClientKeyStore::SetCertificates(ProviderHandle provider, | |
| 36 CertsAndKeys* certs) { | |
| 37 { | |
| 38 base::AutoLock auto_lock(lock_); | |
| 39 CertsAndKeys& stored_certs = certs_per_provider_[provider.id]; | |
| 40 stored_certs.swap(*certs); | |
| 41 } | |
| 42 certs->clear(); | |
| 43 } | |
| 44 | |
| 45 scoped_ptr<SSLPrivateKey> ClientKeyStore::FetchClientCertPrivateKey( | |
| 46 const X509Certificate* certificate) { | |
| 47 base::AutoLock auto_lock(lock_); | |
| 48 for (const auto& provider_and_certs : certs_per_provider_) { | |
| 49 const CertsAndKeys& certs_and_keys = provider_and_certs.second; | |
| 50 for (const auto& cert_and_key : certs_and_keys) { | |
| 51 if (certificate->Equals(cert_and_key.certificate.get())) | |
|
Ryan Sleevi
2015/08/08 00:14:22
This also seems quite inefficient; a linear scan.
pneubeck (no reviews)
2015/08/13 08:20:19
refactored. (I will do so in the implementation of
| |
| 52 return cert_and_key.key_getter.Run(); | |
| 53 } | |
| 54 } | |
| 55 return nullptr; | |
| 56 } | |
| 57 | |
| 58 } // namespace net | |
| OLD | NEW |