Documentation ¶
Index ¶
- Variables
- type DeriveBlindingKeyPairArgs
- type DeriveConfidentialAddressArgs
- type DeriveSigningKeyPairArgs
- type ExtendedKeyArgs
- type NewWalletArgs
- type NewWalletFromMnemonicArgs
- type SignPsetArgs
- type SignTransactionArgs
- type Wallet
- func (w *Wallet) AccountExtendedPrivateKey(args ExtendedKeyArgs) (string, error)
- func (w *Wallet) AccountExtendedPublicKey(args ExtendedKeyArgs) (string, error)
- func (w *Wallet) DeriveBlindingKeyPair(args DeriveBlindingKeyPairArgs) (*btcec.PrivateKey, *btcec.PublicKey, error)
- func (w *Wallet) DeriveConfidentialAddress(args DeriveConfidentialAddressArgs) (string, []byte, error)
- func (w *Wallet) DeriveSigningKeyPair(args DeriveSigningKeyPairArgs) (*btcec.PrivateKey, *btcec.PublicKey, error)
- func (w *Wallet) MasterBlindingKey() (string, error)
- func (w *Wallet) Mnemonic() ([]string, error)
- func (w *Wallet) SignPset(args SignPsetArgs) (string, error)
- func (w *Wallet) SignTransaction(args SignTransactionArgs) (string, error)
Constants ¶
This section is empty.
Variables ¶
var ( ErrMissingNetwork = fmt.Errorf("missing network") ErrMissingMnemonic = fmt.Errorf("missing mnemonic") ErrMissingSigningMasterKey = fmt.Errorf("missing signing master key") ErrMissingBlindingMasterKey = fmt.Errorf("missing blinding master key") ErrMissingDerivationPath = fmt.Errorf("missing derivation path") ErrMissingOutputScript = fmt.Errorf("missing output script") ErrMissingPset = fmt.Errorf("missing pset base64") ErrMissingDerivationPaths = fmt.Errorf("missing derivation path map") ErrInvalidMnemonic = fmt.Errorf("blinding mnemonic is invalid") ErrInvalidRootPathLen = fmt.Errorf("invalid root path length, must be in the form \"m/purpose'/coin_type'\"") ErrInvalidRootPath = fmt.Errorf("root path must contain only hardended values") ErrRequiredAbsoluteDerivationPath = fmt.Errorf("path must be an absolute derivation starting with 'm/'") ErrInvalidDerivationPathLength = fmt.Errorf("derivation path must be a relative path in the form \"account'/branch/index\"") ErrInvalidDerivationPathAccount = fmt.Errorf("derivation path's account (first elem) must be hardened (suffix ')") ErrInvalidSignatures = fmt.Errorf("transaction contains invalid signature(s)") ErrMalformedDerivationPath = fmt.Errorf("path must not start or end with a '/'") ErrOutOfRangeDerivationPathAccount = fmt.Errorf("account index must be in hardened range [0', %d']", hdkeychain.HardenedKeyStart-1) ErrMissingPrevOuts = fmt.Errorf("missing prevouts") ErrMissingInputs = fmt.Errorf("at least one input is mandatory to create a partial transaction with one or more confidential outputs") ErrMissingOwnedInputs = fmt.Errorf("missing list of owned inputs") ErrBlindInvalidInputIndex = fmt.Errorf("input index to blind is out of range") ErrMissingRootPath = fmt.Errorf("missing root derivation path") )
Functions ¶
This section is empty.
Types ¶
type DeriveBlindingKeyPairArgs ¶
type DeriveBlindingKeyPairArgs struct {
Script []byte
}
type DeriveSigningKeyPairArgs ¶
type DeriveSigningKeyPairArgs struct {
DerivationPath string
}
type ExtendedKeyArgs ¶
type ExtendedKeyArgs struct {
Account uint32
}
type NewWalletArgs ¶
type NewWalletArgs struct {
RootPath string
}
type SignPsetArgs ¶
type SignPsetArgs struct { PsetBase64 string DerivationPathMap map[string]string SigHashType txscript.SigHashType }
type SignTransactionArgs ¶
type Wallet ¶
type Wallet struct {
// contains filtered or unexported fields
}
Wallet is the data structure representing an HD wallet of an Elements based network.
func NewWallet ¶
func NewWallet(args NewWalletArgs) (*Wallet, error)
NewWallet creates a new HD wallet with a random mnemonic
func NewWalletFromMnemonic ¶
func NewWalletFromMnemonic(args NewWalletFromMnemonicArgs) (*Wallet, error)
NewWalletFromMnemonic creates a new HD wallet with the given mnemonic seed and root path
func (*Wallet) AccountExtendedPrivateKey ¶
func (w *Wallet) AccountExtendedPrivateKey(args ExtendedKeyArgs) (string, error)
AccountExtendedPrivateKey returns the extended private key in base58 format for the given account index.
func (*Wallet) AccountExtendedPublicKey ¶
func (w *Wallet) AccountExtendedPublicKey(args ExtendedKeyArgs) (string, error)
AccountExtendedPublicKey returns the extended public key in base58 format for the given account index.
func (*Wallet) DeriveBlindingKeyPair ¶
func (w *Wallet) DeriveBlindingKeyPair( args DeriveBlindingKeyPairArgs, ) (*btcec.PrivateKey, *btcec.PublicKey, error)
DeriveBlindingKeyPair derives the SLIP77 blinding key pair from the given output script.
func (*Wallet) DeriveConfidentialAddress ¶
func (w *Wallet) DeriveConfidentialAddress( args DeriveConfidentialAddressArgs, ) (string, []byte, error)
DeriveConfidentialAddress derives both the HD signing and the SLIP-77 blinding key-pairs to generate a confidential address.
func (*Wallet) DeriveSigningKeyPair ¶
func (w *Wallet) DeriveSigningKeyPair(args DeriveSigningKeyPairArgs) ( *btcec.PrivateKey, *btcec.PublicKey, error, )
DeriveSigningKeyPair derives the key pair from the given derivation path.
func (*Wallet) MasterBlindingKey ¶
MasterBlindingKey returns the SLIP-77 master blinding key of the wallet in hex format.
func (*Wallet) SignPset ¶
func (w *Wallet) SignPset(args SignPsetArgs) (string, error)
SignPset signs all inputs of a partial transaction matching the given scripts of the derivation path map.
func (*Wallet) SignTransaction ¶
func (w *Wallet) SignTransaction(args SignTransactionArgs) (string, error)
SignTransaction signs all requested inputs of the given raw transaction.