aboutsummaryrefslogtreecommitdiffstats
path: root/src/cert/x509store/certstor.cpp
diff options
context:
space:
mode:
authorlloyd <[email protected]>2010-09-17 21:43:34 +0000
committerlloyd <[email protected]>2010-09-17 21:43:34 +0000
commitf9d51dc97769c8dcda90221543f743a72391b2c2 (patch)
treed5ff9b210db4d9b30389e5c1dba6bf09a55ce464 /src/cert/x509store/certstor.cpp
parent3d10622abb3d06fb02affe31a25f059a58d8c84e (diff)
Define a simpler Certificate_Store interface which should be much
easier to implement without requiring in-memory linear searching (eg a flatfile store or SQL database with indexes).
Diffstat (limited to 'src/cert/x509store/certstor.cpp')
-rw-r--r--src/cert/x509store/certstor.cpp45
1 files changed, 20 insertions, 25 deletions
diff --git a/src/cert/x509store/certstor.cpp b/src/cert/x509store/certstor.cpp
index 96f2699df..1730dd18f 100644
--- a/src/cert/x509store/certstor.cpp
+++ b/src/cert/x509store/certstor.cpp
@@ -9,40 +9,35 @@
namespace Botan {
-/*
-* Search by name
-*/
-std::vector<X509_Certificate>
-Certificate_Store::by_name(const std::string&) const
+void Certificate_Store_Memory::add_certificate(const X509_Certificate& cert)
{
- return std::vector<X509_Certificate>();
+ certs.push_back(cert);
}
-/*
-* Search by email
-*/
-std::vector<X509_Certificate>
-Certificate_Store::by_email(const std::string&) const
+Certificate_Store* Certificate_Store_Memory::clone() const
{
- return std::vector<X509_Certificate>();
+ return new Certificate_Store_Memory(*this);
}
-/*
-* Search by X.500 distinguished name
-*/
std::vector<X509_Certificate>
-Certificate_Store::by_dn(const X509_DN&) const
+Certificate_Store_Memory::find_by_subject_and_key_id(
+ const X509_DN& subject_dn,
+ const MemoryRegion<byte>& key_id)
{
- return std::vector<X509_Certificate>();
- }
+ std::vector<X509_Certificate> result;
-/*
-* Find any CRLs that might be useful
-*/
-std::vector<X509_CRL>
-Certificate_Store::get_crls_for(const X509_Certificate&) const
- {
- return std::vector<X509_CRL>();
+ for(size_t i = 0; i != certs.size(); ++i)
+ {
+ MemoryVector<byte> skid = certs[i].subject_key_id();
+
+ if(key_id.size() && skid.size() && skid != key_id)
+ continue;
+
+ if(certs[i].subject_dn() == subject_dn)
+ result.push_back(certs[i]);
+ }
+
+ return result;
}
}