Crates.io | tor-linkspec |
lib.rs | tor-linkspec |
version | 0.24.0 |
source | src |
created_at | 2021-06-24 14:35:12.760911 |
updated_at | 2024-10-31 14:08:44.465478 |
description | Parts of the Tor protocol that indicate specific relays on the network |
homepage | https://gitlab.torproject.org/tpo/core/arti/-/wikis/home |
repository | https://gitlab.torproject.org/tpo/core/arti.git/ |
max_upload_size | |
id | 414489 |
size | 156,154 |
Descriptions of Tor relays, as used to connect to them.
The tor-linkspec
crate provides traits and data structures that
describe how to connect to Tor relays.
When describing the location of a Tor relay on the network, the
Tor protocol uses a set of "link specifiers", each of which
corresponds to a single aspect of the relay's location or
identity—such as its IP address and port, its Ed25519 identity
key, its (legacy) RSA identity fingerprint, or so on. This
crate's [LinkSpec
] type encodes these structures.
When a client is building a circuit through the Tor network, it
needs to know certain information about the relays in that
circuit. This crate's [ChanTarget
] and [CircTarget
] traits
represent objects that describe a relay on the network that a
client can use as the first hop, or as any hop, in a circuit.
This crate is part of Arti, a project to implement Tor in Rust. Several other crates in Arti depend on it. You will probably not need this crate yourself unless you are interacting with the Tor protocol at a fairly low level.
tor-linkspec
is a separate crate so that it can be used by other
crates that expose link specifiers and by crates that consume
them.
TODO: Possibly we should rename this crate. "Linkspec" is a pretty esoteric term in the Tor protocols.
TODO: Possibly the link specifiers and the *Target
traits belong in different crates.
pt-client
-- Build with enhanced data types to support pluggable
transports.
full
-- Build with all the features above.
Note that the APIs enabled by these features are NOT covered by semantic versioning1 guarantees: we might break them or remove them between patch versions.
experimental
-- Build with all experimental features above. (Currently,
there are no experimental features in this crate, but there may be in the
future.)License: MIT OR Apache-2.0
Remember, semantic versioning is what makes various cargo
features work reliably. To be explicit: if you want cargo update
to only make safe changes, then you cannot enable these
features. ↩