From 9a67bfac0b4a577f5fd313f8e883c5c0011b9e88 Mon Sep 17 00:00:00 2001 From: Roman Khimov Date: Sun, 19 Apr 2020 23:40:31 +0300 Subject: [PATCH] network: drop checksums from messages Follow neo-project/neo#710 changes. --- pkg/network/message.go | 38 +++++--------------------------------- 1 file changed, 5 insertions(+), 33 deletions(-) diff --git a/pkg/network/message.go b/pkg/network/message.go index a8bedc96c..9f029966d 100644 --- a/pkg/network/message.go +++ b/pkg/network/message.go @@ -1,15 +1,12 @@ package network import ( - "encoding/binary" - "errors" "fmt" "github.com/nspcc-dev/neo-go/pkg/config" "github.com/nspcc-dev/neo-go/pkg/consensus" "github.com/nspcc-dev/neo-go/pkg/core/block" "github.com/nspcc-dev/neo-go/pkg/core/transaction" - "github.com/nspcc-dev/neo-go/pkg/crypto/hash" "github.com/nspcc-dev/neo-go/pkg/io" "github.com/nspcc-dev/neo-go/pkg/network/payload" ) @@ -20,10 +17,6 @@ const ( cmdSize = 12 ) -var ( - errChecksumMismatch = errors.New("checksum mismatch") -) - // Message is the complete message send between nodes. type Message struct { // NetMode of the node that sends this message. @@ -36,10 +29,6 @@ type Message struct { // Length of the payload. Length uint32 - // Checksum is the first 4 bytes of the value that two times SHA256 - // hash of the payload. - Checksum uint32 - // Payload send with the message. Payload payload.Payload } @@ -74,8 +63,7 @@ const ( // NewMessage returns a new message with the given payload. func NewMessage(magic config.NetMode, cmd CommandType, p payload.Payload) *Message { var ( - size uint32 - checksum []byte + size uint32 ) if p != nil { @@ -86,17 +74,13 @@ func NewMessage(magic config.NetMode, cmd CommandType, p payload.Payload) *Messa } b := buf.Bytes() size = uint32(len(b)) - checksum = hash.Checksum(b) - } else { - checksum = hash.Checksum([]byte{}) } return &Message{ - Magic: magic, - Command: cmdToByteArray(cmd), - Length: size, - Payload: p, - Checksum: binary.LittleEndian.Uint32(checksum[:4]), + Magic: magic, + Command: cmdToByteArray(cmd), + Length: size, + Payload: p, } } @@ -152,7 +136,6 @@ func (m *Message) Decode(br *io.BinReader) error { m.Magic = config.NetMode(br.ReadU32LE()) br.ReadBytes(m.Command[:]) m.Length = br.ReadU32LE() - m.Checksum = br.ReadU32LE() if br.Err != nil { return br.Err } @@ -169,10 +152,6 @@ func (m *Message) decodePayload(br *io.BinReader) error { if br.Err != nil { return br.Err } - // Compare the checksum of the payload. - if !compareChecksum(m.Checksum, buf) { - return errChecksumMismatch - } r := io.NewBinReaderFromBuf(buf) var p payload.Payload @@ -215,7 +194,6 @@ func (m *Message) Encode(br *io.BinWriter) error { br.WriteU32LE(uint32(m.Magic)) br.WriteBytes(m.Command[:]) br.WriteU32LE(m.Length) - br.WriteU32LE(m.Checksum) if m.Payload != nil { m.Payload.EncodeBinary(br) @@ -264,9 +242,3 @@ func cmdByteArrayToString(cmd [cmdSize]byte) string { } return string(buf) } - -func compareChecksum(have uint32, b []byte) bool { - sum := hash.Checksum(b) - want := binary.LittleEndian.Uint32(sum) - return have == want -}