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 |