# 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.
```toml
[dependencies]
tdyne-peer-id = "1"
```
## Example
```rust
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_registry`](https://crates.io/crates/tdyne-peer-id-registry), peer ID
database and parser
`tdyne_peer_id` is opensourced from [TORRENTDYNE](https://torrentdyne.com), 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.