package crypto import ( "bytes" "fmt" . "github.com/tendermint/go-common" data "github.com/tendermint/go-data" "github.com/tendermint/go-wire" ) func SignatureFromBytes(sigBytes []byte) (sig Signature, err error) { err = wire.ReadBinaryBytes(sigBytes, &sig) return } //---------------------------------------- type Signature struct { SignatureInner `json:"unwrap"` } // DO NOT USE THIS INTERFACE. // You probably want to use Signature. type SignatureInner interface { AssertIsSignatureInner() Bytes() []byte IsZero() bool String() string Equals(Signature) bool Wrap() Signature } func (sig Signature) MarshalJSON() ([]byte, error) { return sigMapper.ToJSON(sig.SignatureInner) } func (sig *Signature) UnmarshalJSON(data []byte) (err error) { parsed, err := sigMapper.FromJSON(data) if err == nil && parsed != nil { sig.SignatureInner = parsed.(SignatureInner) } return } // Unwrap recovers the concrete interface safely (regardless of levels of embeds) func (sig Signature) Unwrap() SignatureInner { pk := sig.SignatureInner for wrap, ok := pk.(Signature); ok; wrap, ok = pk.(Signature) { pk = wrap.SignatureInner } return pk } func (sig Signature) Empty() bool { return sig.SignatureInner == nil } var sigMapper = data.NewMapper(Signature{}). RegisterImplementation(SignatureEd25519{}, NameEd25519, TypeEd25519). RegisterImplementation(SignatureSecp256k1{}, NameSecp256k1, TypeSecp256k1) //------------------------------------- var _ SignatureInner = SignatureEd25519{} // Implements Signature type SignatureEd25519 [64]byte func (sig SignatureEd25519) AssertIsSignatureInner() {} func (sig SignatureEd25519) Bytes() []byte { return wire.BinaryBytes(Signature{sig}) } func (sig SignatureEd25519) IsZero() bool { return len(sig) == 0 } func (sig SignatureEd25519) String() string { return fmt.Sprintf("/%X.../", Fingerprint(sig[:])) } func (sig SignatureEd25519) Equals(other Signature) bool { if otherEd, ok := other.Unwrap().(SignatureEd25519); ok { return bytes.Equal(sig[:], otherEd[:]) } else { return false } } func (sig SignatureEd25519) MarshalJSON() ([]byte, error) { return data.Encoder.Marshal(sig[:]) } func (sig *SignatureEd25519) UnmarshalJSON(enc []byte) error { var ref []byte err := data.Encoder.Unmarshal(&ref, enc) copy(sig[:], ref) return err } func (sig SignatureEd25519) Wrap() Signature { return Signature{sig} } //------------------------------------- var _ SignatureInner = SignatureSecp256k1{} // Implements Signature type SignatureSecp256k1 []byte func (sig SignatureSecp256k1) AssertIsSignatureInner() {} func (sig SignatureSecp256k1) Bytes() []byte { return wire.BinaryBytes(Signature{sig}) } func (sig SignatureSecp256k1) IsZero() bool { return len(sig) == 0 } func (sig SignatureSecp256k1) String() string { return fmt.Sprintf("/%X.../", Fingerprint(sig[:])) } func (sig SignatureSecp256k1) Equals(other Signature) bool { if otherEd, ok := other.Unwrap().(SignatureSecp256k1); ok { return bytes.Equal(sig[:], otherEd[:]) } else { return false } } func (sig SignatureSecp256k1) MarshalJSON() ([]byte, error) { return data.Encoder.Marshal(sig) } func (sig *SignatureSecp256k1) UnmarshalJSON(enc []byte) error { return data.Encoder.Unmarshal((*[]byte)(sig), enc) } func (sig SignatureSecp256k1) Wrap() Signature { return Signature{sig} }