blob: 79faf733816460d164c6f8686fb5b37a39f407f6 [file] [log] [blame]
Wentao Shang53df1632014-04-21 12:01:32 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Junxiao Shi08d07a72014-06-09 23:17:57 -07003 * Copyright (c) 2014, 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/>.
24 **/
25
26#include "websocket-face.hpp"
27
28namespace nfd {
29
30NFD_LOG_INIT("WebSocketFace");
31
32WebSocketFace::WebSocketFace(const FaceUri& remoteUri, const FaceUri& localUri,
33 websocketpp::connection_hdl hdl,
34 websocket::Server& server)
35 : Face(remoteUri, localUri)
36 , m_handle(hdl)
37 , m_server(server)
38 , m_closed(false)
39{
40}
41
42
43void
44WebSocketFace::sendInterest(const Interest& interest)
45{
Wentao Shang3d36c2b2014-07-04 10:09:58 -040046 if (m_closed)
47 return;
48
Wentao Shang53df1632014-04-21 12:01:32 -070049 this->onSendInterest(interest);
50 const Block& payload = interest.wireEncode();
Wentao Shange612e2f2014-08-04 10:24:59 -040051 this->getMutableCounters().getNOutBytes() += payload.size();
Wentao Shang3d36c2b2014-07-04 10:09:58 -040052
53 try {
54 m_server.send(m_handle, payload.wire(), payload.size(),
55 websocketpp::frame::opcode::binary);
56 }
57 catch (const websocketpp::lib::error_code& e) {
58 NFD_LOG_DEBUG("Failed to send Interest because: " << e
59 << "(" << e.message() << ")");
60 }
Wentao Shang53df1632014-04-21 12:01:32 -070061}
62
63void
64WebSocketFace::sendData(const Data& data)
65{
Wentao Shang3d36c2b2014-07-04 10:09:58 -040066 if (m_closed)
67 return;
68
Wentao Shang53df1632014-04-21 12:01:32 -070069 this->onSendData(data);
70 const Block& payload = data.wireEncode();
Wentao Shange612e2f2014-08-04 10:24:59 -040071 this->getMutableCounters().getNOutBytes() += payload.size();
Wentao Shang3d36c2b2014-07-04 10:09:58 -040072
73 try {
74 m_server.send(m_handle, payload.wire(), payload.size(),
75 websocketpp::frame::opcode::binary);
76 }
77 catch (const websocketpp::lib::error_code& e) {
78 NFD_LOG_DEBUG("Failed to send Data because: " << e
79 << "(" << e.message() << ")");
80 }
Wentao Shang53df1632014-04-21 12:01:32 -070081}
82
83void
84WebSocketFace::close()
85{
86 if (m_closed == false)
87 {
88 m_closed = true;
89 websocketpp::lib::error_code ecode;
90 m_server.close(m_handle, websocketpp::close::status::normal, "closed by nfd", ecode);
Alexander Afanasyev251f3c12014-06-02 18:39:58 +030091
Junxiao Shi08d07a72014-06-09 23:17:57 -070092 fail("Face closed");
Wentao Shang53df1632014-04-21 12:01:32 -070093 }
94}
95
96void
97WebSocketFace::handleReceive(const std::string& msg)
98{
99 // Copy message into Face internal buffer
100 BOOST_ASSERT(msg.size() <= MAX_NDN_PACKET_SIZE);
101
Wentao Shange612e2f2014-08-04 10:24:59 -0400102 this->getMutableCounters().getNInBytes() += msg.size();
103
Wentao Shang53df1632014-04-21 12:01:32 -0700104 // Try to parse message data
105 bool isOk = true;
106 Block element;
107 isOk = Block::fromBuffer(reinterpret_cast<const uint8_t*>(msg.c_str()), msg.size(), element);
108 if (!isOk)
109 {
110 NFD_LOG_TRACE("[id:" << this->getId()
111 << "] Received invalid NDN packet of length ["
112 << msg.size() << "]");
113 return;
114 }
115
116 if (!this->decodeAndDispatchInput(element))
117 {
118 NFD_LOG_WARN("[id:" << this->getId()
119 << "] Received unrecognized block of type ["
120 << element.type() << "]");
121 // ignore unknown packet and proceed
122 }
123}
124
125} // namespace nfd