blob: 9835578e56d10a3f96a8b08bf8da62b48bbb8997 [file] [log] [blame]
Zhiyi Zhang8617a792017-01-17 16:45:56 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -07003 * Copyright (c) 2017-2019, 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
38#include <cstddef>
39#include <cstdint>
40#include <functional>
41#include <list>
42#include <map>
43#include <memory>
44#include <set>
45#include <string>
46#include <unordered_map>
47#include <utility>
48
49#include <ndn-cxx/interest.hpp>
50#include <ndn-cxx/data.hpp>
51#include <ndn-cxx/name.hpp>
Zhiyi Zhangb6fab0f2017-09-21 16:26:27 -070052#include <ndn-cxx/face.hpp>
53#include <ndn-cxx/link.hpp>
Zhiyi Zhang8617a792017-01-17 16:45:56 -080054#include <ndn-cxx/encoding/block.hpp>
55#include <ndn-cxx/lp/nack.hpp>
56#include <ndn-cxx/util/backports.hpp>
Zhiyi Zhang8617a792017-01-17 16:45:56 -080057#include <ndn-cxx/util/signal.hpp>
Zhiyi Zhangb6fab0f2017-09-21 16:26:27 -070058#include <ndn-cxx/security/key-chain.hpp>
Zhiyi Zhang8617a792017-01-17 16:45:56 -080059#include <ndn-cxx/security/v2/certificate.hpp>
60
61#include <boost/algorithm/string.hpp>
62#include <boost/assert.hpp>
63#include <boost/noncopyable.hpp>
64#include <boost/property_tree/ptree.hpp>
65#include <boost/property_tree/json_parser.hpp>
66#include <boost/property_tree/info_parser.hpp>
67#include <boost/throw_exception.hpp>
68
69namespace ndn {
70namespace ndncert {
71
72using std::size_t;
Zhiyi Zhang8617a792017-01-17 16:45:56 -080073using boost::noncopyable;
Zhiyi Zhang8617a792017-01-17 16:45:56 -080074using std::shared_ptr;
75using std::unique_ptr;
76using std::weak_ptr;
77using std::make_shared;
78using ndn::make_unique;
79using std::enable_shared_from_this;
Zhiyi Zhang8617a792017-01-17 16:45:56 -080080using std::function;
81using std::bind;
Zhiyi Zhang8617a792017-01-17 16:45:56 -080082using ndn::Interest;
83using ndn::Data;
84using ndn::Name;
85using ndn::PartialName;
86using ndn::Block;
87using ndn::time::system_clock;
88using ndn::time::toUnixTimestamp;
89
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -070090// JSON format for Certificate Issuer (CA)
91const std::string JSON_CA_NAME = "name";
92const std::string JSON_CA_CONFIG = "ca-config";
93const std::string JSON_CA_ECDH = "ecdh-pub";
94const std::string JSON_CA_SALT = "salt";
Zhiyi Zhangff4bcb62019-09-08 12:57:42 -070095const std::string JSON_CA_REQUEST_ID = "request-id";
Zhiyi Zhangaf7c2902019-03-14 22:13:21 -070096const std::string JSON_CA_STATUS = "status";
97const std::string JSON_CA_CHALLENGES = "challenges";
98const std::string JSON_CA_CHALLENGE_ID = "challenge-id";
99const std::string JSON_CA_CERT_ID = "certificate-id";
100
101// JSON format for Challenge Module
102const std::string JSON_CHALLENGE_STATUS = "challenge-status";
103const std::string JSON_CHALLENGE_REMAINING_TRIES = "remaining-tries";
104const std::string JSON_CHALLENGE_REMAINING_TIME = "remaining-time";
105
106// JSON format for Certificate Requester
107const std::string JSON_CLIENT_PROBE_INFO = "probe-info";
108const std::string JSON_CLIENT_ECDH = "ecdh-pub";
109const std::string JSON_CLIENT_CERT_REQ = "cert-request";
110const std::string JSON_CLIENT_SELECTED_CHALLENGE = "selected-challenge";
111
112// NDNCERT Status Enum
113enum {
114 STATUS_BEFORE_CHALLENGE = 0,
115 STATUS_CHALLENGE = 1,
116 STATUS_PENDING = 2,
117 STATUS_SUCCESS = 3,
118 STATUS_FAILURE = 4,
119 STATUS_NOT_STARTED = 5
120};
121
122// Pre-defined challenge status
123const std::string CHALLENGE_STATUS_SUCCESS = "success";
124const std::string CHALLENGE_STATUS_FAILURE_TIMEOUT = "failure-timeout";
125const std::string CHALLENGE_STATUS_FAILURE_MAXRETRY = "failure-max-retry";
126const std::string CHALLENGE_STATUS_UNKNOWN_CHALLENGE = "unknown-challenge";
127
Zhiyi Zhang8617a792017-01-17 16:45:56 -0800128} // namespace ndncert
129} // namespace ndn
130
Zhiyi Zhangb6fab0f2017-09-21 16:26:27 -0700131#endif // NDNCERT_NDNCERT_COMMON_HPP