blob: 46448073aecc5a619f1ca33c8db1580fa05aefea [file] [log] [blame]
Alexander Afanasyevc169a812014-05-20 20:37:29 -04001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -08002/**
Alexander Afanasyeve6835fe2017-01-19 20:05:01 -08003 * Copyright (c) 2013-2017 Regents of the University of California.
Alexander Afanasyevdfa52c42014-04-24 21:10:11 -07004 *
5 * This file is part of ndn-cxx library (NDN C++ library with eXperimental eXtensions).
Alexander Afanasyevdfa52c42014-04-24 21:10:11 -07006 *
Alexander Afanasyevc169a812014-05-20 20:37:29 -04007 * ndn-cxx library is free software: you can redistribute it and/or modify it under the
8 * terms of the GNU Lesser General Public License as published by the Free Software
9 * Foundation, either version 3 of the License, or (at your option) any later version.
10 *
11 * ndn-cxx library is distributed in the hope that it will be useful, but WITHOUT ANY
12 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
13 * PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
14 *
15 * You should have received copies of the GNU General Public License and GNU Lesser
16 * General Public License along with ndn-cxx, e.g., in COPYING.md file. If not, see
17 * <http://www.gnu.org/licenses/>.
18 *
19 * See AUTHORS.md for complete list of ndn-cxx authors and contributors.
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080020 */
21
22#ifndef NDN_SIGNATURE_HPP
23#define NDN_SIGNATURE_HPP
24
Alexander Afanasyev1c6976d2014-07-13 11:40:50 -070025#include "common.hpp"
Yingdi Yu4a557052014-07-09 16:40:37 -070026#include "signature-info.hpp"
Yingdi Yuebfa4cb2014-06-17 15:28:53 -070027
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080028namespace ndn {
29
30/**
31 * A Signature is storage for the signature-related information (info and value) in a Data packet.
32 */
Alexander Afanasyev2a7f7202014-04-23 14:25:29 -070033class Signature
34{
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080035public:
Steve DiBenedetto54ce6682014-07-22 13:22:57 -060036 class Error : public tlv::Error
Alexander Afanasyevff2d08f2014-04-07 18:28:25 -070037 {
38 public:
39 explicit
40 Error(const std::string& what)
Steve DiBenedetto54ce6682014-07-22 13:22:57 -060041 : tlv::Error(what)
Alexander Afanasyevff2d08f2014-04-07 18:28:25 -070042 {
43 }
44 };
Alexander Afanasyevfa13f8e2014-01-03 15:19:07 -080045
Yingdi Yu1b0311c2015-06-10 14:58:47 -070046 Signature() = default;
Alexander Afanasyevff2d08f2014-04-07 18:28:25 -070047
Yingdi Yu5ec0ee32014-06-24 16:26:09 -070048 explicit
Yingdi Yu4a557052014-07-09 16:40:37 -070049 Signature(const Block& info, const Block& value = Block());
50
51 explicit
52 Signature(const SignatureInfo& info, const Block& value = Block());
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080053
54 operator bool() const
55 {
Yingdi Yu4a557052014-07-09 16:40:37 -070056 return m_info.getSignatureType() != -1;
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080057 }
58
Yingdi Yu1b0311c2015-06-10 14:58:47 -070059 /**
60 * @brief Get SignatureInfo in the wire format
61 */
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080062 const Block&
63 getInfo() const
64 {
Yingdi Yu4a557052014-07-09 16:40:37 -070065 return m_info.wireEncode(); // will do nothing if wire already exists
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080066 }
67
Yingdi Yu4a557052014-07-09 16:40:37 -070068 /**
Zhiyi Zhang387e57b2016-08-01 18:50:00 -070069 * @brief Get SignatureInfo
70 */
71 const SignatureInfo&
72 getSignatureInfo() const
73 {
74 return m_info;
75 }
76
77 /**
Yingdi Yu4a557052014-07-09 16:40:37 -070078 * @brief Set SignatureInfo from a block
79 *
Steve DiBenedetto54ce6682014-07-22 13:22:57 -060080 * @throws tlv::Error if supplied block is not formatted correctly
Yingdi Yu4a557052014-07-09 16:40:37 -070081 */
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080082 void
Yingdi Yu4a557052014-07-09 16:40:37 -070083 setInfo(const Block& info);
84
Yingdi Yu1b0311c2015-06-10 14:58:47 -070085 /**
86 * @brief Set SignatureInfo
87 */
Yingdi Yu4a557052014-07-09 16:40:37 -070088 void
89 setInfo(const SignatureInfo& info)
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080090 {
Alexander Afanasyevff2d08f2014-04-07 18:28:25 -070091 m_info = info;
Alexander Afanasyevff2d08f2014-04-07 18:28:25 -070092 }
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080093
Yingdi Yu1b0311c2015-06-10 14:58:47 -070094 /**
95 * @brief Get SignatureValue in the wire format
96 */
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -080097 const Block&
98 getValue() const
99 {
Alexander Afanasyevff2d08f2014-04-07 18:28:25 -0700100 m_value.encode(); // will do nothing if wire already exists
101 return m_value;
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -0800102 }
103
Yingdi Yu1b0311c2015-06-10 14:58:47 -0700104 /**
105 * @brief Get SignatureValue from a block
106 *
107 * @throws tlv::Error if supplied block has type different from SignatureValue
108 */
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -0800109 void
Yingdi Yu1b0311c2015-06-10 14:58:47 -0700110 setValue(const Block& value);
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -0800111
Yingdi Yu1b0311c2015-06-10 14:58:47 -0700112 /**
113 * @brief Get signature type
114 */
Yingdi Yu4a557052014-07-09 16:40:37 -0700115 uint32_t
116 getType() const
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -0800117 {
Yingdi Yu4a557052014-07-09 16:40:37 -0700118 return m_info.getSignatureType();
Alexander Afanasyevff2d08f2014-04-07 18:28:25 -0700119 }
120
Yingdi Yu1b0311c2015-06-10 14:58:47 -0700121 /**
122 * @brief Check if SignatureInfo block has a KeyLocator
123 */
Yingdi Yu4a557052014-07-09 16:40:37 -0700124 bool
125 hasKeyLocator() const
126 {
127 return m_info.hasKeyLocator();
128 }
129
130 /**
131 * @brief Get KeyLocator
132 *
Yingdi Yu1b0311c2015-06-10 14:58:47 -0700133 * @throws Signature::Error if KeyLocator does not exist
Yingdi Yu4a557052014-07-09 16:40:37 -0700134 */
135 const KeyLocator&
136 getKeyLocator() const
137 {
138 return m_info.getKeyLocator();
139 }
140
Yingdi Yu1b0311c2015-06-10 14:58:47 -0700141 /**
142 * @brief Set KeyLocator
143 */
Alexander Afanasyev1c6976d2014-07-13 11:40:50 -0700144 void
145 setKeyLocator(const KeyLocator& keyLocator)
146 {
147 m_info.setKeyLocator(keyLocator);
148 }
Yingdi Yu4a557052014-07-09 16:40:37 -0700149
Alexander Afanasyeva7c7f9d2014-07-13 11:51:52 -0700150 /**
151 * @brief Unset KeyLocator
152 *
153 * Note that specific signature types may provide advisory (non-virtual) override
154 * to prevent unsetting KeyLocator if it is required by the specification.
155 */
156 void
157 unsetKeyLocator()
158 {
159 m_info.unsetKeyLocator();
160 }
161
Alexander Afanasyevff2d08f2014-04-07 18:28:25 -0700162public: // EqualityComparable concept
163 bool
164 operator==(const Signature& other) const
165 {
166 return getInfo() == other.getInfo() &&
167 getValue() == other.getValue();
168 }
169
170 bool
171 operator!=(const Signature& other) const
172 {
173 return !(*this == other);
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -0800174 }
175
Alexander Afanasyevfa13f8e2014-01-03 15:19:07 -0800176protected:
Yingdi Yu4a557052014-07-09 16:40:37 -0700177 SignatureInfo m_info;
Alexander Afanasyevff2d08f2014-04-07 18:28:25 -0700178 mutable Block m_value;
Alexander Afanasyev2ba8f662014-01-05 22:53:18 -0800179};
180
181} // namespace ndn
182
183#endif // NDN_SIGNATURE_HPP