µD3TN (pronounced "Micro-Dee-Tee-En") is a free, lean, and space-tested DTN protocol implementation running on POSIX (plus Linux ;-)). Though µD3TN is easily portable to further platforms, we currently support only POSIX-compliant systems (former versions also included support for STM32/FreeRTOS platforms).
A general introduction of µD3TN is available on its project web site at https://d3tn.com/ud3tn.html and in our video series on YouTube.
µD3TN currently implements:
- Bundle Protocol version 6 (RFC 5050),
- Bundle Protocol version 7 (RFC 9171),
- Several Bundle Protocol convergence layers, such as:
- MTCP (draft version 0),
- TCPCLv3 (RFC 7242),
- CCSDS Space Packet Protocol (SPP),
- BIBE (draft version 3, see doc/Bundle-in-Bundle Encapsulation_(BIBE).md),
- A persistent storage backend based on SQLite (see doc/sqlite-storage.md).
We provide docker images at registry.gitlab.com/d3tn/ud3tn-docker-images/ud3tn
. Refer to https://gitlab.com/d3tn/ud3tn-docker-images/ for more information.
A comprehensive step-by-step tutorial for Linux and POSIX systems is included in the documentation. It covers a complete scenario in which two µD3TN instances create a small two-node DTN and external applications leverage the latter to exchange data.
For simple setups with just a single node, µD3TN is ready to use with its default settings. For advanced use, the CLI offers at lot of flexibility:
Mandatory arguments to long options are mandatory for short options, too.
-a, --aap-host HOST IP / hostname of the application agent service
-b, --bp-version 6|7 bundle protocol version of bundles created via AAP
-c, --cla CLA_OPTIONS configure the CLA subsystem according to the
syntax documented in the man page
-e, --eid EID local endpoint identifier
-h, --help print this text and exit
-l, --lifetime SECONDS lifetime of bundles created via AAP
-m, --max-bundle-size BYTES bundle fragmentation threshold
-p, --aap-port PORT port number of the application agent service
-r, --status-reports enable status reporting
-R, --allow-remote-config allow configuration via bundles received from CLAs
-s, --aap-socket PATH path to the UNIX domain socket of the application agent service
-S, --aap2-socket PATH path to the UNIX domain socket of the experimental AAP 2.0 service
-u, --usage print usage summary and exit
-x, --bdm-secret-var VAR restrict AAP 2.0 BDM functions to clients providing the secret in the
given environment variable
Default POSIX invocation: ud3tn \
-b 7 \
-c "tcpclv3:*,4556;tcpspp:*,4223,false,1;smtcp:*,4222,false;mtcp:*,4224" \
-e dtn://ud3tn.dtn/ \
-l 86400 \
-m 0 \
-s $PWD/ud3tn.socket \
-S $PWD/ud3tn.aap2.socket
The AAP interface can use either a UNIX domain socket (-s
option) or bind to a TCP address (-a
and -p
options).
Examples for CLA_OPTIONS
are documented in the man page,
which can be viewed with man --local-file doc/ud3tn.1
.
Default arguments and internal settings such as storage, routing, and connection parameters can be adjusted by providing a customised config.mk
file.
µD3TN performs its bundle forwarding decisions based on contacts, which are associated with a specific bundle node. Each instance accepts bundles addressed to dtn://<ud3tn-node-name>/config
or ipn:<ud3tn-node-number>.9000
(by default, only via AAP) and parses them according to the specification documented at doc/contacts_data_format.md
. To sum it up, a contact can be used to configure:
- start and end time (optional),
- data rate (optional),
- reliability of the contact (optional), and
- whether the bundle node can reach other nodes during this specific contact (list of EID, optional).
Nodes themselves can be configured (added / removed) via the same syntax and interface.
This repository includes convenient python tools that can be used after preparing the python environment to configure contacts.
Once a µD3TN enabled DTN network has been created, applications can leverage the Application Agent Protocol (AAP) to interact with it. Applications typically use AAP to:
- register themselves at a µD3TN instance with a local identifier,
- inject bundles (hand over a payload and a destination EID to µD3TN, µD3TN then creates a corresponding bundle and tries to forward / deliver it), and
- listen for application data addressed to their identifier.
µD3TN implements two versions of AAP:
- AAP (v1): a simple binary protocol defined in
doc/ud3tn_aap.md
, which supports only the basic operations listed above. There are dedicated python scripts using AAP for various tasks provided. Python bindings for AAP are also available in theud3tn-utils
Python package. - AAP 2.0: the next generation application protocol based on Protobuf, with more control over bundle metadata plus experimental support for controlling bundle forwarding decisions and links to other nodes. Please refer to the AAP 2.0 Overview and the AAP 2.0 Protobuf Definition for more details.
This project uses git submodules to manage some code dependencies.
Use the --recursive
option if you git clone
the project or run
git submodule init && git submodule update
at a later point in time.
-
Install or unpack the build toolchain
- Install GNU
make
,gcc
andbinutils
. - Install the
sqlite
development package (includingsqlite3.h
andlibsqlite3.so
). - For building with Clang, additionally install a recent version of
clang
andllvm
.
- Install GNU
-
Configure the local build toolchain in
config.mk
(optional for most systems)- Copy
config.mk.example
toconfig.mk
. - Adjust
TOOLCHAIN
if you want to build with Clang. - Adjust
TOOLCHAIN_POSIX
if your toolchain installation is not included in your$PATH
- Copy
-
Run
make run-posix
to build and execute µD3TN on your local machine.- You can find the µD3TN binary file in
build/posix/ud3tn
. To just build it, you can also runmake posix
ormake
(the latter building the library files as well). - Note that on some systems, such as BSD flavors, you may need to explicitly call GNU Make using the
gmake
command. In this case, just substitute all calls tomake
in the documentation bygmake
. - Some build-time options (e.g., building with sanitizers) can be easily specified as arguments to
make
. Seeconfig.mk.example
for the values you can specify. Example:make sanitize=yes
- You can find the µD3TN binary file in
- Install the nix package manager
- Enable flake support
- Temporary: Add
--experimental-features 'nix-command flakes'
when using any nix commands - Permanent: Add
experimental-features = nix-command flakes
to~/.config/nix/nix.conf
or/etc/nix/nix.conf
- Temporary: Add
Most common nix commands are:
-
Build & run ud3tn:
nix run '.?submodules=1'
-
Build individual packages:
nix build '.?submodules=1#ud3tn' nix build '.?submodules=1#pyd3tn' nix build '.?submodules=1#python-ud3tn-utils'
-
Load a development environment with all packages and dependencies:
nix develop '.?submodules=1'
After the development environment has been activated, all development dependencies are fulfilled in order to be able to execute all other described debug and build commands.
Beside the µD3TN daemon binary, two types of library can be built using make posix-lib
or make
:
build/posix/libud3tn.so
: a dynamic library (shared object) containing all but the daemon functions.build/posix/libud3tn.a
: a thin static library providing the same functionality. This only references thecomponent.a
files in thebuild
directory and is intended to statically link µD3TN into other projects. The preferred way to do this is to include µD3TN as part of your project's source tree (e.g. usinggit subtree
orgit submodule
).
The µD3TN development is accompanied by extensive testing. For this purpose, you should install gdb
and a recent version of Python 3 (>= 3.8), plus the, venv
and pip
packages for your Python version. Our test suite covering static analysis, unit, and integration tests is documented in doc/testing.md
.
Contributions in any form (e.g., bug reports, feature, or merge requests) are very welcome! Please have a look at CONTRIBUTING.md first for a smooth experience. The project structure is organized as follows:
.
├── components C source code
├── doc documentation
├── dockerfiles Templates for creating Docker images
├── external 3rd party source code
├── generated generated source code (e.g. for Protobuf)
├── include C header files
├── mk make scripts
├── nix nix derivations, modules and tests
├── pyd3tn Python implementation of several DTN protocols
├── python-ud3tn-utils Python bindings for AAP
├── test various test routines
└── tools various utility scripts
The entry point is implemented in components/daemon/main.c
.
This work is licensed as a whole under the GNU Affero General Public License v3.0, with some parts and components being licensed under the BSD 3-Clause, Apache 2.0, MIT, zLib, and GPL v2.0 licenses. This licensing scheme is applied since early 2024, after the release of version v0.13.0 under the Apache 2 and BSD 3-Clause licenses.
All code files, except those under the external/
directory tree, contain an SPDX license identifier at the top, to indicate the license that applies to the specific file.
The external libraries shipped with µD3TN and contained in external/
are subject to their own licenses, documented in LICENSE-3RD-PARTY.txt
.
SPDX-License-Identifier: AGPL-3.0-or-later
ud3tn-utils
is a Python package that provides bindings for µD3TN's Application Agent Protocol and Application Agent Protocol v2.aap.lua
is a Wireshark dissector for µD3TN's Application Agent Protocol. It can be installed by copying it into one of the Lua script folders listed in the Wireshark GUI atHelp > About Wireshark > Folders
.pyD3TN
is a Python package that provides implementations of several DTN related RFCs.aiodtnsim
is a minimal framework for performing DTN simulations based on Python 3.7 and asyncio.dtn-tvg-util
is a Python package simplifying the analysis and simulation of DTNs based on time-varying network graphs.
- RFC 4838 for a general introduction about DTN networks.
- ION: NASA's (JPL) bundle protocol implementation that has been successfully demonstrated to be interoperable with µD3TN.
- HDTN: NASA's performance optimized implementation of the DTN standard.
- DTN7-rs: Rust implementation of a disruption-tolerant networking (DTN) daemon for the Bundle Protocol version 7 - RFC9171.