Documentation ¶
Overview ¶
Package psrkey is an implementation of PsrKey, the address scheme for the PaysharesNetwork.
Index ¶
Constants ¶
const ( //VersionByteAccountID is the version byte used for encoded payshares addresses VersionByteAccountID VersionByte = 15 << 3 // Base32-encodes to 'P...' //VersionByteSeed is the version byte used for encoded payshares seed VersionByteSeed = 18 << 3 // Base32-encodes to 'S...' //VersionByteHashTx is the version byte used for encoded payshares hashTx //signer keys. VersionByteHashTx = 19 << 3 // Base32-encodes to 'T...' //VersionByteHashX is the version byte used for encoded payshares hashX //signer keys. VersionByteHashX = 23 << 3 // Base32-encodes to 'X...' )
Variables ¶
var ErrInvalidVersionByte = errors.New("invalid version byte")
ErrInvalidVersionByte is returned when the version byte from a provided psrkey-encoded string is not one of the valid values.
Functions ¶
func Decode ¶
func Decode(expected VersionByte, src string) ([]byte, error)
Decode decodes the provided PsrKey into a raw value, checking the checksum and ensuring the expected VersionByte (the version parameter) is the value actually encoded into the provided src string.
func Encode ¶
func Encode(version VersionByte, src []byte) (string, error)
Encode encodes the provided data to a PsrKey, using the provided version byte.
func MustDecode ¶
func MustDecode(expected VersionByte, src string) []byte
MustDecode is like Decode, but panics on error
func MustEncode ¶
func MustEncode(version VersionByte, src []byte) string
MustEncode is like Encode, but panics on error
Types ¶
type VersionByte ¶
type VersionByte byte
VersionByte represents one of the possible prefix values for a PsrKey base string--the string the when encoded using base32 yields a final PsrKey.
func Version ¶
func Version(src string) (VersionByte, error)
Version extracts and returns the version byte from the provided source string.