Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(18)

Side by Side Diff: net/ssl/client_cert_store_chromeos.cc

Issue 1274143002: ClientCertStoreChromeOS: support additional non-platform certs. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Remove inefficient filtering Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "net/ssl/client_cert_store_chromeos.h" 5 #include "net/ssl/client_cert_store_chromeos.h"
6 6
7 #include <cert.h> 7 #include <cert.h>
8 #include <algorithm> 8 #include <algorithm>
9 9
10 #include "base/bind.h" 10 #include "base/bind.h"
11 #include "base/bind_helpers.h" 11 #include "base/bind_helpers.h"
12 #include "base/callback.h" 12 #include "base/callback.h"
13 13
14 namespace net { 14 namespace net {
15 15
16 namespace { 16 namespace {
17 17
18 class CertNotAllowedPredicate { 18 class CertNotAllowedPredicate {
19 public: 19 public:
20 explicit CertNotAllowedPredicate( 20 explicit CertNotAllowedPredicate(
21 const ClientCertStoreChromeOS::CertFilter& filter) 21 const ClientCertStoreChromeOS::CertFilter& filter)
22 : filter_(filter) {} 22 : filter_(filter) {}
23
23 bool operator()(const scoped_refptr<X509Certificate>& cert) const { 24 bool operator()(const scoped_refptr<X509Certificate>& cert) const {
24 return !filter_.IsCertAllowed(cert); 25 return !filter_.IsCertAllowed(cert);
25 } 26 }
26 27
27 private: 28 private:
28 const ClientCertStoreChromeOS::CertFilter& filter_; 29 const ClientCertStoreChromeOS::CertFilter& filter_;
29 }; 30 };
30 31
31 } // namespace 32 } // namespace
32 33
33 ClientCertStoreChromeOS::ClientCertStoreChromeOS( 34 ClientCertStoreChromeOS::ClientCertStoreChromeOS(
35 const CertificateList& additional_certs,
34 scoped_ptr<CertFilter> cert_filter, 36 scoped_ptr<CertFilter> cert_filter,
35 const PasswordDelegateFactory& password_delegate_factory) 37 const PasswordDelegateFactory& password_delegate_factory)
36 : ClientCertStoreNSS(password_delegate_factory), 38 : ClientCertStoreNSS(password_delegate_factory),
37 cert_filter_(cert_filter.Pass()) { 39 additional_certs_(additional_certs),
38 } 40 cert_filter_(cert_filter.Pass()) {}
39 41
40 ClientCertStoreChromeOS::~ClientCertStoreChromeOS() {} 42 ClientCertStoreChromeOS::~ClientCertStoreChromeOS() {}
41 43
42 void ClientCertStoreChromeOS::GetClientCerts( 44 void ClientCertStoreChromeOS::GetClientCerts(
43 const SSLCertRequestInfo& cert_request_info, 45 const SSLCertRequestInfo& cert_request_info,
44 CertificateList* selected_certs, 46 CertificateList* selected_certs,
45 const base::Closure& callback) { 47 const base::Closure& callback) {
46 base::Closure bound_callback = 48 base::Closure bound_callback =
47 base::Bind(&ClientCertStoreChromeOS::CertFilterInitialized, 49 base::Bind(&ClientCertStoreChromeOS::CertFilterInitialized,
48 // Caller is responsible for keeping the ClientCertStore alive 50 // Caller is responsible for keeping the ClientCertStore alive
49 // until the callback is run. 51 // until the callback is run.
50 base::Unretained(this), 52 base::Unretained(this),
51 &cert_request_info, 53 &cert_request_info,
52 selected_certs, 54 selected_certs,
53 callback); 55 callback);
54 56
55 if (cert_filter_->Init(bound_callback)) 57 if (cert_filter_->Init(bound_callback))
56 bound_callback.Run(); 58 bound_callback.Run();
57 } 59 }
58 60
59 void ClientCertStoreChromeOS::GetClientCertsImpl( 61 void ClientCertStoreChromeOS::GetClientCertsImpl(
60 CERTCertList* cert_list, 62 CERTCertList* cert_list,
61 const SSLCertRequestInfo& request, 63 const SSLCertRequestInfo& request,
62 bool query_nssdb, 64 bool query_nssdb,
63 CertificateList* selected_certs) { 65 CertificateList* selected_certs) {
64 ClientCertStoreNSS::GetClientCertsImpl( 66 ClientCertStoreNSS::GetClientCertsImpl(
65 cert_list, request, query_nssdb, selected_certs); 67 cert_list, request, query_nssdb, selected_certs);
66 68
67 size_t pre_size = selected_certs->size(); 69 size_t pre_size = selected_certs->size();
68 selected_certs->erase(std::remove_if(selected_certs->begin(), 70 selected_certs->erase(
69 selected_certs->end(), 71 std::remove_if(selected_certs->begin(), selected_certs->end(),
70 CertNotAllowedPredicate(*cert_filter_)), 72 CertNotAllowedPredicate(*cert_filter_)),
71 selected_certs->end()); 73 selected_certs->end());
74
72 DVLOG(1) << "filtered " << pre_size - selected_certs->size() << " of " 75 DVLOG(1) << "filtered " << pre_size - selected_certs->size() << " of "
73 << pre_size << " certs"; 76 << pre_size << " certs";
77
78 // Additionally to the matching certs from the platform's store, allow
79 // matching certificates from |additional_certs_|.
80 CERTCertList* additional_cert_list = CERT_NewCertList();
81 for (const auto& cert : additional_certs_) {
82 CERT_AddCertToListTail(additional_cert_list,
83 CERT_DupCertificate(cert->os_cert_handle()));
84 }
85 CertificateList filtered_additional_certs;
86 ClientCertStoreNSS::GetClientCertsImpl(
87 additional_cert_list, request, query_nssdb, &filtered_additional_certs);
88
89 selected_certs->insert(selected_certs->end(),
90 filtered_additional_certs.begin(),
91 filtered_additional_certs.end());
74 } 92 }
75 93
76 void ClientCertStoreChromeOS::CertFilterInitialized( 94 void ClientCertStoreChromeOS::CertFilterInitialized(
77 const SSLCertRequestInfo* request, 95 const SSLCertRequestInfo* request,
78 CertificateList* selected_certs, 96 CertificateList* selected_certs,
79 const base::Closure& callback) { 97 const base::Closure& callback) {
80 ClientCertStoreNSS::GetClientCerts(*request, selected_certs, callback); 98 ClientCertStoreNSS::GetClientCerts(*request, selected_certs, callback);
81 } 99 }
82 100
83 } // namespace net 101 } // namespace net
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698