tendermint/signature.go

134 lines
3.2 KiB
Go
Raw Normal View History

2015-10-25 13:45:13 -07:00
package crypto
2015-10-25 13:42:49 -07:00
import (
2016-07-24 13:21:57 -07:00
"bytes"
2015-10-25 13:42:49 -07:00
"fmt"
. "github.com/tendermint/go-common"
2017-02-22 14:15:10 -08:00
data "github.com/tendermint/go-data"
2015-10-25 13:45:13 -07:00
"github.com/tendermint/go-wire"
2015-10-25 13:42:49 -07:00
)
2017-04-09 00:32:54 -07:00
func SignatureFromBytes(sigBytes []byte) (sig Signature, err error) {
err = wire.ReadBinaryBytes(sigBytes, &sig)
return
}
2017-03-29 06:17:06 -07:00
2017-04-09 00:32:54 -07:00
//----------------------------------------
2017-03-29 06:17:06 -07:00
2017-04-09 00:32:54 -07:00
type Signature struct {
SignatureInner `json:"unwrap"`
}
// DO NOT USE THIS INTERFACE.
// You probably want to use Signature.
type SignatureInner interface {
2017-04-09 00:32:54 -07:00
AssertIsSignatureInner()
2016-03-22 15:21:18 -07:00
Bytes() []byte
2015-10-25 13:42:49 -07:00
IsZero() bool
String() string
2016-07-24 13:21:57 -07:00
Equals(Signature) bool
2017-04-09 00:32:54 -07:00
Wrap() Signature
2015-10-25 13:42:49 -07:00
}
2017-04-09 00:32:54 -07:00
func (sig Signature) MarshalJSON() ([]byte, error) {
return sigMapper.ToJSON(sig.SignatureInner)
2017-02-22 14:15:10 -08:00
}
2017-04-09 00:32:54 -07:00
func (sig *Signature) UnmarshalJSON(data []byte) (err error) {
parsed, err := sigMapper.FromJSON(data)
if err == nil && parsed != nil {
sig.SignatureInner = parsed.(SignatureInner)
}
2017-04-09 00:32:54 -07:00
return
}
2017-03-29 06:17:06 -07:00
// Unwrap recovers the concrete interface safely (regardless of levels of embeds)
2017-04-09 00:32:54 -07:00
func (sig Signature) Unwrap() SignatureInner {
pk := sig.SignatureInner
for wrap, ok := pk.(Signature); ok; wrap, ok = pk.(Signature) {
pk = wrap.SignatureInner
}
return pk
}
2017-04-09 00:32:54 -07:00
func (sig Signature) Empty() bool {
return sig.SignatureInner == nil
2017-02-22 14:15:10 -08:00
}
2015-10-25 13:42:49 -07:00
2017-04-09 00:32:54 -07:00
var sigMapper = data.NewMapper(Signature{}).
RegisterImplementation(SignatureEd25519{}, NameEd25519, TypeEd25519).
RegisterImplementation(SignatureSecp256k1{}, NameSecp256k1, TypeSecp256k1)
2016-04-21 18:05:15 -07:00
2015-10-25 13:42:49 -07:00
//-------------------------------------
// Implements Signature
type SignatureEd25519 [64]byte
2017-04-09 00:32:54 -07:00
func (sig SignatureEd25519) AssertIsSignatureInner() {}
2016-03-22 15:21:18 -07:00
func (sig SignatureEd25519) Bytes() []byte {
return wire.BinaryBytes(Signature{sig})
2016-03-22 15:21:18 -07:00
}
2015-10-25 13:42:49 -07:00
func (sig SignatureEd25519) IsZero() bool { return len(sig) == 0 }
func (sig SignatureEd25519) String() string { return fmt.Sprintf("/%X.../", Fingerprint(sig[:])) }
2016-04-19 01:02:31 -07:00
2016-07-24 13:21:57 -07:00
func (sig SignatureEd25519) Equals(other Signature) bool {
if otherEd, ok := other.Unwrap().(SignatureEd25519); ok {
2016-07-24 13:21:57 -07:00
return bytes.Equal(sig[:], otherEd[:])
} else {
return false
}
}
2017-04-09 00:32:54 -07:00
func (sig SignatureEd25519) MarshalJSON() ([]byte, error) {
return data.Encoder.Marshal(sig[:])
2017-02-22 14:15:10 -08:00
}
2017-04-09 00:32:54 -07:00
func (sig *SignatureEd25519) UnmarshalJSON(enc []byte) error {
2017-02-22 14:15:10 -08:00
var ref []byte
err := data.Encoder.Unmarshal(&ref, enc)
2017-04-09 00:32:54 -07:00
copy(sig[:], ref)
2017-02-22 14:15:10 -08:00
return err
}
2017-04-09 00:32:54 -07:00
func (sig SignatureEd25519) Wrap() Signature {
return Signature{sig}
}
2016-04-19 01:02:31 -07:00
//-------------------------------------
// Implements Signature
2017-02-22 14:43:26 -08:00
type SignatureSecp256k1 []byte
2016-04-19 01:02:31 -07:00
2017-04-09 00:32:54 -07:00
func (sig SignatureSecp256k1) AssertIsSignatureInner() {}
2016-04-19 01:02:31 -07:00
func (sig SignatureSecp256k1) Bytes() []byte {
return wire.BinaryBytes(Signature{sig})
2016-04-19 01:02:31 -07:00
}
func (sig SignatureSecp256k1) IsZero() bool { return len(sig) == 0 }
func (sig SignatureSecp256k1) String() string { return fmt.Sprintf("/%X.../", Fingerprint(sig[:])) }
2016-07-24 13:21:57 -07:00
func (sig SignatureSecp256k1) Equals(other Signature) bool {
if otherEd, ok := other.Unwrap().(SignatureSecp256k1); ok {
2016-07-24 13:21:57 -07:00
return bytes.Equal(sig[:], otherEd[:])
} else {
return false
}
}
2017-04-09 00:32:54 -07:00
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)
2017-02-22 14:43:26 -08:00
}
2017-04-09 00:32:54 -07:00
func (sig SignatureSecp256k1) Wrap() Signature {
return Signature{sig}
2017-02-22 14:43:26 -08:00
}