40 lines
1.1 KiB
Go
40 lines
1.1 KiB
Go
|
package filecoin
|
||
|
|
||
|
import (
|
||
|
"bytes"
|
||
|
|
||
|
"github.com/Secured-Finance/dione/consensus/validation"
|
||
|
rtypes "github.com/Secured-Finance/dione/rpc/types"
|
||
|
|
||
|
ftypes "github.com/Secured-Finance/dione/rpc/filecoin/types"
|
||
|
"github.com/Secured-Finance/dione/sigs"
|
||
|
"github.com/sirupsen/logrus"
|
||
|
"golang.org/x/xerrors"
|
||
|
)
|
||
|
|
||
|
func ValidateGetTransaction(payload []byte) error {
|
||
|
var msg ftypes.SignedMessage
|
||
|
if err := msg.UnmarshalCBOR(bytes.NewReader(payload)); err != nil {
|
||
|
if err := msg.Message.UnmarshalCBOR(bytes.NewReader(payload)); err != nil {
|
||
|
return xerrors.Errorf("cannot unmarshal payload")
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if msg.Type == ftypes.MessageTypeSecp256k1 {
|
||
|
if err := sigs.Verify(msg.Signature, msg.Message.From.Bytes(), msg.Message.Cid().Bytes()); err != nil {
|
||
|
logrus.Errorf("Couldn't verify transaction %v", err)
|
||
|
return xerrors.Errorf("Couldn't verify transaction: %v")
|
||
|
}
|
||
|
return nil
|
||
|
} else {
|
||
|
// TODO: BLS Signature verification
|
||
|
return nil
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func init() {
|
||
|
validation.RegisterValidation(rtypes.RPCTypeFilecoin, map[string]func([]byte) error{
|
||
|
"getTransaction": ValidateGetTransaction,
|
||
|
})
|
||
|
}
|