CertificateStore.h
1 /*
2  * Copyright (C) 2010-2013 by Marc Duerner
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * As a special exception, you may use this file as part of a free
10  * software library without restriction. Specifically, if other files
11  * instantiate templates or use macros or inline functions from this
12  * file, or you compile this file and link it with other files to
13  * produce an executable, this file does not by itself cause the
14  * resulting executable to be covered by the GNU General Public
15  * License. This exception does not however invalidate any other
16  * reasons why the executable file might be covered by the GNU Library
17  * General Public License.
18  *
19  * This library is distributed in the hope that it will be useful,
20  * but WITHOUT ANY WARRANTY; without even the implied warranty of
21  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
22  * Lesser General Public License for more details.
23  *
24  * You should have received a copy of the GNU Lesser General Public
25  * License along with this library; if not, write to the Free Software
26  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
27  */
28 
29 #ifndef PT_SSL_CERTIFICATESTORE_H
30 #define PT_SSL_CERTIFICATESTORE_H
31 
32 #include <Pt/Ssl/Api.h>
33 #include <Pt/Ssl/Certificate.h>
34 #include <string>
35 #include <iosfwd>
36 #include <cstddef>
37 
38 namespace Pt {
39 
40 namespace Ssl {
41 
44 class PT_SSL_API CertificateStore
45 {
46  public:
47  class ConstIterator;
48 
49  public:
53 
57 
60  void loadPkcs12(std::istream& is, const char* passwd);
61 
64  void loadPkcs12(const char* data, std::size_t len, const char* passwd);
65 
71  const Certificate* findCertificate(const std::string& subject);
72 
79  const Certificate& getCertificate(const std::string& subject);
80 
83  std::size_t size() const;
84 
87  ConstIterator begin() const;
88 
91  ConstIterator end() const;
92 
93  private:
94  class CertificateStoreImpl* _impl;
95 };
96 
100 {
101  public:
103  ConstIterator();
104 
106  ConstIterator(const ConstIterator& other);
107 
108  explicit ConstIterator(Certificate* const* cert);
109 
111  ConstIterator& operator=(const ConstIterator& other);
112 
114  ConstIterator& operator++();
115 
117  const Certificate& operator*() const;
118 
120  const Certificate* operator->() const;
121 
123  bool operator!=(const ConstIterator& other) const;
124 
126  bool operator==(const ConstIterator& other) const;
127 
128  private:
129  Certificate* const* _cert;
130 };
131 
132 } // namespace Ssl
133 
134 } // namespace Pt
135 
136 #endif // PT_SSL_CERTIFICATESTOREIMPL_H
X509 certificate.
Definition: Certificate.h:44
Iterator to a certificate in the store.
Definition: CertificateStore.h:99
A store for X509 certificates.
Definition: CertificateStore.h:44