SkillAgentSearch skills...

Reticulum

The cryptography-based networking stack for building unstoppable networks with LoRa, Packet Radio, WiFi and everything in between.

Install / Use

/learn @markqvist/Reticulum
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

Reticulum Network Stack <img align="right" src="https://static.pepy.tech/personalized-badge/rns?period=month&units=international_system&left_color=grey&right_color=blue&left_text=Installs/month" style="padding-left:10px"/><a href="https://github.com/markqvist/Reticulum/actions/workflows/build.yml"><img align="right" src="https://github.com/markqvist/Reticulum/actions/workflows/build.yml/badge.svg"/></a>

<p align="center"><img width="200" src="https://raw.githubusercontent.com/markqvist/Reticulum/master/docs/source/graphics/rns_logo_512.png"></p>

This repository is a public mirror. All development is happening elsewhere.

To understand the foundational philosophy and goals of this system, read the Zen of Reticulum.

Reticulum is the cryptography-based networking stack for building local and wide-area networks with readily available hardware. It can operate even with very high latency and extremely low bandwidth. Reticulum allows you to build wide-area networks with off-the-shelf tools, and offers end-to-end encryption and connectivity, initiator anonymity, autoconfiguring cryptographically backed multi-hop transport, efficient addressing, unforgeable delivery acknowledgements and more.

The vision of Reticulum is to allow anyone to be their own network operator, and to make it cheap and easy to cover vast areas with a myriad of independent, inter-connectable and autonomous networks. Reticulum is not one network. It is a tool for building thousands of networks. Networks without kill-switches, surveillance, censorship and control. Networks that can freely interoperate, associate and disassociate with each other, and require no central oversight. Networks for human beings. Networks for the people.

Reticulum is a complete networking stack, and does not rely on IP or higher layers, but it is possible to use IP as the underlying carrier for Reticulum. It is therefore trivial to tunnel Reticulum over the Internet or private IP networks.

Having no dependencies on traditional networking stacks frees up overhead that has been used to implement a networking stack built directly on cryptographic principles, allowing resilience and stable functionality, even in open and trustless networks.

No kernel modules or drivers are required. Reticulum runs completely in userland, and can run on practically any system that runs Python 3.

Read The Manual

The full documentation for Reticulum is available at markqvist.github.io/Reticulum/manual/.

You can also download the Reticulum manual as a PDF or as an e-book in EPUB format.

For more info, see reticulum.network and the FAQ section of the wiki.

Notable Features

  • Coordination-less globally unique addressing and identification
  • Fully self-configuring multi-hop routing over heterogeneous carriers
  • Flexible scalability over heterogeneous topologies
    • Reticulum can carry data over any mixture of physical mediums and topologies
    • Low-bandwidth networks can co-exist and interoperate with large, high-bandwidth networks
  • Initiator anonymity, communicate without revealing your identity
    • Reticulum does not include source addresses on any packets
  • Asymmetric X25519 encryption and Ed25519 signatures as a basis for all communication
    • The foundational Reticulum Identity Keys are 512-bit Elliptic Curve keysets
  • Forward Secrecy is available for all communication types, both for single packets and over links
  • Reticulum uses the following format for encrypted tokens:
    • Ephemeral per-packet and link keys and derived from an ECDH key exchange on Curve25519
    • AES-256 in CBC mode with PKCS7 padding
    • HMAC using SHA256 for authentication
    • IVs are generated through os.urandom()
  • Unforgeable packet delivery confirmations
  • Flexible and extensible interface system
    • Reticulum includes a large variety of built-in interface types
    • Ability to load and utilise custom user- or community-supplied interface types
    • Easily create your own custom interfaces for communicating over anything
  • Authentication and virtual network segmentation on all supported interface types
  • An intuitive and easy-to-use API
    • Simpler and easier to use than sockets APIs, but more powerful
    • Makes building distributed and decentralised applications much simpler
  • Reliable and efficient transfer of arbitrary amounts of data
    • Reticulum can handle a few bytes of data or files of many gigabytes
    • Sequencing, compression, transfer coordination and checksumming are automatic
    • The API is very easy to use, and provides transfer progress
  • Lightweight, flexible and expandable Request/Response mechanism
  • Efficient link establishment
    • Total cost of setting up an encrypted and verified link is only 3 packets, totalling 297 bytes
    • Low cost of keeping links open at only 0.44 bits per second
  • Reliable sequential delivery with Channel and Buffer mechanisms

Reference Implementation

The Python code in this repository is the Reference Implementation of Reticulum. The Reticulum Protocol is defined entirely and authoritatively by this reference implementation, and its associated manual. It is maintained by Mark Qvist, identified by the Reticulum Identity <bc7291552be7a58f361522990465165c>.

Compatibility with the Reticulum Protocol is defined as having full interoperability, and sufficient functional parity with this reference implementation. Any specific protocol implementation that achieves this is Reticulum. Any that does not is not Reticulum.

The reference implementation is licensed under the Reticulum License.

The Reticulum Protocol was dedicated to the Public Domain in 2016.

Examples of Reticulum Applications

If you want to quickly get an idea of what Reticulum can do, take a look at the Programs Using Reticulum section of the manual, or the following resources:

  • You can use the rnsh program to establish remote shell sessions over Reticulum.
  • LXMF is a distributed, delay and disruption tolerant message transfer protocol built on Reticulum
  • The LXST protocol and framework provides real-time audio and signals transport over Reticulum. It includes primitives and utilities for building voice-based applications and hardware devices, such as the rnphone program, that can be used to build hardware telephones.
  • For an off-grid, encrypted and resilient mesh communications platform, see Nomad Network
  • The Android, Linux, macOS and Windows app Sideband has a graphical interface and many advanced features, such as file transfers, image and voice messages, real-time voice calls, a distributed telemetry system, mapping capabilities and full plugin extensibility.
  • MeshChat is a user-friendly LXMF client with a web-based interface, that also supports image and voice messages, as well as file transfers. It also includes a built-in page browser for browsing Nomad Network nodes.

Where can Reticulum be used?

Over practically any medium that can support at least a half-duplex channel with greater throughput than 5 bits per second, and an MTU of 500 bytes. Data radios, modems, LoRa radios, serial lines, AX.25 TNCs, amateur radio digital modes, WiFi and Ethernet devices, free-space optical links, and similar systems are all examples of the types of physical devices Reticulum can use.

An open-source LoRa-based interface called RNode has been designed specifically for use with Reticulum. It is possible to build yourself, or it can be purchased as a complete transceiver that just needs a USB connection to the host.

Reticulum can also be encapsulated over existing IP networks, so there's nothing stopping you from using it over wired Ethernet, your local WiFi network or the Internet, where it'll work just as well. In fact, one of the strengths of Reticulum is how easily it allows you to connect different mediums into a self-configuring, resilient and encrypted mesh, using any available mixture of available infrastructure.

As an example, it's possible to set up a Raspberry Pi connected to both a LoRa radio, a packet radio TNC and a WiFi network. Once the interfaces are configured, Reticulum will take care of the rest, and any device on the WiFi network can communicate with nodes on the LoRa and packet radio sides of the network, and vice versa.

How do I get started?

The best way to get started with the Reticulum Network Stack depends on what you want to do. For full details and examples, have a look at the Getting Started Fast section of the Reticulum Manual.

To simply install Reticulum and related utilities on your system, the easiest way is via pip. You can then start any program that uses Reticulum, or start Reticulum as a system service with the rnsd utility.

pip install rns

If you are using an operating system that blocks normal user package installation via pip, you can return pip to normal behaviour by editing the ~/.config/pip/pip.conf file, and adding the following directive in the [global] section:

[global]
break-system-packages = true

Alternatively, you can use the pipx tool to install Reticulum in an isol

View on GitHub
GitHub Stars5.3k
CategoryDevelopment
Updated1h ago
Forks362

Languages

Python

Security Score

85/100

Audited on Mar 27, 2026

No findings