blob: a1aa5b656c8a541f41312b2f90197632fafef770 [file] [log] [blame]
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil -*- */
/**
* Copyright (C) 2013 Regents of the University of California.
* @author: Yingdi Yu <yingdi@cs.ucla.edu>
* @author: Jeff Thompson <jefft0@remap.ucla.edu>
* See COPYING for copyright and distribution information.
*/
#ifndef NDN_SECURITY_CERTIFICATE_EXTENSION_HPP
#define NDN_SECURITY_CERTIFICATE_EXTENSION_HPP
#include "../common.hpp"
#include "../encoding/buffer.hpp"
#include "../encoding/oid.hpp"
namespace CryptoPP { class BufferedTransformation; }
namespace ndn {
/**
* A CertificateExtension represents the Extension entry in a certificate.
*/
class CertificateExtension
{
public:
class Error : public std::runtime_error
{
public:
explicit
Error(const std::string& what)
: std::runtime_error(what)
{
}
};
CertificateExtension(CryptoPP::BufferedTransformation& in)
{
decode(in);
}
/**
* Create a new CertificateExtension.
* @param oid The oid of subject description entry.
* @param isCritical If true, the extension must be handled.
* @param value The extension value.
*/
CertificateExtension(const OID& oid, const bool isCritical, const Buffer& value)
: m_extensionId(oid), m_isCritical(isCritical), m_extensionValue(value)
{
}
CertificateExtension(const OID& oid, const bool isCritical,
const uint8_t* value, size_t valueSize)
: m_extensionId(oid), m_isCritical(isCritical), m_extensionValue(value, valueSize)
{
}
/**
* The virtual destructor.
*/
virtual
~CertificateExtension()
{
}
void
encode(CryptoPP::BufferedTransformation& out) const;
void
decode(CryptoPP::BufferedTransformation& in);
inline const OID&
getOid() const
{
return m_extensionId;
}
inline const bool
getIsCritical() const
{
return m_isCritical;
}
inline const Buffer&
getValue() const
{
return m_extensionValue;
}
protected:
OID m_extensionId;
bool m_isCritical;
Buffer m_extensionValue;
};
} // namespace ndn
#endif //NDN_SECURITY_CERTIFICATE_EXTENSION_HPP