blob: 5cda79e89f3155237e7bdff427f0f5261fc1cf6d [file] [log] [blame]
Alexander Afanasyev31c781e2015-02-09 17:39:59 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Junxiao Shi2d491752017-07-14 21:32:05 +00002/*
Davide Pesavento6cc95412022-09-20 19:10:55 -04003 * Copyright (c) 2014-2022, Regents of the University of California,
Alexander Afanasyev31c781e2015-02-09 17:39:59 -08004 * Arizona Board of Regents,
5 * Colorado State University,
6 * University Pierre & Marie Curie, Sorbonne University,
7 * Washington University in St. Louis,
8 * Beijing Institute of Technology,
9 * The University of Memphis.
10 *
11 * This file is part of NFD (Named Data Networking Forwarding Daemon).
12 * See AUTHORS.md for complete list of NFD authors and contributors.
13 *
14 * NFD is free software: you can redistribute it and/or modify it under the terms
15 * of the GNU General Public License as published by the Free Software Foundation,
16 * either version 3 of the License, or (at your option) any later version.
17 *
18 * NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
19 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
20 * PURPOSE. See the GNU General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License along with
23 * NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24 */
25
26#include "nfd.hpp"
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040027#include "common/global.hpp"
28#include "common/logger.hpp"
29#include "common/privilege-helper.hpp"
Junxiao Shiea47bde2017-01-26 17:49:16 +000030#include "face/face-system.hpp"
Yanbiao Li4ee73d42015-08-19 16:30:16 -070031#include "face/internal-face.hpp"
Junxiao Shif2bfb442018-01-05 12:34:57 +000032#include "face/null-face.hpp"
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040033#include "fw/face-table.hpp"
Junxiao Shif2bfb442018-01-05 12:34:57 +000034#include "fw/forwarder.hpp"
35#include "mgmt/cs-manager.hpp"
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080036#include "mgmt/face-manager.hpp"
Junxiao Shif2bfb442018-01-05 12:34:57 +000037#include "mgmt/fib-manager.hpp"
Yanbiao Li7cec7ea2015-08-19 16:30:16 -070038#include "mgmt/forwarder-status-manager.hpp"
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080039#include "mgmt/general-config-section.hpp"
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040040#include "mgmt/log-config-section.hpp"
Junxiao Shif2bfb442018-01-05 12:34:57 +000041#include "mgmt/strategy-choice-manager.hpp"
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080042#include "mgmt/tables-config-section.hpp"
43
44namespace nfd {
45
Davide Pesaventoa3148082018-04-12 18:21:54 -040046NFD_LOG_INIT(Nfd);
Alexander Afanasyev3f41ade2015-06-29 18:31:22 -070047
Davide Pesavento6cc95412022-09-20 19:10:55 -040048const std::string INTERNAL_CONFIG{"internal://nfd.conf"};
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080049
Junxiao Shi2d491752017-07-14 21:32:05 +000050Nfd::Nfd(ndn::KeyChain& keyChain)
51 : m_keyChain(keyChain)
52 , m_netmon(make_shared<ndn::net::NetworkMonitor>(getGlobalIoService()))
Alexander Afanasyev441ba212015-09-10 23:41:07 -070053{
Davide Pesavento859a69e2019-07-13 17:10:46 -040054 // Disable automatic verification of parameters digest for decoded Interests.
55 Interest::setAutoCheckParametersDigest(false);
Alexander Afanasyev441ba212015-09-10 23:41:07 -070056}
57
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080058Nfd::Nfd(const std::string& configFile, ndn::KeyChain& keyChain)
Junxiao Shi2d491752017-07-14 21:32:05 +000059 : Nfd(keyChain)
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080060{
Junxiao Shi2d491752017-07-14 21:32:05 +000061 m_configFile = configFile;
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080062}
63
64Nfd::Nfd(const ConfigSection& config, ndn::KeyChain& keyChain)
Junxiao Shi2d491752017-07-14 21:32:05 +000065 : Nfd(keyChain)
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080066{
Junxiao Shi2d491752017-07-14 21:32:05 +000067 m_configSection = config;
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080068}
69
Junxiao Shi9ddf1b52016-08-22 03:58:55 +000070// It is necessary to explicitly define the destructor, because some member variables (e.g.,
71// unique_ptr<Forwarder>) are forward-declared, but implicitly declared destructor requires
72// complete types for all members when instantiated.
73Nfd::~Nfd() = default;
Alexander Afanasyev2bda6f82015-02-10 14:17:19 -080074
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080075void
76Nfd::initialize()
77{
Davide Pesaventoa3148082018-04-12 18:21:54 -040078 configureLogging();
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080079
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040080 m_faceTable = make_unique<FaceTable>();
81 m_faceTable->addReserved(face::makeNullFace(), face::FACEID_NULL);
82 m_faceTable->addReserved(face::makeNullFace(FaceUri("contentstore://")), face::FACEID_CONTENT_STORE);
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080083
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040084 m_faceSystem = make_unique<face::FaceSystem>(*m_faceTable, m_netmon);
85 m_forwarder = make_unique<Forwarder>(*m_faceTable);
Junxiao Shiea47bde2017-01-26 17:49:16 +000086
87 initializeManagement();
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080088
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080089 PrivilegeHelper::drop();
Alexander Afanasyev3f41ade2015-06-29 18:31:22 -070090
Junxiao Shi2d491752017-07-14 21:32:05 +000091 m_netmon->onNetworkStateChanged.connect([this] {
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040092 // delay stages, so if multiple events are triggered in short sequence,
93 // only one auto-detection procedure is triggered
94 m_reloadConfigEvent = getScheduler().schedule(5_s, [this] {
95 NFD_LOG_INFO("Network change detected, reloading face section of the config file...");
96 reloadConfigFileFaceSection();
Junxiao Shi2d491752017-07-14 21:32:05 +000097 });
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040098 });
Alexander Afanasyev31c781e2015-02-09 17:39:59 -080099}
100
101void
Davide Pesaventoa3148082018-04-12 18:21:54 -0400102Nfd::configureLogging()
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800103{
104 ConfigFile config(&ConfigFile::ignoreUnknownSection);
Davide Pesaventoa3148082018-04-12 18:21:54 -0400105 log::setConfigFile(config);
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800106
107 if (!m_configFile.empty()) {
108 config.parse(m_configFile, true);
109 config.parse(m_configFile, false);
110 }
111 else {
112 config.parse(m_configSection, true, INTERNAL_CONFIG);
113 config.parse(m_configSection, false, INTERNAL_CONFIG);
114 }
115}
116
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800117static inline void
118ignoreRibAndLogSections(const std::string& filename, const std::string& sectionName,
119 const ConfigSection& section, bool isDryRun)
120{
121 // Ignore "log" and "rib" sections, but raise an error if we're missing a
122 // handler for an NFD section.
123 if (sectionName == "rib" || sectionName == "log") {
124 // do nothing
125 }
126 else {
127 // missing NFD section
128 ConfigFile::throwErrorOnUnknownSection(filename, sectionName, section, isDryRun);
129 }
130}
131
132void
133Nfd::initializeManagement()
134{
Junxiao Shi6535f1e2015-10-08 13:02:18 -0700135 std::tie(m_internalFace, m_internalClientFace) = face::makeInternalFace(m_keyChain);
Davide Pesaventoa4abfb02019-10-06 16:02:56 -0400136 m_faceTable->addReserved(m_internalFace, face::FACEID_INTERNAL_FACE);
Junxiao Shi9ddf1b52016-08-22 03:58:55 +0000137
Davide Pesaventocfb1a312018-03-01 01:30:56 -0500138 m_dispatcher = make_unique<ndn::mgmt::Dispatcher>(*m_internalClientFace, m_keyChain);
Junxiao Shi9ddf1b52016-08-22 03:58:55 +0000139 m_authenticator = CommandAuthenticator::create();
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800140
Davide Pesaventocfb1a312018-03-01 01:30:56 -0500141 m_forwarderStatusManager = make_unique<ForwarderStatusManager>(*m_forwarder, *m_dispatcher);
142 m_faceManager = make_unique<FaceManager>(*m_faceSystem, *m_dispatcher, *m_authenticator);
Davide Pesaventoa4abfb02019-10-06 16:02:56 -0400143 m_fibManager = make_unique<FibManager>(m_forwarder->getFib(), *m_faceTable,
Davide Pesaventocfb1a312018-03-01 01:30:56 -0500144 *m_dispatcher, *m_authenticator);
145 m_csManager = make_unique<CsManager>(m_forwarder->getCs(), m_forwarder->getCounters(),
146 *m_dispatcher, *m_authenticator);
147 m_strategyChoiceManager = make_unique<StrategyChoiceManager>(m_forwarder->getStrategyChoice(),
148 *m_dispatcher, *m_authenticator);
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800149
150 ConfigFile config(&ignoreRibAndLogSections);
151 general::setConfigFile(config);
152
Philipp Molla1033342021-06-14 09:34:21 +0200153 m_forwarder->setConfigFile(config);
154
Junxiao Shi0cc125c2016-08-25 21:50:04 +0000155 TablesConfigSection tablesConfig(*m_forwarder);
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800156 tablesConfig.setConfigFile(config);
157
Junxiao Shi9ddf1b52016-08-22 03:58:55 +0000158 m_authenticator->setConfigFile(config);
Davide Pesaventocfb1a312018-03-01 01:30:56 -0500159 m_faceSystem->setConfigFile(config);
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800160
161 // parse config file
162 if (!m_configFile.empty()) {
163 config.parse(m_configFile, true);
164 config.parse(m_configFile, false);
165 }
166 else {
167 config.parse(m_configSection, true, INTERNAL_CONFIG);
168 config.parse(m_configSection, false, INTERNAL_CONFIG);
169 }
170
Junxiao Shi0cc125c2016-08-25 21:50:04 +0000171 tablesConfig.ensureConfigured();
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800172
173 // add FIB entry for NFD Management Protocol
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700174 Name topPrefix("/localhost/nfd");
Ju Pand8315bf2019-07-31 06:59:07 +0000175 fib::Entry* entry = m_forwarder->getFib().insert(topPrefix).first;
176 m_forwarder->getFib().addOrUpdateNextHop(*entry, *m_internalFace, 0);
Yanbiao Li698f4fe2015-08-19 16:30:16 -0700177 m_dispatcher->addTopPrefix(topPrefix, false);
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800178}
179
180void
181Nfd::reloadConfigFile()
182{
Davide Pesaventoa3148082018-04-12 18:21:54 -0400183 configureLogging();
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800184
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800185 ConfigFile config(&ignoreRibAndLogSections);
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800186 general::setConfigFile(config);
187
Philipp Molla1033342021-06-14 09:34:21 +0200188 m_forwarder->setConfigFile(config);
189
Junxiao Shi0cc125c2016-08-25 21:50:04 +0000190 TablesConfigSection tablesConfig(*m_forwarder);
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800191 tablesConfig.setConfigFile(config);
192
Junxiao Shi9ddf1b52016-08-22 03:58:55 +0000193 m_authenticator->setConfigFile(config);
Davide Pesaventocfb1a312018-03-01 01:30:56 -0500194 m_faceSystem->setConfigFile(config);
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800195
196 if (!m_configFile.empty()) {
197 config.parse(m_configFile, false);
198 }
199 else {
200 config.parse(m_configSection, false, INTERNAL_CONFIG);
201 }
202}
203
Alexander Afanasyev3f41ade2015-06-29 18:31:22 -0700204void
205Nfd::reloadConfigFileFaceSection()
206{
207 // reload only face_system section of the config file to re-initialize multicast faces
208 ConfigFile config(&ConfigFile::ignoreUnknownSection);
Davide Pesaventocfb1a312018-03-01 01:30:56 -0500209 m_faceSystem->setConfigFile(config);
Alexander Afanasyev3f41ade2015-06-29 18:31:22 -0700210
211 if (!m_configFile.empty()) {
212 config.parse(m_configFile, false);
213 }
214 else {
215 config.parse(m_configSection, false, INTERNAL_CONFIG);
216 }
217}
218
Alexander Afanasyev31c781e2015-02-09 17:39:59 -0800219} // namespace nfd