blob: d7d534b9081d1da8f7f9bface1bdcddf07f7bf82 [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 Pesaventoaa9e3b22022-10-21 17:00:07 -04003 * Copyright (c) 2014-2022, 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 "network-predicate.hpp"
30#include "common/config-file.hpp"
31
Junxiao Shi2d491752017-07-14 21:32:05 +000032#include <ndn-cxx/net/network-address.hpp>
33#include <ndn-cxx/net/network-interface.hpp>
34#include <ndn-cxx/net/network-monitor.hpp>
Junxiao Shib8590312016-12-29 21:22:25 +000035
36namespace nfd {
37
38class FaceTable;
Junxiao Shib8590312016-12-29 21:22:25 +000039
40namespace face {
41
Junxiao Shieef49a92018-11-10 12:19:36 +000042class NetdevBound;
Junxiao Shi38b24c72017-01-05 02:59:31 +000043class ProtocolFactory;
Junxiao Shi0ba6d642017-07-17 00:53:22 +000044struct ProtocolFactoryCtorParams;
Junxiao Shi38b24c72017-01-05 02:59:31 +000045
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040046/**
47 * \brief Entry point of NFD's face system.
Junxiao Shib8590312016-12-29 21:22:25 +000048 *
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040049 * NFD's face system is organized as a FaceSystem-ProtocolFactory-Channel-Face hierarchy.
50 * The FaceSystem class is the entry point of the face system and owns all ProtocolFactory objects.
Junxiao Shib8590312016-12-29 21:22:25 +000051 */
52class FaceSystem : noncopyable
53{
54public:
Junxiao Shi0ba6d642017-07-17 00:53:22 +000055 FaceSystem(FaceTable& faceTable, shared_ptr<ndn::net::NetworkMonitor> netmon);
Junxiao Shi2d491752017-07-14 21:32:05 +000056
Junxiao Shib47247d2017-01-24 15:09:16 +000057 ~FaceSystem();
58
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040059 /**
60 * \brief Returns all ProtocolFactory objects owned by the face system.
Junxiao Shib8590312016-12-29 21:22:25 +000061 */
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040062 [[nodiscard]] std::set<const ProtocolFactory*>
Junxiao Shib8590312016-12-29 21:22:25 +000063 listProtocolFactories() const;
64
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040065 /** \return ProtocolFactory for the specified registered factory id or nullptr if not found.
Junxiao Shib8590312016-12-29 21:22:25 +000066 */
67 ProtocolFactory*
Junxiao Shi38b24c72017-01-05 02:59:31 +000068 getFactoryById(const std::string& id);
69
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040070 /** \return ProtocolFactory for the specified FaceUri scheme or nullptr if not found.
Junxiao Shi38b24c72017-01-05 02:59:31 +000071 */
72 ProtocolFactory*
73 getFactoryByScheme(const std::string& scheme);
Junxiao Shib8590312016-12-29 21:22:25 +000074
Junxiao Shieef49a92018-11-10 12:19:36 +000075 bool
76 hasFactoryForScheme(const std::string& scheme) const;
77
Junxiao Shiea47bde2017-01-26 17:49:16 +000078 FaceTable&
79 getFaceTable()
80 {
81 return m_faceTable;
82 }
83
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040084 /** \brief Register handler for the `face_system` section of NFD's configuration file.
Junxiao Shib8590312016-12-29 21:22:25 +000085 */
86 void
87 setConfigFile(ConfigFile& configFile);
88
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040089 /** \brief Configuration options from `general` section.
Eric Newberry0c841642018-01-17 15:01:00 -070090 */
91 struct GeneralConfig
92 {
Eric Newberry17d18492018-02-10 22:50:06 -070093 bool wantCongestionMarking = true;
Eric Newberry0c841642018-01-17 15:01:00 -070094 };
95
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040096 /** \brief Context for processing a config section in ProtocolFactory.
Junxiao Shi38b24c72017-01-05 02:59:31 +000097 */
98 class ConfigContext : noncopyable
99 {
100 public:
Eric Newberry0c841642018-01-17 15:01:00 -0700101 GeneralConfig generalConfig;
Junxiao Shi38b24c72017-01-05 02:59:31 +0000102 bool isDryRun;
Junxiao Shi38b24c72017-01-05 02:59:31 +0000103 };
104
Davide Pesavento264af772021-02-09 21:48:24 -0500105NFD_PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Junxiao Shi0ba6d642017-07-17 00:53:22 +0000106 ProtocolFactoryCtorParams
107 makePFCtorParams();
108
Junxiao Shib8590312016-12-29 21:22:25 +0000109private:
110 void
111 processConfig(const ConfigSection& configSection, bool isDryRun,
112 const std::string& filename);
113
Davide Pesavento264af772021-02-09 21:48:24 -0500114NFD_PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -0400115 /** \brief Config section name => protocol factory.
Junxiao Shi38b24c72017-01-05 02:59:31 +0000116 */
Junxiao Shib47247d2017-01-24 15:09:16 +0000117 std::map<std::string, unique_ptr<ProtocolFactory>> m_factories;
Junxiao Shieef49a92018-11-10 12:19:36 +0000118 unique_ptr<NetdevBound> m_netdevBound;
Junxiao Shi38b24c72017-01-05 02:59:31 +0000119
Junxiao Shib47247d2017-01-24 15:09:16 +0000120private:
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -0400121 /** \brief Scheme => protocol factory.
Junxiao Shib8590312016-12-29 21:22:25 +0000122 *
123 * The same protocol factory may be available under multiple schemes.
124 */
Junxiao Shib47247d2017-01-24 15:09:16 +0000125 std::map<std::string, ProtocolFactory*> m_factoryByScheme;
Junxiao Shib8590312016-12-29 21:22:25 +0000126
127 FaceTable& m_faceTable;
Junxiao Shi0ba6d642017-07-17 00:53:22 +0000128 shared_ptr<ndn::net::NetworkMonitor> m_netmon;
Junxiao Shib8590312016-12-29 21:22:25 +0000129};
130
131} // namespace face
132
133using face::FaceSystem;
134
135} // namespace nfd
136
137#endif // NFD_DAEMON_FACE_FACE_SYSTEM_HPP