blob: da170b97112d24608251d46da0d2d2e46458b2ff [file] [log] [blame]
Zhiyi Zhang3f20f952020-11-19 19:26:43 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2017-2020, Regents of the University of California.
4 *
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
21#ifndef NDNCERT_DETAIL_CA_CONFIGURATION_HPP
22#define NDNCERT_DETAIL_CA_CONFIGURATION_HPP
23
24#include "detail/ca-profile.hpp"
25
26namespace ndn {
27namespace ndncert {
28namespace ca {
29
30/**
31 * @brief CA's configuration on NDNCERT.
32 * @sa https://github.com/named-data/ndncert/wiki/NDNCERT-Protocol-0.3
33 *
34 * The format of CA configuration in JSON
35 * {
36 * "ca-prefix": "",
37 * "ca-info": "",
38 * "max-validity-period": "",
39 * "max-suffix-length": "",
40 * "probe-parameters":
41 * [
42 * {"probe-parameter-key": ""},
43 * {"probe-parameter-key": ""}
44 * ]
45 * "supported-challenges":
46 * [
47 * {"challenge": ""},
48 * {"challenge": ""}
49 * ]
50 * }
51 */
52class CaConfig
53{
54public:
55 /**
56 * Load CA configuration from the file.
57 * @throw std::runtime_error when config file cannot be correctly parsed.
58 */
59 void
60 load(const std::string& fileName);
61
62public:
63 CaProfile m_caItem;
64 /**
65 * Used for CA redirection
66 * @sa https://github.com/named-data/ndncert/wiki/NDNCERT-Protocol-0.3-PROBE-Extensions#probe-extension-for-redirection
67 */
68 optional<std::vector<std::shared_ptr<security::Certificate>>> m_redirection = nullopt;
69 /**
70 * Name Assignment Functions
71 */
72 std::vector<std::unique_ptr<NameAssignmentFunc>> m_nameAssignmentFuncs;
73};
74
75} // namespace ca
76} // namespace ndncert
77} // namespace ndn
78
79#endif // NDNCERT_DETAIL_CA_CONFIGURATION_HPP