blob: db4760bacaa5d043c4663899650682c9644d060f [file] [log] [blame]
Giulio Grassi624f6c62014-02-18 19:42:14 +01001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Chengyu Fan4381fb62015-01-14 11:37:04 -07003 * Copyright (c) 2014-2015, Regents of the University of California,
4 * 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 */
Giulio Grassi624f6c62014-02-18 19:42:14 +010025
Alexander Afanasyev613e2a92014-04-15 13:36:58 -070026#ifndef NFD_DAEMON_FACE_UDP_FACTORY_HPP
27#define NFD_DAEMON_FACE_UDP_FACTORY_HPP
Giulio Grassi624f6c62014-02-18 19:42:14 +010028
29#include "protocol-factory.hpp"
30#include "udp-channel.hpp"
31#include "multicast-udp-face.hpp"
32
33
34namespace nfd {
35
36// @todo The multicast support for ipv6 must be implemented
37
38class UdpFactory : public ProtocolFactory
39{
40public:
41 /**
42 * \brief Exception of UdpFactory
43 */
Alexander Afanasyev5959b012014-06-02 19:18:12 +030044 class Error : public ProtocolFactory::Error
Giulio Grassi624f6c62014-02-18 19:42:14 +010045 {
Alexander Afanasyev5959b012014-06-02 19:18:12 +030046 public:
47 explicit
48 Error(const std::string& what)
49 : ProtocolFactory::Error(what)
50 {
51 }
Giulio Grassi624f6c62014-02-18 19:42:14 +010052 };
Steve DiBenedettoca53ac62014-03-27 19:58:40 -060053
Alexander Afanasyev5959b012014-06-02 19:18:12 +030054 typedef std::map< udp::Endpoint, shared_ptr<MulticastUdpFace> > MulticastFaceMap;
55
Giulio Grassi624f6c62014-02-18 19:42:14 +010056 explicit
57 UdpFactory(const std::string& defaultPort = "6363");
58
59 /**
60 * \brief Create UDP-based channel using udp::Endpoint
61 *
62 * udp::Endpoint is really an alias for boost::asio::ip::udp::endpoint.
63 *
64 * If this method called twice with the same endpoint, only one channel
65 * will be created. The second call will just retrieve the existing
66 * channel.
67 *
68 * If a multicast face is already active on the same local endpoint,
69 * the creation fails and an exception is thrown
70 *
71 * Once a face is created, if it doesn't send/receive anything for
72 * a period of time equal to timeout, it will be destroyed
73 * @todo this funcionality has to be implemented
74 *
75 * \returns always a valid pointer to a UdpChannel object, an exception
76 * is thrown if it cannot be created.
77 *
78 * \throws UdpFactory::Error
79 *
80 * \see http://www.boost.org/doc/libs/1_42_0/doc/html/boost_asio/reference/ip__udp/endpoint.html
81 * for details on ways to create udp::Endpoint
82 */
83 shared_ptr<UdpChannel>
84 createChannel(const udp::Endpoint& localEndpoint,
Alexander Afanasyev5959b012014-06-02 19:18:12 +030085 const time::seconds& timeout = time::seconds(600));
Giulio Grassi624f6c62014-02-18 19:42:14 +010086
87 /**
88 * \brief Create UDP-based channel using specified host and port number
89 *
90 * This method will attempt to resolve the provided host and port numbers
91 * and will throw UdpFactory::Error when channel cannot be created.
92 *
93 * Note that this call will **BLOCK** until resolution is done or failed.
94 *
Steve DiBenedettoca53ac62014-03-27 19:58:40 -060095 * If localHost is a IPv6 address of a specific device, it must be in the form:
Giulio Grassi624f6c62014-02-18 19:42:14 +010096 * ip address%interface name
97 * Example: fe80::5e96:9dff:fe7d:9c8d%en1
Steve DiBenedettoca53ac62014-03-27 19:58:40 -060098 * Otherwise, you can use ::
Giulio Grassi624f6c62014-02-18 19:42:14 +010099 *
Giulio Grassi624f6c62014-02-18 19:42:14 +0100100 * \throws UdpChannel::Error if the bind on the socket fails
101 * \throws UdpFactory::Error
102 */
103 shared_ptr<UdpChannel>
104 createChannel(const std::string& localHost,
Alexander Afanasyev5959b012014-06-02 19:18:12 +0300105 const std::string& localPort,
106 const time::seconds& timeout = time::seconds(600));
Giulio Grassi624f6c62014-02-18 19:42:14 +0100107
108 /**
109 * \brief Create MulticastUdpFace using udp::Endpoint
110 *
111 * udp::Endpoint is really an alias for boost::asio::ip::udp::endpoint.
112 *
113 * The face will join the multicast group
114 *
115 * If this method called twice with the same endpoint and group, only one face
116 * will be created. The second call will just retrieve the existing
117 * channel.
118 *
119 * If an unicast face is already active on the same local NIC and port, the
120 * creation fails and an exception is thrown
121 *
Giulio Grassi6d7176d2014-04-16 16:08:48 +0200122 * \param networkInterfaceName name of the network interface on which the face will be bound
123 * (Used only on multihomed linux machine with more than one MulticastUdpFace for
124 * the same multicast group. If specified, will requires CAP_NET_RAW capability)
125 * An empty string can be provided in other system or in linux machine with only one
126 * MulticastUdpFace per multicast group
127 *
128 *
Giulio Grassi624f6c62014-02-18 19:42:14 +0100129 * \returns always a valid pointer to a MulticastUdpFace object, an exception
Steve DiBenedettoca53ac62014-03-27 19:58:40 -0600130 * is thrown if it cannot be created.
Giulio Grassi624f6c62014-02-18 19:42:14 +0100131 *
132 * \throws UdpFactory::Error
133 *
134 * \see http://www.boost.org/doc/libs/1_42_0/doc/html/boost_asio/reference/ip__udp/endpoint.html
135 * for details on ways to create udp::Endpoint
136 */
137 shared_ptr<MulticastUdpFace>
138 createMulticastFace(const udp::Endpoint& localEndpoint,
Giulio Grassi6d7176d2014-04-16 16:08:48 +0200139 const udp::Endpoint& multicastEndpoint,
140 const std::string& networkInterfaceName = "");
Steve DiBenedettoca53ac62014-03-27 19:58:40 -0600141
Giulio Grassi624f6c62014-02-18 19:42:14 +0100142 shared_ptr<MulticastUdpFace>
143 createMulticastFace(const std::string& localIp,
144 const std::string& multicastIp,
Giulio Grassi6d7176d2014-04-16 16:08:48 +0200145 const std::string& multicastPort,
146 const std::string& networkInterfaceName = "");
Steve DiBenedettoca53ac62014-03-27 19:58:40 -0600147
Giulio Grassi624f6c62014-02-18 19:42:14 +0100148 // from Factory
149 virtual void
150 createFace(const FaceUri& uri,
151 const FaceCreatedCallback& onCreated,
152 const FaceConnectFailedCallback& onConnectFailed);
153
Steve DiBenedettoef04f272014-06-04 14:28:31 -0600154 virtual std::list<shared_ptr<const Channel> >
155 getChannels() const;
Giulio Grassi624f6c62014-02-18 19:42:14 +0100156
157 /**
Alexander Afanasyev5959b012014-06-02 19:18:12 +0300158 * \brief Get map of configured multicast faces
Giulio Grassi624f6c62014-02-18 19:42:14 +0100159 */
Alexander Afanasyev5959b012014-06-02 19:18:12 +0300160 const MulticastFaceMap&
161 getMulticastFaces() const;
Giulio Grassi624f6c62014-02-18 19:42:14 +0100162
Alexander Afanasyev70aaf8a2014-12-13 00:44:22 -0800163PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Steve DiBenedettoca53ac62014-03-27 19:58:40 -0600164
165 void
166 prohibitEndpoint(const udp::Endpoint& endpoint);
167
168 void
169 prohibitAllIpv4Endpoints(const uint16_t port);
170
171 void
172 prohibitAllIpv6Endpoints(const uint16_t port);
173
Giulio Grassi624f6c62014-02-18 19:42:14 +0100174 void
175 afterFaceFailed(udp::Endpoint& endpoint);
Steve DiBenedettoca53ac62014-03-27 19:58:40 -0600176
Giulio Grassi624f6c62014-02-18 19:42:14 +0100177 /**
178 * \brief Look up UdpChannel using specified local endpoint
179 *
180 * \returns shared pointer to the existing UdpChannel object
181 * or empty shared pointer when such channel does not exist
182 *
183 * \throws never
184 */
185 shared_ptr<UdpChannel>
186 findChannel(const udp::Endpoint& localEndpoint);
Steve DiBenedettoca53ac62014-03-27 19:58:40 -0600187
188
Giulio Grassi624f6c62014-02-18 19:42:14 +0100189 /**
190 * \brief Look up multicast UdpFace using specified local endpoint
191 *
192 * \returns shared pointer to the existing multicast MulticastUdpFace object
193 * or empty shared pointer when such face does not exist
194 *
195 * \throws never
196 */
197 shared_ptr<MulticastUdpFace>
198 findMulticastFace(const udp::Endpoint& localEndpoint);
Steve DiBenedettoca53ac62014-03-27 19:58:40 -0600199
Alexander Afanasyev70aaf8a2014-12-13 00:44:22 -0800200PUBLIC_WITH_TESTS_ELSE_PRIVATE:
Giulio Grassi624f6c62014-02-18 19:42:14 +0100201 typedef std::map< udp::Endpoint, shared_ptr<UdpChannel> > ChannelMap;
Alexander Afanasyev5959b012014-06-02 19:18:12 +0300202
Giulio Grassi624f6c62014-02-18 19:42:14 +0100203 ChannelMap m_channels;
Alexander Afanasyev5959b012014-06-02 19:18:12 +0300204 MulticastFaceMap m_multicastFaces;
Steve DiBenedettoca53ac62014-03-27 19:58:40 -0600205
Giulio Grassi624f6c62014-02-18 19:42:14 +0100206 std::string m_defaultPort;
Steve DiBenedettoca53ac62014-03-27 19:58:40 -0600207 std::set<udp::Endpoint> m_prohibitedEndpoints;
Giulio Grassi624f6c62014-02-18 19:42:14 +0100208};
209
Alexander Afanasyev5959b012014-06-02 19:18:12 +0300210
211inline const UdpFactory::MulticastFaceMap&
212UdpFactory::getMulticastFaces() const
213{
214 return m_multicastFaces;
215}
216
217
Giulio Grassi624f6c62014-02-18 19:42:14 +0100218} // namespace nfd
219
Alexander Afanasyev613e2a92014-04-15 13:36:58 -0700220#endif // NFD_DAEMON_FACE_UDP_FACTORY_HPP