blob: b19530df96ee84b6805251b84065072bc128bcb5 [file] [log] [blame]
Junxiao Shia4f2be82014-03-02 22:56:41 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesaventoa4abfb02019-10-06 16:02:56 -04002/*
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -04003 * Copyright (c) 2014-2022, Regents of the University of California,
Junxiao Shicde37ad2015-12-24 01:02:05 -07004 * 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.
Alexander Afanasyev9bcbc7c2014-04-06 19:37:37 -070010 *
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/>.
Junxiao Shi7b984c62014-07-17 22:18:34 -070024 */
Junxiao Shia4f2be82014-03-02 22:56:41 -070025
Alexander Afanasyev613e2a92014-04-15 13:36:58 -070026#ifndef NFD_DAEMON_FW_FACE_TABLE_HPP
27#define NFD_DAEMON_FW_FACE_TABLE_HPP
Junxiao Shia4f2be82014-03-02 22:56:41 -070028
29#include "face/face.hpp"
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040030
Junxiao Shib84e6742016-07-19 13:16:22 +000031#include <boost/range/adaptor/indirected.hpp>
Junxiao Shiafbd74d2014-11-29 21:18:17 -070032#include <boost/range/adaptor/map.hpp>
Junxiao Shia4f2be82014-03-02 22:56:41 -070033
Junxiao Shi1e064172014-12-14 19:37:46 -070034namespace nfd {
Junxiao Shia4f2be82014-03-02 22:56:41 -070035
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040036/**
37 * \brief Container of all faces.
Junxiao Shia4f2be82014-03-02 22:56:41 -070038 */
Junxiao Shi7b984c62014-07-17 22:18:34 -070039class FaceTable : noncopyable
Junxiao Shia4f2be82014-03-02 22:56:41 -070040{
41public:
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040042 /** \brief Add a face.
Junxiao Shi5b43f9a2016-07-19 13:15:56 +000043 *
44 * FaceTable obtains shared ownership of the face.
45 * The channel or protocol factory that creates the face may retain ownership.
46 */
Junxiao Shidcffdaa2016-07-26 02:23:56 +000047 void
Junxiao Shia4f2be82014-03-02 22:56:41 -070048 add(shared_ptr<Face> face);
49
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040050 /** \brief Add a special face with a reserved FaceId.
Junxiao Shi5b43f9a2016-07-19 13:15:56 +000051 */
Junxiao Shidcffdaa2016-07-26 02:23:56 +000052 void
Junxiao Shi7b984c62014-07-17 22:18:34 -070053 addReserved(shared_ptr<Face> face, FaceId faceId);
54
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040055 /** \brief Get face by FaceId.
56 * \return A pointer to the face if found, nullptr otherwise;
57 * `face->shared_from_this()` can be used if a `shared_ptr` is desired.
Junxiao Shi5b43f9a2016-07-19 13:15:56 +000058 */
Junxiao Shidcffdaa2016-07-26 02:23:56 +000059 Face*
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040060 get(FaceId id) const noexcept;
Junxiao Shia4f2be82014-03-02 22:56:41 -070061
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040062 /** \brief Return the total number of faces.
Junxiao Shi5b43f9a2016-07-19 13:15:56 +000063 */
Junxiao Shia4f2be82014-03-02 22:56:41 -070064 size_t
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -040065 size() const noexcept;
Junxiao Shia4f2be82014-03-02 22:56:41 -070066
67public: // enumeration
Davide Pesavento6fd1e7e2017-02-17 18:45:27 +000068 using FaceMap = std::map<FaceId, shared_ptr<Face>>;
69 using ForwardRange = boost::indirected_range<const boost::select_second_const_range<FaceMap>>;
Davide Pesavento6fd1e7e2017-02-17 18:45:27 +000070 using const_iterator = boost::range_iterator<ForwardRange>::type;
Alexander Afanasyev7b7dfdd2014-03-21 13:57:54 -070071
Junxiao Shia4f2be82014-03-02 22:56:41 -070072 const_iterator
73 begin() const;
74
75 const_iterator
76 end() const;
77
Junxiao Shi1e064172014-12-14 19:37:46 -070078public: // signals
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040079 /** \brief Fires immediately after a face is added.
Junxiao Shibd392bf2014-03-17 15:54:11 -070080 */
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040081 signal::Signal<FaceTable, Face> afterAdd;
Junxiao Shibd392bf2014-03-17 15:54:11 -070082
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040083 /** \brief Fires immediately before a face is removed.
Junxiao Shibd392bf2014-03-17 15:54:11 -070084 *
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040085 * When this signal is emitted, the face is still in FaceTable and has a valid FaceId.
Junxiao Shibd392bf2014-03-17 15:54:11 -070086 */
Davide Pesaventoa4abfb02019-10-06 16:02:56 -040087 signal::Signal<FaceTable, Face> beforeRemove;
Junxiao Shibd392bf2014-03-17 15:54:11 -070088
Junxiao Shia4f2be82014-03-02 22:56:41 -070089private:
Junxiao Shi7b984c62014-07-17 22:18:34 -070090 void
91 addImpl(shared_ptr<Face> face, FaceId faceId);
92
Junxiao Shic542b2b2014-03-16 21:45:52 -070093 void
Junxiao Shiae04d342016-07-19 13:20:22 +000094 remove(FaceId faceId);
Junxiao Shic542b2b2014-03-16 21:45:52 -070095
Junxiao Shiafbd74d2014-11-29 21:18:17 -070096 ForwardRange
97 getForwardRange() const;
98
Junxiao Shic542b2b2014-03-16 21:45:52 -070099private:
Davide Pesaventoaa9e3b22022-10-21 17:00:07 -0400100 FaceId m_lastFaceId = face::FACEID_RESERVED_MAX;
Junxiao Shia4f2be82014-03-02 22:56:41 -0700101 FaceMap m_faces;
102};
103
Junxiao Shia4f2be82014-03-02 22:56:41 -0700104} // namespace nfd
105
Alexander Afanasyev613e2a92014-04-15 13:36:58 -0700106#endif // NFD_DAEMON_FW_FACE_TABLE_HPP