Fix address version processing in Base58 encoding/decoding
This commit is contained in:
parent
c5c21fd069
commit
fee9bfd3af
25
base58.go
25
base58.go
|
@ -22,14 +22,12 @@ func Base58Encode(input []byte) []byte {
|
|||
result = append(result, b58Alphabet[mod.Int64()])
|
||||
}
|
||||
|
||||
// https://en.bitcoin.it/wiki/Base58Check_encoding#Version_bytes
|
||||
if input[0] == 0x00 {
|
||||
result = append(result, b58Alphabet[0])
|
||||
}
|
||||
|
||||
ReverseBytes(result)
|
||||
for _, b := range input {
|
||||
if b == 0x00 {
|
||||
result = append([]byte{b58Alphabet[0]}, result...)
|
||||
} else {
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
return result
|
||||
}
|
||||
|
@ -37,23 +35,18 @@ func Base58Encode(input []byte) []byte {
|
|||
// Base58Decode decodes Base58-encoded data
|
||||
func Base58Decode(input []byte) []byte {
|
||||
result := big.NewInt(0)
|
||||
zeroBytes := 0
|
||||
|
||||
for _, b := range input {
|
||||
if b == 0x00 {
|
||||
zeroBytes++
|
||||
}
|
||||
}
|
||||
|
||||
payload := input[zeroBytes:]
|
||||
for _, b := range payload {
|
||||
charIndex := bytes.IndexByte(b58Alphabet, b)
|
||||
result.Mul(result, big.NewInt(58))
|
||||
result.Add(result, big.NewInt(int64(charIndex)))
|
||||
}
|
||||
|
||||
decoded := result.Bytes()
|
||||
decoded = append(bytes.Repeat([]byte{byte(0x00)}, zeroBytes), decoded...)
|
||||
|
||||
if input[0] == b58Alphabet[0] {
|
||||
decoded = append([]byte{0x00}, decoded...)
|
||||
}
|
||||
|
||||
return decoded
|
||||
}
|
||||
|
|
|
@ -0,0 +1,24 @@
|
|||
package main
|
||||
|
||||
import (
|
||||
"encoding/hex"
|
||||
"log"
|
||||
"strings"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestBase58(t *testing.T) {
|
||||
rawHash := "00010966776006953D5567439E5E39F86A0D273BEED61967F6"
|
||||
hash, err := hex.DecodeString(rawHash)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
encoded := Base58Encode(hash)
|
||||
assert.Equal(t, "16UwLL9Risc3QfPqBUvKofHmBQ7wMtjvM", string(encoded))
|
||||
|
||||
decoded := Base58Decode([]byte("16UwLL9Risc3QfPqBUvKofHmBQ7wMtjvM"))
|
||||
assert.Equal(t, strings.ToLower("00010966776006953D5567439E5E39F86A0D273BEED61967F6"), hex.EncodeToString(decoded))
|
||||
}
|
Loading…
Reference in New Issue