blob: 1c0452dd66e3fd854a825a2ea1782de15610f4d6 [file] [log] [blame]
Junxiao Shi61e3cc52014-03-03 20:40:28 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Junxiao Shi38b24c72017-01-05 02:59:31 +00003 * Copyright (c) 2014-2017, 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
Junxiao Shicde37ad2015-12-24 01:02:05 -070029#include "face.hpp"
Junxiao Shi61e3cc52014-03-03 20:40:28 -070030
31namespace nfd {
32
Davide Pesavento47ab0292015-11-02 18:45:39 +010033/**
34 * \brief Prototype for the callback that is invoked when the face
35 * is created (as a response to incoming connection or after
36 * connection is established)
37 */
38typedef function<void(const shared_ptr<Face>& newFace)> FaceCreatedCallback;
39
40/**
41 * \brief Prototype for the callback that is invoked when the face
42 * fails to be created
43 */
Eric Newberry42602412016-08-27 09:33:18 -070044typedef function<void(uint32_t status, const std::string& reason)> FaceCreationFailedCallback;
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&
59 getUri() const;
60
61protected:
62 void
63 setUri(const FaceUri& uri);
64
65private:
66 FaceUri m_uri;
67};
68
69inline const FaceUri&
70Channel::getUri() const
71{
72 return m_uri;
73}
74
Junxiao Shicde37ad2015-12-24 01:02:05 -070075/** \brief invokes a callback when the face is closed
76 * \param face the face
77 * \param f the callback to be invoked when the face enters CLOSED state
78 *
79 * This function connects a callback to the afterStateChange signal on the \p face,
80 * and invokes \p f when the state becomes CLOSED.
81 */
82void
83connectFaceClosedSignal(Face& face, const std::function<void()>& f);
84
Junxiao Shi61e3cc52014-03-03 20:40:28 -070085} // namespace nfd
86
Alexander Afanasyev613e2a92014-04-15 13:36:58 -070087#endif // NFD_DAEMON_FACE_CHANNEL_HPP