X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fcertificates.h;h=ebc4cc53560d42a7e6916a1a511ad4ec8028fab1;hb=595d4fbfee788edfad7f9f8dfe7e76ee634c1a94;hp=42ae8d27b3e8424f5b5d3c0f8d4092e66946d200;hpb=62701cd6827b885fdfaef5159a542ea25a6c24b7;p=libdcp.git diff --git a/src/certificates.h b/src/certificates.h index 42ae8d27..ebc4cc53 100644 --- a/src/certificates.h +++ b/src/certificates.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2012 Carl Hetherington + Copyright (C) 2012-2014 Carl Hetherington This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -17,14 +17,18 @@ */ +/** @file src/certificates.h + * @brief Certificate and CertificateChain classes. + */ + #ifndef LIBDCP_CERTIFICATES_H #define LIBDCP_CERTIFICATES_H +#undef X509_NAME +#include +#include #include #include -#include -#include -#include class certificates; @@ -32,49 +36,84 @@ namespace xmlpp { class Element; } -namespace libdcp { +namespace dcp { -class Certificate : public boost::noncopyable +/** @class Certificate + * @brief A wrapper for an X509 certificate. + * + * This class can take a Certificate from a string or an OpenSSL X509 object. + */ +class Certificate { public: Certificate () : _certificate (0) + , _public_key (0) {} - Certificate (std::string const &); + Certificate (std::string); Certificate (X509 *); + Certificate (Certificate const &); ~Certificate (); - std::string certificate () const; + Certificate& operator= (Certificate const &); + + std::string certificate (bool with_begin_end = false) const; std::string issuer () const; std::string serial () const; std::string subject () const; + std::string common_name () const; + + X509* x509 () const { + return _certificate; + } + + RSA* public_key () const; std::string thumbprint () const; private: + void read_string (std::string); + static std::string name_for_xml (X509_NAME *); static std::string asn_to_utf8 (ASN1_STRING *); static std::string get_name_part (X509_NAME *, int); X509* _certificate; + mutable RSA* _public_key; }; +bool operator== (Certificate const & a, Certificate const & b); +bool operator< (Certificate const & a, Certificate const & b); +std::ostream& operator<< (std::ostream&s, Certificate const & c); + +/** @class CertificateChain + * @brief A chain of any number of certificates, from root to leaf. + */ class CertificateChain { public: CertificateChain () {} - void add (boost::shared_ptr); + void add (Certificate c); + void remove (Certificate c); + void remove (int); - boost::shared_ptr root () const; - boost::shared_ptr leaf () const; + Certificate root () const; + Certificate leaf () const; - std::list > leaf_to_root () const; + typedef std::list List; + + List leaf_to_root () const; + List root_to_leaf () const; + + bool valid () const; + bool attempt_reorder (); private: friend class ::certificates; - std::list > _certificates; + + List _certificates; }; }