signing

package
v4.1.0+incompatible Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 17, 2018 License: Apache-2.0 Imports: 12 Imported by: 45

Documentation

Index

Constants

View Source
const (

	// Hardened denotes a hardened key derivation.
	Hardened = true

	// NonHardened denotes a non-hardened key derivation.
	NonHardened = false
)

Variables

This section is empty.

Functions

This section is empty.

Types

type AbsoluteKeypath

type AbsoluteKeypath keypath

AbsoluteKeypath models an absolute keypath according to BIP32.

func NewAbsoluteKeypath

func NewAbsoluteKeypath(input string) (AbsoluteKeypath, error)

NewAbsoluteKeypath creates a new absolute keypath from a string like `m/44'/1'`.

func NewEmptyAbsoluteKeypath

func NewEmptyAbsoluteKeypath() AbsoluteKeypath

NewEmptyAbsoluteKeypath creates a new empty absolute keypath.

func (AbsoluteKeypath) Append

func (absoluteKeypath AbsoluteKeypath) Append(suffix RelativeKeypath) AbsoluteKeypath

Append appends a relative keypath to this absolute keypath.

func (AbsoluteKeypath) Child

func (absoluteKeypath AbsoluteKeypath) Child(index uint32, hardened bool) AbsoluteKeypath

Child appends the given node to this absolute keypath.

func (AbsoluteKeypath) Derive

func (absoluteKeypath AbsoluteKeypath) Derive(
	extendedKey *hdkeychain.ExtendedKey,
) (*hdkeychain.ExtendedKey, error)

Derive derives the extended key at this path from the given extended key.

func (AbsoluteKeypath) Encode

func (absoluteKeypath AbsoluteKeypath) Encode() string

Encode encodes the absolute keypath as a string.

func (AbsoluteKeypath) MarshalJSON

func (absoluteKeypath AbsoluteKeypath) MarshalJSON() ([]byte, error)

MarshalJSON implements json.Marshaler.

func (*AbsoluteKeypath) UnmarshalJSON

func (absoluteKeypath *AbsoluteKeypath) UnmarshalJSON(bytes []byte) error

UnmarshalJSON implements json.Unmarshaler.

type Configuration

type Configuration struct {
	// contains filtered or unexported fields
}

Configuration models a signing configuration, which can be singlesig or multisig.

func NewConfiguration

func NewConfiguration(
	scriptType ScriptType,
	absoluteKeypath AbsoluteKeypath,
	extendedPublicKeys []*hdkeychain.ExtendedKey,
	signingThreshold int,
) *Configuration

NewConfiguration creates a new configuration. At the moment, multisig is a predefined multisig-P2SH script, and is active if there are more than one xpubs. Otherwise, it's single sig and `scriptType` defines the type of script.

func NewSinglesigConfiguration

func NewSinglesigConfiguration(
	scriptType ScriptType,
	absoluteKeypath AbsoluteKeypath,
	extendedPublicKey *hdkeychain.ExtendedKey,
) *Configuration

NewSinglesigConfiguration creates a new singlesig configuration.

func (*Configuration) AbsoluteKeypath

func (configuration *Configuration) AbsoluteKeypath() AbsoluteKeypath

AbsoluteKeypath returns the configuration's keypath.

func (*Configuration) Derive

func (configuration *Configuration) Derive(relativeKeypath RelativeKeypath) (*Configuration, error)

Derive derives a subkeypath from the configuration's base absolute keypath.

func (*Configuration) ExtendedPublicKeys

func (configuration *Configuration) ExtendedPublicKeys() []*hdkeychain.ExtendedKey

ExtendedPublicKeys returns the configuration's extended public keys.

func (*Configuration) Hash

func (configuration *Configuration) Hash() string

Hash returns a hash of the configuration.

func (Configuration) MarshalJSON

func (configuration Configuration) MarshalJSON() ([]byte, error)

MarshalJSON implements json.Marshaler.

func (*Configuration) Multisig

func (configuration *Configuration) Multisig() bool

Multisig returns whether this is a multisig configuration.

func (*Configuration) NumberOfSigners

func (configuration *Configuration) NumberOfSigners() int

NumberOfSigners returns the number of signers (1 in single sig, N in a M/N multisig).

func (*Configuration) PublicKeys

func (configuration *Configuration) PublicKeys() []*btcec.PublicKey

PublicKeys returns the configuration's public keys.

func (*Configuration) ScriptType

func (configuration *Configuration) ScriptType() ScriptType

ScriptType returns the configuration's keypath.

func (*Configuration) SigningThreshold

func (configuration *Configuration) SigningThreshold() int

SigningThreshold returns the signing threshold in case of a multisig config.

func (*Configuration) Singlesig

func (configuration *Configuration) Singlesig() bool

Singlesig returns whether this is a singlesig configuration.

func (*Configuration) SortedPublicKeys

func (configuration *Configuration) SortedPublicKeys() []*btcec.PublicKey

SortedPublicKeys returns the configuration's public keys sorted in compressed form.

func (*Configuration) String

func (configuration *Configuration) String() string

String returns a short summary of the configuration to be used in logs, etc.

func (*Configuration) UnmarshalJSON

func (configuration *Configuration) UnmarshalJSON(bytes []byte) error

UnmarshalJSON implements json.Unmarshaler.

type RelativeKeypath

type RelativeKeypath keypath

RelativeKeypath models a relative keypath according to BIP32.

func NewEmptyRelativeKeypath

func NewEmptyRelativeKeypath() RelativeKeypath

NewEmptyRelativeKeypath creates a new empty relative keypath.

func NewRelativeKeypath

func NewRelativeKeypath(input string) (RelativeKeypath, error)

NewRelativeKeypath creates a new relative keypath from a string like `1/2'/3`.

func (RelativeKeypath) Child

func (relativeKeypath RelativeKeypath) Child(index uint32, hardened bool) RelativeKeypath

Child appends the given node to this relative keypath.

func (RelativeKeypath) Derive

func (relativeKeypath RelativeKeypath) Derive(
	extendedKey *hdkeychain.ExtendedKey,
) (*hdkeychain.ExtendedKey, error)

Derive derives the extended key at this path from the given extended key.

func (RelativeKeypath) Encode

func (relativeKeypath RelativeKeypath) Encode() string

Encode encodes the relative keypath as a string.

func (RelativeKeypath) Hardened

func (relativeKeypath RelativeKeypath) Hardened() bool

Hardened returns whether the keypath contains a hardened derivation.

type ScriptType

type ScriptType string

ScriptType indicates which type of output should be produced in case of singlesig.

const (
	// ScriptTypeP2PKH is a PayToPubKeyHash output.
	ScriptTypeP2PKH ScriptType = "p2pkh"

	// ScriptTypeP2WPKHP2SH is a segwit PayToPubKeyHash output wrapped in p2sh.
	ScriptTypeP2WPKHP2SH ScriptType = "p2wpkh-p2sh"

	// ScriptTypeP2WPKH is a segwit PayToPubKeyHash output.
	ScriptTypeP2WPKH ScriptType = "p2wpkh"
)

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL