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 23:15:10 +01: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-03-21 21:44:24 +01:00
|
|
|
// SignatureInner is now the interface itself.
|
|
|
|
// Use Signature in all code
|
|
|
|
type SignatureInner interface {
|
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
|
2015-10-25 13:42:49 -07:00
|
|
|
}
|
|
|
|
|
2017-02-22 23:15:10 +01:00
|
|
|
var sigMapper data.Mapper
|
|
|
|
|
|
|
|
// register both public key types with go-data (and thus go-wire)
|
|
|
|
func init() {
|
2017-03-21 21:44:24 +01:00
|
|
|
sigMapper = data.NewMapper(Signature{}).
|
2017-03-21 21:13:50 +01:00
|
|
|
RegisterImplementation(SignatureEd25519{}, NameEd25519, TypeEd25519).
|
|
|
|
RegisterImplementation(SignatureSecp256k1{}, NameSecp256k1, TypeSecp256k1)
|
2017-02-22 23:15:10 +01:00
|
|
|
}
|
|
|
|
|
2017-03-21 21:44:24 +01:00
|
|
|
// Signature add json serialization to Signature
|
|
|
|
type Signature struct {
|
2017-03-22 15:59:00 +01:00
|
|
|
SignatureInner `json:"unwrap"`
|
2017-02-22 23:15:10 +01:00
|
|
|
}
|
|
|
|
|
2017-03-21 21:44:24 +01:00
|
|
|
func WrapSignature(pk SignatureInner) Signature {
|
|
|
|
if wrap, ok := pk.(Signature); ok {
|
|
|
|
pk = wrap.Unwrap()
|
2017-03-19 17:56:33 +01:00
|
|
|
}
|
2017-03-21 21:44:24 +01:00
|
|
|
return Signature{pk}
|
2017-03-19 17:56:33 +01:00
|
|
|
}
|
|
|
|
|
2017-03-21 21:44:24 +01:00
|
|
|
func (p Signature) Unwrap() SignatureInner {
|
|
|
|
pk := p.SignatureInner
|
|
|
|
for wrap, ok := pk.(Signature); ok; wrap, ok = pk.(Signature) {
|
|
|
|
pk = wrap.SignatureInner
|
|
|
|
}
|
|
|
|
return pk
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p Signature) MarshalJSON() ([]byte, error) {
|
|
|
|
return sigMapper.ToJSON(p.SignatureInner)
|
2017-02-22 23:15:10 +01:00
|
|
|
}
|
|
|
|
|
2017-03-21 21:44:24 +01:00
|
|
|
func (p *Signature) UnmarshalJSON(data []byte) (err error) {
|
2017-02-22 23:15:10 +01:00
|
|
|
parsed, err := sigMapper.FromJSON(data)
|
2017-02-23 18:11:20 +01:00
|
|
|
if err == nil && parsed != nil {
|
2017-03-21 21:44:24 +01:00
|
|
|
p.SignatureInner = parsed.(SignatureInner)
|
2017-02-22 23:15:10 +01:00
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
2015-10-25 13:42:49 -07:00
|
|
|
|
2017-03-21 21:44:24 +01:00
|
|
|
func (p Signature) Empty() bool {
|
|
|
|
return p.SignatureInner == nil
|
2017-02-23 15:35:04 +01:00
|
|
|
}
|
|
|
|
|
2016-04-21 18:05:15 -07:00
|
|
|
func SignatureFromBytes(sigBytes []byte) (sig Signature, err error) {
|
|
|
|
err = wire.ReadBinaryBytes(sigBytes, &sig)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2015-10-25 13:42:49 -07:00
|
|
|
//-------------------------------------
|
|
|
|
|
|
|
|
// Implements Signature
|
|
|
|
type SignatureEd25519 [64]byte
|
|
|
|
|
2016-03-22 15:21:18 -07:00
|
|
|
func (sig SignatureEd25519) Bytes() []byte {
|
2017-03-21 21:44:24 +01:00
|
|
|
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 {
|
2017-03-21 21:44:24 +01:00
|
|
|
if otherEd, ok := other.Unwrap().(SignatureEd25519); ok {
|
2016-07-24 13:21:57 -07:00
|
|
|
return bytes.Equal(sig[:], otherEd[:])
|
|
|
|
} else {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-22 23:15:10 +01:00
|
|
|
func (p SignatureEd25519) MarshalJSON() ([]byte, error) {
|
|
|
|
return data.Encoder.Marshal(p[:])
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *SignatureEd25519) UnmarshalJSON(enc []byte) error {
|
|
|
|
var ref []byte
|
|
|
|
err := data.Encoder.Unmarshal(&ref, enc)
|
|
|
|
copy(p[:], ref)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2016-04-19 01:02:31 -07:00
|
|
|
//-------------------------------------
|
|
|
|
|
|
|
|
// Implements Signature
|
2017-02-22 23:43:26 +01:00
|
|
|
type SignatureSecp256k1 []byte
|
2016-04-19 01:02:31 -07:00
|
|
|
|
|
|
|
func (sig SignatureSecp256k1) Bytes() []byte {
|
2017-03-21 21:44:24 +01:00
|
|
|
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 {
|
2017-03-21 21:44:24 +01:00
|
|
|
if otherEd, ok := other.Unwrap().(SignatureSecp256k1); ok {
|
2016-07-24 13:21:57 -07:00
|
|
|
return bytes.Equal(sig[:], otherEd[:])
|
|
|
|
} else {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
2017-02-22 23:43:26 +01:00
|
|
|
func (p SignatureSecp256k1) MarshalJSON() ([]byte, error) {
|
|
|
|
return data.Encoder.Marshal(p)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (p *SignatureSecp256k1) UnmarshalJSON(enc []byte) error {
|
|
|
|
return data.Encoder.Unmarshal((*[]byte)(p), enc)
|
|
|
|
}
|