Release Notes
Version 24.07
The build dependencies have been increased as follows:
- GCC >= 9.3 or Clang >= 7.0 are strongly recommended on Linux; GCC 8.x is also known to work but is not officially supported
- Xcode 13 or later is recommended on macOS; older versions may still work but are not officially supported
- Boost >= 1.71.0 is required on all platforms
docker:
- Added an official Dockerfile to the repository
- A prebuilt image for linux/amd64 and linux/arm64 platforms is available on the GitHub container registry
build system:
- Fix detection of libpcap 1.10.2 and later on Linux
- Fix building the man pages with Python 3.12 (#5298)
- Reduce amount of debugging information produced in compiled binaries by default (#5279)
- Upgrade
waf
to version 2.0.27
Version 22.12
The minimum build requirements have been increased as follows:
- Either GCC >= 7.4.0 or Clang >= 6.0 is required on Linux
- On macOS, Xcode 11.3 or later is recommended; older versions may still work but are not officially supported
- Boost >= 1.65.1 is required on all platforms
- Sphinx 4.0 or later is required to build the manual pages
chunks:
- Avoid excess window decrease in certain conditions (#5202)
- Use ndn-cxx's
Segmenter
class (#4702)
dissect:
- Recognize several TLV elements that appear in
Certificate
and SafeBag
- Remove support for obsolete TLV types
dissect-wireshark:
- Expose
type
, len
, and bin
fields
build system:
- Switch to C++17
- macOS 12 (Monterey) and 13 (Ventura) running on arm64 are now supported out-of-the-box (#5135)
- CentOS Stream 9 is now supported; CentOS 8 has been dropped (#5181)
- Stop using the
gold
linker on Linux; prefer instead linking with lld
if installed - Upgrade
waf
to version 2.0.24
Version 22.02
Starting with this release, ndn-tools switched to a date-based versioning scheme: YEAR.MONTH[.PATCH]
(YY.0M[.MICRO]
in CalVer notation).
chunks:
- Add
--naming-convention
command-line option (Issue #5109) - Increase the default segment size to 8000 bytes
dissect:
- Support
InterestSignature
fields and more types of name components - The
Content
field is no longer dissected by default; use the new --content
option to enable it - Minor cosmetic improvements to the tool output
dissect-wireshark:
- Remove support for obsolete TLV elements
- Recognize
ForwardingHint
(Issue #4185) - Recognize
ParametersSha256DigestComponent
- Fix decoding of several TLV elements such as
HopLimit
and PitToken
- Update the TLV type of
IncomingFaceId
(Issue #5185)
peek:
- Replace
--link-file
option with --fwhint
and adapt to the new ForwardingHint
format (Issues #4207, #5187)
poke:
- Remove deprecated
--force
option; use --unsolicited
instead - Remove deprecated
--identity
and --digest
options; use --signing-info
instead - Change the short form of
--freshness
to -f
pingserver:
- Remove deprecated
-x
alias for the --freshness
option
build system:
- Upgrade
waf
to version 2.0.23
Version 0.7.1
The build requirements have been increased to require Clang >= 4.0, Xcode >= 9.0, and Python >= 3.6. Meanwhile, it is recommended to use GCC >= 7.4.0 and Boost >= 1.65.1.
This release contains minor build fixes and code cleanups.
Version 0.7
chunks:
- Add
--no-version-discovery
option to ndncatchunks (Issue #5021) - Improve CUBIC performance on lossy networks (Issue #5036)
- Switch to ndn-cxx's
RttEstimatorWithStats
class (Issue #4887) - Remove previously deprecated options
-d
and -t
from ndncatchunks
ping:
- Change the short form of ndnpingserver's
--freshness
option to -f
, for consistency with ndnputchunks
peek:
- Add
--app-params
, --app-params-file
, and --hop-limit
options - The
--link-file
option now expects a raw binary file - Print Data name and Nack reason if
--verbose
is specified - Code cleanup
- Manual page improvements
poke:
- Add
--signing-info
option, replacing --digest
and --identity
which are now deprecated - Add
--verbose
option - Wait indefinitely if
--timeout
is not specified - The program now exits with status 3 when a timeout occurs and with status 5 if prefix registration fails
- Rename
--force
option to --unsolicited
- Code cleanup
- Major rewrite of the manual page
Version 0.6.4
chunks:
- Add metadata-based version discovery and remove iterative discovery (Issue #4556)
- Remove manual selection of version discovery method via
-d
option (Issue #4832) - Implement CUBIC congestion window adaptation in ndncatchunks (Issue #4861)
- Increase the default retransmission limit from 3 to 15 (Issue #4861)
- Improve stats printed by ndncatchunks after transfer completes (Issue #4603)
- Add manual page for ndnputchunks
dissect & dissect-wireshark:
- Follow packet specification changes to renumber the
Parameters
element and rename it to ApplicationParameters
(Issues #4658, #4780)
dump:
- Fix compilation on CentOS 7 (Issue #4852)
pib:
- Completely remove this obsolete and unmaintained tool (Issue #4205)
Version 0.6.3
chunks:
- Fix impossible RTT values (Issue #4604)
- Add support for RDR metadata in ndnputchunks (Issue #4556)
- Use
PendingInterestHandle
and RegisteredPrefixHandle
(Issues #4316, #3919)
ping:
- Add systemd unit file for ndnpingserver (Issue #4594)
- Use
PendingInterestHandle
and RegisteredPrefixHandle
(Issues #4316, #3919)
poke:
- Use
PendingInterestHandle
and RegisteredPrefixHandle
(Issues #4316, #3919)
build system:
- Upgrade
waf
to version 2.0.14 and other improvements
Version 0.6.2
The build requirements have been upgraded to gcc >= 5.3 or clang >= 3.6, boost >= 1.58, openssl >= 1.0.2. This effectively drops support for all versions of Ubuntu older than 16.04 that use distribution-provided compilers and packages.
The compilation now uses the C++14 standard.
chunks:
- Fix AIMD hanging with files smaller than the chunk size (Issue #4439)
dissect-wireshark:
- Show
Name
and FinalBlockId
as URIs (Issue #3106) - Improve NDNLPv2 support (Issue #4463)
- Add support for dissecting PPP frames
dump:
- Remove dependency on Boost.Regex
- Stop using tcpdump headers files
- Compile pcap filter with optimizations enabled
- Capture in promiscuous mode by default, add an option to disable it
- Add
-t
option to suppress printing per-packet timestamp - Properly handle exceptions thrown by
lp::Packet::wireDecode()
(Issue #3943) - Add UDP port 56363 to the default pcap filter
- Stricter parsing of IP/TCP/UDP headers
- Add IPv6 support
- Code cleanup
poke:
- Use
Face::unsetInterestFilter
instead of shutdown
(Issue #4642) - Improve unit testing (Issue #3740)
ping:
- Add
--quiet
option to ndnpingserver (Issue #4673) - Set
CanBePrefix=false
in Interests sent by ndnping (Issue #4581) - Code cleanup
Version 0.6.1
chunks:
- Show correct packet loss stats in final summary (Issue #4437)
- Avoid printing meaningless values when no RTT measurements are available (Issue #4551)
dissect:
- Recognize
CanBePrefix
, HopLimit
, and Parameters
TLV elements (Issue #4590)
dissect-wireshark:
- Recognize
CanBePrefix
, HopLimit
, and Parameters
TLV elements (Issue #4517)
peek:
- Drop
Selectors
support (Issue #4571) - Add
-P/--prefix
option to set CanBePrefix
in the Interest packet
build system:
- Upgrade
waf
to version 2.0.6 and other improvements
Version 0.6
chunks:
- Change the default Interest pipeline to AIMD (Issue #4402)
- Include RTT stats in final summary (Issue #4406)
- Respect
--retries=-1
in the AIMD pipeline (Issue #4409) - React to congestion marks by default as a timeout event (can be disabled using
--aimd-ignore-cong-marks
) (Issue #4289) - Print a final summary of the transfer regardless of the pipeline type, and even if
--verbose
was not specified (Issue #4421)
Version 0.5
all:
- Switch to version 2 of certificates,
KeyChain
, and Validator
(Issue #4089) - Compilation fixes (Issue #4259)
chunks:
- Make
ndnputchunks
display some output by default; a new -q
flag makes the tool completely silent, except for errors (Issue #4286) - Refactor
ndnputchunks
options handling - Reduce initial timeout of iterative version discovery in
ndncatchunks
(Issue #4291) - Fix potential
ndncatchunks
crash on exit
peek:
- Convert use of
Link
into ForwardingHint
(Issue #4055)
Version 0.4
As of this version, NDN Essential Tools require a modern compiler (gcc >= 4.8.2, clang >= 3.4) and a relatively new version of the Boost libraries (>= 1.54). This means that the code no longer compiles with the packaged version of gcc and Boost libraries on Ubuntu 12.04. NDN Essential Tools can still be compiled on such systems, but require a separate installation of a newer version of the compiler (e.g., clang-3.4) and dependencies.
chunks:
- Change default version discovery to iterative
- Improve help text of
ndnputchunks
- Fix
DiscoverVersionIterative
build error - Modularize Interest pipeline implementation
- Add AIMD congestion control (Issue #3636)
- Code cleanup and improvements
dissect-wireshark:
- Add initial support for NDNLPv2 (Issue #3197)
- Fix potential memory overflow
dump:
- Add support for Linux cooked-mode capture (SLL) (Issue #3061)
- Improve error messages
pib:
- Disable by default (can be compiled with ndn-cxx version 0.5.0)
- Fix compilation error with new version of ndn-cxx library
- Avoid use of deprecated block helpers
- Correct build target path
ping:
- Recognize and trace NACK
- Fix potential divide-by-zero bug in
StatisticsCollector
(Issue #3504)
peek:
- Recognize and properly handle NACK
- Refactor implementation
Version 0.3
chunks: New (pair of) tool(s) for segmented file transfer
peek:
- Allow verbose output
- Switch from
getopt
to boost::program_options
- Add
--link-file
option
ping:
- Document ndnping protocol
dump:
- Capture and print network NACK packets
- Update docs to include NACK capture feature
build system:
- Enable
-Wextra
by default - Fix missing tool name in
configure --help
output - Fix compatibility with Python 3
Version 0.2
Code improvements and two new tools:
- PIB service to manage the public information of keys and publish certificates (Issue 3018)
- A Wireshark dissector for NDN packets (Issue 3092)
Version 0.1
Initial release of NDN Essential Tools, featuring:
- ndnpeek, ndnpoke: a pair of programs to request and make available for retrieval a single Data packet.
- ndnping, ndnpingserver: reachability testing tools for Named Data Networking.
- ndndump: a traffic analysis tool that captures NDN packets on the wire.
- ndn-dissect: an NDN packet format inspector. It reads zero or more NDN packets from either an input file or the standard input, and displays the Type-Length-Value (TLV) structure of those packets on the standard output.