lotus/chain/types/signedmessage.go

79 lines
1.4 KiB
Go
Raw Normal View History

package types
import (
2019-08-21 17:15:28 +00:00
"bytes"
2020-02-12 23:52:36 +00:00
"github.com/filecoin-project/specs-actors/actors/crypto"
block "github.com/ipfs/go-block-format"
"github.com/ipfs/go-cid"
"github.com/multiformats/go-multihash"
)
func (m *SignedMessage) ToStorageBlock() (block.Block, error) {
2020-02-12 23:52:36 +00:00
if m.Signature.Type == crypto.SigTypeBLS {
2019-10-09 12:57:48 +00:00
return m.Message.ToStorageBlock()
}
data, err := m.Serialize()
if err != nil {
return nil, err
}
2019-08-21 17:15:28 +00:00
pref := cid.NewPrefixV1(cid.DagCBOR, multihash.BLAKE2B_MIN+31)
c, err := pref.Sum(data)
if err != nil {
return nil, err
}
return block.NewBlockWithCid(data, c)
}
func (m *SignedMessage) Cid() cid.Cid {
2020-02-12 23:52:36 +00:00
if m.Signature.Type == crypto.SigTypeBLS {
2019-08-16 22:10:34 +00:00
return m.Message.Cid()
}
sb, err := m.ToStorageBlock()
if err != nil {
panic(err)
}
return sb.Cid()
}
type SignedMessage struct {
Message Message
2020-02-12 23:52:36 +00:00
Signature crypto.Signature
}
func DecodeSignedMessage(data []byte) (*SignedMessage, error) {
var msg SignedMessage
2019-08-21 17:15:28 +00:00
if err := msg.UnmarshalCBOR(bytes.NewReader(data)); err != nil {
return nil, err
}
return &msg, nil
}
func (sm *SignedMessage) Serialize() ([]byte, error) {
2019-08-21 17:15:28 +00:00
buf := new(bytes.Buffer)
if err := sm.MarshalCBOR(buf); err != nil {
return nil, err
}
2019-08-21 17:15:28 +00:00
return buf.Bytes(), nil
}
2019-09-27 23:55:15 +00:00
func (sm *SignedMessage) Size() int {
serdata, err := sm.Serialize()
if err != nil {
log.Errorf("serializing message failed: %s", err)
return 0
}
return len(serdata)
}
2019-09-27 23:55:15 +00:00
func (sm *SignedMessage) VMMessage() *Message {
return &sm.Message
}