|
|
- package account
-
- import (
- "errors"
- "io"
- "reflect"
-
- "github.com/tendermint/go-ed25519"
- . "github.com/tendermint/tendermint/binary"
- . "github.com/tendermint/tendermint/common"
- )
-
- // PrivKey is part of PrivAccount and state.PrivValidator.
- type PrivKey interface {
- Sign(msg []byte) Signature
- }
-
- // Types of PrivKey implementations
- const (
- PrivKeyTypeEd25519 = byte(0x01)
- )
-
- //-------------------------------------
- // For binary.readReflect
-
- func PrivKeyDecoder(r io.Reader, n *int64, err *error) interface{} {
- switch t := ReadByte(r, n, err); t {
- case PrivKeyTypeEd25519:
- return ReadBinary(&PrivKeyEd25519{}, r, n, err)
- default:
- *err = Errorf("Unknown PrivKey type %X", t)
- return nil
- }
- }
-
- var _ = RegisterType(&TypeInfo{
- Type: reflect.TypeOf((*PrivKey)(nil)).Elem(),
- Decoder: PrivKeyDecoder,
- })
-
- //-------------------------------------
-
- // Implements PrivKey
- type PrivKeyEd25519 struct {
- PubKey []byte
- PrivKey []byte
- }
-
- func (key PrivKeyEd25519) TypeByte() byte { return PrivKeyTypeEd25519 }
-
- func (key PrivKeyEd25519) ValidateBasic() error {
- if len(key.PubKey) != ed25519.PublicKeySize {
- return errors.New("Invalid PrivKeyEd25519 pubkey size")
- }
- if len(key.PrivKey) != ed25519.PrivateKeySize {
- return errors.New("Invalid PrivKeyEd25519 privkey size")
- }
- return nil
- }
-
- func (key PrivKeyEd25519) Sign(msg []byte) Signature {
- signature := ed25519.SignMessage(msg, key.PrivKey, key.PubKey)
- return SignatureEd25519{signature}
- }
|