tdyne-peer-id

Crates.iotdyne-peer-id
lib.rstdyne-peer-id
version1.0.2
sourcesrc
created_at2023-10-06 18:19:53.693751
updated_at2023-10-06 18:42:38.627919
descriptionBasic Peer ID type used across BitTorrent related libraries.
homepagehttps://github.com/torrentdyne/tdyne-peer-id
repositoryhttps://github.com/torrentdyne/tdyne-peer-id
max_upload_size
id995294
size19,079
Dan Groshev (si14)

documentation

https://docs.rs/tdyne-peer-id

README

Base type for BitTorrent peer IDs

tdyne_peer_id is a newtype for BitTorrent peer IDs, represented as [u8; 20]. It's intentionally kept very minimalist to minimise the possibility of backwards-incompatible changes.

[dependencies]
tdyne-peer-id = "1"

Example

use tdyne_peer_id::{PeerId, BadPeerIdLengthError};

fn main() {
    let byte_array: &[u8; 20] = b"-TR0000-*\x00\x01d7xkqq04n";
    let byte_slice: &[u8] = b"-TR0000-*\x00\x01d7xkqq04n";
    let short_byte_slice: &[u8] = b"-TR0000-";

    // creating a PeerId from an array is simple
    let peer_id = PeerId::from(b"-TR0000-*\x00\x01d7xkqq04n");
    assert_eq!(peer_id.to_string(), "-TR0000-???d7xkqq04n".to_string());

    // you can also create PeerId from a byte slice if its 20 bytes long
    _ = PeerId::try_from(byte_slice).expect("matching lengths");

    // …if it's not, you get an error
    let error = BadPeerIdLengthError(short_byte_slice.len());
    assert_eq!(PeerId::try_from(short_byte_slice).expect_err("lengths don't match"), error);
}

Libraries and projects using tdyne_peer_id

tdyne_peer_id is opensourced from TORRENTDYNE, a BitTorrent diagnostic service.

License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Commit count: 4

cargo fmt