blob: f8768235edf4370906eba75206948284397cad41 [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.
*/
#include "security/certificate-extension.hpp"
#include <cryptopp/asn.h>
using namespace std;
using namespace CryptoPP;
namespace ndn {
void
CertificateExtension::encode(CryptoPP::BufferedTransformation &out) const
{
// Extension ::= SEQUENCE {
// extnID OBJECT IDENTIFIER,
// critical BOOLEAN DEFAULT FALSE,
// extnValue OCTET STRING }
DERSequenceEncoder extension(out);
{
extensionId_.encode(extension);
DEREncodeUnsigned(extension, isCritical_, BOOLEAN);
DEREncodeOctetString(extension, extensionValue_.buf(), extensionValue_.size());
}
extension.MessageEnd();
}
void
CertificateExtension::decode(CryptoPP::BufferedTransformation &in)
{
// Extension ::= SEQUENCE {
// extnID OBJECT IDENTIFIER,
// critical BOOLEAN DEFAULT FALSE,
// extnValue OCTET STRING }
BERSequenceDecoder extension(in);
{
extensionId_.decode(extension);
BERDecodeUnsigned(extension, isCritical_, BOOLEAN);
// the extra copy operation can be optimized, but not trivial,
// since the length is not known in advance
SecByteBlock tmpBlock;
BERDecodeOctetString(extension, tmpBlock);
extensionValue_.assign(tmpBlock.begin(), tmpBlock.end());
}
extension.MessageEnd();
}
}