| Index: net/cert/nss_cert_database_chromeos.cc
|
| diff --git a/net/cert/nss_cert_database_chromeos.cc b/net/cert/nss_cert_database_chromeos.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..936287c2204fa75f5b350540d4363d910952760e
|
| --- /dev/null
|
| +++ b/net/cert/nss_cert_database_chromeos.cc
|
| @@ -0,0 +1,65 @@
|
| +// Copyright 2013 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/cert/nss_cert_database_chromeos.h"
|
| +
|
| +#include <cert.h>
|
| +#include <pk11pub.h>
|
| +
|
| +#include "net/base/crypto_module.h"
|
| +#include "net/cert/x509_certificate.h"
|
| +
|
| +namespace net {
|
| +
|
| +NSSCertDatabaseChromeOS::NSSCertDatabaseChromeOS(
|
| + crypto::ScopedPK11Slot public_slot,
|
| + crypto::ScopedPK11Slot private_slot)
|
| + : public_slot_(public_slot.Pass()),
|
| + private_slot_(private_slot.Pass()) {
|
| + profile_filter_.Init(GetPublicSlot(), GetPrivateSlot());
|
| +}
|
| +
|
| +NSSCertDatabaseChromeOS::~NSSCertDatabaseChromeOS() {}
|
| +
|
| +void NSSCertDatabaseChromeOS::ListCerts(CertificateList* certs) {
|
| + NSSCertDatabase::ListCerts(certs);
|
| +
|
| + size_t pre_size = certs->size();
|
| + certs->erase(std::remove_if(
|
| + certs->begin(),
|
| + certs->end(),
|
| + NSSProfileFilterChromeOS::CertNotAllowedForProfilePredicate(
|
| + profile_filter_)),
|
| + certs->end());
|
| + DVLOG(1) << "filtered " << pre_size - certs->size() << " of " << pre_size
|
| + << " certs";
|
| +}
|
| +
|
| +crypto::ScopedPK11Slot NSSCertDatabaseChromeOS::GetPublicSlot() const {
|
| + return crypto::ScopedPK11Slot(
|
| + public_slot_ ? PK11_ReferenceSlot(public_slot_.get()) : NULL);
|
| +}
|
| +
|
| +crypto::ScopedPK11Slot NSSCertDatabaseChromeOS::GetPrivateSlot() const {
|
| + return crypto::ScopedPK11Slot(
|
| + private_slot_ ? PK11_ReferenceSlot(private_slot_.get()) : NULL);
|
| +}
|
| +
|
| +void NSSCertDatabaseChromeOS::ListModules(CryptoModuleList* modules,
|
| + bool need_rw) const {
|
| + NSSCertDatabase::ListModules(modules, need_rw);
|
| +
|
| + size_t pre_size = modules->size();
|
| + modules->erase(
|
| + std::remove_if(
|
| + modules->begin(),
|
| + modules->end(),
|
| + NSSProfileFilterChromeOS::ModuleNotAllowedForProfilePredicate(
|
| + profile_filter_)),
|
| + modules->end());
|
| + DVLOG(1) << "filtered " << pre_size - modules->size() << " of " << pre_size
|
| + << " modules";
|
| +}
|
| +
|
| +} // namespace net
|
|
|