|
1 | 1 | use super::*; |
2 | 2 |
|
| 3 | +#[derive(Debug)] |
3 | 4 | pub(crate) struct Bech32Decoder<'a> { |
4 | 5 | data: &'a [u8], |
5 | 6 | i: usize, |
@@ -32,18 +33,8 @@ impl<'a> Bech32Decoder<'a> { |
32 | 33 | if let Some((i, last)) = fes.clone().enumerate().last() { |
33 | 34 | let padding_len = (i + 1) * 5 % 8; |
34 | 35 |
|
35 | | - if padding_len > 4 { |
36 | | - return Err(Bech32Error::Padding { |
37 | | - source: PaddingError::TooMuch, |
38 | | - ty: self.ty, |
39 | | - }); |
40 | | - } |
41 | | - |
42 | 36 | if u64::from(last.to_u8().trailing_zeros()) < padding_len.into_u64() { |
43 | | - return Err(Bech32Error::Padding { |
44 | | - source: PaddingError::NonZero, |
45 | | - ty: self.ty, |
46 | | - }); |
| 37 | + return Err(Bech32Error::Padding { ty: self.ty }); |
47 | 38 | } |
48 | 39 | } |
49 | 40 |
|
@@ -99,6 +90,43 @@ impl<'a> Bech32Decoder<'a> { |
99 | 90 | mod tests { |
100 | 91 | use super::*; |
101 | 92 |
|
| 93 | + fn checksum(s: &str) -> String { |
| 94 | + let checked_hrpstring = CheckedHrpstring::new::<bech32::NoChecksum>(s).unwrap(); |
| 95 | + |
| 96 | + checked_hrpstring |
| 97 | + .fe32_iter::<std::vec::IntoIter<u8>>() |
| 98 | + .with_checksum::<bech32::Bech32m>(&checked_hrpstring.hrp()) |
| 99 | + .chars() |
| 100 | + .collect() |
| 101 | + } |
| 102 | + |
| 103 | + #[test] |
| 104 | + fn errors() { |
| 105 | + #[track_caller] |
| 106 | + fn case(s: &str, err: &str) { |
| 107 | + assert_eq!( |
| 108 | + Bech32Decoder::new(Bech32Type::PublicKey, &checksum(s)) |
| 109 | + .and_then(Bech32Decoder::byte_array::<1>) |
| 110 | + .unwrap_err() |
| 111 | + .to_string(), |
| 112 | + err, |
| 113 | + ); |
| 114 | + } |
| 115 | + |
| 116 | + case( |
| 117 | + "foo1", |
| 118 | + "expected bech32 human-readable part `public1...` but found `foo1...`", |
| 119 | + ); |
| 120 | + |
| 121 | + case("public1c", "bech32 public key version `c` not supported"); |
| 122 | + |
| 123 | + case("public1a", "bech32 public key truncated"); |
| 124 | + |
| 125 | + case("public1aqqq", "bech32 public key overlong by 1 character"); |
| 126 | + |
| 127 | + case("public1aql", "bech32 public key has nonzero padding"); |
| 128 | + } |
| 129 | + |
102 | 130 | #[test] |
103 | 131 | fn length() { |
104 | 132 | #[track_caller] |
|
0 commit comments