blob: 36148df519442690b2520ec1503ddff00f3fd50c [file] [log] [blame]
Junxiao Shib8590312016-12-29 21:22:25 +00001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Junxiao Shi2d491752017-07-14 21:32:05 +00002/*
Davide Pesaventoc5a9f812023-10-17 18:01:52 -04003 * Copyright (c) 2014-2023, Regents of the University of California,
Junxiao Shib8590312016-12-29 21:22:25 +00004 * 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#ifndef NFD_DAEMON_FACE_FACE_SYSTEM_HPP
27#define NFD_DAEMON_FACE_FACE_SYSTEM_HPP
28
Davide Pesavento2cae8ca2019-04-18 20:48:05 -040029#include "common/config-file.hpp"
30
Junxiao Shi2d491752017-07-14 21:32:05 +000031#include <ndn-cxx/net/network-address.hpp>
32#include <ndn-cxx/net/network-interface.hpp>
33#include <ndn-cxx/net/network-monitor.hpp>
Junxiao Shib8590312016-12-29 21:22:25 +000034
35namespace nfd {
36
37class FaceTable;
Junxiao Shib8590312016-12-29 21:22:25 +000038
39namespace face {
40
Junxiao Shieef49a92018-11-10 12:19:36 +000041class NetdevBound;
Junxiao Shi38b24c72017-01-05 02:59:31 +000042class ProtocolFactory;
Junxiao Shi0ba6d642017-07-17 00:53:22 +000043struct ProtocolFactoryCtorParams;
Junxiao Shi38b24c72017-01-05 02:59:31 +000044
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040045/**
46 * \brief Entry point of NFD's face system.
Junxiao Shib8590312016-12-29 21:22:25 +000047 *
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040048 * NFD's face system is organized as a FaceSystem-ProtocolFactory-Channel-Face hierarchy.
49 * The FaceSystem class is the entry point of the face system and owns all ProtocolFactory objects.
Junxiao Shib8590312016-12-29 21:22:25 +000050 */
51class FaceSystem : noncopyable
52{
53public:
Junxiao Shi0ba6d642017-07-17 00:53:22 +000054 FaceSystem(FaceTable& faceTable, shared_ptr<ndn::net::NetworkMonitor> netmon);
Junxiao Shi2d491752017-07-14 21:32:05 +000055
Junxiao Shib47247d2017-01-24 15:09:16 +000056 ~FaceSystem();
57
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040058 /**
59 * \brief Returns all ProtocolFactory objects owned by the face system.
Junxiao Shib8590312016-12-29 21:22:25 +000060 */
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040061 [[nodiscard]] std::set<const ProtocolFactory*>
Junxiao Shib8590312016-12-29 21:22:25 +000062 listProtocolFactories() const;
63
Davide Pesaventoc5a9f812023-10-17 18:01:52 -040064 /**
65 * \return ProtocolFactory for the specified registered factory id or nullptr if not found.
Junxiao Shib8590312016-12-29 21:22:25 +000066 */
67 ProtocolFactory*
Davide Pesaventoc5a9f812023-10-17 18:01:52 -040068 getFactoryById(const std::string& id) const;
Junxiao Shi38b24c72017-01-05 02:59:31 +000069
Davide Pesaventoc5a9f812023-10-17 18:01:52 -040070 /**
71 * \return ProtocolFactory for the specified FaceUri scheme or nullptr if not found.
Junxiao Shi38b24c72017-01-05 02:59:31 +000072 */
73 ProtocolFactory*
Davide Pesaventoc5a9f812023-10-17 18:01:52 -040074 getFactoryByScheme(const std::string& scheme) const;
Junxiao Shib8590312016-12-29 21:22:25 +000075
Junxiao Shieef49a92018-11-10 12:19:36 +000076 bool
77 hasFactoryForScheme(const std::string& scheme) const;
78
Junxiao Shiea47bde2017-01-26 17:49:16 +000079 FaceTable&
80 getFaceTable()
81 {
82 return m_faceTable;
83 }
84
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040085 /** \brief Register handler for the `face_system` section of NFD's configuration file.
Junxiao Shib8590312016-12-29 21:22:25 +000086 */
87 void
88 setConfigFile(ConfigFile& configFile);
89
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040090 /** \brief Configuration options from `general` section.
Eric Newberry0c841642018-01-17 15:01:00 -070091 */
92 struct GeneralConfig
93 {
Eric Newberry17d18492018-02-10 22:50:06 -070094 bool wantCongestionMarking = true;
Eric Newberry0c841642018-01-17 15:01:00 -070095 };
96
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040097 /** \brief Context for processing a config section in ProtocolFactory.
Junxiao Shi38b24c72017-01-05 02:59:31 +000098 */
99 class ConfigContext : noncopyable
100 {
101 public:
Eric Newberry0c841642018-01-17 15:01:00 -0700102 GeneralConfig generalConfig;
Junxiao Shi38b24c72017-01-05 02:59:31 +0000103 bool isDryRun;
Junxiao Shi38b24c72017-01-05 02:59:31 +0000104 };
105
Davide Pesavento264af772021-02-09 21:48:24 -0500106NFD_PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Junxiao Shi0ba6d642017-07-17 00:53:22 +0000107 ProtocolFactoryCtorParams
108 makePFCtorParams();
109
Junxiao Shib8590312016-12-29 21:22:25 +0000110private:
111 void
112 processConfig(const ConfigSection& configSection, bool isDryRun,
113 const std::string& filename);
114
Davide Pesavento264af772021-02-09 21:48:24 -0500115NFD_PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -0400116 /** \brief Config section name => protocol factory.
Junxiao Shi38b24c72017-01-05 02:59:31 +0000117 */
Junxiao Shib47247d2017-01-24 15:09:16 +0000118 std::map<std::string, unique_ptr<ProtocolFactory>> m_factories;
Junxiao Shieef49a92018-11-10 12:19:36 +0000119 unique_ptr<NetdevBound> m_netdevBound;
Junxiao Shi38b24c72017-01-05 02:59:31 +0000120
Junxiao Shib47247d2017-01-24 15:09:16 +0000121private:
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -0400122 /** \brief Scheme => protocol factory.
Junxiao Shib8590312016-12-29 21:22:25 +0000123 *
124 * The same protocol factory may be available under multiple schemes.
125 */
Junxiao Shib47247d2017-01-24 15:09:16 +0000126 std::map<std::string, ProtocolFactory*> m_factoryByScheme;
Junxiao Shib8590312016-12-29 21:22:25 +0000127
128 FaceTable& m_faceTable;
Junxiao Shi0ba6d642017-07-17 00:53:22 +0000129 shared_ptr<ndn::net::NetworkMonitor> m_netmon;
Junxiao Shib8590312016-12-29 21:22:25 +0000130};
131
132} // namespace face
133
134using face::FaceSystem;
135
136} // namespace nfd
137
138#endif // NFD_DAEMON_FACE_FACE_SYSTEM_HPP