lp-reassembler.hpp
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2014-2024, 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.
10  *
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 #ifndef NFD_DAEMON_FACE_LP_REASSEMBLER_HPP
27 #define NFD_DAEMON_FACE_LP_REASSEMBLER_HPP
28 
29 #include "face-common.hpp"
30 
31 #include <ndn-cxx/lp/packet.hpp>
32 #include <ndn-cxx/lp/sequence.hpp>
33 #include <ndn-cxx/util/scheduler.hpp>
34 
35 #include <map>
36 
37 namespace nfd::face {
38 
43 class LpReassembler : noncopyable
44 {
45 public:
49  struct Options
50  {
56  size_t nMaxFragments = 400;
57 
61  time::nanoseconds reassemblyTimeout = 500_ms;
62  };
63 
64  explicit
65  LpReassembler(const Options& options, const LinkService* linkService = nullptr);
66 
70  void
71  setOptions(const Options& options)
72  {
73  m_options = options;
74  }
75 
81  const LinkService*
82  getLinkService() const noexcept
83  {
84  return m_linkService;
85  }
86 
97  std::tuple<bool, Block, lp::Packet>
98  receiveFragment(const EndpointId& remoteEndpoint, const lp::Packet& packet);
99 
103  size_t
104  size() const noexcept
105  {
106  return m_partialPackets.size();
107  }
108 
117  signal::Signal<LpReassembler, EndpointId, size_t> beforeTimeout;
118 
119 private:
123  struct PartialPacket
124  {
125  std::vector<lp::Packet> fragments;
126  size_t fragCount;
127  size_t nReceivedFragments;
128  ndn::scheduler::ScopedEventId dropTimer;
129  };
130 
134  using Key = std::tuple<
135  EndpointId, // remote endpoint
136  lp::Sequence // message identifier (sequence number of the first fragment)
137  >;
138 
139  Block
140  doReassembly(const Key& key);
141 
142  void
143  timeoutPartialPacket(const Key& key);
144 
145 private:
146  Options m_options;
147  const LinkService* m_linkService;
148  std::map<Key, PartialPacket> m_partialPackets;
149 };
150 
151 std::ostream&
152 operator<<(std::ostream& os, const FaceLogHelper<LpReassembler>& flh);
153 
154 } // namespace nfd::face
155 
156 #endif // NFD_DAEMON_FACE_LP_REASSEMBLER_HPP
Reassembles fragmented network-layer packets.
size_t size() const noexcept
Count of partial packets.
std::tuple< bool, Block, lp::Packet > receiveFragment(const EndpointId &remoteEndpoint, const lp::Packet &packet)
Adds received fragment to the buffer.
signal::Signal< LpReassembler, EndpointId, size_t > beforeTimeout
Notifies before a partial packet is dropped due to timeout.
LpReassembler(const Options &options, const LinkService *linkService=nullptr)
const LinkService * getLinkService() const noexcept
Returns the LinkService that owns this instance.
void setOptions(const Options &options)
Set options for reassembler.
std::ostream & operator<<(std::ostream &os, const FaceLogHelper< Face > &flh)
Definition: face.cpp:63
std::variant< std::monostate, ethernet::Address, udp::Endpoint > EndpointId
Identifies a remote endpoint on the link.
Definition: face-common.hpp:78
Options that control the behavior of LpReassembler.
time::nanoseconds reassemblyTimeout
Timeout before a partially reassembled packet is dropped.
size_t nMaxFragments
Maximum number of fragments in a packet.