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

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: 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 CertificateList& additional_certs,
21 const ClientCertStoreChromeOS::CertFilter& filter) 22 const ClientCertStoreChromeOS::CertFilter& filter)
22 : filter_(filter) {} 23 : additional_certs_(additional_certs), filter_(filter) {}
24
23 bool operator()(const scoped_refptr<X509Certificate>& cert) const { 25 bool operator()(const scoped_refptr<X509Certificate>& cert) const {
26 for (const auto& additional_cert : additional_certs_) {
27 if (additional_cert->Equals(cert.get()))
28 return false;
29 }
24 return !filter_.IsCertAllowed(cert); 30 return !filter_.IsCertAllowed(cert);
25 } 31 }
26 32
27 private: 33 private:
34 const CertificateList& additional_certs_;
28 const ClientCertStoreChromeOS::CertFilter& filter_; 35 const ClientCertStoreChromeOS::CertFilter& filter_;
29 }; 36 };
30 37
31 } // namespace 38 } // namespace
32 39
33 ClientCertStoreChromeOS::ClientCertStoreChromeOS( 40 ClientCertStoreChromeOS::ClientCertStoreChromeOS(
41 const CertificateList& additional_certs,
34 scoped_ptr<CertFilter> cert_filter, 42 scoped_ptr<CertFilter> cert_filter,
35 const PasswordDelegateFactory& password_delegate_factory) 43 const PasswordDelegateFactory& password_delegate_factory)
36 : ClientCertStoreNSS(password_delegate_factory), 44 : ClientCertStoreNSS(password_delegate_factory),
37 cert_filter_(cert_filter.Pass()) { 45 additional_certs_(additional_certs),
38 } 46 cert_filter_(cert_filter.Pass()) {}
39 47
40 ClientCertStoreChromeOS::~ClientCertStoreChromeOS() {} 48 ClientCertStoreChromeOS::~ClientCertStoreChromeOS() {}
41 49
42 void ClientCertStoreChromeOS::GetClientCerts( 50 void ClientCertStoreChromeOS::GetClientCerts(
43 const SSLCertRequestInfo& cert_request_info, 51 const SSLCertRequestInfo& cert_request_info,
44 CertificateList* selected_certs, 52 CertificateList* selected_certs,
45 const base::Closure& callback) { 53 const base::Closure& callback) {
46 base::Closure bound_callback = 54 base::Closure bound_callback =
47 base::Bind(&ClientCertStoreChromeOS::CertFilterInitialized, 55 base::Bind(&ClientCertStoreChromeOS::CertFilterInitialized,
48 // Caller is responsible for keeping the ClientCertStore alive 56 // Caller is responsible for keeping the ClientCertStore alive
49 // until the callback is run. 57 // until the callback is run.
50 base::Unretained(this), 58 base::Unretained(this),
51 &cert_request_info, 59 &cert_request_info,
52 selected_certs, 60 selected_certs,
53 callback); 61 callback);
54 62
55 if (cert_filter_->Init(bound_callback)) 63 if (cert_filter_->Init(bound_callback))
56 bound_callback.Run(); 64 bound_callback.Run();
57 } 65 }
58 66
59 void ClientCertStoreChromeOS::GetClientCertsImpl( 67 void ClientCertStoreChromeOS::GetClientCertsImpl(
60 CERTCertList* cert_list, 68 CERTCertList* cert_list,
61 const SSLCertRequestInfo& request, 69 const SSLCertRequestInfo& request,
62 bool query_nssdb, 70 bool query_nssdb,
63 CertificateList* selected_certs) { 71 CertificateList* selected_certs) {
72 for (const auto& cert : additional_certs_) {
73 CERT_AddCertToListTail(cert_list,
74 CERT_DupCertificate(cert->os_cert_handle()));
75 }
76
64 ClientCertStoreNSS::GetClientCertsImpl( 77 ClientCertStoreNSS::GetClientCertsImpl(
65 cert_list, request, query_nssdb, selected_certs); 78 cert_list, request, query_nssdb, selected_certs);
66 79
67 size_t pre_size = selected_certs->size(); 80 size_t pre_size = selected_certs->size();
68 selected_certs->erase(std::remove_if(selected_certs->begin(), 81
69 selected_certs->end(), 82 // Remove certificates that are not allowed by |cert_filter_| but always keep
70 CertNotAllowedPredicate(*cert_filter_)), 83 // certificates from |additional_certs_|.
71 selected_certs->end()); 84 selected_certs->erase(
85 std::remove_if(selected_certs->begin(), selected_certs->end(),
86 CertNotAllowedPredicate(additional_certs_, *cert_filter_)),
87 selected_certs->end());
Ryan Sleevi 2015/08/07 23:51:09 This seems highly inefficient - the operator() ope
pneubeck (no reviews) 2015/08/10 12:09:56 Done.
72 DVLOG(1) << "filtered " << pre_size - selected_certs->size() << " of " 88 DVLOG(1) << "filtered " << pre_size - selected_certs->size() << " of "
73 << pre_size << " certs"; 89 << pre_size << " certs";
74 } 90 }
75 91
76 void ClientCertStoreChromeOS::CertFilterInitialized( 92 void ClientCertStoreChromeOS::CertFilterInitialized(
77 const SSLCertRequestInfo* request, 93 const SSLCertRequestInfo* request,
78 CertificateList* selected_certs, 94 CertificateList* selected_certs,
79 const base::Closure& callback) { 95 const base::Closure& callback) {
80 ClientCertStoreNSS::GetClientCerts(*request, selected_certs, callback); 96 ClientCertStoreNSS::GetClientCerts(*request, selected_certs, callback);
81 } 97 }
82 98
83 } // namespace net 99 } // namespace net
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698