28 releases (16 breaking)

new 0.26.0 Jan 7, 2025
0.25.0 Dec 2, 2024
0.24.0 Oct 31, 2024
0.20.0 Jun 27, 2024
0.0.0 Jun 24, 2021

#2042 in Network programming

Download history 1236/week @ 2024-09-17 1786/week @ 2024-09-24 1420/week @ 2024-10-01 846/week @ 2024-10-08 947/week @ 2024-10-15 1269/week @ 2024-10-22 1876/week @ 2024-10-29 1459/week @ 2024-11-05 1704/week @ 2024-11-12 2123/week @ 2024-11-19 2116/week @ 2024-11-26 2017/week @ 2024-12-03 2659/week @ 2024-12-10 1886/week @ 2024-12-17 747/week @ 2024-12-24 895/week @ 2024-12-31

6,529 downloads per month
Used in 53 crates (6 directly)

MIT/Apache

33KB
473 lines

tor-protover

Implementation of Tor's "subprotocol versioning" feature.

Overview

The Tor system is built out of numerous "subprotocols" that are versioned more or less independently. The tor-protover crate implements parsing and handling for these subprotocol versions, so that different Tor instances know which parts of the protocol they support.

Subprotocol versions are also used to determine which versions of the protocol are required to connect to the network (or just recommended).

For more details, see tor-spec.txt section 9.

This crate is part of Arti, a project to implement Tor in Rust. It's unlikely to be of general interest unless you are writing a Tor implementation, or a program that needs to examine fine-grained details of the Tor network.

Design notes

We're giving tor-protover its own crate within arti because it needs to be used to multiple higher level crates that do not themselves depend on one another. (For example, tor-proto needs to know which variant of a subprotocol can be used with a given relay, whereas tor-netdoc needs to parse lists of subprotocol versions from directory documents. Eventually, arti-client will need to check its own list of supported protocols against the required list in the consensus.)

License: MIT OR Apache-2.0

Dependencies

~240–680KB
~16K SLoC