Crates.io | tor-relay-selection |
lib.rs | tor-relay-selection |
version | 0.24.0 |
source | src |
created_at | 2024-04-02 14:35:37.018862 |
updated_at | 2024-10-31 14:10:42.893699 |
description | Logic to select Tor relays for specific purposes |
homepage | https://gitlab.torproject.org/tpo/core/arti/-/wikis/home |
repository | https://gitlab.torproject.org/tpo/core/arti.git/ |
max_upload_size | |
id | 1193605 |
size | 66,436 |
Logic to select Tor relays for specific purposes
The tor-relay-selection
crate provides higher-level functions
in order to select Tor relays for specific purposes,
or check whether they are suitable for those purposes.
It wraps lower-level functionality from tor-netdir
.
This crate is part of Arti, a project to implement Tor in Rust.
Our main types are RelayUsage
, RelayExclusion
, RelayRestriction
, and RelaySelector
.
A RelayUsage
answers the question "what is this relay for?"
A RelayExclusion
excludes one or more relays
as having already been selected,
or as sharing families with already-selected relays.
A RelayRestriction
imposes additional restrictions on a relay.
A RelaySelector
is a collection of a usage, an exclusion, and any number of restrictions.
In a RelaySelector
, usages and restrictions can be strict or flexible.
If we fail to pick a relay, and there are any flexible usages/restrictions,
then we remove those usages/restrictions to produce a relaxed selector
and we try again.
License: MIT OR Apache-2.0