Loading...
Searching...
No Matches
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
37namespace nfd::face {
38
43class LpReassembler : noncopyable
44{
45public:
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
119private:
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
145private:
146 Options m_options;
147 const LinkService* m_linkService;
148 std::map<Key, PartialPacket> m_partialPackets;
149};
150
151std::ostream&
152operator<<(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.
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.
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.