Giulio Grassi | 624f6c6 | 2014-02-18 19:42:14 +0100 | [diff] [blame] | 1 | /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */ |
| 2 | /** |
| 3 | * Copyright (C) 2014 Named Data Networking Project |
| 4 | * See COPYING for copyright and distribution information. |
| 5 | */ |
| 6 | |
| 7 | #include "udp-face.hpp" |
| 8 | |
| 9 | namespace nfd { |
| 10 | |
| 11 | NFD_LOG_INCLASS_TEMPLATE_SPECIALIZATION_DEFINE(DatagramFace, UdpFace::protocol, "UdpFace"); |
| 12 | |
| 13 | UdpFace::UdpFace(const shared_ptr<UdpFace::protocol::socket>& socket) |
Alexander Afanasyev | a39b90b | 2014-03-05 15:31:00 +0000 | [diff] [blame] | 14 | : DatagramFace<protocol>(FaceUri(socket->remote_endpoint()), socket) |
Giulio Grassi | 624f6c6 | 2014-02-18 19:42:14 +0100 | [diff] [blame] | 15 | { |
| 16 | } |
| 17 | |
| 18 | void |
| 19 | UdpFace::handleFirstReceive(const uint8_t* buffer, |
| 20 | std::size_t nBytesReceived, |
| 21 | const boost::system::error_code& error) |
| 22 | { |
Alexander Afanasyev | 7e698e6 | 2014-03-07 16:48:35 +0000 | [diff] [blame] | 23 | NFD_LOG_DEBUG("handleFirstReceive"); |
Giulio Grassi | 624f6c6 | 2014-02-18 19:42:14 +0100 | [diff] [blame] | 24 | //checking if the received message size is too big. |
| 25 | //This check is redundant, since in the actual implementation a packet |
| 26 | //cannot be bigger than MAX_NDN_PACKET_SIZE |
| 27 | if (!error && (nBytesReceived > MAX_NDN_PACKET_SIZE)) |
| 28 | { |
| 29 | NFD_LOG_WARN("[id:" << this->getId() |
| 30 | << ",endpoint:" << m_socket->local_endpoint() |
| 31 | << "] Received message too big. Maximum size is " |
| 32 | << MAX_NDN_PACKET_SIZE ); |
| 33 | return; |
| 34 | } |
| 35 | receiveDatagram(buffer, nBytesReceived, error); |
| 36 | } |
| 37 | |
| 38 | |
| 39 | } // namespace nfd |