2020-01-04 03:51:53 +00:00
|
|
|
package keymanager
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
|
2020-03-03 16:21:58 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
2020-01-04 03:51:53 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/bls"
|
|
|
|
)
|
|
|
|
|
|
|
|
// ErrNoSuchKey is returned whenever a request is made for a key of which a key manager is unaware.
|
|
|
|
var ErrNoSuchKey = errors.New("no such key")
|
|
|
|
|
2020-02-03 17:13:58 +00:00
|
|
|
// ErrCannotSign is returned whenever a signing attempt fails.
|
|
|
|
var ErrCannotSign = errors.New("cannot sign")
|
|
|
|
|
2020-03-03 16:21:58 +00:00
|
|
|
// ErrCouldSlash is returned whenever a signing attempt is refused due to a potential slashing event.
|
|
|
|
var ErrCouldSlash = errors.New("could result in a slashing event")
|
|
|
|
|
2020-01-04 03:51:53 +00:00
|
|
|
// KeyManager controls access to private keys by the validator.
|
|
|
|
type KeyManager interface {
|
|
|
|
// FetchValidatingKeys fetches the list of public keys that should be used to validate with.
|
|
|
|
FetchValidatingKeys() ([][48]byte, error)
|
|
|
|
// Sign signs a message for the validator to broadcast.
|
|
|
|
Sign(pubKey [48]byte, root [32]byte, domain uint64) (*bls.Signature, error)
|
|
|
|
}
|
2020-03-03 16:21:58 +00:00
|
|
|
|
|
|
|
// ProtectingKeyManager provides access to a keymanager that protects its clients from slashing events.
|
|
|
|
type ProtectingKeyManager interface {
|
|
|
|
// SignProposal signs a block proposal for the validator to broadcast.
|
2020-03-09 13:08:30 +00:00
|
|
|
SignProposal(pubKey [48]byte, domain uint64, data *ethpb.BeaconBlockHeader) (*bls.Signature, error)
|
2020-03-03 16:21:58 +00:00
|
|
|
|
|
|
|
// SignAttestation signs an attestation for the validator to broadcast.
|
|
|
|
SignAttestation(pubKey [48]byte, domain uint64, data *ethpb.AttestationData) (*bls.Signature, error)
|
|
|
|
}
|