7 #include <botan/base58.h>
8 #include <botan/exceptn.h>
9 #include <botan/bigint.h>
10 #include <botan/divide.h>
11 #include <botan/loadstor.h>
12 #include <botan/hash.h>
18 uint32_t sha256_d_checksum(
const uint8_t input[],
size_t input_length)
22 std::vector<uint8_t> checksum(32);
24 sha256->update(input, input_length);
25 sha256->final(checksum);
27 sha256->update(checksum);
28 sha256->final(checksum);
37 Character_Table(
const char* alphabet) :
40 const size_t alpha_len = std::strlen(alphabet);
43 if(alpha_len == 0 || alpha_len >= 128)
44 throw Invalid_Argument(
"Bad Character_Table string");
52 const uint8_t b =
static_cast<uint8_t
>(
m_alphabet[i]);
54 m_tab[b] =
static_cast<uint8_t
>(i);
60 char operator[](
size_t i)
const
66 uint8_t code_for(
char c)
const
68 return m_tab[
static_cast<uint8_t
>(c)];
77 static const Character_Table& BASE58_ALPHA()
79 static const Character_Table base58_alpha(
"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz");
85 const auto base58 = BASE58_ALPHA();
94 result.push_back(base58[r]);
98 for(
size_t i = 0; i != leading_zeros; ++i)
99 result.push_back(base58[0]);
101 return std::string(result.rbegin(), result.rend());
104 template<
typename T,
typename Z>
105 size_t count_leading_zeros(
const T input[],
size_t input_length,
Z zero)
107 size_t leading_zeros = 0;
109 while(leading_zeros < input_length && input[leading_zeros] == zero)
112 return leading_zeros;
119 BigInt v(input, input_length);
120 return base58_encode(v, count_leading_zeros(input, input_length, 0));
125 BigInt v(input, input_length);
127 v += sha256_d_checksum(input, input_length);
128 return base58_encode(v, count_leading_zeros(input, input_length, 0));
133 const auto base58 = BASE58_ALPHA();
135 const size_t leading_zeros = count_leading_zeros(input, input_length, base58[0]);
139 for(
size_t i = leading_zeros; i != input_length; ++i)
141 const char c = input[i];
143 if(c ==
' ' || c ==
'\n')
146 const size_t idx = base58.code_for(c);
155 std::vector<uint8_t> output(v.
bytes() + leading_zeros);
162 std::vector<uint8_t> dec =
base58_decode(input, input_length);
167 const uint32_t computed_checksum = sha256_d_checksum(dec.data(), dec.size() - 4);
170 if(checksum != computed_checksum)
173 dec.resize(dec.size() - 4);
void binary_encode(uint8_t buf[]) const
static std::unique_ptr< HashFunction > create_or_throw(const std::string &algo_spec, const std::string &provider="")
std::vector< uint8_t > base58_check_decode(const char input[], size_t input_length)
uint32_t load_be< uint32_t >(const uint8_t in[], size_t off)
void set_mem(uint8_t *ptr, size_t n, uint8_t val)
std::string base58_encode(const uint8_t input[], size_t input_length)
#define BOTAN_ASSERT(expr, assertion_made)
std::vector< uint8_t > base58_decode(const char input[], size_t input_length)
std::string base58_check_encode(const uint8_t input[], size_t input_length)
void ct_divide_u8(const BigInt &x, uint8_t y, BigInt &q_out, uint8_t &r_out)