Crates.io | bitcoin-bech32 |
lib.rs | bitcoin-bech32 |
version | 0.13.0 |
source | src |
created_at | 2017-05-17 16:03:16.293718 |
updated_at | 2023-04-05 04:49:28.976814 |
description | Encodes and decodes Bitcoin Segregated Witness addresses in Bech32 |
homepage | |
repository | https://github.com/rust-bitcoin/rust-bech32-bitcoin |
max_upload_size | |
id | 14939 |
size | 28,217 |
Encodes and decodes Bitcoin Segregated Witness addresses in the Bech32 format described in BIP-0173 and Bech32m format described in BIP-0350.
use bitcoin_bech32::{WitnessProgram, u5};
use bitcoin_bech32::constants::Network;
let witness_program = WitnessProgram::new(
u5::try_from_u8(0).unwrap(),
vec![
0x00, 0x00, 0x00, 0xc4, 0xa5, 0xca, 0xd4, 0x62,
0x21, 0xb2, 0xa1, 0x87, 0x90, 0x5e, 0x52, 0x66,
0x36, 0x2b, 0x99, 0xd5, 0xe9, 0x1c, 0x6c, 0xe2,
0x4d, 0x16, 0x5d, 0xab, 0x93, 0xe8, 0x64, 0x33],
Network::Testnet,
).unwrap();
let address = witness_program.to_address();
assert_eq!(address,
"tb1qqqqqp399et2xygdj5xreqhjjvcmzhxw4aywxecjdzew6hylgvsesrxh6hy".to_string());
let decoded = WitnessProgram::from_address(&address).unwrap();
assert_eq!(decoded, witness_program);