blob: 75ff009c9c9757adbbb26839b1a7c9e917ec064c [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
32
33namespace nfd {
34
35class WebSocketFactory : public ProtocolFactory
36{
37public:
38 /**
39 * \brief Exception of WebSocketFactory
40 */
41 class Error : public ProtocolFactory::Error
42 {
43 public:
44 explicit
45 Error(const std::string& what)
46 : ProtocolFactory::Error(what)
47 {
48 }
49 };
50
51 explicit
52 WebSocketFactory(const std::string& defaultPort);
53
54 /**
55 * \brief Create WebSocket-based channel using websocket::Endpoint
56 *
57 * websocket::Endpoint is really an alias for boost::asio::ip::tcp::endpoint.
58 *
59 * If this method called twice with the same endpoint, only one channel
60 * will be created. The second call will just retrieve the existing
61 * channel.
62 *
63 * \returns always a valid pointer to a WebSocketChannel object, an exception
64 * is thrown if it cannot be created.
65 *
Steve DiBenedettoef04f272014-06-04 14:28:31 -060066 * \throws WebSocketFactory::Error, TcpResolver::Error
Wentao Shang53df1632014-04-21 12:01:32 -070067 *
68 */
69 shared_ptr<WebSocketChannel>
70 createChannel(const websocket::Endpoint& localEndpoint);
71
72 /**
Alexander Afanasyev0e156df2015-01-26 22:33:43 -080073 * \brief Create WebSocket-based channel using specified IP address and port number
74 *
75 * This method is just a helper that converts a string representation of localIp and port to
76 * websocket::Endpoint and calls the other createChannel overload.
Wentao Shang53df1632014-04-21 12:01:32 -070077 *
78 * \throws WebSocketFactory::Error
79 */
80 shared_ptr<WebSocketChannel>
Alexander Afanasyev0e156df2015-01-26 22:33:43 -080081 createChannel(const std::string& localIp, const std::string& port);
Wentao Shang53df1632014-04-21 12:01:32 -070082
83 // from Factory
84 virtual void
85 createFace(const FaceUri& uri,
86 const FaceCreatedCallback& onCreated,
87 const FaceConnectFailedCallback& onConnectFailed);
88
Steve DiBenedettoef04f272014-06-04 14:28:31 -060089 virtual std::list<shared_ptr<const Channel> >
90 getChannels() const;
91
Wentao Shang53df1632014-04-21 12:01:32 -070092private:
93
94 /**
95 * \brief Look up WebSocketChannel using specified local endpoint
96 *
97 * \returns shared pointer to the existing WebSocketChannel object
98 * or empty shared pointer when such channel does not exist
99 *
100 * \throws never
101 */
102 shared_ptr<WebSocketChannel>
103 findChannel(const websocket::Endpoint& localEndpoint);
104
105 typedef std::map< websocket::Endpoint, shared_ptr<WebSocketChannel> > ChannelMap;
106 ChannelMap m_channels;
107
108 std::string m_defaultPort;
109};
110
111} // namespace nfd
112
113#endif // NFD_DAEMON_FACE_WEBSOCKET_FACTORY_HPP