blob: 5b870fe67de0b90d507f6de032d2632dec2ca9b1 [file] [log] [blame]
Junxiao Shi61e3cc52014-03-03 20:40:28 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Davide Pesavento15b55052018-01-27 19:09:28 -05002/*
3 * Copyright (c) 2014-2018, Regents of the University of California,
Davide Pesavento47ab0292015-11-02 18:45:39 +01004 * 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/>.
Davide Pesavento47ab0292015-11-02 18:45:39 +010024 */
Junxiao Shi61e3cc52014-03-03 20:40:28 -070025
Alexander Afanasyev613e2a92014-04-15 13:36:58 -070026#ifndef NFD_DAEMON_FACE_CHANNEL_HPP
27#define NFD_DAEMON_FACE_CHANNEL_HPP
Junxiao Shi61e3cc52014-03-03 20:40:28 -070028
Davide Pesavento77911cc2017-04-08 22:12:30 -040029#include "channel-log.hpp"
Junxiao Shicde37ad2015-12-24 01:02:05 -070030#include "face.hpp"
Junxiao Shi61e3cc52014-03-03 20:40:28 -070031
Eric Newberry0c3e57b2018-01-25 20:54:46 -070032#include <boost/logic/tribool.hpp>
33
Junxiao Shi61e3cc52014-03-03 20:40:28 -070034namespace nfd {
Davide Pesavento8fd15e62017-04-06 19:58:54 -040035namespace face {
Junxiao Shi61e3cc52014-03-03 20:40:28 -070036
Davide Pesaventoc19408d2017-04-08 00:42:55 -040037/** \brief Prototype for the callback that is invoked when a face is created
38 * (in response to an incoming connection or after a connection is established)
Davide Pesavento47ab0292015-11-02 18:45:39 +010039 */
Davide Pesavento87fc0f82018-04-11 23:43:51 -040040using FaceCreatedCallback = std::function<void(const shared_ptr<Face>& face)>;
Davide Pesavento47ab0292015-11-02 18:45:39 +010041
Davide Pesaventoc19408d2017-04-08 00:42:55 -040042/** \brief Prototype for the callback that is invoked when a face fails to be created
Davide Pesavento47ab0292015-11-02 18:45:39 +010043 */
Davide Pesavento87fc0f82018-04-11 23:43:51 -040044using FaceCreationFailedCallback = std::function<void(uint32_t status, const std::string& reason)>;
Davide Pesavento47ab0292015-11-02 18:45:39 +010045
Junxiao Shi38b24c72017-01-05 02:59:31 +000046/** \brief represent a channel that communicates on a local endpoint
47 * \sa FaceSystem
48 *
49 * A channel can listen on a local endpoint and initiate outgoing connection from a local endpoint.
50 * A channel creates Face objects and retains shared ownership of them.
51 */
Junxiao Shi61e3cc52014-03-03 20:40:28 -070052class Channel : noncopyable
53{
54public:
Junxiao Shi61e3cc52014-03-03 20:40:28 -070055 virtual
56 ~Channel();
57
58 const FaceUri&
Davide Pesaventoc19408d2017-04-08 00:42:55 -040059 getUri() const
60 {
61 return m_uri;
62 }
63
64 /** \brief Returns whether the channel is listening
65 */
66 virtual bool
67 isListening() const = 0;
68
69 /** \brief Returns the number of faces in the channel
70 */
71 virtual size_t
72 size() const = 0;
Junxiao Shi61e3cc52014-03-03 20:40:28 -070073
74protected:
75 void
76 setUri(const FaceUri& uri);
77
78private:
79 FaceUri m_uri;
80};
81
Davide Pesavento15b55052018-01-27 19:09:28 -050082/** \brief Parameters used to set Transport properties or LinkService options on a newly created face
83 *
84 * Parameters are passed as a struct rather than individually, so that a future change in the list
85 * of parameters does not require an update to the method signature in all subclasses.
86 */
87class FaceParams
88{
89public:
90 // get rid of this constructor and use aggregate init + NSDMIs when we switch to C++14
91 FaceParams() noexcept
92 : persistency(ndn::nfd::FACE_PERSISTENCY_PERSISTENT)
93 , wantLocalFields(false)
94 , wantLpReliability(false)
Eric Newberry0c3e57b2018-01-25 20:54:46 -070095 , wantCongestionMarking(boost::logic::indeterminate)
Davide Pesavento15b55052018-01-27 19:09:28 -050096 {
97 }
98
99public:
100 ndn::nfd::FacePersistency persistency;
Davide Pesavento87fc0f82018-04-11 23:43:51 -0400101 optional<time::nanoseconds> baseCongestionMarkingInterval;
102 optional<uint64_t> defaultCongestionThreshold;
Davide Pesavento15b55052018-01-27 19:09:28 -0500103 bool wantLocalFields;
104 bool wantLpReliability;
Eric Newberry0c3e57b2018-01-25 20:54:46 -0700105 boost::logic::tribool wantCongestionMarking;
Davide Pesavento15b55052018-01-27 19:09:28 -0500106};
107
Junxiao Shicde37ad2015-12-24 01:02:05 -0700108/** \brief invokes a callback when the face is closed
109 * \param face the face
110 * \param f the callback to be invoked when the face enters CLOSED state
111 *
112 * This function connects a callback to the afterStateChange signal on the \p face,
113 * and invokes \p f when the state becomes CLOSED.
114 */
115void
116connectFaceClosedSignal(Face& face, const std::function<void()>& f);
117
Davide Pesavento8fd15e62017-04-06 19:58:54 -0400118} // namespace face
Junxiao Shi61e3cc52014-03-03 20:40:28 -0700119} // namespace nfd
120
Alexander Afanasyev613e2a92014-04-15 13:36:58 -0700121#endif // NFD_DAEMON_FACE_CHANNEL_HPP