blob: 94d927318ef17d0dcdd30b0246562540cc8078c3 [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 Pesavento9510c912024-02-25 17:50:05 -05003 * Copyright (c) 2017-2024, 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
Davide Pesavento9510c912024-02-25 17:50:05 -050026#ifdef NDNCERT_WITH_TESTS
tylerliudd359912020-10-20 13:05:22 -070027#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>
Davide Pesavento9510c912024-02-25 17:50:05 -050041#include <stdexcept>
Davide Pesaventoe5b43692021-11-15 22:05:03 -050042#include <string>
Davide Pesavento0d1d11c2022-04-11 22:11:34 -040043#include <vector>
Davide Pesaventoe5b43692021-11-15 22:05:03 -050044
Zhiyi Zhang48f23782020-09-28 12:11:24 -070045#include <ndn-cxx/data.hpp>
Zhiyi Zhangaeab4972020-10-22 22:20:40 -070046#include <ndn-cxx/encoding/block.hpp>
Davide Pesavento0dc02012021-11-23 22:55:03 -050047#include <ndn-cxx/encoding/block-helpers.hpp>
Zhiyi Zhang48f23782020-09-28 12:11:24 -070048#include <ndn-cxx/interest.hpp>
Zhiyi Zhang48f23782020-09-28 12:11:24 -070049#include <ndn-cxx/name.hpp>
tylerliua7bea662020-10-08 18:51:02 -070050#include <ndn-cxx/security/certificate.hpp>
Davide Pesavento0dc02012021-11-23 22:55:03 -050051#include <ndn-cxx/util/exception.hpp>
Davide Pesavento0dc02012021-11-23 22:55:03 -050052#include <ndn-cxx/util/time.hpp>
Davide Pesaventoe5b43692021-11-15 22:05:03 -050053
Zhiyi Zhangc87d52b2020-09-28 22:07:18 -070054#include <boost/assert.hpp>
Davide Pesavento9510c912024-02-25 17:50:05 -050055#include <boost/core/noncopyable.hpp>
Zhiyi Zhanga749f442020-09-29 17:19:51 -070056#include <boost/property_tree/ptree.hpp>
Zhiyi Zhang8617a792017-01-17 16:45:56 -080057
Zhiyi Zhang8617a792017-01-17 16:45:56 -080058namespace ndncert {
59
Davide Pesavento0dc02012021-11-23 22:55:03 -050060using ndn::Block;
61using ndn::Data;
62using ndn::Interest;
63using ndn::Name;
64using ndn::SignatureInfo;
65using ndn::security::Certificate;
66
Davide Pesavento0dc02012021-11-23 22:55:03 -050067namespace time = ndn::time;
68using namespace ndn::time_literals;
69using namespace std::string_literals;
70
Zhiyi Zhang8f1ade32020-10-14 16:42:57 -070071namespace tlv {
72
73enum : uint32_t {
74 CaPrefix = 129,
75 CaInfo = 131,
76 ParameterKey = 133,
77 ParameterValue = 135,
78 CaCertificate = 137,
79 MaxValidityPeriod = 139,
80 ProbeResponse = 141,
81 MaxSuffixLength = 143,
82 EcdhPub = 145,
83 CertRequest = 147,
84 Salt = 149,
85 RequestId = 151,
86 Challenge = 153,
87 Status = 155,
88 InitializationVector = 157,
89 EncryptedPayload = 159,
90 SelectedChallenge = 161,
91 ChallengeStatus = 163,
92 RemainingTries = 165,
93 RemainingTime = 167,
94 IssuedCertName = 169,
95 ErrorCode = 171,
96 ErrorInfo = 173,
97 AuthenticationTag = 175,
98 CertToRevoke = 177,
Davide Pesavento9510c912024-02-25 17:50:05 -050099 ProbeRedirect = 179,
Zhiyi Zhang8f1ade32020-10-14 16:42:57 -0700100};
101
102} // namespace tlv
103
Davide Pesaventoe5b43692021-11-15 22:05:03 -0500104using JsonSection = boost::property_tree::ptree;
Zhiyi Zhang8617a792017-01-17 16:45:56 -0800105
Zhiyi Zhang4b118092020-10-10 10:28:38 -0700106// NDNCERT error code
tylerliu96a67e82020-10-15 13:37:12 -0700107enum class ErrorCode : uint64_t {
Zhiyi Zhang46049832020-09-28 17:08:12 -0700108 NO_ERROR = 0,
Zhiyi Zhang48f23782020-09-28 12:11:24 -0700109 BAD_INTEREST_FORMAT = 1,
110 BAD_PARAMETER_FORMAT = 2,
111 BAD_SIGNATURE = 3,
112 INVALID_PARAMETER = 4,
113 NAME_NOT_ALLOWED = 5,
114 BAD_VALIDITY_PERIOD = 6,
115 OUT_OF_TRIES = 7,
116 OUT_OF_TIME = 8,
Davide Pesavento9510c912024-02-25 17:50:05 -0500117 NO_AVAILABLE_NAMES = 9,
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -0700118};
119
Zhiyi Zhang4b118092020-10-10 10:28:38 -0700120// Convert error code to string
tylerliu96a67e82020-10-15 13:37:12 -0700121std::ostream&
122operator<<(std::ostream& os, ErrorCode code);
Zhiyi Zhang4b118092020-10-10 10:28:38 -0700123
124// NDNCERT request type
tylerliu96a67e82020-10-15 13:37:12 -0700125enum class RequestType : uint64_t {
Zhiyi Zhangc87d52b2020-09-28 22:07:18 -0700126 NOTINITIALIZED = 0,
127 NEW = 1,
128 RENEW = 2,
Davide Pesavento9510c912024-02-25 17:50:05 -0500129 REVOKE = 3,
Zhiyi Zhangc87d52b2020-09-28 22:07:18 -0700130};
131
Zhiyi Zhang4b118092020-10-10 10:28:38 -0700132// Convert request type to string
tylerliu96a67e82020-10-15 13:37:12 -0700133std::ostream&
134operator<<(std::ostream& out, RequestType type);
Zhiyi Zhanga749f442020-09-29 17:19:51 -0700135
Zhiyi Zhange4891b72020-10-10 15:11:57 -0700136} // namespace ndncert
Zhiyi Zhang8617a792017-01-17 16:45:56 -0800137
Zhiyi Zhangaeab4972020-10-22 22:20:40 -0700138#endif // NDNCERT_DETAIL_NDNCERT_COMMON_HPP