6 releases (breaking)

0.7.0 Dec 30, 2023
0.6.0 Mar 6, 2023
0.5.0 Nov 29, 2022
0.4.0 Nov 24, 2022
0.1.0 Nov 18, 2022

#1742 in Network programming

MIT license

52KB
912 lines

Peerlink

Documentation Crates.io License Test Status

What is Peerlink? Peerlink is a low-level building block for P2P applications. It uses a nonblocking reactor to accept inbound connections, make outbound connections, do message streaming and reassembly, track peers and perform other low-level operations. It entirely abstracts away menial networking plumbing such as managing TCP sockets and reading bytes off the wire. In other words, it provides the consumer with a simple interface to talking with other nodes in a P2P network.

How is this meant to be used? Mainly as a building block for a variety of applications that communicate in a P2P fashion. For instance, if writing a Bitcoin node or BitTorrent client implementation, Peerlink can handle and abstract away the networking aspect and provide the developer with simplified messaging capabilities and enable them to focus on the business logic of their application. There is a single trait called Message that needs to be implemented on whatever message type you plan on sending and receiving and Peerlink does the heavy lifting.

How is this different from competitors? The philosophy of this crate is extreme simplicity. Rather than make assumptions about NAT traversal, peer discovery, encryption and other application-level aspects of decentralized networking, Peerlink provides the developer with a simple API to connecting to other peers, handling incoming peers and sending and receiving arbitrary messages.

Features

  • Simple usage (see examples).
  • First class support for proxying (Socks5, Tor...)
  • Efficient: low latency operations based on nonblocking IO.
  • Safe: written in Rust.

Proxying

To enable socks5 proxying, enable the socks feature.

Async/await

By default the reactor exposes a blocking handle. To use this in async contexts, enable the async feature.

Usage

Please refer to the documentation or the supplied examples and integration tests.

Disclaimer

This project comes with no warranty whatsoever. Please refer to the license for details.

Dependencies

~0.7–10MB
~71K SLoC