Documentation ¶
Index ¶
Constants ¶
const ( EcdsaRLen = 32 EcdsaSLen = 32 EcdsaMsgLen = 32 )
The Ecdsa signature is the couple (R, S), both R and S are 32 bytes
const EcdsaSignatureLen = 64
EcdsaSignatureLen is 64 bytes
const PrivKeyBytesLen = 32
PrivKeyBytesLen are 32-bytes for all supported curvetypes
Variables ¶
var ( ErrPrivKeyUndecodable = errors.New("could not decode privkey") ErrPrivKeyLengthInvalid = errors.New("invalid privkey length") ErrPrivKeyZero = errors.New("privkey cannot be 0") ErrPubKeyNotOnCurve = errors.New("pubkey is not on the curve") ErrCurveTypeNotSupported = errors.New("not a supported CurveType") ErrSignUnsupportedPayloadSignatureType = errors.New( "sign: unexpected payload.SignatureType while signing", ) ErrSignUnsupportedSignatureType = errors.New( "sign: unexpected Signature type while signing", ) ErrVerifyUnsupportedPayloadSignatureType = errors.New( "verify: unexpected payload.SignatureType while verifying", ) ErrVerifyUnsupportedSignatureType = errors.New( "verify: unexpected Signature type while verifying", ) ErrVerifyFailed = errors.New("verify: verify returned false") ErrPaymentNotFound = errors.New("payment not found in signingPayload") )
Named error types for Keys errors
var ErrPallasTransactionValidationErr = errors.New("transaction with pallas validation failed")
Functions ¶
func Err ¶
Err takes an error as an argument and returns whether or not the error is one thrown by the keys package
func ParseSigningPayload ¶
func ParseSigningPayload(rawPayload *types.SigningPayload) (*mina.Transaction, error)
Types ¶
type KeyPair ¶
type KeyPair struct { PublicKey *types.PublicKey `json:"public_key"` PrivateKey []byte `json:"private_key"` }
KeyPair contains a PrivateKey and its associated PublicKey
func GenerateKeypair ¶
GenerateKeypair returns a Keypair of a specified CurveType
func ImportPrivateKey ¶
ImportPrivateKey returns a Keypair from a hex-encoded privkey string
func (*KeyPair) MarshalJSON ¶
MarshalJSON overrides the default JSON marshaler and encodes bytes as hex instead of base64.
func (*KeyPair) UnmarshalJSON ¶
UnmarshalJSON overrides the default JSON unmarshaler and decodes bytes from hex instead of base64.
type PayloadFields ¶
type Signer ¶
type Signer interface { PublicKey() *types.PublicKey Sign(payload *types.SigningPayload, sigType types.SignatureType) (*types.Signature, error) Verify(signature *types.Signature) error }
Signer is an interface for different curve signers
type SignerEdwards25519 ¶
type SignerEdwards25519 struct {
KeyPair *KeyPair
}
SignerEdwards25519 is initialized from a keypair
func (*SignerEdwards25519) PublicKey ¶
func (s *SignerEdwards25519) PublicKey() *types.PublicKey
PublicKey returns the PublicKey of the signer
func (*SignerEdwards25519) Sign ¶
func (s *SignerEdwards25519) Sign( payload *types.SigningPayload, sigType types.SignatureType, ) (*types.Signature, error)
Sign arbitrary payloads using a KeyPair
type SignerPallas ¶
type SignerPallas struct {
KeyPair *KeyPair
}
func (*SignerPallas) PublicKey ¶
func (s *SignerPallas) PublicKey() *types.PublicKey
func (*SignerPallas) Sign ¶
func (s *SignerPallas) Sign( payload *types.SigningPayload, sigType types.SignatureType, ) (*types.Signature, error)
Sign transaction payloads using a KeyPair
type SignerSecp256k1 ¶
type SignerSecp256k1 struct {
KeyPair *KeyPair
}
SignerSecp256k1 is initialized from a keypair
func (*SignerSecp256k1) PublicKey ¶
func (s *SignerSecp256k1) PublicKey() *types.PublicKey
PublicKey returns the PublicKey of the signer
func (*SignerSecp256k1) Sign ¶
func (s *SignerSecp256k1) Sign( payload *types.SigningPayload, sigType types.SignatureType, ) (*types.Signature, error)
Sign arbitrary payloads using a KeyPair
type SignerSecp256r1 ¶
type SignerSecp256r1 struct {
KeyPair *KeyPair
}
SignerSecp256r1 is initialized from a keypair
func (*SignerSecp256r1) PublicKey ¶
func (s *SignerSecp256r1) PublicKey() *types.PublicKey
PublicKey returns the PublicKey of the signer
func (*SignerSecp256r1) Sign ¶
func (s *SignerSecp256r1) Sign( payload *types.SigningPayload, sigType types.SignatureType, ) (*types.Signature, error)
Sign arbitrary payloads using a KeyPair with specific sigType. Currently, we only support sigType types.Ecdsa for secp256r1 and the signature format is R || S.
type SigningPayload ¶
type SigningPayload struct {
Payment *PayloadFields `json:"payment"`
}