Documentation ¶
Index ¶
- Constants
- Variables
- func Decrypt(opts DecryptOpts) (string, error)
- func DeriveKey(passphrase, salt []byte) ([]byte, []byte, error)
- func Encrypt(opts EncryptOpts) (string, error)
- func FinalizeAndExtractTransaction(opts FinalizeAndExtractTransactionOpts) (string, string, error)
- func NewMnemonic(opts NewMnemonicOpts) ([]string, error)
- type BlindSwapTransactionOpts
- type BlindTransactionOpts
- type DecryptOpts
- type DerivationPath
- type DeriveBlindingKeyPairOpts
- type DeriveConfidentialAddressOpts
- type DeriveSigningKeyPairOpts
- type EncryptOpts
- type ExtendedKeyOpts
- type FinalizeAndExtractTransactionOpts
- type NewMnemonicOpts
- type NewWalletFromMnemonicOpts
- type NewWalletOpts
- type SignInputOpts
- type SignTransactionOpts
- type UpdateSwapTxOpts
- type UpdateTxOpts
- type UpdateTxResult
- type Wallet
- func (w *Wallet) BlindSwapTransaction(opts BlindSwapTransactionOpts) (string, error)
- func (w *Wallet) BlindTransaction(opts BlindTransactionOpts) (string, error)
- func (w *Wallet) BlindingMnemonic() ([]string, error)
- func (w *Wallet) CreateTx() (string, error)
- func (w *Wallet) DeriveBlindingKeyPair(opts DeriveBlindingKeyPairOpts) (*btcec.PrivateKey, *btcec.PublicKey, error)
- func (w *Wallet) DeriveConfidentialAddress(opts DeriveConfidentialAddressOpts) (string, []byte, error)
- func (w *Wallet) DeriveSigningKeyPair(opts DeriveSigningKeyPairOpts) (*btcec.PrivateKey, *btcec.PublicKey, error)
- func (w *Wallet) ExtendedPrivateKey(opts ExtendedKeyOpts) (string, error)
- func (w *Wallet) ExtendedPublicKey(opts ExtendedKeyOpts) (string, error)
- func (w *Wallet) SignInput(opts SignInputOpts) (string, error)
- func (w *Wallet) SignTransaction(opts SignTransactionOpts) (string, error)
- func (w *Wallet) SigningMnemonic() ([]string, error)
- func (w *Wallet) UpdateSwapTx(opts UpdateSwapTxOpts) (string, []explorer.Utxo, error)
- func (w *Wallet) UpdateTx(opts UpdateTxOpts) (*UpdateTxResult, error)
Constants ¶
const ( // MaxHardenedValue is the max value for hardened indexes of BIP32 // derivation paths MaxHardenedValue = math.MaxUint32 - hdkeychain.HardenedKeyStart // MinRelayFee is the minimum fee amount that the Liquid miners accept to // broadcast the transaction MinRelayFee = 650 )
Variables ¶
var ( // ErrNullNetwork ... ErrNullNetwork = errors.New("network must not be null") // ErrNullInputWitnessUtxo ... ErrNullInputWitnessUtxo = errors.New("input witness utxo must not be null") // ErrNullSigningMnemonic ... ErrNullSigningMnemonic = errors.New("signing mnemonic is null") // ErrNullBlindingMnemonic ... ErrNullBlindingMnemonic = errors.New("blinding mnemonic is null") // ErrNullSigningMasterKey ... ErrNullSigningMasterKey = errors.New("signing master key is null") // ErrNullBlindingMasterKey ... ErrNullBlindingMasterKey = errors.New("blinding master key is null") // ErrNullPassphrase ... ErrNullPassphrase = errors.New("passphrase must not be null") // ErrNullPlainText ... ErrNullPlainText = errors.New("text to encrypt must not be null") // ErrNullCypherText ... ErrNullCypherText = errors.New("cypher to decrypt must not be null") // ErrNullDerivationPath ... ErrNullDerivationPath = errors.New("derivation path must not be null") // ErrNullOutputDerivationPath ... ErrNullOutputDerivationPath = fmt.Errorf("output %v", ErrNullDerivationPath) // ErrNullChangeDerivationPath ... ErrNullChangeDerivationPath = fmt.Errorf("change %v", ErrNullDerivationPath) // ErrNullOutputScript ... ErrNullOutputScript = errors.New("output script must not be null") // ErrNullPset ... ErrNullPset = errors.New("pset base64 must not be null") // ErrNullChangePathsByAsset ... ErrNullChangePathsByAsset = errors.New( "derivation paths for eventual change(s) must not be null", ) // ErrInvalidSigningMnemonic ... ErrInvalidSigningMnemonic = errors.New("signing mnemonic is invalid") // ErrInvalidEntropySize ... ErrInvalidEntropySize = errors.New( "entropy size must be a multiple of 32 in the range [128,256]", ) // ErrInvalidBlindingMnemonic ... ErrInvalidBlindingMnemonic = errors.New("blinding mnemonic is invalid") // ErrInvalidCypherText ... ErrInvalidCypherText = errors.New("cypher must be in base64 format") // ErrInvalidDerivationPath ... ErrInvalidDerivationPath = errors.New("invalid derivation path") // ErrInvalidDerivationPathLength ... ErrInvalidDerivationPathLength = errors.New( "derivation path must be a relative path in the form \"account'/branch/index\"", ) // ErrInvalidDerivationPathAccount ... ErrInvalidDerivationPathAccount = errors.New( "derivation path's account (first elem) must be hardened (suffix \"'\")", ) // ErrInvalidInputAsset ... ErrInvalidInputAsset = errors.New("input asset must be a 32 byte array in hex format") // ErrInvalidOutputAsset ... ErrInvalidOutputAsset = errors.New("output asset must be a 32 byte array in hex format") // ErrInvalidOutputAddress ... ErrInvalidOutputAddress = errors.New("output address must be a valid address") // ErrInvalidChangeAddress ... ErrInvalidChangeAddress = errors.New("change address must be a valid address") // ErrInvalidMilliSatsPerBytes ... ErrInvalidMilliSatsPerBytes = errors.New("unit of mSats/byte must be at least 100 (0.1 sats/byte)") // ErrInvalidOutputBlindingKeysLen ... ErrInvalidOutputBlindingKeysLen = errors.New( "number of output blinding keys must match number of outputs", ) // ErrInvalidPassphrase ... ErrInvalidPassphrase = errors.New("passphrase provided is not correct") // ErrInvalidSignatures ... ErrInvalidSignatures = errors.New("transaction contains invalid signature(s)") // ErrEmptyDerivationPaths ... ErrEmptyDerivationPaths = errors.New("derivation path list must not be empty") // ErrEmptyUnspents ... ErrEmptyUnspents = errors.New("unspents list must not be empty") // ErrMalformedDerivationPath ... ErrMalformedDerivationPath = errors.New( "path must not start or end with a '/' and " + "can optionally start with 'm/' for absolute paths", ) // ErrOutOfRangeDerivationPathAccount ... ErrOutOfRangeDerivationPathAccount = fmt.Errorf( "account index must be in hardened range [0, %d]", MaxHardenedValue, ) // ErrZeroInputAmount ... ErrZeroInputAmount = errors.New("input amount must not be zero") // ErrZeroOutputAmount ... ErrZeroOutputAmount = errors.New("output amount must not be zero") )
var ( // DefaultBaseDerivationPath m/84'/0' DefaultBaseDerivationPath = DerivationPath{ hdkeychain.HardenedKeyStart + 84, hdkeychain.HardenedKeyStart + 0, } )
Functions ¶
func Decrypt ¶
func Decrypt(opts DecryptOpts) (string, error)
Decrypt decrypts (with AES-128) a cyphertext with the provided passphrase
func Encrypt ¶
func Encrypt(opts EncryptOpts) (string, error)
Encrypt encrypts (with AES-128) a plaintext with the provided passphrase
func FinalizeAndExtractTransaction ¶
func FinalizeAndExtractTransaction(opts FinalizeAndExtractTransactionOpts) (string, string, error)
FinalizeAndExtractTransaction attempts to finalize the provided partial transaction and eventually extracts the final transaction and returns it in hex string format, along with its transaction id
func NewMnemonic ¶
func NewMnemonic(opts NewMnemonicOpts) ([]string, error)
NewMnemonic returns a new mnemonic as a list of words
Types ¶
type BlindSwapTransactionOpts ¶
type BlindSwapTransactionOpts struct { PsetBase64 string InputBlindingKeys map[string][]byte OutputBlindingKeys map[string][]byte }
BlindSwapTransactionOpts is the struct given to BlindSwapTransaction method
type BlindTransactionOpts ¶
BlindTransactionOpts is the struct given to BlindTransaction method
type DecryptOpts ¶
DecryptOpts is the struct given to Decrypt method
type DerivationPath ¶
type DerivationPath []uint32
DerivationPath is the internal representation of a hierarchical deterministic wallet account
func ParseDerivationPath ¶
func ParseDerivationPath(strPath string) (DerivationPath, error)
ParseDerivationPath converts a derivation path string to the internal binary representation
func (DerivationPath) String ¶
func (path DerivationPath) String() string
String converts a binary derivation path to its canonical representation
type DeriveBlindingKeyPairOpts ¶
type DeriveBlindingKeyPairOpts struct {
Script []byte
}
DeriveBlindingKeyPairOpts is the struct given to DeriveBlindingKeyPair method
type DeriveConfidentialAddressOpts ¶
DeriveConfidentialAddressOpts is the struct given to DeriveConfidentialAddress method
type DeriveSigningKeyPairOpts ¶
type DeriveSigningKeyPairOpts struct {
DerivationPath string
}
DeriveSigningKeyPairOpts is the struct given to DeriveSigningKeyPair method
type EncryptOpts ¶
EncryptOpts is the struct given to Encrypt method
type ExtendedKeyOpts ¶
type ExtendedKeyOpts struct {
Account uint32
}
ExtendedKeyOpts is the struct given to ExtendedPrivateKey and ExtendedPublicKey methods
type FinalizeAndExtractTransactionOpts ¶
type FinalizeAndExtractTransactionOpts struct {
PsetBase64 string
}
FinalizeAndExtractTransactionOpts is the struct given to FinalizeAndExtractTransaction method
type NewMnemonicOpts ¶
type NewMnemonicOpts struct {
EntropySize int
}
type NewWalletFromMnemonicOpts ¶
NewWalletFromMnemonicOpts is the struct given to the NewWalletFromMnemonicOpts method
type NewWalletOpts ¶
type NewWalletOpts struct {
ExtraMnemonic bool
}
NewWalletOpts is the struct given to the NewWallet method
type SignInputOpts ¶
SignInputOpts is the struct given to SignInput method
type SignTransactionOpts ¶
SignTransactionOpts is the struct given to SignTransaction method
type UpdateSwapTxOpts ¶
type UpdateSwapTxOpts struct { PsetBase64 string Unspents []explorer.Utxo InputAmount uint64 InputAsset string OutputAmount uint64 OutputAsset string OutputDerivationPath string ChangeDerivationPath string Network *network.Network }
UpdateSwapTxOpts is the struct given to UpdateTx method
type UpdateTxOpts ¶
type UpdateTxOpts struct { PsetBase64 string Unspents []explorer.Utxo Outputs []*transaction.TxOutput ChangePathsByAsset map[string]string MilliSatsPerBytes int Network *network.Network WantPrivateBlindKeys bool WantChangeForFees bool }
UpdateTxOpts is the struct given to UpdateTx method
type UpdateTxResult ¶
type UpdateTxResult struct { PsetBase64 string SelectedUnspents []explorer.Utxo ChangeOutputsBlindingKeys map[string][]byte FeeAmount uint64 }
UpdateTxResult is the struct returned by UpdateTx method. PsetBase64: the updated partial transaction with new inputs and outputs SelectedUnspents: the list of unspents added as inputs to the pset ChangeOutptusBlindingKeys: the list of blinding keys for the evnutal
change(s) added to the pset
FeeAmount: the amount in satoshi of the fee amount that can added in a
second moment giving the user the possibility to eventually blind the pset first
type Wallet ¶
type Wallet struct {
// contains filtered or unexported fields
}
Wallet data structure allows to create a new wallet from seed/mnemonic, derive signing and blinding key pairs, and manage those keys to blind and sign transactions
func NewWallet ¶
func NewWallet(opts NewWalletOpts) (*Wallet, error)
NewWallet creates a new wallet holding signing/blinding mnemonic and seed
func NewWalletFromMnemonic ¶
func NewWalletFromMnemonic(opts NewWalletFromMnemonicOpts) (*Wallet, error)
NewWalletFromMnemonic generates the sigining and (optionally) blinding seeds from the corresponding mnemonics provided
func (*Wallet) BlindSwapTransaction ¶
func (w *Wallet) BlindSwapTransaction(opts BlindSwapTransactionOpts) (string, error)
BlindSwapTransaction blinds the outputs of a swap transaction. Since this type of transaciton is composed of inputs and outputs owned by 2 different parties, the blinding keys for inputs and outputs are provided through maps outputScript -> blinding key. Note that all the blinding keys provided must be private, thus for the outputs this function will use the provided blinding keys to get the list of all public keys. This of course also means that no blinding keys are derived internally, but these are all provided as function arguments.
func (*Wallet) BlindTransaction ¶
func (w *Wallet) BlindTransaction(opts BlindTransactionOpts) (string, error)
BlindTransaction blinds the outputs of the provided partial transaction by deriving the blinding keys from the output scripts following SLIP-77 spec
func (*Wallet) BlindingMnemonic ¶
BlindingMnemonic is getter for blinding mnemonic
func (*Wallet) DeriveBlindingKeyPair ¶
func (w *Wallet) DeriveBlindingKeyPair(opts DeriveBlindingKeyPairOpts) ( *btcec.PrivateKey, *btcec.PublicKey, error, )
DeriveBlindingKeyPair derives the SLIP77 blinding key pair from the provided output script
func (*Wallet) DeriveConfidentialAddress ¶
func (w *Wallet) DeriveConfidentialAddress( opts DeriveConfidentialAddressOpts, ) (string, []byte, error)
DeriveConfidentialAddress derives both the signing and blinding pubkeys to then generate the corresponding confidential address
func (*Wallet) DeriveSigningKeyPair ¶
func (w *Wallet) DeriveSigningKeyPair(opts DeriveSigningKeyPairOpts) ( *btcec.PrivateKey, *btcec.PublicKey, error, )
DeriveSigningKeyPair derives the key pair of the provided derivation path
func (*Wallet) ExtendedPrivateKey ¶
func (w *Wallet) ExtendedPrivateKey(opts ExtendedKeyOpts) (string, error)
ExtendedPrivateKey returns the signing extended private key in base58 format for the provided account index
func (*Wallet) ExtendedPublicKey ¶
func (w *Wallet) ExtendedPublicKey(opts ExtendedKeyOpts) (string, error)
ExtendedPublicKey returns the signing extended public key in base58 format for the provided account index
func (*Wallet) SignInput ¶
func (w *Wallet) SignInput(opts SignInputOpts) (string, error)
SignInput takes care of producing (and verifying) a signature for a specific input of a partial transaction with the provided private key
func (*Wallet) SignTransaction ¶
func (w *Wallet) SignTransaction(opts SignTransactionOpts) (string, error)
SignTransaction signs all inputs of a partial transaction using the keys derived with the help of the map script:derivation_path
func (*Wallet) SigningMnemonic ¶
SigningMnemonic is getter for signing mnemonic
func (*Wallet) UpdateSwapTx ¶
UpdateSwapTx takes care of adding inputs and output(s) to the provided partial transaction. Inputs are selected so that the minimum number of them is used to reach the target InputAmount. The subset of selected inputs is returned along with the updated partial transaction
func (*Wallet) UpdateTx ¶
func (w *Wallet) UpdateTx(opts UpdateTxOpts) (*UpdateTxResult, error)
UpdateTx adds the provided outputs and eventual inputs to the provided partial transaction. The assets of the inputs to add is determined by the assets of the provided outputs. For each assset type a derivation path for an eventual change must be provided. Its also mandatory to provide a derivation path for the LBTC asset type since this method takes care of adding inputs (if necessary) for covering the fee amount. While the list of outputs is required, the list of unspents is optional. In case it's not empty, a coin selection is performed for each type of asset, adding the eventual change output to the list of outputs to add to the tx. In the other case, only the outputs are added to the provided partial transaction.