blob: 6727a88b59d3bde27b0e80b63bf017fc64c77553 [file] [log] [blame]
Zhiyi Zhang8617a792017-01-17 16:45:56 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Zhiyi Zhangad9e04f2020-03-27 12:04:31 -07003 * Copyright (c) 2017-2020, Regents of the University of California.
Zhiyi Zhang8617a792017-01-17 16:45:56 -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 Zhangb6fab0f2017-09-21 16:26:27 -070021#ifndef NDNCERT_NDNCERT_COMMON_HPP
22#define NDNCERT_NDNCERT_COMMON_HPP
Zhiyi Zhang8617a792017-01-17 16:45:56 -080023
24#include "ndncert-config.hpp"
25
Zhiyi Zhangdaf2fd72017-01-19 11:31:35 -080026#ifdef HAVE_TESTS
Zhiyi Zhang8617a792017-01-17 16:45:56 -080027#define VIRTUAL_WITH_TESTS virtual
28#define PUBLIC_WITH_TESTS_ELSE_PROTECTED public
29#define PUBLIC_WITH_TESTS_ELSE_PRIVATE public
30#define PROTECTED_WITH_TESTS_ELSE_PRIVATE protected
31#else
32#define VIRTUAL_WITH_TESTS
33#define PUBLIC_WITH_TESTS_ELSE_PROTECTED protected
34#define PUBLIC_WITH_TESTS_ELSE_PRIVATE private
35#define PROTECTED_WITH_TESTS_ELSE_PRIVATE private
36#endif
37
Zhiyi Zhang8617a792017-01-17 16:45:56 -080038#include <boost/algorithm/string.hpp>
39#include <boost/assert.hpp>
40#include <boost/noncopyable.hpp>
Zhiyi Zhang8617a792017-01-17 16:45:56 -080041#include <boost/throw_exception.hpp>
Zhiyi Zhang48f23782020-09-28 12:11:24 -070042#include <cstddef>
43#include <cstdint>
44#include <ndn-cxx/data.hpp>
45#include <ndn-cxx/encoding/block.hpp>
46#include <ndn-cxx/face.hpp>
47#include <ndn-cxx/interest.hpp>
48#include <ndn-cxx/link.hpp>
49#include <ndn-cxx/lp/nack.hpp>
50#include <ndn-cxx/name.hpp>
51#include <ndn-cxx/security/key-chain.hpp>
52#include <ndn-cxx/security/v2/certificate.hpp>
Zhiyi Zhang8617a792017-01-17 16:45:56 -080053
54namespace ndn {
55namespace ndncert {
56
Zhiyi Zhang8617a792017-01-17 16:45:56 -080057using boost::noncopyable;
Zhiyi Zhang48f23782020-09-28 12:11:24 -070058using ndn::Block;
Zhiyi Zhang8617a792017-01-17 16:45:56 -080059using ndn::Data;
Zhiyi Zhang48f23782020-09-28 12:11:24 -070060using ndn::Interest;
61using ndn::make_unique;
Zhiyi Zhang8617a792017-01-17 16:45:56 -080062using ndn::Name;
63using ndn::PartialName;
Zhiyi Zhang8617a792017-01-17 16:45:56 -080064using ndn::time::system_clock;
65using ndn::time::toUnixTimestamp;
Zhiyi Zhang48f23782020-09-28 12:11:24 -070066using std::bind;
67using std::enable_shared_from_this;
68using std::function;
69using std::make_shared;
70using std::shared_ptr;
71using std::size_t;
72using std::unique_ptr;
73using std::weak_ptr;
Zhiyi Zhang8617a792017-01-17 16:45:56 -080074
Zhiyi Zhang0453dbb2020-04-28 22:39:17 -070075enum : uint32_t {
76 tlv_ca_prefix = 129,
77 tlv_ca_info = 131,
78 tlv_parameter_key = 133,
79 tlv_parameter_value = 135,
80 tlv_ca_certificate = 137,
81 tlv_max_validity_period = 139,
Zhiyi Zhang48f23782020-09-28 12:11:24 -070082 tlv_max_suffix_length = 177,
Zhiyi Zhang0453dbb2020-04-28 22:39:17 -070083 tlv_probe_response = 141,
84 tlv_allow_longer_name = 143,
85 tlv_ecdh_pub = 145,
86 tlv_cert_request = 147,
87 tlv_salt = 149,
88 tlv_request_id = 151,
89 tlv_challenge = 153,
90 tlv_status = 155,
91 tlv_initialization_vector = 157,
92 tlv_encrypted_payload = 159,
93 tlv_selected_challenge = 161,
94 tlv_challenge_status = 163,
95 tlv_remaining_tries = 165,
96 tlv_remaining_time = 167,
97 tlv_issued_cert_name = 169,
98 tlv_error_code = 171,
Zhiyi Zhangb8cb0472020-05-05 20:55:05 -070099 tlv_error_info = 173,
tylerliu182bc532020-09-25 01:54:45 -0700100 tlv_authentication_tag = 175,
tylerliu9a831352020-09-28 11:16:01 -0700101 tlv_cert_to_revoke = 179
Zhiyi Zhang0453dbb2020-04-28 22:39:17 -0700102};
103
104// Parse CA Configuration file
105const std::string CONFIG_CA_PREFIX = "ca-prefix";
106const std::string CONFIG_CA_INFO = "ca-info";
107const std::string CONFIG_MAX_VALIDITY_PERIOD = "max-validity-period";
108const std::string CONFIG_PROBE_PARAMETERS = "probe-parameters";
109const std::string CONFIG_PROBE_PARAMETER = "probe-parameter-key";
110const std::string CONFIG_SUPPORTED_CHALLENGES = "supported-challenges";
111const std::string CONFIG_CHALLENGE = "challenge";
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700112const std::string CONFIG_MAX_SUFFIX_LENGTH = "max-suffix-length";
Zhiyi Zhang0453dbb2020-04-28 22:39:17 -0700113
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700114// // JSON format for Certificate Issuer (CA)
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700115const std::string JSON_CA_NAME = "name";
116const std::string JSON_CA_CONFIG = "ca-config";
117const std::string JSON_CA_ECDH = "ecdh-pub";
118const std::string JSON_CA_SALT = "salt";
Zhiyi Zhangff4bcb62019-09-08 12:57:42 -0700119const std::string JSON_CA_REQUEST_ID = "request-id";
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700120const std::string JSON_CA_STATUS = "status";
121const std::string JSON_CA_CHALLENGES = "challenges";
122const std::string JSON_CA_CHALLENGE_ID = "challenge-id";
123const std::string JSON_CA_CERT_ID = "certificate-id";
124
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700125// // JSON format for Challenge Module
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700126const std::string JSON_CHALLENGE_STATUS = "challenge-status";
127const std::string JSON_CHALLENGE_REMAINING_TRIES = "remaining-tries";
128const std::string JSON_CHALLENGE_REMAINING_TIME = "remaining-time";
swa770cf1d8f72020-04-21 23:12:39 -0700129const std::string JSON_CHALLENGE_ISSUED_CERT_NAME = "issued-cert-name";
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700130
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700131// // JSON format for Certificate Requester
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700132const std::string JSON_CLIENT_PROBE_INFO = "probe-info";
133const std::string JSON_CLIENT_ECDH = "ecdh-pub";
134const std::string JSON_CLIENT_CERT_REQ = "cert-request";
135const std::string JSON_CLIENT_SELECTED_CHALLENGE = "selected-challenge";
tylerliu9a831352020-09-28 11:16:01 -0700136const std::string JSON_CLIENT_CERT_TO_REVOKE = "cert-to-revoke";
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700137
138// NDNCERT Status Enum
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700139enum class Status : uint16_t {
140 BEFORE_CHALLENGE = 0,
141 CHALLENGE = 1,
142 PENDING = 2,
143 SUCCESS = 3,
144 FAILURE = 4,
145 NOT_STARTED = 5,
146 ENDED = 6
147};
148
149std::string statusToString(Status status);
150
151enum class Error : uint16_t {
Zhiyi Zhang46049832020-09-28 17:08:12 -0700152 NO_ERROR = 0,
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700153 BAD_INTEREST_FORMAT = 1,
154 BAD_PARAMETER_FORMAT = 2,
155 BAD_SIGNATURE = 3,
156 INVALID_PARAMETER = 4,
157 NAME_NOT_ALLOWED = 5,
158 BAD_VALIDITY_PERIOD = 6,
159 OUT_OF_TRIES = 7,
160 OUT_OF_TIME = 8,
161 NO_AVAILABLE_NAMES = 9
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700162};
163
164// Pre-defined challenge status
165const std::string CHALLENGE_STATUS_SUCCESS = "success";
166const std::string CHALLENGE_STATUS_FAILURE_TIMEOUT = "failure-timeout";
167const std::string CHALLENGE_STATUS_FAILURE_MAXRETRY = "failure-max-retry";
168const std::string CHALLENGE_STATUS_UNKNOWN_CHALLENGE = "unknown-challenge";
169
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700170} // namespace ndncert
171} // namespace ndn
Zhiyi Zhang8617a792017-01-17 16:45:56 -0800172
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700173#endif // NDNCERT_NDNCERT_COMMON_HPP