blob: fb4735d593736e0f8475811dd665195d58e93d9a [file] [log] [blame]
Alexander Afanasyeva9034b02014-01-26 18:32:02 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Junxiao Shi0ba6d642017-07-17 00:53:22 +00002/*
Junxiao Shi38b24c72017-01-05 02:59:31 +00003 * Copyright (c) 2014-2017, Regents of the University of California,
Chengyu Fan4381fb62015-01-14 11:37:04 -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/>.
Steve DiBenedettoef04f272014-06-04 14:28:31 -060024 */
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080025
Alexander Afanasyev613e2a92014-04-15 13:36:58 -070026#ifndef NFD_DAEMON_FACE_TCP_FACTORY_HPP
27#define NFD_DAEMON_FACE_TCP_FACTORY_HPP
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080028
Alexander Afanasyev0eb70652014-02-27 18:35:07 -080029#include "protocol-factory.hpp"
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080030#include "tcp-channel.hpp"
31
Alexander Afanasyev18bbf812014-01-29 01:40:23 -080032namespace nfd {
Junxiao Shi38b24c72017-01-05 02:59:31 +000033namespace face {
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080034
Junxiao Shi38b24c72017-01-05 02:59:31 +000035/** \brief protocol factory for TCP over IPv4 and IPv6
36 */
Alexander Afanasyev0eb70652014-02-27 18:35:07 -080037class TcpFactory : public ProtocolFactory
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080038{
39public:
Junxiao Shib47247d2017-01-24 15:09:16 +000040 static const std::string&
41 getId();
42
Junxiao Shi0ba6d642017-07-17 00:53:22 +000043 explicit
44 TcpFactory(const CtorParams& params);
45
Junxiao Shi38b24c72017-01-05 02:59:31 +000046 /** \brief process face_system.tcp config section
47 */
48 void
49 processConfig(OptionalConfigSection configSection,
50 FaceSystem::ConfigContext& context) override;
51
52 void
Eric Newberry944f38b2017-07-20 20:54:22 -040053 createFace(const CreateFaceParams& params,
Junxiao Shi38b24c72017-01-05 02:59:31 +000054 const FaceCreatedCallback& onCreated,
55 const FaceCreationFailedCallback& onFailure) override;
56
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080057 /**
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080058 * \brief Create TCP-based channel using tcp::Endpoint
59 *
60 * tcp::Endpoint is really an alias for boost::asio::ip::tcp::endpoint.
61 *
Davide Pesavento46afec42017-05-28 14:28:47 -040062 * If this method is called twice with the same endpoint, only one channel
63 * will be created. The second call will just return the existing channel.
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080064 *
Davide Pesavento46afec42017-05-28 14:28:47 -040065 * \return always a valid pointer to a TcpChannel object, an exception
66 * is thrown if it cannot be created.
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080067 */
68 shared_ptr<TcpChannel>
Alexander Afanasyevd6655302014-02-28 08:41:28 -080069 createChannel(const tcp::Endpoint& localEndpoint);
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080070
71 /**
Alexander Afanasyev0e156df2015-01-26 22:33:43 -080072 * \brief Create TCP-based channel using specified IP address and port number
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080073 *
Davide Pesavento46afec42017-05-28 14:28:47 -040074 * This method is just a helper that converts the string representation of \p localIp
75 * and \p localPort to tcp::Endpoint and calls the other createChannel overload.
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080076 *
Davide Pesavento46afec42017-05-28 14:28:47 -040077 * \return always a valid pointer to a UdpChannel object, an exception
78 * is thrown if it cannot be created.
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080079 */
80 shared_ptr<TcpChannel>
Alexander Afanasyev0e156df2015-01-26 22:33:43 -080081 createChannel(const std::string& localIp, const std::string& localPort);
Alexander Afanasyevd6655302014-02-28 08:41:28 -080082
Junxiao Shi38b24c72017-01-05 02:59:31 +000083 std::vector<shared_ptr<const Channel>>
Davide Pesaventob84bd3a2016-04-22 02:21:45 +020084 getChannels() const override;
Steve DiBenedettoef04f272014-06-04 14:28:31 -060085
Davide Pesavento1d7e7af2015-10-10 23:54:08 +020086private:
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080087 /**
88 * \brief Look up TcpChannel using specified local endpoint
89 *
Davide Pesavento46afec42017-05-28 14:28:47 -040090 * \return shared pointer to the existing TcpChannel object
91 * or empty shared pointer when such channel does not exist
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080092 */
93 shared_ptr<TcpChannel>
Davide Pesavento1d7e7af2015-10-10 23:54:08 +020094 findChannel(const tcp::Endpoint& localEndpoint) const;
95
96private:
97 std::map<tcp::Endpoint, shared_ptr<TcpChannel>> m_channels;
Alexander Afanasyeva9034b02014-01-26 18:32:02 -080098};
99
Junxiao Shi38b24c72017-01-05 02:59:31 +0000100} // namespace face
Alexander Afanasyev18bbf812014-01-29 01:40:23 -0800101} // namespace nfd
Alexander Afanasyeva9034b02014-01-26 18:32:02 -0800102
Alexander Afanasyev613e2a92014-04-15 13:36:58 -0700103#endif // NFD_DAEMON_FACE_TCP_FACTORY_HPP