blob: 1cd2618a7cb9de42e1b9d9d1b290997c6d9cec58 [file] [log] [blame]
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -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 Zhang32dbb9f2017-02-16 15:15:10 -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
21#include "client-config.hpp"
Zhiyi Zhang5ebeb692017-03-10 14:13:01 -080022#include <ndn-cxx/util/io.hpp>
Zhiyi Zhangcaab5462019-10-18 13:41:02 -070023#include <fstream>
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080024
25namespace ndn {
26namespace ndncert {
27
28void
29ClientConfig::load(const std::string& fileName)
30{
Zhiyi Zhange4ee8222017-12-08 22:43:04 -080031 JsonSection config;
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080032 try {
Zhiyi Zhange4ee8222017-12-08 22:43:04 -080033 boost::property_tree::read_json(fileName, config);
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080034 }
Zhiyi Zhang8da54d62019-11-21 00:03:05 -080035 catch (const std::exception& error) {
36 BOOST_THROW_EXCEPTION(Error("Failed to parse configuration file " + fileName + ", " + error.what()));
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080037 }
38
Zhiyi Zhange4ee8222017-12-08 22:43:04 -080039 if (config.begin() == config.end()) {
Zhiyi Zhang8da54d62019-11-21 00:03:05 -080040 BOOST_THROW_EXCEPTION(Error("Error processing configuration file: " + fileName + ", no data"));
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080041 }
42
Zhiyi Zhange4ee8222017-12-08 22:43:04 -080043 load(config);
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080044}
45
46void
Zhiyi Zhange4ee8222017-12-08 22:43:04 -080047ClientConfig::load(const JsonSection& configSection)
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080048{
49 m_caItems.clear();
Zhiyi Zhange4ee8222017-12-08 22:43:04 -080050 auto caList = configSection.get_child("ca-list");
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080051 auto it = caList.begin();
52 for (; it != caList.end(); it++) {
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +080053 m_caItems.push_back(extractCaItem(it->second));
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080054 }
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +080055 m_localNdncertAnchor = configSection.get("local-ndncert-anchor", "");
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080056}
57
Zhiyi Zhangcaab5462019-10-18 13:41:02 -070058void
59ClientConfig::save(const std::string& fileName)
60{
61 JsonSection configJson;
62 JsonSection caList;
63 std::stringstream ss;
64 for (const auto& item : m_caItems) {
65 JsonSection caItem;
66 caItem.put("ca-prefix", item.m_caName.toUri());
67 caItem.put("ca-info", item.m_caInfo);
68 caItem.put("probe", item.m_probe);
69 ss.str(std::string());
70 io::save(item.m_anchor, ss);
71 caItem.put("certificate", ss.str());
72 caList.push_back(std::make_pair("", caItem));
73 }
74 configJson.add_child("ca-list", caList);
75 ss.str(std::string());
76 boost::property_tree::write_json(ss, configJson);
77
78 std::ofstream configFile;
79 configFile.open(fileName, std::ios::trunc);
80 configFile << ss.str();
81 configFile.close();
82}
83
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +080084ClientCaItem
85ClientConfig::extractCaItem(const JsonSection& configSection)
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -080086{
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +080087 ClientCaItem item;
Zhiyi Zhang8da54d62019-11-21 00:03:05 -080088 item.m_caName = Name(configSection.get("ca-prefix", ""));
89 if (item.m_caName.empty()) {
90 BOOST_THROW_EXCEPTION(Error("Cannot read ca-prefix from the config file"));
91 }
92 item.m_caInfo = configSection.get("ca-info", "");
93 item.m_probe = configSection.get("probe", "");
94 std::istringstream ss(configSection.get("certificate", ""));
95 auto anchor = io::load<security::v2::Certificate>(ss);
96 if (anchor == nullptr) {
97 BOOST_THROW_EXCEPTION(Error("Cannot load the certificate from config file"));
98 }
99 item.m_anchor = *anchor;
Zhiyi Zhang1c0bd372017-12-18 18:32:55 +0800100 return item;
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -0800101}
102
103void
104ClientConfig::removeCaItem(const Name& caName)
105{
Zhiyi Zhang5ebeb692017-03-10 14:13:01 -0800106 m_caItems.remove_if([&] (const ClientCaItem& item) {return item.m_caName == caName;});
Zhiyi Zhang32dbb9f2017-02-16 15:15:10 -0800107}
108
109} // namespace ndncert
110} // namespace ndn