Documentation ¶
Overview ¶
Package bech32 provides a Go implementation of the bech32 format specified in BIP 173.
Bech32 strings consist of a human-readable part (hrp), followed by the separator 1, then a checksummed data part encoded using the 32 characters "qpzry9x8gf2tvdw0s3jn54khce6mua7l".
More info: https://github.com/bitcoin/bips/blob/master/bip-0173.mediawiki
Index ¶
- Constants
- Variables
- func Convert5to8(data by, pad bo) (by, er)
- func Convert8to5(data by, pad bo) (by, er)
- func ConvertBits(data by, fromBits, toBits uint8, pad bo) (by, er)
- func Decode(bech by) (by, by, er)
- func DecodeNoLimit(bech by) (by, by, er)
- func DecodeToBase256(bech by) (by, by, er)
- func Encode(hrp, data by) (by, er)
- func EncodeFromBase256(hrp, data by) (by, er)
- func EncodeM(hrp, data by) (by, er)
- type ChecksumConst
- type ErrInvalidBitGroups
- type ErrInvalidCharacter
- type ErrInvalidChecksum
- type ErrInvalidDataByte
- type ErrInvalidIncompleteGroup
- type ErrInvalidLength
- type ErrInvalidSeparatorIndex
- type ErrMixedCase
- type ErrNonCharsetChar
- type Version
Examples ¶
Constants ¶
const Charset = "qpzry9x8gf2tvdw0s3jn54khce6mua7l"
Charset is the set of characters used in the data section of bech32 strings. Note that this is ordered, such that for a given charset[i], i is the binary value of the character.
This wasn't exported in the original lol.
Variables ¶
var ConstsToVersion = map[ChecksumConst]Version{ Version0Const: Version0, VersionMConst: VersionM, }
ConstsToVersion maps a bech32 constant to the version it's associated with.
var VersionToConsts = map[Version]ChecksumConst{ Version0: Version0Const, VersionM: VersionMConst, }
VersionToConsts maps bech32 versions to the checksum constant to be used when encoding, and asserting a particular version when decoding.
Functions ¶
func Convert5to8 ¶
func Convert5to8(data by, pad bo) (by, er)
func Convert8to5 ¶
func Convert8to5(data by, pad bo) (by, er)
func ConvertBits ¶
func ConvertBits(data by, fromBits, toBits uint8, pad bo) (by, er)
ConvertBits converts a byte slice where each byte is encoding fromBits bits, to a byte slice where each byte is encoding toBits bits.
func Decode ¶
func Decode(bech by) (by, by, er)
Decode decodes a bech32 encoded string, returning the human-readable part and the data part excluding the checksum.
Note that the returned data is 5-bit (base32) encoded and the human-readable part will be lowercase.
Example ¶
This example demonstrates how to decode a bech32 encoded string.
encoded := "bc1pw508d6qejxtdg4y5r3zarvary0c5xw7kw508d6qejxtdg4y5r3zarvary0c5xw7k7grplx" hrp, decoded, err := Decode(by(encoded)) if err != nil { fmt.Println("Error:", err) } // Show the decoded data. fmt.Printf("Decoded human-readable part: %s\n", hrp) fmt.Println("Decoded Data:", hex.EncodeToString(decoded))
Output: Decoded human-readable part: bc Decoded Data: 010e140f070d1a001912060b0d081504140311021d030c1d03040f1814060e1e160e140f070d1a001912060b0d081504140311021d030c1d03040f1814060e1e16
func DecodeNoLimit ¶
func DecodeNoLimit(bech by) (by, by, er)
DecodeNoLimit decodes a bech32 encoded string, returning the human-readable part and the data part excluding the checksum. This function does NOT validate against the BIP-173 maximum length allowed for bech32 strings and is meant for use in custom applications (such as lightning network payment requests), NOT on-chain addresses.
Note that the returned data is 5-bit (base32) encoded and the human-readable part will be lowercase.
func DecodeToBase256 ¶
func DecodeToBase256(bech by) (by, by, er)
DecodeToBase256 decodes a bech32-encoded string into its associated human-readable part (HRP) and base32-encoded data, converts that data to a base256-encoded byte slice and returns it along with the lowercase HRP.
func Encode ¶
func Encode(hrp, data by) (by, er)
Encode encodes a byte slice into a bech32 string with the given human-readable part (HRP). The HRP will be converted to lowercase if needed since mixed cased encodings are not permitted and lowercase is used for checksum purposes. Note that the bytes must each encode 5 bits (base32).
Example ¶
This example demonstrates how to encode data into a bech32 string.
data := by("Test data") // Convert test data to base32: conv, err := ConvertBits(data, 8, 5, true) if err != nil { fmt.Println("Error:", err) } encoded, err := Encode(by("customHrp!11111q"), conv) if err != nil { fmt.Println("Error:", err) } // Show the encoded data. fmt.Printf("Encoded Data: %s", encoded)
Output: Encoded Data: customhrp!11111q123jhxapqv3shgcgkxpuhe
func EncodeFromBase256 ¶
func EncodeFromBase256(hrp, data by) (by, er)
EncodeFromBase256 converts a base256-encoded byte slice into a base32-encoded byte slice and then encodes it into a bech32 string with the given human-readable part (HRP). The HRP will be converted to lowercase if needed since mixed cased encodings are not permitted and lowercase is used for checksum purposes.
Types ¶
type ChecksumConst ¶
type ChecksumConst no
ChecksumConst is a type that represents the currently defined bech32 checksum constants.
const ( // Version0Const is the original constant used in the checksum // verification for bech32. Version0Const ChecksumConst = 1 // VersionMConst is the new constant used for bech32m checksum // verification. VersionMConst ChecksumConst = 0x2bc830a3 )
type ErrInvalidBitGroups ¶
type ErrInvalidBitGroups struct{}
ErrInvalidBitGroups is returned when conversion is attempted between byte slices using bit-per-element of unsupported value.
func (ErrInvalidBitGroups) Error ¶
func (err ErrInvalidBitGroups) Error() st
type ErrInvalidCharacter ¶
type ErrInvalidCharacter rune
ErrInvalidCharacter is returned when the bech32 string has a character outside the range of the supported charset.
func (ErrInvalidCharacter) Error ¶
func (err ErrInvalidCharacter) Error() st
type ErrInvalidChecksum ¶
type ErrInvalidChecksum struct { Expected st ExpectedM st Actual st }
ErrInvalidChecksum is returned when the extracted checksum of the string is different than what was expected. Both the original version, as well as the new bech32m checksum may be specified.
func (ErrInvalidChecksum) Error ¶
func (err ErrInvalidChecksum) Error() st
type ErrInvalidDataByte ¶
type ErrInvalidDataByte byte
ErrInvalidDataByte is returned when a byte outside the range required for conversion into a string was found.
func (ErrInvalidDataByte) Error ¶
func (err ErrInvalidDataByte) Error() st
type ErrInvalidIncompleteGroup ¶
type ErrInvalidIncompleteGroup struct{}
ErrInvalidIncompleteGroup is returned when then byte slice used as input has data of wrong length.
func (ErrInvalidIncompleteGroup) Error ¶
func (err ErrInvalidIncompleteGroup) Error() st
type ErrInvalidLength ¶
type ErrInvalidLength no
ErrInvalidLength is returned when the bech32 string has an invalid length given the BIP-173 defined restrictions.
func (ErrInvalidLength) Error ¶
func (err ErrInvalidLength) Error() st
type ErrInvalidSeparatorIndex ¶
type ErrInvalidSeparatorIndex no
ErrInvalidSeparatorIndex is returned when the separator character '1' is in an invalid position in the bech32 string.
func (ErrInvalidSeparatorIndex) Error ¶
func (err ErrInvalidSeparatorIndex) Error() st
type ErrMixedCase ¶
type ErrMixedCase struct{}
ErrMixedCase is returned when the bech32 string has both lower and uppercase characters.
func (ErrMixedCase) Error ¶
func (err ErrMixedCase) Error() st
type ErrNonCharsetChar ¶
type ErrNonCharsetChar rune
ErrNonCharsetChar is returned when a character outside of the specific bech32 charset is used in the string.
func (ErrNonCharsetChar) Error ¶
func (err ErrNonCharsetChar) Error() st
type Version ¶
type Version uint8
Version defines the current set of bech32 versions.
func DecodeGeneric ¶
func DecodeGeneric(bech by) (by, by, Version, er)
DecodeGeneric is identical to the existing Decode method, but will also return bech32 version that matches the decoded checksum. This method should be used when decoding segwit addresses, as it enables additional verification to ensure the proper checksum is used.