blob: 55495506028b525bc7704b3d687b878c2e28beb9 [file] [log] [blame]
Zhiyi Zhang8617a792017-01-17 16:45:56 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesaventoe5b43692021-11-15 22:05:03 -05002/*
Davide Pesavento0d1d11c2022-04-11 22:11:34 -04003 * Copyright (c) 2017-2022, 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 Zhangaeab4972020-10-22 22:20:40 -070021#ifndef NDNCERT_DETAIL_NDNCERT_COMMON_HPP
22#define NDNCERT_DETAIL_NDNCERT_COMMON_HPP
Zhiyi Zhang8617a792017-01-17 16:45:56 -080023
Zhiyi Zhang840afd92020-10-21 13:24:08 -070024#include "detail/ndncert-config.hpp"
Zhiyi Zhang8617a792017-01-17 16:45:56 -080025
tylerliudd359912020-10-20 13:05:22 -070026#ifdef NDNCERT_HAVE_TESTS
27#define NDNCERT_VIRTUAL_WITH_TESTS virtual
28#define NDNCERT_PUBLIC_WITH_TESTS_ELSE_PROTECTED public
29#define NDNCERT_PUBLIC_WITH_TESTS_ELSE_PRIVATE public
30#define NDNCERT_PROTECTED_WITH_TESTS_ELSE_PRIVATE protected
Zhiyi Zhang8617a792017-01-17 16:45:56 -080031#else
tylerliudd359912020-10-20 13:05:22 -070032#define NDNCERT_VIRTUAL_WITH_TESTS
33#define NDNCERT_PUBLIC_WITH_TESTS_ELSE_PROTECTED protected
34#define NDNCERT_PUBLIC_WITH_TESTS_ELSE_PRIVATE private
35#define NDNCERT_PROTECTED_WITH_TESTS_ELSE_PRIVATE private
Zhiyi Zhang8617a792017-01-17 16:45:56 -080036#endif
37
Zhiyi Zhang48f23782020-09-28 12:11:24 -070038#include <cstddef>
39#include <cstdint>
Davide Pesavento0d1d11c2022-04-11 22:11:34 -040040#include <memory>
41#include <optional>
Davide Pesaventoe5b43692021-11-15 22:05:03 -050042#include <string>
43#include <tuple>
Davide Pesavento0d1d11c2022-04-11 22:11:34 -040044#include <vector>
Davide Pesaventoe5b43692021-11-15 22:05:03 -050045
Zhiyi Zhang48f23782020-09-28 12:11:24 -070046#include <ndn-cxx/data.hpp>
Zhiyi Zhangaeab4972020-10-22 22:20:40 -070047#include <ndn-cxx/encoding/block.hpp>
Davide Pesavento0dc02012021-11-23 22:55:03 -050048#include <ndn-cxx/encoding/block-helpers.hpp>
Zhiyi Zhang48f23782020-09-28 12:11:24 -070049#include <ndn-cxx/interest.hpp>
Zhiyi Zhang48f23782020-09-28 12:11:24 -070050#include <ndn-cxx/name.hpp>
tylerliua7bea662020-10-08 18:51:02 -070051#include <ndn-cxx/security/certificate.hpp>
Davide Pesavento0dc02012021-11-23 22:55:03 -050052#include <ndn-cxx/util/exception.hpp>
Zhiyi Zhang523f0c22020-09-29 14:19:20 -070053#include <ndn-cxx/util/logger.hpp>
Davide Pesavento0dc02012021-11-23 22:55:03 -050054#include <ndn-cxx/util/time.hpp>
Davide Pesaventoe5b43692021-11-15 22:05:03 -050055
Zhiyi Zhangc87d52b2020-09-28 22:07:18 -070056#include <boost/algorithm/string.hpp>
57#include <boost/assert.hpp>
58#include <boost/noncopyable.hpp>
Zhiyi Zhanga749f442020-09-29 17:19:51 -070059#include <boost/property_tree/ptree.hpp>
Zhiyi Zhang8617a792017-01-17 16:45:56 -080060
Zhiyi Zhang8617a792017-01-17 16:45:56 -080061namespace ndncert {
62
Davide Pesavento0dc02012021-11-23 22:55:03 -050063using ndn::Block;
64using ndn::Data;
65using ndn::Interest;
66using ndn::Name;
67using ndn::SignatureInfo;
68using ndn::security::Certificate;
69
Davide Pesavento0dc02012021-11-23 22:55:03 -050070namespace time = ndn::time;
71using namespace ndn::time_literals;
72using namespace std::string_literals;
73
Zhiyi Zhang8f1ade32020-10-14 16:42:57 -070074namespace tlv {
75
76enum : uint32_t {
77 CaPrefix = 129,
78 CaInfo = 131,
79 ParameterKey = 133,
80 ParameterValue = 135,
81 CaCertificate = 137,
82 MaxValidityPeriod = 139,
83 ProbeResponse = 141,
84 MaxSuffixLength = 143,
85 EcdhPub = 145,
86 CertRequest = 147,
87 Salt = 149,
88 RequestId = 151,
89 Challenge = 153,
90 Status = 155,
91 InitializationVector = 157,
92 EncryptedPayload = 159,
93 SelectedChallenge = 161,
94 ChallengeStatus = 163,
95 RemainingTries = 165,
96 RemainingTime = 167,
97 IssuedCertName = 169,
98 ErrorCode = 171,
99 ErrorInfo = 173,
100 AuthenticationTag = 175,
101 CertToRevoke = 177,
102 ProbeRedirect = 179
103};
104
105} // namespace tlv
106
Davide Pesaventoe5b43692021-11-15 22:05:03 -0500107using JsonSection = boost::property_tree::ptree;
Zhiyi Zhang8617a792017-01-17 16:45:56 -0800108
Zhiyi Zhang4b118092020-10-10 10:28:38 -0700109// NDNCERT error code
tylerliu96a67e82020-10-15 13:37:12 -0700110enum class ErrorCode : uint64_t {
Zhiyi Zhang46049832020-09-28 17:08:12 -0700111 NO_ERROR = 0,
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700112 BAD_INTEREST_FORMAT = 1,
113 BAD_PARAMETER_FORMAT = 2,
114 BAD_SIGNATURE = 3,
115 INVALID_PARAMETER = 4,
116 NAME_NOT_ALLOWED = 5,
117 BAD_VALIDITY_PERIOD = 6,
118 OUT_OF_TRIES = 7,
119 OUT_OF_TIME = 8,
120 NO_AVAILABLE_NAMES = 9
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700121};
122
Zhiyi Zhang4b118092020-10-10 10:28:38 -0700123// Convert error code to string
tylerliu96a67e82020-10-15 13:37:12 -0700124std::ostream&
125operator<<(std::ostream& os, ErrorCode code);
Zhiyi Zhang4b118092020-10-10 10:28:38 -0700126
127// NDNCERT request type
tylerliu96a67e82020-10-15 13:37:12 -0700128enum class RequestType : uint64_t {
Zhiyi Zhangc87d52b2020-09-28 22:07:18 -0700129 NOTINITIALIZED = 0,
130 NEW = 1,
131 RENEW = 2,
132 REVOKE = 3
133};
134
Zhiyi Zhang4b118092020-10-10 10:28:38 -0700135// Convert request type to string
tylerliu96a67e82020-10-15 13:37:12 -0700136std::ostream&
137operator<<(std::ostream& out, RequestType type);
Zhiyi Zhanga749f442020-09-29 17:19:51 -0700138
Zhiyi Zhange4891b72020-10-10 15:11:57 -0700139} // namespace ndncert
Zhiyi Zhang8617a792017-01-17 16:45:56 -0800140
Zhiyi Zhangaeab4972020-10-22 22:20:40 -0700141#endif // NDNCERT_DETAIL_NDNCERT_COMMON_HPP