blob: 22c0d564e3aa25978b3099663e00663767362339 [file] [log] [blame]
Zhiyi Zhangf5246c42017-01-26 09:39:20 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesavento914d05f2019-07-13 16:20:19 -04002/*
swa770de007bc2020-03-24 21:26:21 -07003 * Copyright (c) 2017-2020, Regents of the University of California.
Zhiyi Zhangf5246c42017-01-26 09:39:20 -08004 *
5 * This file is part of ndncert, a certificate management system based on NDN.
6 *
7 * ndncert is free software: you can redistribute it and/or modify it under the terms
8 * of the GNU General Public License as published by the Free Software Foundation, either
9 * version 3 of the License, or (at your option) any later version.
10 *
11 * ndncert 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 General Public License for more details.
14 *
15 * You should have received copies of the GNU General Public License along with
16 * ndncert, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
17 *
18 * See AUTHORS.md for complete list of ndncert authors and contributors.
19 */
20
Zhiyi Zhangf5246c42017-01-26 09:39:20 -080021#include "ca-module.hpp"
Zhiyi Zhangf5246c42017-01-26 09:39:20 -080022#include "challenge-module.hpp"
Zhiyi Zhang8bd8e5b2020-09-29 17:40:40 -070023#include "challenge-modules/challenge-email.hpp"
24#include "challenge-modules/challenge-pin.hpp"
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -070025#include "client-module.hpp"
Suyong Won7968f7a2020-05-12 01:01:25 -070026#include "protocol-detail/info.hpp"
Zhiyi Zhang5d80e1e2020-09-25 11:34:54 -070027#include "test-common.hpp"
Zhiyi Zhangf5246c42017-01-26 09:39:20 -080028
29namespace ndn {
30namespace ndncert {
31namespace tests {
32
Zhiyi Zhangae123bf2017-04-14 12:24:53 -070033BOOST_FIXTURE_TEST_SUITE(TestCaModule, DatabaseFixture)
Zhiyi Zhangf5246c42017-01-26 09:39:20 -080034
35BOOST_AUTO_TEST_CASE(Initialization)
36{
Zhiyi Zhang22998612020-09-25 14:43:23 -070037 util::DummyClientFace face(io, m_keyChain, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -070038 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1", "ca-storage-memory");
39 BOOST_CHECK_EQUAL(ca.getCaConf().m_caItem.m_caPrefix, "/ndn");
Zhiyi Zhangf5246c42017-01-26 09:39:20 -080040
41 auto identity = addIdentity(Name("/ndn/site2"));
42 auto key = identity.getDefaultKey();
43 auto cert = key.getDefaultCertificate();
44 ca.getCaStorage()->addCertificate("111", cert);
45 BOOST_CHECK_EQUAL(ca.getCaStorage()->getCertificate("111").getIdentity(), Name("/ndn/site2"));
46
47 advanceClocks(time::milliseconds(20), 60);
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -070048 BOOST_CHECK_EQUAL(ca.m_registeredPrefixHandles.size(), 2);
Zhiyi Zhang46049832020-09-28 17:08:12 -070049 BOOST_CHECK_EQUAL(ca.m_interestFilterHandles.size(), 5); // onInfo, onProbe, onNew, onChallenge, onRevoke
Zhiyi Zhangf5246c42017-01-26 09:39:20 -080050}
51
swa77020643ac2020-03-26 02:24:45 -070052BOOST_AUTO_TEST_CASE(HandleInfo)
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -070053{
54 auto identity = addIdentity(Name("/ndn"));
55 auto key = identity.getDefaultKey();
56 auto cert = key.getDefaultCertificate();
57
Zhiyi Zhang22998612020-09-25 14:43:23 -070058 util::DummyClientFace face(io, m_keyChain, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -070059 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1", "ca-storage-memory");
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -070060 advanceClocks(time::milliseconds(20), 60);
61
swa77020643ac2020-03-26 02:24:45 -070062 Interest interest("/ndn/CA/INFO");
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -070063 interest.setCanBePrefix(false);
64
65 int count = 0;
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -070066 face.onSendData.connect([&](const Data& response) {
67 count++;
68 BOOST_CHECK(security::verifySignature(response, cert));
69 auto contentBlock = response.getContent();
70 contentBlock.parse();
Zhiyi Zhang9829da92020-09-30 16:19:34 -070071 auto caItem = INFO::decodeDataContentToCaProfile(contentBlock);
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -070072 BOOST_CHECK_EQUAL(caItem.m_caPrefix, "/ndn");
Zhiyi Zhangb940aa12020-09-30 16:38:57 -070073 BOOST_CHECK_EQUAL(caItem.m_probeParameterKeys.size(), 1);
Zhiyi Zhang9829da92020-09-30 16:19:34 -070074 BOOST_CHECK_EQUAL(caItem.m_cert->wireEncode(), cert.wireEncode());
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -070075 BOOST_CHECK_EQUAL(caItem.m_caInfo, "ndn testbed ca");
76 });
Zhiyi Zhangf5246c42017-01-26 09:39:20 -080077 face.receive(interest);
78
79 advanceClocks(time::milliseconds(20), 60);
80 BOOST_CHECK_EQUAL(count, 1);
81}
82
Zhiyi Zhang6f395812020-09-29 14:42:03 -070083BOOST_AUTO_TEST_CASE(HandleProbe)
84{
85 auto identity = addIdentity(Name("/ndn"));
86 auto key = identity.getDefaultKey();
87 auto cert = key.getDefaultCertificate();
88
89 util::DummyClientFace face(io, m_keyChain, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -070090 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1", "ca-storage-memory");
Zhiyi Zhang6f395812020-09-29 14:42:03 -070091 ca.setNameAssignmentFunction([&](const std::vector<std::tuple<std::string, std::string>>) -> std::vector<std::string> {
92 std::vector<std::string> result;
93 result.push_back("example");
94 return result;
95 });
96 advanceClocks(time::milliseconds(20), 60);
97
98 Interest interest("/ndn/CA/PROBE");
99 interest.setCanBePrefix(false);
100
101 Block paramTLV = makeEmptyBlock(tlv::ApplicationParameters);
102 paramTLV.push_back(makeStringBlock(tlv_parameter_key, "name"));
103 paramTLV.push_back(makeStringBlock(tlv_parameter_value, "zhiyi"));
104 paramTLV.encode();
105
106 interest.setApplicationParameters(paramTLV);
107
108 int count = 0;
109 face.onSendData.connect([&](const Data& response) {
110 count++;
111 BOOST_CHECK(security::verifySignature(response, cert));
112 Block contentBlock = response.getContent();
113 contentBlock.parse();
114 Block probeResponse = contentBlock.get(tlv_probe_response);
115 probeResponse.parse();
116 Name caName;
117 caName.wireDecode(probeResponse.get(tlv::Name));
118 BOOST_CHECK_EQUAL(caName, "/ndn/example");
119 });
120 face.receive(interest);
121
122 advanceClocks(time::milliseconds(20), 60);
123 BOOST_CHECK_EQUAL(count, 1);
124}
125
Zhiyi Zhanga63b7372017-05-17 14:14:34 -0700126BOOST_AUTO_TEST_CASE(HandleProbeUsingDefaultHandler)
127{
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700128 auto identity = addIdentity(Name("/ndn"));
Zhiyi Zhanga63b7372017-05-17 14:14:34 -0700129 auto key = identity.getDefaultKey();
130 auto cert = key.getDefaultCertificate();
131
Zhiyi Zhang22998612020-09-25 14:43:23 -0700132 util::DummyClientFace face(io, m_keyChain, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700133 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1", "ca-storage-memory");
Zhiyi Zhanga63b7372017-05-17 14:14:34 -0700134 advanceClocks(time::milliseconds(20), 60);
135
swa770de007bc2020-03-24 21:26:21 -0700136 Interest interest("/ndn/CA/PROBE");
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700137 interest.setCanBePrefix(false);
Suyong Won7968f7a2020-05-12 01:01:25 -0700138
139 Block paramTLV = makeEmptyBlock(tlv::ApplicationParameters);
Zhiyi Zhang6f395812020-09-29 14:42:03 -0700140 paramTLV.push_back(makeStringBlock(tlv_parameter_key, "name"));
Suyong Won7968f7a2020-05-12 01:01:25 -0700141 paramTLV.push_back(makeStringBlock(tlv_parameter_value, "zhiyi"));
142 paramTLV.encode();
143
144 interest.setApplicationParameters(paramTLV);
Zhiyi Zhanga63b7372017-05-17 14:14:34 -0700145
146 int count = 0;
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700147 face.onSendData.connect([&](const Data& response) {
148 count++;
149 BOOST_CHECK(security::verifySignature(response, cert));
150 auto contentBlock = response.getContent();
151 contentBlock.parse();
152 auto probeResponseBlock = contentBlock.get(tlv_probe_response);
153 probeResponseBlock.parse();
154 Name caPrefix;
155 caPrefix.wireDecode(probeResponseBlock.get(tlv::Name));
156 BOOST_CHECK(caPrefix != "");
157 });
Zhiyi Zhanga63b7372017-05-17 14:14:34 -0700158 face.receive(interest);
159
160 advanceClocks(time::milliseconds(20), 60);
161 BOOST_CHECK_EQUAL(count, 1);
162}
163
Zhiyi Zhangf5246c42017-01-26 09:39:20 -0800164BOOST_AUTO_TEST_CASE(HandleNew)
165{
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700166 auto identity = addIdentity(Name("/ndn"));
Zhiyi Zhangf5246c42017-01-26 09:39:20 -0800167 auto key = identity.getDefaultKey();
168 auto cert = key.getDefaultCertificate();
169
Zhiyi Zhang22998612020-09-25 14:43:23 -0700170 util::DummyClientFace face(io, m_keyChain, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700171 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1", "ca-storage-memory");
Zhiyi Zhangf5246c42017-01-26 09:39:20 -0800172 advanceClocks(time::milliseconds(20), 60);
173
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700174 ClientModule client(m_keyChain);
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700175 CaConfigItem item;
Suyong Won256c9062020-05-11 02:45:56 -0700176 item.m_caPrefix = Name("/ndn");
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700177 item.m_cert = std::make_shared<security::v2::Certificate>(cert);
Zhiyi Zhangf5246c42017-01-26 09:39:20 -0800178 client.getClientConf().m_caItems.push_back(item);
Zhiyi Zhang5f749a22019-06-12 17:02:33 -0700179
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700180 auto interest = client.generateNewInterest(time::system_clock::now(),
Suyong Won7968f7a2020-05-12 01:01:25 -0700181 time::system_clock::now() + time::days(1),
Zhiyi Zhang5f749a22019-06-12 17:02:33 -0700182 Name("/ndn/zhiyi"));
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +0800183
184 int count = 0;
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700185 face.onSendData.connect([&](const Data& response) {
186 count++;
187 BOOST_CHECK(security::verifySignature(response, cert));
188 auto contentBlock = response.getContent();
189 contentBlock.parse();
Suyong Won7968f7a2020-05-12 01:01:25 -0700190
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700191 BOOST_CHECK(readString(contentBlock.get(tlv_ecdh_pub)) != "");
192 BOOST_CHECK(readString(contentBlock.get(tlv_salt)) != "");
193 BOOST_CHECK(readString(contentBlock.get(tlv_request_id)) != "");
Suyong Won7968f7a2020-05-12 01:01:25 -0700194
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700195 auto challengeBlockCount = 0;
196 for (auto const& element : contentBlock.elements()) {
197 if (element.type() == tlv_challenge) {
198 challengeBlockCount++;
Suyong Won7968f7a2020-05-12 01:01:25 -0700199 }
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700200 }
Suyong Won7968f7a2020-05-12 01:01:25 -0700201
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700202 BOOST_CHECK(challengeBlockCount != 0);
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700203
tylerliu0e176c32020-09-29 11:39:46 -0700204 client.onNewRenewRevokeResponse(response);
tylerliu8e170d62020-09-30 01:31:53 -0700205 auto ca_encryption_key = ca.getCaStorage()->getRequest(readString(contentBlock.get(tlv_request_id))).m_encryptionKey;
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700206 BOOST_CHECK_EQUAL_COLLECTIONS(client.m_aesKey, client.m_aesKey + sizeof(client.m_aesKey),
tylerliu8e170d62020-09-30 01:31:53 -0700207 ca_encryption_key.value(), ca_encryption_key.value() + ca_encryption_key.value_size());
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700208 });
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700209 face.receive(*interest);
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +0800210
211 advanceClocks(time::milliseconds(20), 60);
212 BOOST_CHECK_EQUAL(count, 1);
213}
214
Zhiyi Zhang1a735bc2019-07-04 21:36:49 -0700215BOOST_AUTO_TEST_CASE(HandleNewWithInvalidValidityPeriod1)
216{
217 auto identity = addIdentity(Name("/ndn"));
218 auto key = identity.getDefaultKey();
219 auto cert = key.getDefaultCertificate();
220
Zhiyi Zhang22998612020-09-25 14:43:23 -0700221 util::DummyClientFace face(io, m_keyChain, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700222 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1");
Zhiyi Zhang1a735bc2019-07-04 21:36:49 -0700223 advanceClocks(time::milliseconds(20), 60);
224
225 ClientModule client(m_keyChain);
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700226 CaConfigItem item;
Suyong Won256c9062020-05-11 02:45:56 -0700227 item.m_caPrefix = Name("/ndn");
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700228 item.m_cert = std::make_shared<security::v2::Certificate>(cert);
Zhiyi Zhang1a735bc2019-07-04 21:36:49 -0700229 client.getClientConf().m_caItems.push_back(item);
230 auto current_tp = time::system_clock::now();
231 auto interest1 = client.generateNewInterest(current_tp, current_tp - time::hours(1),
232 Name("/ndn/zhiyi"));
233 auto interest2 = client.generateNewInterest(current_tp, current_tp + time::days(361),
234 Name("/ndn/zhiyi"));
235 auto interest3 = client.generateNewInterest(current_tp - time::hours(1),
236 current_tp + time::hours(2),
237 Name("/ndn/zhiyi"));
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700238 face.onSendData.connect([&](const Data& response) {
Zhiyi Zhang01e91a32020-09-29 12:10:00 -0700239 auto contentTlv = response.getContent();
240 contentTlv.parse();
241 auto errorCode = static_cast<ErrorCode>(readNonNegativeInteger(contentTlv.get(tlv_error_code)));
242 BOOST_CHECK(errorCode != ErrorCode::NO_ERROR);
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700243 });
Zhiyi Zhang1a735bc2019-07-04 21:36:49 -0700244 face.receive(*interest1);
245 face.receive(*interest2);
246 face.receive(*interest3);
247
248 advanceClocks(time::milliseconds(20), 60);
249}
250
tylerliu0b6d0db2020-09-28 17:52:02 -0700251BOOST_AUTO_TEST_CASE(HandleNewWithLongSuffix)
252{
253 auto identity = addIdentity(Name("/ndn"));
254 auto key = identity.getDefaultKey();
255 auto cert = key.getDefaultCertificate();
256
Zhiyi Zhang01e91a32020-09-29 12:10:00 -0700257 util::DummyClientFace face(io, m_keyChain, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700258 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1", "ca-storage-memory");
tylerliu0b6d0db2020-09-28 17:52:02 -0700259 advanceClocks(time::milliseconds(20), 60);
260
261 ClientModule client(m_keyChain);
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700262 CaConfigItem item;
tylerliu0b6d0db2020-09-28 17:52:02 -0700263 item.m_caPrefix = Name("/ndn");
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700264 item.m_cert = std::make_shared<security::v2::Certificate>(cert);
tylerliu0b6d0db2020-09-28 17:52:02 -0700265 client.getClientConf().m_caItems.push_back(item);
266
Zhiyi Zhang01e91a32020-09-29 12:10:00 -0700267 auto interest1 = client.generateNewInterest(time::system_clock::now(),
268 time::system_clock::now() + time::days(1),
269 Name("/ndn/a"));
270 auto interest2 = client.generateNewInterest(time::system_clock::now(),
271 time::system_clock::now() + time::days(1),
272 Name("/ndn/a/b"));
273 auto interest3 = client.generateNewInterest(time::system_clock::now(),
274 time::system_clock::now() + time::days(1),
275 Name("/ndn/a/b/c/d"));
tylerliu0b6d0db2020-09-28 17:52:02 -0700276
tylerliu0b6d0db2020-09-28 17:52:02 -0700277 face.onSendData.connect([&](const Data& response) {
Zhiyi Zhang01e91a32020-09-29 12:10:00 -0700278 auto contentTlv = response.getContent();
279 contentTlv.parse();
280 if (interest3->getName().isPrefixOf(response.getName())) {
281 auto errorCode = static_cast<ErrorCode>(readNonNegativeInteger(contentTlv.get(tlv_error_code)));
282 BOOST_CHECK(errorCode != ErrorCode::NO_ERROR);
283 }
284 else {
285 // should successfully get responses
286 BOOST_CHECK_EXCEPTION(readNonNegativeInteger(contentTlv.get(tlv_error_code)), std::runtime_error,
287 [](const auto& e) { return true; });
288 }
tylerliu0b6d0db2020-09-28 17:52:02 -0700289 });
Zhiyi Zhang01e91a32020-09-29 12:10:00 -0700290 face.receive(*interest1);
291 face.receive(*interest2);
292 face.receive(*interest3);
tylerliu0b6d0db2020-09-28 17:52:02 -0700293 advanceClocks(time::milliseconds(20), 60);
tylerliu0b6d0db2020-09-28 17:52:02 -0700294}
295
tylerliu0b6d0db2020-09-28 17:52:02 -0700296BOOST_AUTO_TEST_CASE(HandleNewWithInvalidLength1)
297{
298 auto identity = addIdentity(Name("/ndn"));
299 auto key = identity.getDefaultKey();
300 auto cert = key.getDefaultCertificate();
301
302 util::DummyClientFace face(io, m_keyChain, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700303 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1");
tylerliu0b6d0db2020-09-28 17:52:02 -0700304 advanceClocks(time::milliseconds(20), 60);
305
306 ClientModule client(m_keyChain);
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700307 CaConfigItem item;
tylerliu0b6d0db2020-09-28 17:52:02 -0700308 item.m_caPrefix = Name("/ndn");
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700309 item.m_cert = std::make_shared<security::v2::Certificate>(cert);
tylerliu0b6d0db2020-09-28 17:52:02 -0700310 client.getClientConf().m_caItems.push_back(item);
311 auto current_tp = time::system_clock::now();
Zhiyi Zhang01e91a32020-09-29 12:10:00 -0700312 auto interest1 = client.generateNewInterest(current_tp, current_tp + time::days(1), Name("/ndn"));
313 auto interest2 = client.generateNewInterest(current_tp, current_tp + time::days(1), Name("/ndn/a/b/c/d"));
tylerliu0b6d0db2020-09-28 17:52:02 -0700314 face.onSendData.connect([&](const Data& response) {
Zhiyi Zhang01e91a32020-09-29 12:10:00 -0700315 auto contentTlv = response.getContent();
316 contentTlv.parse();
317 auto errorCode = static_cast<ErrorCode>(readNonNegativeInteger(contentTlv.get(tlv_error_code)));
318 BOOST_CHECK(errorCode != ErrorCode::NO_ERROR);
tylerliu0b6d0db2020-09-28 17:52:02 -0700319 });
320 face.receive(*interest1);
321 face.receive(*interest2);
322
323 advanceClocks(time::milliseconds(20), 60);
324}
325
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700326BOOST_AUTO_TEST_CASE(HandleChallenge)
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +0800327{
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700328 auto identity = addIdentity(Name("/ndn"));
329 auto key = identity.getDefaultKey();
330 auto cert = key.getDefaultCertificate();
331
Zhiyi Zhang22998612020-09-25 14:43:23 -0700332 util::DummyClientFace face(io, m_keyChain, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700333 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1", "ca-storage-memory");
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +0800334 advanceClocks(time::milliseconds(20), 60);
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700335
336 // generate NEW Interest
337 ClientModule client(m_keyChain);
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700338 CaConfigItem item;
Suyong Won256c9062020-05-11 02:45:56 -0700339 item.m_caPrefix = Name("/ndn");
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700340 item.m_cert = std::make_shared<security::v2::Certificate>(cert);
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700341 client.getClientConf().m_caItems.push_back(item);
342 auto newInterest = client.generateNewInterest(time::system_clock::now(),
Suyong Won7968f7a2020-05-12 01:01:25 -0700343 time::system_clock::now() + time::days(1), Name("/ndn/zhiyi"));
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700344
345 // generate CHALLENGE Interest
346 ChallengePin pinChallenge;
347 shared_ptr<Interest> challengeInterest = nullptr;
348 shared_ptr<Interest> challengeInterest2 = nullptr;
349 shared_ptr<Interest> challengeInterest3 = nullptr;
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +0800350
351 int count = 0;
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700352 face.onSendData.connect([&](const Data& response) {
swa770de007bc2020-03-24 21:26:21 -0700353 if (Name("/ndn/CA/NEW").isPrefixOf(response.getName())) {
tylerliu0e176c32020-09-29 11:39:46 -0700354 client.onNewRenewRevokeResponse(response);
Zhiyi Zhang46049832020-09-28 17:08:12 -0700355 auto paramList = pinChallenge.getRequestedParameterList(client.m_status, client.m_challengeStatus);
Suyong Won44d0cce2020-05-10 04:07:43 -0700356 challengeInterest = client.generateChallengeInterest(pinChallenge.genChallengeRequestTLV(client.m_status,
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700357 client.m_challengeStatus,
Zhiyi Zhang46049832020-09-28 17:08:12 -0700358 std::move(paramList)));
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700359 }
swa770de007bc2020-03-24 21:26:21 -0700360 else if (Name("/ndn/CA/CHALLENGE").isPrefixOf(response.getName()) && count == 0) {
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +0800361 count++;
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700362 BOOST_CHECK(security::verifySignature(response, cert));
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +0800363
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700364 client.onChallengeResponse(response);
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700365 BOOST_CHECK(client.m_status == Status::CHALLENGE);
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700366 BOOST_CHECK_EQUAL(client.m_challengeStatus, ChallengePin::NEED_CODE);
Davide Pesavento914d05f2019-07-13 16:20:19 -0400367
Zhiyi Zhang46049832020-09-28 17:08:12 -0700368 auto paramList = pinChallenge.getRequestedParameterList(client.m_status, client.m_challengeStatus);
Suyong Won44d0cce2020-05-10 04:07:43 -0700369 challengeInterest2 = client.generateChallengeInterest(pinChallenge.genChallengeRequestTLV(client.m_status,
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700370 client.m_challengeStatus,
Zhiyi Zhang46049832020-09-28 17:08:12 -0700371 std::move(paramList)));
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700372 }
swa770de007bc2020-03-24 21:26:21 -0700373 else if (Name("/ndn/CA/CHALLENGE").isPrefixOf(response.getName()) && count == 1) {
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700374 count++;
375 BOOST_CHECK(security::verifySignature(response, cert));
376
377 client.onChallengeResponse(response);
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700378 BOOST_CHECK(client.m_status == Status::CHALLENGE);
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700379 BOOST_CHECK_EQUAL(client.m_challengeStatus, ChallengePin::WRONG_CODE);
Davide Pesavento914d05f2019-07-13 16:20:19 -0400380
Zhiyi Zhang46049832020-09-28 17:08:12 -0700381 auto paramList = pinChallenge.getRequestedParameterList(client.m_status, client.m_challengeStatus);
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700382 auto request = ca.getCertificateRequest(*challengeInterest2);
Zhiyi Zhanga749f442020-09-29 17:19:51 -0700383 auto secret = request.m_challengeState->m_secrets.get(ChallengePin::PARAMETER_KEY_CODE, "");
Zhiyi Zhang46049832020-09-28 17:08:12 -0700384 std::get<1>(paramList[0]) = secret;
Suyong Won44d0cce2020-05-10 04:07:43 -0700385 challengeInterest3 = client.generateChallengeInterest(pinChallenge.genChallengeRequestTLV(client.m_status,
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700386 client.m_challengeStatus,
Zhiyi Zhang46049832020-09-28 17:08:12 -0700387 std::move(paramList)));
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700388 }
swa770de007bc2020-03-24 21:26:21 -0700389 else if (Name("/ndn/CA/CHALLENGE").isPrefixOf(response.getName()) && count == 2) {
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700390 count++;
391 BOOST_CHECK(security::verifySignature(response, cert));
392
393 client.onChallengeResponse(response);
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700394 BOOST_CHECK(client.m_status == Status::SUCCESS);
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700395 }
Davide Pesavento914d05f2019-07-13 16:20:19 -0400396 });
397
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700398 face.receive(*newInterest);
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +0800399 advanceClocks(time::milliseconds(20), 60);
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700400 face.receive(*challengeInterest);
401 advanceClocks(time::milliseconds(20), 60);
402 face.receive(*challengeInterest2);
403 advanceClocks(time::milliseconds(20), 60);
404 face.receive(*challengeInterest3);
405 advanceClocks(time::milliseconds(20), 60);
406 BOOST_CHECK_EQUAL(count, 3);
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +0800407}
408
tylerliu182bc532020-09-25 01:54:45 -0700409BOOST_AUTO_TEST_CASE(HandleRevoke)
410{
411 auto identity = addIdentity(Name("/ndn"));
412 auto key = identity.getDefaultKey();
413 auto cert = key.getDefaultCertificate();
414
Zhiyi Zhang46049832020-09-28 17:08:12 -0700415 util::DummyClientFace face(io, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700416 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1", "ca-storage-memory");
tylerliu182bc532020-09-25 01:54:45 -0700417 advanceClocks(time::milliseconds(20), 60);
418
419 //generate a certificate
420 auto clientIdentity = m_keyChain.createIdentity("/ndn/qwerty");
421 auto clientKey = clientIdentity.getDefaultKey();
422 security::v2::Certificate clientCert;
423 clientCert.setName(Name(clientKey.getName()).append("cert-request").appendVersion());
424 clientCert.setContentType(tlv::ContentType_Key);
425 clientCert.setFreshnessPeriod(time::hours(24));
426 clientCert.setContent(clientKey.getPublicKey().data(), clientKey.getPublicKey().size());
427 SignatureInfo signatureInfo;
428 signatureInfo.setValidityPeriod(security::ValidityPeriod(time::system_clock::now(),
Zhiyi Zhang46049832020-09-28 17:08:12 -0700429 time::system_clock::now() + time::hours(10)));
tylerliu182bc532020-09-25 01:54:45 -0700430 m_keyChain.sign(clientCert, signingByKey(clientKey.getName()).setSignatureInfo(signatureInfo));
tylerliu8e170d62020-09-30 01:31:53 -0700431 RequestState certRequest(Name("/ndn"), "122", RequestType::NEW, Status::SUCCESS, clientCert, makeEmptyBlock(tlv::ContentType_Key));
tylerliu182bc532020-09-25 01:54:45 -0700432 auto issuedCert = ca.issueCertificate(certRequest);
433
434 ClientModule client(m_keyChain);
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700435 CaConfigItem item;
436 item.m_caPrefix = Name("/ndn");
437 item.m_cert = std::make_shared<security::v2::Certificate>(cert);
tylerliu182bc532020-09-25 01:54:45 -0700438 client.getClientConf().m_caItems.push_back(item);
439
440 auto interest = client.generateRevokeInterest(issuedCert);
441
442 int count = 0;
Zhiyi Zhang46049832020-09-28 17:08:12 -0700443 face.onSendData.connect([&](const Data& response) {
tylerliu182bc532020-09-25 01:54:45 -0700444 count++;
445 BOOST_CHECK(security::verifySignature(response, cert));
446 auto contentBlock = response.getContent();
447 contentBlock.parse();
448
449 BOOST_CHECK(readString(contentBlock.get(tlv_ecdh_pub)) != "");
450 BOOST_CHECK(readString(contentBlock.get(tlv_salt)) != "");
451 BOOST_CHECK(readString(contentBlock.get(tlv_request_id)) != "");
452
453 auto challengeBlockCount = 0;
454 for (auto const& element : contentBlock.elements()) {
Zhiyi Zhang46049832020-09-28 17:08:12 -0700455 if (element.type() == tlv_challenge) {
456 challengeBlockCount++;
457 }
tylerliu182bc532020-09-25 01:54:45 -0700458 }
459
460 BOOST_CHECK(challengeBlockCount != 0);
461
tylerliu0e176c32020-09-29 11:39:46 -0700462 client.onNewRenewRevokeResponse(response);
tylerliu8e170d62020-09-30 01:31:53 -0700463 auto ca_encryption_key = ca.getCaStorage()->getRequest(readString(contentBlock.get(tlv_request_id))).m_encryptionKey;
tylerliu182bc532020-09-25 01:54:45 -0700464 BOOST_CHECK_EQUAL_COLLECTIONS(client.m_aesKey, client.m_aesKey + sizeof(client.m_aesKey),
tylerliu8e170d62020-09-30 01:31:53 -0700465 ca_encryption_key.value(), ca_encryption_key.value() + ca_encryption_key.value_size());
tylerliu182bc532020-09-25 01:54:45 -0700466 });
467 face.receive(*interest);
468
469 advanceClocks(time::milliseconds(20), 60);
470 BOOST_CHECK_EQUAL(count, 1);
471}
472
473BOOST_AUTO_TEST_CASE(HandleRevokeWithBadCert)
474{
475 auto identity = addIdentity(Name("/ndn"));
476 auto key = identity.getDefaultKey();
477 auto cert = key.getDefaultCertificate();
478
Zhiyi Zhang46049832020-09-28 17:08:12 -0700479 util::DummyClientFace face(io, {true, true});
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700480 CaModule ca(face, m_keyChain, "tests/unit-tests/config-files/config-ca-1", "ca-storage-memory");
tylerliu182bc532020-09-25 01:54:45 -0700481 advanceClocks(time::milliseconds(20), 60);
482
483 //generate a certificate
484 auto clientIdentity = m_keyChain.createIdentity("/ndn/qwerty");
485 auto clientKey = clientIdentity.getDefaultKey();
486 security::v2::Certificate clientCert;
487 clientCert.setName(Name(clientKey.getName()).append("NDNCERT").append(std::to_string(1473283247810732701)));
488 clientCert.setContentType(tlv::ContentType_Key);
489 clientCert.setFreshnessPeriod(time::hours(24));
490 clientCert.setContent(clientKey.getPublicKey().data(), clientKey.getPublicKey().size());
491 SignatureInfo signatureInfo;
492 signatureInfo.setValidityPeriod(security::ValidityPeriod(time::system_clock::now(),
Zhiyi Zhang46049832020-09-28 17:08:12 -0700493 time::system_clock::now() + time::hours(10)));
tylerliu182bc532020-09-25 01:54:45 -0700494 m_keyChain.sign(clientCert, signingByKey(clientKey.getName()).setSignatureInfo(signatureInfo));
495
496 ClientModule client(m_keyChain);
Zhiyi Zhang9829da92020-09-30 16:19:34 -0700497 CaConfigItem item;
498 item.m_caPrefix = Name("/ndn");
499 item.m_cert = std::make_shared<security::v2::Certificate>(cert);
tylerliu182bc532020-09-25 01:54:45 -0700500 client.getClientConf().m_caItems.push_back(item);
501
502 auto interest = client.generateRevokeInterest(clientCert);
503
504 int count = 0;
Zhiyi Zhang46049832020-09-28 17:08:12 -0700505 face.onSendData.connect([&](const Data& response) {
tylerliu182bc532020-09-25 01:54:45 -0700506 count++;
507 });
508 face.receive(*interest);
509
510 advanceClocks(time::milliseconds(20), 60);
511 BOOST_CHECK_EQUAL(count, 0);
512}
513
Zhiyi Zhang46049832020-09-28 17:08:12 -0700514BOOST_AUTO_TEST_SUITE_END() // TestCaModule
Zhiyi Zhangf5246c42017-01-26 09:39:20 -0800515
Zhiyi Zhangfc1678a2020-05-12 16:52:14 -0700516} // namespace tests
517} // namespace ndncert
518} // namespace ndn