Documentation ¶
Index ¶
- Constants
- Variables
- func NewKeyPairFromTendermint() (PublicKey, PrivateKey, error)
- type Address
- type Algorithm
- type MultiSig
- type MultiSigner
- type PrivateKey
- type PrivateKeyED25519
- type PrivateKeyHandler
- type PrivateKeySECP256K1
- type PublicKey
- type PublicKeyED25519
- type PublicKeyHandler
- type PublicKeySECP256K1
- type Signature
Constants ¶
const ( UNKNOWN Algorithm = iota ED25519 SECP256K1 ED25519_PUB_SIZE int = ed25519.PubKeyEd25519Size ED25519_PRIV_SIZE int = 64 SECP256K1_PUB_SIZE int = secp256k1.PubKeySecp256k1Size SECP256K1_PRIV_SIZE int = 32 )
Variables ¶
var ( ErrWrongPublicKeyAdapter = errors.New("error in asserting to PublicKey Addapter") ErrWrongPrivateKeyAdapter = errors.New("error in asserting to PrivateKey Addapter") ErrMissMsg = errors.New("miss message to sign") ErrMissSigners = errors.New("signers not specified") ErrInvalidThreshold = errors.New("invalid threshold") ErrNotExpectedSigner = errors.New("not expected signer") ErrInvalidSignedMsg = errors.New("invalid signed message") )
Functions ¶
func NewKeyPairFromTendermint ¶
func NewKeyPairFromTendermint() (PublicKey, PrivateKey, error)
Types ¶
type Address ¶
type Address []byte
Address to be used as to reference a key-pair.
func (Address) MarshalText ¶ added in v0.10.8
MarshalText returns the text form for an Address. It returns a byteslice containing the hex encoding of the address including the 0x prefix
func (*Address) UnmarshalText ¶ added in v0.10.8
UnmarshalText decodes the given text in a byteslice of characters, and works regardless of whether the 0x prefix is present or not.
type Algorithm ¶
type Algorithm int
func GetAlgorithmFromTmKeyName ¶ added in v0.10.4
func (Algorithm) MarshalText ¶ added in v0.10.8
func (*Algorithm) UnmarshalText ¶ added in v0.10.8
type MultiSig ¶ added in v0.11.0
type MultiSig struct { // message that need to be sign by this multisig Msg []byte //used for threshold signature where M represent the minimal signatures for the multisig to be valid // M is between (0, len(Signer)] // when M = len(Signer): need all signers to sign M int //the expected signers that need to sign for the message, the signers will be sorted in the slice. Signers []Address //the collection of signatures for signers, the index of signatures should match the index of signers. this should // be empty when created and before add Signature Signatures []Signature }
func (*MultiSig) AddSignature ¶ added in v0.11.0
type MultiSigner ¶ added in v0.11.0
type MultiSigner interface { //Initialize the MultiSig // "msg" that need to be sign by this multisig // "threshold" used for threshold signature representing the minimal signatures for the multisig to be valid // "signers" are the expected signers that need to sign for the message, the signers will be sorted in the slice. Init(msg []byte, threshold int, signers []Address) error // Add a signature to the MultiSig. Return error if the signature not satisfy: // - Valid s.PubKey in signature // - PubKey's address doesn't match signer address of s.Index // - Signed info is not the signature for message in the MultiSig AddSignature(s Signature) error // check MultiSig contains enough signature with threshold IsValid() bool // Return the bytes for the MultiSig, // the Bytes should include all info Bytes() []byte // Set MultiSig from []byte FromBytes(b []byte) error }
type PrivateKey ¶
func GetPrivateKeyFromBytes ¶
func GetPrivateKeyFromBytes(k []byte, algorithm Algorithm) (PrivateKey, error)
func NodeKeyFromTendermint ¶
func NodeKeyFromTendermint(key *p2p.NodeKey) (PrivateKey, error)
NodeKeyFromTendermint returns a PrivateKey from a tendermint NodeKey. The input key must be a ED25519 key.
func PVKeyFromTendermint ¶ added in v0.10.4
func PVKeyFromTendermint(key *privval.FilePVKey) (PrivateKey, error)
NodeKeyFromTendermint returns a PrivateKey from a tendermint NodeKey. The input key must be a ED25519 key.
func (PrivateKey) GetHandler ¶
func (privKey PrivateKey) GetHandler() (PrivateKeyHandler, error)
get the private key handler
func (*PrivateKey) GobDecode ¶
func (privKey *PrivateKey) GobDecode(buf []byte) error
func (*PrivateKey) GobEncode ¶
func (privKey *PrivateKey) GobEncode() ([]byte, error)
type PrivateKeyED25519 ¶
type PrivateKeyED25519 ed25519.PrivKeyEd25519
func (PrivateKeyED25519) Bytes ¶
func (k PrivateKeyED25519) Bytes() []byte
func (PrivateKeyED25519) Equals ¶
func (k PrivateKeyED25519) Equals(privkey PrivateKey) bool
func (PrivateKeyED25519) PubKey ¶
func (k PrivateKeyED25519) PubKey() PublicKey
type PrivateKeyHandler ¶
type PrivateKeySECP256K1 ¶
type PrivateKeySECP256K1 secp256k1.PrivKeySecp256k1
func (PrivateKeySECP256K1) Bytes ¶
func (k PrivateKeySECP256K1) Bytes() []byte
func (PrivateKeySECP256K1) Equals ¶
func (k PrivateKeySECP256K1) Equals(privkey PrivateKey) bool
func (PrivateKeySECP256K1) PubKey ¶
func (k PrivateKeySECP256K1) PubKey() PublicKey
type PublicKey ¶
Key Types
func GetPublicKeyFromBytes ¶
func PubKeyFromTendermint ¶ added in v0.12.0
func (PublicKey) GetABCIPubKey ¶
func (PublicKey) GetHandler ¶
func (pubKey PublicKey) GetHandler() (PublicKeyHandler, error)
Get the public key handler
type PublicKeyED25519 ¶
type PublicKeyED25519 struct {
// contains filtered or unexported fields
}
func (PublicKeyED25519) Address ¶
func (k PublicKeyED25519) Address() Address
Address hashes the key with a RIPEMD-160 hash
func (PublicKeyED25519) Bytes ¶
func (k PublicKeyED25519) Bytes() []byte
func (PublicKeyED25519) Equals ¶
func (k PublicKeyED25519) Equals(pubkey PublicKey) bool
func (PublicKeyED25519) String ¶
func (k PublicKeyED25519) String() string
func (PublicKeyED25519) VerifyBytes ¶
func (k PublicKeyED25519) VerifyBytes(msg []byte, sig []byte) bool
type PublicKeyHandler ¶
type PublicKeyHandler interface { Address() Address Bytes() []byte VerifyBytes(msg []byte, sig []byte) bool Equals(PublicKey) bool }
Interfaces
type PublicKeySECP256K1 ¶
type PublicKeySECP256K1 struct {
// contains filtered or unexported fields
}
func (PublicKeySECP256K1) Address ¶
func (k PublicKeySECP256K1) Address() Address
Address hashes the key with a RIPEMD-160 hash
func (PublicKeySECP256K1) Bytes ¶
func (k PublicKeySECP256K1) Bytes() []byte
func (PublicKeySECP256K1) Equals ¶
func (k PublicKeySECP256K1) Equals(PubkeySECP256K1 PublicKey) bool
func (PublicKeySECP256K1) String ¶
func (k PublicKeySECP256K1) String() string
func (PublicKeySECP256K1) VerifyBytes ¶
func (k PublicKeySECP256K1) VerifyBytes(msg []byte, sig []byte) bool