base58: Rename public functions
The `base58` module is for encoding and decoding, it makes sense for the public functions to be called `encode` and `decode`. We also have some functions that operate on data with a checksum, for these it makes sense to tack `check` onto the _end_ of the function name. With this applied the public API is: - decode - decode_check - encode - encode_check - encode_check_to_fmt
This commit is contained in:
parent
a94af5c052
commit
6151d4c841
|
@ -523,13 +523,13 @@ impl<'a> fmt::Display for AddressEncoding<'a> {
|
||||||
let mut prefixed = [0; 21];
|
let mut prefixed = [0; 21];
|
||||||
prefixed[0] = self.p2pkh_prefix;
|
prefixed[0] = self.p2pkh_prefix;
|
||||||
prefixed[1..].copy_from_slice(&hash[..]);
|
prefixed[1..].copy_from_slice(&hash[..]);
|
||||||
base58::check_encode_slice_to_fmt(fmt, &prefixed[..])
|
base58::encode_check_to_fmt(fmt, &prefixed[..])
|
||||||
}
|
}
|
||||||
Payload::ScriptHash(hash) => {
|
Payload::ScriptHash(hash) => {
|
||||||
let mut prefixed = [0; 21];
|
let mut prefixed = [0; 21];
|
||||||
prefixed[0] = self.p2sh_prefix;
|
prefixed[0] = self.p2sh_prefix;
|
||||||
prefixed[1..].copy_from_slice(&hash[..]);
|
prefixed[1..].copy_from_slice(&hash[..]);
|
||||||
base58::check_encode_slice_to_fmt(fmt, &prefixed[..])
|
base58::encode_check_to_fmt(fmt, &prefixed[..])
|
||||||
}
|
}
|
||||||
Payload::WitnessProgram { version, program: prog } => {
|
Payload::WitnessProgram { version, program: prog } => {
|
||||||
let mut upper_writer;
|
let mut upper_writer;
|
||||||
|
@ -839,7 +839,7 @@ impl FromStr for Address {
|
||||||
if s.len() > 50 {
|
if s.len() > 50 {
|
||||||
return Err(Error::Base58(base58::Error::InvalidLength(s.len() * 11 / 15)));
|
return Err(Error::Base58(base58::Error::InvalidLength(s.len() * 11 / 15)));
|
||||||
}
|
}
|
||||||
let data = base58::from_check(s)?;
|
let data = base58::decode_check(s)?;
|
||||||
if data.len() != 21 {
|
if data.len() != 21 {
|
||||||
return Err(Error::Base58(base58::Error::InvalidLength(data.len())));
|
return Err(Error::Base58(base58::Error::InvalidLength(data.len())));
|
||||||
}
|
}
|
||||||
|
|
|
@ -780,7 +780,7 @@ impl ExtendedPubKey {
|
||||||
|
|
||||||
impl fmt::Display for ExtendedPrivKey {
|
impl fmt::Display for ExtendedPrivKey {
|
||||||
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
||||||
base58::check_encode_slice_to_fmt(fmt, &self.encode()[..])
|
base58::encode_check_to_fmt(fmt, &self.encode()[..])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -788,7 +788,7 @@ impl FromStr for ExtendedPrivKey {
|
||||||
type Err = Error;
|
type Err = Error;
|
||||||
|
|
||||||
fn from_str(inp: &str) -> Result<ExtendedPrivKey, Error> {
|
fn from_str(inp: &str) -> Result<ExtendedPrivKey, Error> {
|
||||||
let data = base58::from_check(inp)?;
|
let data = base58::decode_check(inp)?;
|
||||||
|
|
||||||
if data.len() != 78 {
|
if data.len() != 78 {
|
||||||
return Err(base58::Error::InvalidLength(data.len()).into());
|
return Err(base58::Error::InvalidLength(data.len()).into());
|
||||||
|
@ -800,7 +800,7 @@ impl FromStr for ExtendedPrivKey {
|
||||||
|
|
||||||
impl fmt::Display for ExtendedPubKey {
|
impl fmt::Display for ExtendedPubKey {
|
||||||
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
||||||
base58::check_encode_slice_to_fmt(fmt, &self.encode()[..])
|
base58::encode_check_to_fmt(fmt, &self.encode()[..])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -808,7 +808,7 @@ impl FromStr for ExtendedPubKey {
|
||||||
type Err = Error;
|
type Err = Error;
|
||||||
|
|
||||||
fn from_str(inp: &str) -> Result<ExtendedPubKey, Error> {
|
fn from_str(inp: &str) -> Result<ExtendedPubKey, Error> {
|
||||||
let data = base58::from_check(inp)?;
|
let data = base58::decode_check(inp)?;
|
||||||
|
|
||||||
if data.len() != 78 {
|
if data.len() != 78 {
|
||||||
return Err(base58::Error::InvalidLength(data.len()).into());
|
return Err(base58::Error::InvalidLength(data.len()).into());
|
||||||
|
|
|
@ -36,7 +36,13 @@ static BASE58_DIGITS: [Option<u8>; 128] = [
|
||||||
];
|
];
|
||||||
|
|
||||||
/// Decodes a base58-encoded string into a byte vector.
|
/// Decodes a base58-encoded string into a byte vector.
|
||||||
|
#[deprecated(since = "0.30.0", note = "Use base58::decode() instead")]
|
||||||
pub fn from(data: &str) -> Result<Vec<u8>, Error> {
|
pub fn from(data: &str) -> Result<Vec<u8>, Error> {
|
||||||
|
decode(data)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Decodes a base58-encoded string into a byte vector.
|
||||||
|
pub fn decode(data: &str) -> Result<Vec<u8>, Error> {
|
||||||
// 11/15 is just over log_256(58)
|
// 11/15 is just over log_256(58)
|
||||||
let mut scratch = vec![0u8; 1 + data.len() * 11 / 15];
|
let mut scratch = vec![0u8; 1 + data.len() * 11 / 15];
|
||||||
// Build in base 256
|
// Build in base 256
|
||||||
|
@ -67,8 +73,14 @@ pub fn from(data: &str) -> Result<Vec<u8>, Error> {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Decodes a base58check-encoded string into a byte vector verifying the checksum.
|
/// Decodes a base58check-encoded string into a byte vector verifying the checksum.
|
||||||
|
#[deprecated(since = "0.30.0", note = "Use base58::decode_check() instead")]
|
||||||
pub fn from_check(data: &str) -> Result<Vec<u8>, Error> {
|
pub fn from_check(data: &str) -> Result<Vec<u8>, Error> {
|
||||||
let mut ret: Vec<u8> = from(data)?;
|
decode_check(data)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Decodes a base58check-encoded string into a byte vector verifying the checksum.
|
||||||
|
pub fn decode_check(data: &str) -> Result<Vec<u8>, Error> {
|
||||||
|
let mut ret: Vec<u8> = decode(data)?;
|
||||||
if ret.len() < 4 {
|
if ret.len() < 4 {
|
||||||
return Err(Error::TooShort(ret.len()));
|
return Err(Error::TooShort(ret.len()));
|
||||||
}
|
}
|
||||||
|
@ -89,14 +101,28 @@ pub fn from_check(data: &str) -> Result<Vec<u8>, Error> {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Encodes `data` as a base58 string.
|
/// Encodes `data` as a base58 string.
|
||||||
|
#[deprecated(since = "0.30.0", note = "Use base58::encode() instead")]
|
||||||
pub fn encode_slice(data: &[u8]) -> String {
|
pub fn encode_slice(data: &[u8]) -> String {
|
||||||
|
encode(data)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Encodes `data` as a base58 string (see also `base58::encode_check()`).
|
||||||
|
pub fn encode(data: &[u8]) -> String {
|
||||||
encode_iter(data.iter().cloned())
|
encode_iter(data.iter().cloned())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Encodes `data` as a base58 string including the checksum.
|
/// Encodes `data` as a base58 string including the checksum.
|
||||||
///
|
///
|
||||||
/// The checksum is the first 4 256-digits of the object's Bitcoin hash, concatenated onto the end.
|
/// The checksum is the first 4 256-digits of the object's Bitcoin hash, concatenated onto the end.
|
||||||
|
#[deprecated(since = "0.30.0", note = "Use base58::encode_check() instead")]
|
||||||
pub fn check_encode_slice(data: &[u8]) -> String {
|
pub fn check_encode_slice(data: &[u8]) -> String {
|
||||||
|
encode_check(data)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Encodes `data` as a base58 string including the checksum.
|
||||||
|
///
|
||||||
|
/// The checksum is the first 4 256-digits of the object's Bitcoin hash, concatenated onto the end.
|
||||||
|
pub fn encode_check(data: &[u8]) -> String {
|
||||||
let checksum = sha256d::Hash::hash(data);
|
let checksum = sha256d::Hash::hash(data);
|
||||||
encode_iter(
|
encode_iter(
|
||||||
data.iter()
|
data.iter()
|
||||||
|
@ -108,7 +134,15 @@ pub fn check_encode_slice(data: &[u8]) -> String {
|
||||||
/// Encodes `data` as base58, including the checksum, into a formatter.
|
/// Encodes `data` as base58, including the checksum, into a formatter.
|
||||||
///
|
///
|
||||||
/// The checksum is the first 4 256-digits of the object's Bitcoin hash, concatenated onto the end.
|
/// The checksum is the first 4 256-digits of the object's Bitcoin hash, concatenated onto the end.
|
||||||
|
#[deprecated(since = "0.30.0", note = "Use base58::encode_check_to_fmt() instead")]
|
||||||
pub fn check_encode_slice_to_fmt(fmt: &mut fmt::Formatter, data: &[u8]) -> fmt::Result {
|
pub fn check_encode_slice_to_fmt(fmt: &mut fmt::Formatter, data: &[u8]) -> fmt::Result {
|
||||||
|
encode_check_to_fmt(fmt, data)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Encodes a slice as base58, including the checksum, into a formatter.
|
||||||
|
///
|
||||||
|
/// The checksum is the first 4 256-digits of the object's Bitcoin hash, concatenated onto the end.
|
||||||
|
pub fn encode_check_to_fmt(fmt: &mut fmt::Formatter, data: &[u8]) -> fmt::Result {
|
||||||
let checksum = sha256d::Hash::hash(data);
|
let checksum = sha256d::Hash::hash(data);
|
||||||
let iter = data.iter()
|
let iter = data.iter()
|
||||||
.cloned()
|
.cloned()
|
||||||
|
@ -260,17 +294,17 @@ mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
fn test_base58_encode() {
|
fn test_base58_encode() {
|
||||||
// Basics
|
// Basics
|
||||||
assert_eq!(&encode_slice(&[0][..]), "1");
|
assert_eq!(&encode(&[0][..]), "1");
|
||||||
assert_eq!(&encode_slice(&[1][..]), "2");
|
assert_eq!(&encode(&[1][..]), "2");
|
||||||
assert_eq!(&encode_slice(&[58][..]), "21");
|
assert_eq!(&encode(&[58][..]), "21");
|
||||||
assert_eq!(&encode_slice(&[13, 36][..]), "211");
|
assert_eq!(&encode(&[13, 36][..]), "211");
|
||||||
|
|
||||||
// Leading zeroes
|
// Leading zeroes
|
||||||
assert_eq!(&encode_slice(&[0, 13, 36][..]), "1211");
|
assert_eq!(&encode(&[0, 13, 36][..]), "1211");
|
||||||
assert_eq!(&encode_slice(&[0, 0, 0, 0, 13, 36][..]), "1111211");
|
assert_eq!(&encode(&[0, 0, 0, 0, 13, 36][..]), "1111211");
|
||||||
|
|
||||||
// Long input (>100 bytes => has to use heap)
|
// Long input (>100 bytes => has to use heap)
|
||||||
let res = encode_slice("BitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBit\
|
let res = encode("BitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBit\
|
||||||
coinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoin".as_bytes());
|
coinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoinBitcoin".as_bytes());
|
||||||
let exp = "ZqC5ZdfpZRi7fjA8hbhX5pEE96MdH9hEaC1YouxscPtbJF16qVWksHWR4wwvx7MotFcs2ChbJqK8KJ9X\
|
let exp = "ZqC5ZdfpZRi7fjA8hbhX5pEE96MdH9hEaC1YouxscPtbJF16qVWksHWR4wwvx7MotFcs2ChbJqK8KJ9X\
|
||||||
wZznwWn1JFDhhTmGo9v6GjAVikzCsBWZehu7bm22xL8b5zBR5AsBygYRwbFJsNwNkjpyFuDKwmsUTKvkULCvucPJrN5\
|
wZznwWn1JFDhhTmGo9v6GjAVikzCsBWZehu7bm22xL8b5zBR5AsBygYRwbFJsNwNkjpyFuDKwmsUTKvkULCvucPJrN5\
|
||||||
|
@ -279,39 +313,39 @@ mod tests {
|
||||||
|
|
||||||
// Addresses
|
// Addresses
|
||||||
let addr = Vec::from_hex("00f8917303bfa8ef24f292e8fa1419b20460ba064d").unwrap();
|
let addr = Vec::from_hex("00f8917303bfa8ef24f292e8fa1419b20460ba064d").unwrap();
|
||||||
assert_eq!(&check_encode_slice(&addr[..]), "1PfJpZsjreyVrqeoAfabrRwwjQyoSQMmHH");
|
assert_eq!(&encode_check(&addr[..]), "1PfJpZsjreyVrqeoAfabrRwwjQyoSQMmHH");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_base58_decode() {
|
fn test_base58_decode() {
|
||||||
// Basics
|
// Basics
|
||||||
assert_eq!(from("1").ok(), Some(vec![0u8]));
|
assert_eq!(decode("1").ok(), Some(vec![0u8]));
|
||||||
assert_eq!(from("2").ok(), Some(vec![1u8]));
|
assert_eq!(decode("2").ok(), Some(vec![1u8]));
|
||||||
assert_eq!(from("21").ok(), Some(vec![58u8]));
|
assert_eq!(decode("21").ok(), Some(vec![58u8]));
|
||||||
assert_eq!(from("211").ok(), Some(vec![13u8, 36]));
|
assert_eq!(decode("211").ok(), Some(vec![13u8, 36]));
|
||||||
|
|
||||||
// Leading zeroes
|
// Leading zeroes
|
||||||
assert_eq!(from("1211").ok(), Some(vec![0u8, 13, 36]));
|
assert_eq!(decode("1211").ok(), Some(vec![0u8, 13, 36]));
|
||||||
assert_eq!(from("111211").ok(), Some(vec![0u8, 0, 0, 13, 36]));
|
assert_eq!(decode("111211").ok(), Some(vec![0u8, 0, 0, 13, 36]));
|
||||||
|
|
||||||
// Addresses
|
// Addresses
|
||||||
assert_eq!(from_check("1PfJpZsjreyVrqeoAfabrRwwjQyoSQMmHH").ok(),
|
assert_eq!(decode_check("1PfJpZsjreyVrqeoAfabrRwwjQyoSQMmHH").ok(),
|
||||||
Some(Vec::from_hex("00f8917303bfa8ef24f292e8fa1419b20460ba064d").unwrap()));
|
Some(Vec::from_hex("00f8917303bfa8ef24f292e8fa1419b20460ba064d").unwrap()));
|
||||||
// Non Base58 char.
|
// Non Base58 char.
|
||||||
assert_eq!(from("¢").unwrap_err(), Error::BadByte(194));
|
assert_eq!(decode("¢").unwrap_err(), Error::BadByte(194));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_base58_roundtrip() {
|
fn test_base58_roundtrip() {
|
||||||
let s = "xprv9wTYmMFdV23N2TdNG573QoEsfRrWKQgWeibmLntzniatZvR9BmLnvSxqu53Kw1UmYPxLgboyZQaXwTCg8MSY3H2EU4pWcQDnRnrVA1xe8fs";
|
let s = "xprv9wTYmMFdV23N2TdNG573QoEsfRrWKQgWeibmLntzniatZvR9BmLnvSxqu53Kw1UmYPxLgboyZQaXwTCg8MSY3H2EU4pWcQDnRnrVA1xe8fs";
|
||||||
let v: Vec<u8> = from_check(s).unwrap();
|
let v: Vec<u8> = decode_check(s).unwrap();
|
||||||
assert_eq!(check_encode_slice(&v[..]), s);
|
assert_eq!(encode_check(&v[..]), s);
|
||||||
assert_eq!(from_check(&check_encode_slice(&v[..])).ok(), Some(v));
|
assert_eq!(decode_check(&encode_check(&v[..])).ok(), Some(v));
|
||||||
|
|
||||||
// Check that empty slice passes roundtrip.
|
// Check that empty slice passes roundtrip.
|
||||||
assert_eq!(from_check(&check_encode_slice(&[])), Ok(vec![]));
|
assert_eq!(decode_check(&encode_check(&[])), Ok(vec![]));
|
||||||
// Check that `len > 4` is enforced.
|
// Check that `len > 4` is enforced.
|
||||||
assert_eq!(from_check(&encode_slice(&[1,2,3])), Err(Error::TooShort(3)));
|
assert_eq!(decode_check(&encode(&[1,2,3])), Err(Error::TooShort(3)));
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -360,9 +360,9 @@ impl PrivateKey {
|
||||||
ret[1..33].copy_from_slice(&self.inner[..]);
|
ret[1..33].copy_from_slice(&self.inner[..]);
|
||||||
let privkey = if self.compressed {
|
let privkey = if self.compressed {
|
||||||
ret[33] = 1;
|
ret[33] = 1;
|
||||||
base58::check_encode_slice(&ret[..])
|
base58::encode_check(&ret[..])
|
||||||
} else {
|
} else {
|
||||||
base58::check_encode_slice(&ret[..33])
|
base58::encode_check(&ret[..33])
|
||||||
};
|
};
|
||||||
fmt.write_str(&privkey)
|
fmt.write_str(&privkey)
|
||||||
}
|
}
|
||||||
|
@ -377,7 +377,7 @@ impl PrivateKey {
|
||||||
|
|
||||||
/// Parse WIF encoded private key.
|
/// Parse WIF encoded private key.
|
||||||
pub fn from_wif(wif: &str) -> Result<PrivateKey, Error> {
|
pub fn from_wif(wif: &str) -> Result<PrivateKey, Error> {
|
||||||
let data = base58::from_check(wif)?;
|
let data = base58::decode_check(wif)?;
|
||||||
|
|
||||||
let compressed = match data.len() {
|
let compressed = match data.len() {
|
||||||
33 => false,
|
33 => false,
|
||||||
|
|
Loading…
Reference in New Issue