blob: 38598930954a948acd545317a330999031583199 [file] [log] [blame]
Wentao Shang53df1632014-04-21 12:01:32 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Alexander Afanasyev7c10b3b2015-01-20 12:24:27 -08003 * 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.
Wentao Shang53df1632014-04-21 12:01:32 -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 */
Wentao Shang53df1632014-04-21 12:01:32 -070025
26#ifndef NFD_DAEMON_FACE_WEBSOCKET_FACTORY_HPP
27#define NFD_DAEMON_FACE_WEBSOCKET_FACTORY_HPP
28
29#include "protocol-factory.hpp"
30#include "websocket-channel.hpp"
31
Wentao Shang53df1632014-04-21 12:01:32 -070032namespace nfd {
33
34class WebSocketFactory : public ProtocolFactory
35{
36public:
37 /**
38 * \brief Exception of WebSocketFactory
39 */
40 class Error : public ProtocolFactory::Error
41 {
42 public:
43 explicit
44 Error(const std::string& what)
45 : ProtocolFactory::Error(what)
46 {
47 }
48 };
49
50 explicit
51 WebSocketFactory(const std::string& defaultPort);
52
53 /**
54 * \brief Create WebSocket-based channel using websocket::Endpoint
55 *
56 * websocket::Endpoint is really an alias for boost::asio::ip::tcp::endpoint.
57 *
58 * If this method called twice with the same endpoint, only one channel
59 * will be created. The second call will just retrieve the existing
60 * channel.
61 *
62 * \returns always a valid pointer to a WebSocketChannel object, an exception
63 * is thrown if it cannot be created.
64 *
Davide Pesavento2231ab52015-03-16 00:15:13 +010065 * \throws WebSocketFactory::Error
Wentao Shang53df1632014-04-21 12:01:32 -070066 */
67 shared_ptr<WebSocketChannel>
68 createChannel(const websocket::Endpoint& localEndpoint);
69
70 /**
Alexander Afanasyev0e156df2015-01-26 22:33:43 -080071 * \brief Create WebSocket-based channel using specified IP address and port number
72 *
73 * This method is just a helper that converts a string representation of localIp and port to
74 * websocket::Endpoint and calls the other createChannel overload.
Wentao Shang53df1632014-04-21 12:01:32 -070075 *
76 * \throws WebSocketFactory::Error
77 */
78 shared_ptr<WebSocketChannel>
Alexander Afanasyev0e156df2015-01-26 22:33:43 -080079 createChannel(const std::string& localIp, const std::string& port);
Wentao Shang53df1632014-04-21 12:01:32 -070080
Davide Pesavento2231ab52015-03-16 00:15:13 +010081 // from ProtocolFactory
Wentao Shang53df1632014-04-21 12:01:32 -070082 virtual void
83 createFace(const FaceUri& uri,
Yukai Tu7c90e6d2015-07-11 12:21:46 +080084 ndn::nfd::FacePersistency persistency,
Wentao Shang53df1632014-04-21 12:01:32 -070085 const FaceCreatedCallback& onCreated,
Yukai Tu7c90e6d2015-07-11 12:21:46 +080086 const FaceConnectFailedCallback& onConnectFailed) DECL_OVERRIDE;
Wentao Shang53df1632014-04-21 12:01:32 -070087
Steve DiBenedettoef04f272014-06-04 14:28:31 -060088 virtual std::list<shared_ptr<const Channel> >
89 getChannels() const;
90
Wentao Shang53df1632014-04-21 12:01:32 -070091private:
Wentao Shang53df1632014-04-21 12:01:32 -070092 /**
93 * \brief Look up WebSocketChannel using specified local endpoint
94 *
95 * \returns shared pointer to the existing WebSocketChannel object
96 * or empty shared pointer when such channel does not exist
97 *
98 * \throws never
99 */
100 shared_ptr<WebSocketChannel>
101 findChannel(const websocket::Endpoint& localEndpoint);
102
103 typedef std::map< websocket::Endpoint, shared_ptr<WebSocketChannel> > ChannelMap;
104 ChannelMap m_channels;
105
106 std::string m_defaultPort;
107};
108
109} // namespace nfd
110
111#endif // NFD_DAEMON_FACE_WEBSOCKET_FACTORY_HPP