blob: 25eb6ae36561024cd36b79771cac444c3d67098b [file] [log] [blame]
Jeff Thompson25b4e612013-10-10 16:03:24 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil -*- */
Jeff Thompson20af0732013-09-12 17:01:45 -07002/**
Jeff Thompson7687dc02013-09-13 11:54:07 -07003 * Copyright (C) 2013 Regents of the University of California.
4 * @author: Jeff Thompson <jefft0@remap.ucla.edu>
Jeff Thompson20af0732013-09-12 17:01:45 -07005 * See COPYING for copyright and distribution information.
6 */
7
8#ifndef NDN_SHA256_WITH_RSA_SIGNATURE_HPP
9#define NDN_SHA256_WITH_RSA_SIGNATURE_HPP
10
11#include "data.hpp"
Jeff Thompsonbad29b32013-09-17 14:23:41 -070012#include "key.hpp"
Jeff Thompson20af0732013-09-12 17:01:45 -070013#include "publisher-public-key-digest.hpp"
14
15namespace ndn {
16
17/**
18 * A Sha256WithRsaSignature extends Signature and holds the signature bits and other info representing a
19 * SHA256-with-RSA signature in a data packet.
20 */
21class Sha256WithRsaSignature : public Signature {
22public:
23 /**
24 * Return a pointer to a new Sha256WithRsaSignature which is a copy of this signature.
25 */
Jeff Thompson0050abe2013-09-17 12:50:25 -070026 virtual ptr_lib::shared_ptr<Signature>
27 clone() const;
Jeff Thompson20af0732013-09-12 17:01:45 -070028
29 /**
30 * Set the signatureStruct to point to the values in this signature object, without copying any memory.
31 * WARNING: The resulting pointers in signatureStruct are invalid after a further use of this object which could reallocate memory.
32 * @param signatureStruct a C ndn_Signature struct where the name components array is already allocated.
33 */
Jeff Thompson0050abe2013-09-17 12:50:25 -070034 virtual void
35 get(struct ndn_Signature& signatureStruct) const;
Jeff Thompson20af0732013-09-12 17:01:45 -070036
37 /**
38 * Clear this signature, and set the values by copying from the ndn_Signature struct.
39 * @param signatureStruct a C ndn_Signature struct
40 */
Jeff Thompson0050abe2013-09-17 12:50:25 -070041 virtual void
42 set(const struct ndn_Signature& signatureStruct);
Jeff Thompson20af0732013-09-12 17:01:45 -070043
Jeff Thompson0050abe2013-09-17 12:50:25 -070044 const Blob&
45 getDigestAlgorithm() const { return digestAlgorithm_; }
Jeff Thompson20af0732013-09-12 17:01:45 -070046
Jeff Thompson0050abe2013-09-17 12:50:25 -070047 const Blob&
48 getWitness() const { return witness_; }
Jeff Thompson20af0732013-09-12 17:01:45 -070049
Jeff Thompson0050abe2013-09-17 12:50:25 -070050 const Blob&
51 getSignature() const { return signature_; }
Jeff Thompson20af0732013-09-12 17:01:45 -070052
Jeff Thompson0050abe2013-09-17 12:50:25 -070053 const PublisherPublicKeyDigest&
54 getPublisherPublicKeyDigest() const { return publisherPublicKeyDigest_; }
Jeff Thompson20af0732013-09-12 17:01:45 -070055
Jeff Thompson0050abe2013-09-17 12:50:25 -070056 PublisherPublicKeyDigest&
57 getPublisherPublicKeyDigest() { return publisherPublicKeyDigest_; }
58
59 const KeyLocator&
60 getKeyLocator() const { return keyLocator_; }
61
62 KeyLocator&
63 getKeyLocator() { return keyLocator_; }
Jeff Thompson20af0732013-09-12 17:01:45 -070064
Jeff Thompson0050abe2013-09-17 12:50:25 -070065 void
Jeff Thompson10ad12a2013-09-24 16:19:11 -070066 setDigestAlgorithm(const std::vector<uint8_t>& digestAlgorithm) { digestAlgorithm_ = digestAlgorithm; }
Jeff Thompson0050abe2013-09-17 12:50:25 -070067
68 void
Jeff Thompson97223af2013-09-24 17:01:27 -070069 setDigestAlgorithm(const uint8_t *digestAlgorithm, size_t digestAlgorithmLength)
Jeff Thompson20af0732013-09-12 17:01:45 -070070 {
71 digestAlgorithm_ = Blob(digestAlgorithm, digestAlgorithmLength);
72 }
73
Jeff Thompson0050abe2013-09-17 12:50:25 -070074 void
Jeff Thompson10ad12a2013-09-24 16:19:11 -070075 setWitness(const std::vector<uint8_t>& witness) { witness_ = witness; }
Jeff Thompson0050abe2013-09-17 12:50:25 -070076
77 void
Jeff Thompson97223af2013-09-24 17:01:27 -070078 setWitness(const uint8_t *witness, size_t witnessLength)
Jeff Thompson20af0732013-09-12 17:01:45 -070079 {
80 witness_ = Blob(witness, witnessLength);
81 }
82
Jeff Thompson0050abe2013-09-17 12:50:25 -070083 void
Jeff Thompson10ad12a2013-09-24 16:19:11 -070084 setSignature(const std::vector<uint8_t>& signature) { signature_ = signature; }
Jeff Thompson0050abe2013-09-17 12:50:25 -070085
86 void
Jeff Thompson97223af2013-09-24 17:01:27 -070087 setSignature(const uint8_t *signature, size_t signatureLength)
Jeff Thompson20af0732013-09-12 17:01:45 -070088 {
89 signature_ = Blob(signature, signatureLength);
90 }
91
Jeff Thompsonbad29b32013-09-17 14:23:41 -070092 /**
93 * Set signature to point to an existing byte array. IMPORTANT: After calling this,
94 * if you keep a pointer to the array then you must treat the array as immutable and promise not to change it.
95 * @param signature A pointer to a vector with the byte array. This takes another reference and does not copy the bytes.
96 */
97 void
Jeff Thompson10ad12a2013-09-24 16:19:11 -070098 setSignature(const ptr_lib::shared_ptr<std::vector<uint8_t> > &signature) { signature_ = signature; }
Jeff Thompsonbad29b32013-09-17 14:23:41 -070099
100 void
Jeff Thompson10ad12a2013-09-24 16:19:11 -0700101 setSignature(const ptr_lib::shared_ptr<const std::vector<uint8_t> > &signature) { signature_ = signature; }
Jeff Thompsonbad29b32013-09-17 14:23:41 -0700102
Jeff Thompson0050abe2013-09-17 12:50:25 -0700103 void
104 setPublisherPublicKeyDigest(const PublisherPublicKeyDigest& publisherPublicKeyDigest) { publisherPublicKeyDigest_ = publisherPublicKeyDigest; }
Jeff Thompson20af0732013-09-12 17:01:45 -0700105
Jeff Thompson0050abe2013-09-17 12:50:25 -0700106 void
107 setKeyLocator(const KeyLocator& keyLocator) { keyLocator_ = keyLocator; }
Jeff Thompson20af0732013-09-12 17:01:45 -0700108
109 /**
110 * Clear all the fields.
111 */
Jeff Thompson0050abe2013-09-17 12:50:25 -0700112 void
113 clear()
Jeff Thompson20af0732013-09-12 17:01:45 -0700114 {
115 digestAlgorithm_.reset();
116 witness_.reset();
117 signature_.reset();
118 publisherPublicKeyDigest_.clear();
119 keyLocator_.clear();
120 }
121
122private:
123 Blob digestAlgorithm_; /**< if empty, the default is 2.16.840.1.101.3.4.2.1 (sha-256) */
124 Blob witness_;
125 Blob signature_;
126 PublisherPublicKeyDigest publisherPublicKeyDigest_;
127 KeyLocator keyLocator_;
128};
129
130}
131
132#endif