diff --git a/blockchain/msgs_test.go b/blockchain/msgs_test.go index a01ddf4936..80ff2c6b65 100644 --- a/blockchain/msgs_test.go +++ b/blockchain/msgs_test.go @@ -97,7 +97,7 @@ func TestBlockchainMessageVectors(t *testing.T) { BlockRequest: &bcproto.BlockRequest{Height: math.MaxInt64}}}, "0a0a08ffffffffffffffff7f"}, {"BlockResponseMessage", &bcproto.Message{Sum: &bcproto.Message_BlockResponse{ - BlockResponse: &bcproto.BlockResponse{Block: bpb}}}, "1ac0020abd020a5b0a02080b1803220b088092b8c398feffffff012a00380142204c149a7cfadc92b669b0cbfa4951a1b18c2d9f3177a3b8756d39ebb96e9d63317220e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b85512130a0b48656c6c6f20576f726c6412001a0022001ac8010a3000000000000000010000000000000001b81cb5596c28d044214b9f935e4af7dbe76e417f6182d86fbee68bfff7b2ff3a0a30ffffffffffffffffffffffffffffffffc4096ba8fccf882c309896e9168fa43fe62fccb752cb12d5160cc1d9c2ebffe7123000000000000000010000000000000001b81cb5596c28d044214b9f935e4af7dbe76e417f6182d86fbee68bfff7b2ff3a1230ffffffffffffffffffffffffffffffffc4096ba8fccf882c309896e9168fa43fe62fccb752cb12d5160cc1d9c2ebffe7"}, + BlockResponse: &bcproto.BlockResponse{Block: bpb}}}, "1ac2020abf020a5d0a02080b1803220b088092b8c398feffffff012a00320040014a204c149a7cfadc92b669b0cbfa4951a1b18c2d9f3177a3b8756d39ebb96e9d63317a20e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b85512130a0b48656c6c6f20576f726c6412001a0022001ac8010a3000000000000000010000000000000001b81cb5596c28d044214b9f935e4af7dbe76e417f6182d86fbee68bfff7b2ff3a0a30ffffffffffffffffffffffffffffffffc4096ba8fccf882c309896e9168fa43fe62fccb752cb12d5160cc1d9c2ebffe7123000000000000000010000000000000001b81cb5596c28d044214b9f935e4af7dbe76e417f6182d86fbee68bfff7b2ff3a1230ffffffffffffffffffffffffffffffffc4096ba8fccf882c309896e9168fa43fe62fccb752cb12d5160cc1d9c2ebffe7"}, {"NoBlockResponseMessage", &bcproto.Message{Sum: &bcproto.Message_NoBlockResponse{ NoBlockResponse: &bcproto.NoBlockResponse{Height: 1}}}, "12020801"}, {"NoBlockResponseMessage", &bcproto.Message{Sum: &bcproto.Message_NoBlockResponse{ diff --git a/evidence/verify_test.go b/evidence/verify_test.go index 1463c104f3..2cdedb707e 100644 --- a/evidence/verify_test.go +++ b/evidence/verify_test.go @@ -442,6 +442,7 @@ func makeHeaderRandom(height int64) *types.Header { Height: height, Time: defaultEvidenceTime, LastBlockID: makeBlockID([]byte("headerhash")), + LastPartSetHeader: makePartSetHeader(1000, []byte("partshash")), LastCommitHash: crypto.CRandBytes(tmhash.Size), DataHash: crypto.CRandBytes(tmhash.Size), ValidatorsHash: crypto.CRandBytes(tmhash.Size), diff --git a/proto/tendermint/types/canonical.pb.go b/proto/tendermint/types/canonical.pb.go index b058083ff5..f362c30feb 100644 --- a/proto/tendermint/types/canonical.pb.go +++ b/proto/tendermint/types/canonical.pb.go @@ -233,12 +233,13 @@ func (m *CanonicalProposal) GetPartSetHeader() *CanonicalPartSetHeader { } type CanonicalVote struct { - Type SignedMsgType `protobuf:"varint,1,opt,name=type,proto3,enum=tendermint.types.SignedMsgType" json:"type,omitempty"` - Height int64 `protobuf:"fixed64,2,opt,name=height,proto3" json:"height,omitempty"` - Round int64 `protobuf:"fixed64,3,opt,name=round,proto3" json:"round,omitempty"` - BlockID *CanonicalBlockID `protobuf:"bytes,4,opt,name=block_id,json=blockId,proto3" json:"block_id,omitempty"` - Timestamp time.Time `protobuf:"bytes,5,opt,name=timestamp,proto3,stdtime" json:"timestamp"` - ChainID string `protobuf:"bytes,6,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` + Type SignedMsgType `protobuf:"varint,1,opt,name=type,proto3,enum=tendermint.types.SignedMsgType" json:"type,omitempty"` + Height int64 `protobuf:"fixed64,2,opt,name=height,proto3" json:"height,omitempty"` + Round int64 `protobuf:"fixed64,3,opt,name=round,proto3" json:"round,omitempty"` + BlockID *CanonicalBlockID `protobuf:"bytes,4,opt,name=block_id,json=blockId,proto3" json:"block_id,omitempty"` + Timestamp time.Time `protobuf:"bytes,5,opt,name=timestamp,proto3,stdtime" json:"timestamp"` + ChainID string `protobuf:"bytes,6,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` + PartSetHeader *CanonicalPartSetHeader `protobuf:"bytes,7,opt,name=part_set_header,json=partSetHeader,proto3" json:"part_set_header,omitempty"` } func (m *CanonicalVote) Reset() { *m = CanonicalVote{} } @@ -316,6 +317,13 @@ func (m *CanonicalVote) GetChainID() string { return "" } +func (m *CanonicalVote) GetPartSetHeader() *CanonicalPartSetHeader { + if m != nil { + return m.PartSetHeader + } + return nil +} + func init() { proto.RegisterType((*CanonicalBlockID)(nil), "tendermint.types.CanonicalBlockID") proto.RegisterType((*CanonicalPartSetHeader)(nil), "tendermint.types.CanonicalPartSetHeader") @@ -326,40 +334,41 @@ func init() { func init() { proto.RegisterFile("tendermint/types/canonical.proto", fileDescriptor_8d1a1a84ff7267ed) } var fileDescriptor_8d1a1a84ff7267ed = []byte{ - // 528 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x54, 0xbd, 0x6e, 0xdb, 0x3c, - 0x14, 0xb5, 0x12, 0xff, 0xc8, 0x4c, 0xfc, 0x7d, 0x2e, 0x11, 0x04, 0x86, 0x51, 0x48, 0x86, 0x87, - 0xc0, 0x1d, 0x2a, 0x01, 0xc9, 0xda, 0x25, 0x8a, 0x87, 0xba, 0x68, 0x51, 0x83, 0x0e, 0x32, 0x74, - 0x31, 0x28, 0x91, 0x95, 0x88, 0xd2, 0xa2, 0x20, 0xd1, 0x05, 0xdc, 0xa9, 0x8f, 0x90, 0xe7, 0xe8, - 0x93, 0x64, 0xcc, 0xd8, 0xc9, 0x2d, 0xe4, 0x17, 0x29, 0x44, 0xca, 0x3f, 0xb0, 0x9b, 0xa9, 0x45, - 0x17, 0xe1, 0x9e, 0x7b, 0x0f, 0xcf, 0xbd, 0xba, 0x47, 0x22, 0xe8, 0x49, 0x1a, 0x13, 0x9a, 0xce, - 0x58, 0x2c, 0x5d, 0xb9, 0x48, 0x68, 0xe6, 0x06, 0x38, 0x16, 0x31, 0x0b, 0x30, 0x77, 0x92, 0x54, - 0x48, 0x01, 0xdb, 0x5b, 0x86, 0xa3, 0x18, 0xdd, 0xb3, 0x50, 0x84, 0x42, 0x15, 0xdd, 0x22, 0xd2, - 0xbc, 0xee, 0xf3, 0x03, 0x25, 0xf5, 0x2c, 0xab, 0x76, 0x28, 0x44, 0xc8, 0xa9, 0xab, 0x90, 0x3f, - 0xff, 0xe8, 0x4a, 0x36, 0xa3, 0x99, 0xc4, 0xb3, 0x44, 0x13, 0xfa, 0x17, 0xa0, 0x7d, 0xb3, 0xee, - 0xec, 0x71, 0x11, 0x7c, 0x1a, 0x0d, 0x21, 0x04, 0xd5, 0x08, 0x67, 0x51, 0xc7, 0xe8, 0x19, 0x83, - 0x53, 0xa4, 0xe2, 0xbe, 0x07, 0xce, 0x37, 0xbc, 0x31, 0x4e, 0xe5, 0x84, 0xca, 0xd7, 0x14, 0x13, - 0x9a, 0xc2, 0x33, 0x50, 0x93, 0x42, 0x62, 0xae, 0xe8, 0x2d, 0xa4, 0xc1, 0x46, 0xe3, 0x68, 0x47, - 0xe3, 0x6b, 0x15, 0x3c, 0xdb, 0x8a, 0xa4, 0x22, 0x11, 0x19, 0xe6, 0xf0, 0x0a, 0x54, 0x8b, 0x89, - 0xd5, 0xf1, 0xff, 0x2e, 0x6d, 0x67, 0xff, 0xbd, 0x9d, 0x09, 0x0b, 0x63, 0x4a, 0xde, 0x65, 0xe1, - 0xed, 0x22, 0xa1, 0x48, 0x91, 0xe1, 0x39, 0xa8, 0x47, 0x94, 0x85, 0x91, 0x54, 0x0d, 0xda, 0xa8, - 0x44, 0xc5, 0x30, 0xa9, 0x98, 0xc7, 0xa4, 0x73, 0xac, 0xd2, 0x1a, 0xc0, 0x17, 0xa0, 0x99, 0x08, - 0x3e, 0xd5, 0x95, 0x6a, 0xcf, 0x18, 0x1c, 0x7b, 0xa7, 0xf9, 0xd2, 0x36, 0xc7, 0xef, 0xdf, 0xa2, - 0x22, 0x87, 0xcc, 0x44, 0x70, 0x15, 0xc1, 0x37, 0xc0, 0xf4, 0x8b, 0x35, 0x4c, 0x19, 0xe9, 0xd4, - 0x7a, 0xc6, 0xe0, 0xe4, 0xb2, 0x7f, 0x38, 0xd1, 0xfe, 0xc6, 0xbc, 0x93, 0x7c, 0x69, 0x37, 0x4a, - 0x80, 0x1a, 0x4a, 0x60, 0x44, 0xa0, 0x07, 0x9a, 0x9b, 0x75, 0x77, 0xea, 0x4a, 0xac, 0xeb, 0x68, - 0x43, 0x9c, 0xb5, 0x21, 0xce, 0xed, 0x9a, 0xe1, 0x99, 0x0f, 0x4b, 0xbb, 0x72, 0xff, 0xc3, 0x36, - 0xd0, 0xf6, 0x18, 0xbc, 0x00, 0x66, 0x10, 0x61, 0x16, 0x17, 0xf3, 0x34, 0x7a, 0xc6, 0xa0, 0xa9, - 0x7b, 0xdd, 0x14, 0xb9, 0xa2, 0x97, 0x2a, 0x8e, 0x08, 0x9c, 0x80, 0x26, 0xc1, 0xd3, 0x48, 0x59, - 0xd2, 0x31, 0x55, 0xaf, 0xc1, 0xe1, 0xe0, 0x43, 0x2c, 0xf1, 0xf5, 0x67, 0xcc, 0x38, 0xf6, 0x19, - 0x67, 0x72, 0xa1, 0x2d, 0xd4, 0xcb, 0x18, 0x5e, 0x6b, 0x84, 0x4c, 0x82, 0x4b, 0x6b, 0xc7, 0xe0, - 0xff, 0x04, 0xa7, 0x72, 0x9a, 0x51, 0xb9, 0x96, 0x6e, 0x3e, 0x25, 0xfd, 0xfb, 0xaf, 0x03, 0xb5, - 0x92, 0x5d, 0xd8, 0xff, 0x76, 0x04, 0x5a, 0x1b, 0xe6, 0x9d, 0x90, 0xf4, 0x5f, 0xd8, 0xbf, 0xeb, - 0x69, 0xf5, 0x6f, 0x7a, 0x5a, 0xfb, 0x73, 0x4f, 0xeb, 0x4f, 0x7b, 0xea, 0xdd, 0x3d, 0xe4, 0x96, - 0xf1, 0x98, 0x5b, 0xc6, 0xcf, 0xdc, 0x32, 0xee, 0x57, 0x56, 0xe5, 0x71, 0x65, 0x55, 0xbe, 0xaf, - 0xac, 0xca, 0x87, 0x57, 0x21, 0x93, 0xd1, 0xdc, 0x77, 0x02, 0x31, 0x73, 0x39, 0xfe, 0xb2, 0xe0, - 0x94, 0x84, 0x34, 0xdd, 0x09, 0x5f, 0x06, 0x22, 0x2d, 0xff, 0x7a, 0x77, 0xff, 0x82, 0xf0, 0xeb, - 0x2a, 0x7f, 0xf5, 0x2b, 0x00, 0x00, 0xff, 0xff, 0xa4, 0x25, 0x48, 0x96, 0x85, 0x04, 0x00, 0x00, + // 533 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x54, 0x3d, 0x6f, 0xdb, 0x30, + 0x10, 0xb5, 0x12, 0x7f, 0xc8, 0x4c, 0xdc, 0xba, 0x44, 0x10, 0x18, 0x46, 0x21, 0x19, 0x1e, 0x02, + 0x77, 0xa8, 0x04, 0x24, 0x6b, 0x97, 0x28, 0x1e, 0xea, 0xa2, 0x45, 0x0d, 0x3a, 0xc8, 0xd0, 0xc5, + 0xa0, 0x45, 0x56, 0x22, 0x4a, 0x8b, 0x82, 0x44, 0x17, 0x70, 0xa7, 0xfe, 0x84, 0xfc, 0xac, 0x8c, + 0x19, 0x3b, 0xb9, 0x85, 0xfc, 0x37, 0x3a, 0x14, 0x22, 0xe5, 0x0f, 0xd8, 0x69, 0x97, 0x14, 0x59, + 0x84, 0x7b, 0x77, 0x8f, 0xef, 0x4e, 0xf7, 0x08, 0x82, 0x8e, 0xa4, 0x11, 0xa1, 0xc9, 0x94, 0x45, + 0xd2, 0x95, 0xf3, 0x98, 0xa6, 0xae, 0x8f, 0x23, 0x11, 0x31, 0x1f, 0x73, 0x27, 0x4e, 0x84, 0x14, + 0xb0, 0xb9, 0x61, 0x38, 0x8a, 0xd1, 0x3e, 0x09, 0x44, 0x20, 0x54, 0xd1, 0xcd, 0x23, 0xcd, 0x6b, + 0xbf, 0xdc, 0x53, 0x52, 0xdf, 0xa2, 0x6a, 0x07, 0x42, 0x04, 0x9c, 0xba, 0x0a, 0x4d, 0x66, 0x9f, + 0x5d, 0xc9, 0xa6, 0x34, 0x95, 0x78, 0x1a, 0x6b, 0x42, 0xf7, 0x0c, 0x34, 0xaf, 0x56, 0x9d, 0x3d, + 0x2e, 0xfc, 0x2f, 0x83, 0x3e, 0x84, 0xa0, 0x1c, 0xe2, 0x34, 0x6c, 0x19, 0x1d, 0xa3, 0x77, 0x8c, + 0x54, 0xdc, 0xf5, 0xc0, 0xe9, 0x9a, 0x37, 0xc4, 0x89, 0x1c, 0x51, 0xf9, 0x96, 0x62, 0x42, 0x13, + 0x78, 0x02, 0x2a, 0x52, 0x48, 0xcc, 0x15, 0xbd, 0x81, 0x34, 0x58, 0x6b, 0x1c, 0x6c, 0x69, 0x7c, + 0x2f, 0x83, 0x17, 0x1b, 0x91, 0x44, 0xc4, 0x22, 0xc5, 0x1c, 0x5e, 0x80, 0x72, 0x3e, 0xb1, 0x3a, + 0xfe, 0xec, 0xdc, 0x76, 0x76, 0xff, 0xdb, 0x19, 0xb1, 0x20, 0xa2, 0xe4, 0x43, 0x1a, 0x5c, 0xcf, + 0x63, 0x8a, 0x14, 0x19, 0x9e, 0x82, 0x6a, 0x48, 0x59, 0x10, 0x4a, 0xd5, 0xa0, 0x89, 0x0a, 0x94, + 0x0f, 0x93, 0x88, 0x59, 0x44, 0x5a, 0x87, 0x2a, 0xad, 0x01, 0x7c, 0x05, 0xea, 0xb1, 0xe0, 0x63, + 0x5d, 0x29, 0x77, 0x8c, 0xde, 0xa1, 0x77, 0x9c, 0x2d, 0x6c, 0x73, 0xf8, 0xf1, 0x3d, 0xca, 0x73, + 0xc8, 0x8c, 0x05, 0x57, 0x11, 0x7c, 0x07, 0xcc, 0x49, 0xbe, 0x86, 0x31, 0x23, 0xad, 0x4a, 0xc7, + 0xe8, 0x1d, 0x9d, 0x77, 0xf7, 0x27, 0xda, 0xdd, 0x98, 0x77, 0x94, 0x2d, 0xec, 0x5a, 0x01, 0x50, + 0x4d, 0x09, 0x0c, 0x08, 0xf4, 0x40, 0x7d, 0xbd, 0xee, 0x56, 0x55, 0x89, 0xb5, 0x1d, 0x6d, 0x88, + 0xb3, 0x32, 0xc4, 0xb9, 0x5e, 0x31, 0x3c, 0xf3, 0x6e, 0x61, 0x97, 0x6e, 0x7f, 0xda, 0x06, 0xda, + 0x1c, 0x83, 0x67, 0xc0, 0xf4, 0x43, 0xcc, 0xa2, 0x7c, 0x9e, 0x5a, 0xc7, 0xe8, 0xd5, 0x75, 0xaf, + 0xab, 0x3c, 0x97, 0xf7, 0x52, 0xc5, 0x01, 0x81, 0x23, 0x50, 0x27, 0x78, 0x1c, 0x2a, 0x4b, 0x5a, + 0xa6, 0xea, 0xd5, 0xdb, 0x1f, 0xbc, 0x8f, 0x25, 0xbe, 0xfc, 0x8a, 0x19, 0xc7, 0x13, 0xc6, 0x99, + 0x9c, 0x6b, 0x0b, 0xf5, 0x32, 0xfa, 0x97, 0x1a, 0x21, 0x93, 0xe0, 0xc2, 0xda, 0x21, 0x78, 0x1e, + 0xe3, 0x44, 0x8e, 0x53, 0x2a, 0x57, 0xd2, 0xf5, 0xbf, 0x49, 0x3f, 0x7c, 0x3b, 0x50, 0x23, 0xde, + 0x86, 0xdd, 0xdf, 0x07, 0xa0, 0xb1, 0x66, 0xde, 0x08, 0x49, 0x9f, 0xc2, 0xfe, 0x6d, 0x4f, 0xcb, + 0xff, 0xd3, 0xd3, 0xca, 0xe3, 0x3d, 0xad, 0xfe, 0xc3, 0xd3, 0x07, 0xd6, 0x5f, 0x7b, 0xd4, 0xfa, + 0xbd, 0x9b, 0xbb, 0xcc, 0x32, 0xee, 0x33, 0xcb, 0xf8, 0x95, 0x59, 0xc6, 0xed, 0xd2, 0x2a, 0xdd, + 0x2f, 0xad, 0xd2, 0x8f, 0xa5, 0x55, 0xfa, 0xf4, 0x26, 0x60, 0x32, 0x9c, 0x4d, 0x1c, 0x5f, 0x4c, + 0x5d, 0x8e, 0xbf, 0xcd, 0x39, 0x25, 0x01, 0x4d, 0xb6, 0xc2, 0xd7, 0xbe, 0x48, 0x8a, 0x77, 0xc4, + 0xdd, 0x7d, 0x72, 0x26, 0x55, 0x95, 0xbf, 0xf8, 0x13, 0x00, 0x00, 0xff, 0xff, 0x86, 0x9b, 0x2b, + 0x01, 0xd7, 0x04, 0x00, 0x00, } func (m *CanonicalBlockID) Marshal() (dAtA []byte, err error) { @@ -543,6 +552,18 @@ func (m *CanonicalVote) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l + if m.PartSetHeader != nil { + { + size, err := m.PartSetHeader.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintCanonical(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x3a + } if len(m.ChainID) > 0 { i -= len(m.ChainID) copy(dAtA[i:], m.ChainID) @@ -550,12 +571,12 @@ func (m *CanonicalVote) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x32 } - n5, err5 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) - if err5 != nil { - return 0, err5 + n6, err6 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) + if err6 != nil { + return 0, err6 } - i -= n5 - i = encodeVarintCanonical(dAtA, i, uint64(n5)) + i -= n6 + i = encodeVarintCanonical(dAtA, i, uint64(n6)) i-- dAtA[i] = 0x2a if m.BlockID != nil { @@ -694,6 +715,10 @@ func (m *CanonicalVote) Size() (n int) { if l > 0 { n += 1 + l + sovCanonical(uint64(l)) } + if m.PartSetHeader != nil { + l = m.PartSetHeader.Size() + n += 1 + l + sovCanonical(uint64(l)) + } return n } @@ -1340,6 +1365,42 @@ func (m *CanonicalVote) Unmarshal(dAtA []byte) error { } m.ChainID = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PartSetHeader", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCanonical + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthCanonical + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthCanonical + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.PartSetHeader == nil { + m.PartSetHeader = &CanonicalPartSetHeader{} + } + if err := m.PartSetHeader.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipCanonical(dAtA[iNdEx:]) diff --git a/proto/tendermint/types/canonical.proto b/proto/tendermint/types/canonical.proto index 1d0911d356..6de5c35d87 100644 --- a/proto/tendermint/types/canonical.proto +++ b/proto/tendermint/types/canonical.proto @@ -35,4 +35,5 @@ message CanonicalVote { CanonicalBlockID block_id = 4 [(gogoproto.customname) = "BlockID"]; google.protobuf.Timestamp timestamp = 5 [(gogoproto.nullable) = false, (gogoproto.stdtime) = true]; string chain_id = 6 [(gogoproto.customname) = "ChainID"]; + CanonicalPartSetHeader part_set_header = 7; } diff --git a/proto/tendermint/types/types.pb.go b/proto/tendermint/types/types.pb.go index ca771349dd..d7139a655f 100644 --- a/proto/tendermint/types/types.pb.go +++ b/proto/tendermint/types/types.pb.go @@ -261,20 +261,21 @@ type Header struct { Height int64 `protobuf:"varint,3,opt,name=height,proto3" json:"height,omitempty"` Time time.Time `protobuf:"bytes,4,opt,name=time,proto3,stdtime" json:"time"` // prev block info - LastBlockId BlockID `protobuf:"bytes,5,opt,name=last_block_id,json=lastBlockId,proto3" json:"last_block_id"` + LastBlockId BlockID `protobuf:"bytes,5,opt,name=last_block_id,json=lastBlockId,proto3" json:"last_block_id"` + LastPartSetHeader *PartSetHeader `protobuf:"bytes,6,opt,name=last_part_set_header,json=lastPartSetHeader,proto3" json:"last_part_set_header,omitempty"` // hashes of block data - LastCommitHash []byte `protobuf:"bytes,6,opt,name=last_commit_hash,json=lastCommitHash,proto3" json:"last_commit_hash,omitempty"` - NumOriginalDataShares uint64 `protobuf:"varint,7,opt,name=num_original_data_shares,json=numOriginalDataShares,proto3" json:"num_original_data_shares,omitempty"` - DataHash []byte `protobuf:"bytes,8,opt,name=data_hash,json=dataHash,proto3" json:"data_hash,omitempty"` + LastCommitHash []byte `protobuf:"bytes,7,opt,name=last_commit_hash,json=lastCommitHash,proto3" json:"last_commit_hash,omitempty"` + NumOriginalDataShares uint64 `protobuf:"varint,8,opt,name=num_original_data_shares,json=numOriginalDataShares,proto3" json:"num_original_data_shares,omitempty"` + DataHash []byte `protobuf:"bytes,9,opt,name=data_hash,json=dataHash,proto3" json:"data_hash,omitempty"` // hashes from the app output from the prev block - ValidatorsHash []byte `protobuf:"bytes,9,opt,name=validators_hash,json=validatorsHash,proto3" json:"validators_hash,omitempty"` - NextValidatorsHash []byte `protobuf:"bytes,10,opt,name=next_validators_hash,json=nextValidatorsHash,proto3" json:"next_validators_hash,omitempty"` - ConsensusHash []byte `protobuf:"bytes,11,opt,name=consensus_hash,json=consensusHash,proto3" json:"consensus_hash,omitempty"` - AppHash []byte `protobuf:"bytes,12,opt,name=app_hash,json=appHash,proto3" json:"app_hash,omitempty"` - LastResultsHash []byte `protobuf:"bytes,13,opt,name=last_results_hash,json=lastResultsHash,proto3" json:"last_results_hash,omitempty"` + ValidatorsHash []byte `protobuf:"bytes,10,opt,name=validators_hash,json=validatorsHash,proto3" json:"validators_hash,omitempty"` + NextValidatorsHash []byte `protobuf:"bytes,11,opt,name=next_validators_hash,json=nextValidatorsHash,proto3" json:"next_validators_hash,omitempty"` + ConsensusHash []byte `protobuf:"bytes,12,opt,name=consensus_hash,json=consensusHash,proto3" json:"consensus_hash,omitempty"` + AppHash []byte `protobuf:"bytes,13,opt,name=app_hash,json=appHash,proto3" json:"app_hash,omitempty"` + LastResultsHash []byte `protobuf:"bytes,14,opt,name=last_results_hash,json=lastResultsHash,proto3" json:"last_results_hash,omitempty"` // consensus info - EvidenceHash []byte `protobuf:"bytes,14,opt,name=evidence_hash,json=evidenceHash,proto3" json:"evidence_hash,omitempty"` - ProposerAddress []byte `protobuf:"bytes,15,opt,name=proposer_address,json=proposerAddress,proto3" json:"proposer_address,omitempty"` + EvidenceHash []byte `protobuf:"bytes,15,opt,name=evidence_hash,json=evidenceHash,proto3" json:"evidence_hash,omitempty"` + ProposerAddress []byte `protobuf:"bytes,16,opt,name=proposer_address,json=proposerAddress,proto3" json:"proposer_address,omitempty"` } func (m *Header) Reset() { *m = Header{} } @@ -345,6 +346,13 @@ func (m *Header) GetLastBlockId() BlockID { return BlockID{} } +func (m *Header) GetLastPartSetHeader() *PartSetHeader { + if m != nil { + return m.LastPartSetHeader + } + return nil +} + func (m *Header) GetLastCommitHash() []byte { if m != nil { return m.LastCommitHash @@ -1632,126 +1640,127 @@ func init() { func init() { proto.RegisterFile("tendermint/types/types.proto", fileDescriptor_d3a6e55e2345de56) } var fileDescriptor_d3a6e55e2345de56 = []byte{ - // 1893 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x58, 0x49, 0x6f, 0xe3, 0xc8, - 0xf5, 0x37, 0xb5, 0x58, 0xd4, 0x93, 0x64, 0xcb, 0xf5, 0xb7, 0xdd, 0xb2, 0xba, 0x2d, 0xeb, 0xaf, - 0x2c, 0xe3, 0xd9, 0xe4, 0x8e, 0x27, 0xc8, 0x02, 0x4c, 0x06, 0x23, 0xd9, 0x9e, 0x6e, 0x65, 0xbc, - 0x08, 0x94, 0xc7, 0x59, 0x2e, 0x44, 0x49, 0xac, 0x96, 0x98, 0xa6, 0x48, 0x82, 0x55, 0x72, 0xdb, - 0x7d, 0xcc, 0x29, 0xf0, 0xa9, 0xbf, 0x80, 0x91, 0x43, 0x72, 0x08, 0x72, 0xcb, 0xb7, 0x98, 0x4b, - 0x80, 0x49, 0x2e, 0xc9, 0x25, 0x9d, 0xc0, 0x9d, 0x5b, 0xbe, 0x44, 0x50, 0x0b, 0x29, 0xca, 0x92, - 0x3a, 0x13, 0xc3, 0xc8, 0x45, 0x10, 0xdf, 0xfb, 0xbd, 0x57, 0x6f, 0xaf, 0x47, 0xc2, 0x23, 0x46, - 0x5c, 0x8b, 0x04, 0x43, 0xdb, 0x65, 0x3b, 0xec, 0xd2, 0x27, 0x54, 0xfe, 0xd6, 0xfd, 0xc0, 0x63, - 0x1e, 0x2a, 0x8e, 0xb9, 0x75, 0x41, 0x2f, 0xaf, 0xf6, 0xbd, 0xbe, 0x27, 0x98, 0x3b, 0xfc, 0x9f, - 0xc4, 0x95, 0xb7, 0xfa, 0x9e, 0xd7, 0x77, 0xc8, 0x8e, 0x78, 0xea, 0x8e, 0x9e, 0xed, 0x30, 0x7b, - 0x48, 0x28, 0xc3, 0x43, 0x5f, 0x01, 0x36, 0x63, 0xc7, 0xf4, 0x82, 0x4b, 0x9f, 0x79, 0x1c, 0xeb, - 0x3d, 0x53, 0xec, 0x4a, 0x8c, 0x7d, 0x4e, 0x02, 0x6a, 0x7b, 0x6e, 0xdc, 0x8e, 0x72, 0x75, 0xca, - 0xca, 0x73, 0xec, 0xd8, 0x16, 0x66, 0x5e, 0x20, 0x11, 0xb5, 0x1f, 0x42, 0xa1, 0x8d, 0x03, 0xd6, - 0x21, 0xec, 0x29, 0xc1, 0x16, 0x09, 0xd0, 0x2a, 0xa4, 0x99, 0xc7, 0xb0, 0x53, 0xd2, 0xaa, 0xda, - 0x76, 0xc1, 0x90, 0x0f, 0x08, 0x41, 0x6a, 0x80, 0xe9, 0xa0, 0x94, 0xa8, 0x6a, 0xdb, 0x79, 0x43, - 0xfc, 0xaf, 0x0d, 0x20, 0xc5, 0x45, 0xb9, 0x84, 0xed, 0x5a, 0xe4, 0x22, 0x94, 0x10, 0x0f, 0x9c, - 0xda, 0xbd, 0x64, 0x84, 0x2a, 0x11, 0xf9, 0x80, 0xbe, 0x0b, 0x69, 0x61, 0x7f, 0x29, 0x59, 0xd5, - 0xb6, 0x73, 0xbb, 0xa5, 0x7a, 0x2c, 0x50, 0xd2, 0xbf, 0x7a, 0x9b, 0xf3, 0x9b, 0xa9, 0x2f, 0x5f, - 0x6f, 0x2d, 0x18, 0x12, 0x5c, 0xdb, 0x84, 0x4c, 0xd3, 0xf1, 0x7a, 0xcf, 0x5b, 0xfb, 0x91, 0x21, - 0x5a, 0xcc, 0x90, 0x5f, 0xa7, 0x61, 0x51, 0x59, 0xff, 0x23, 0xc8, 0xa8, 0x38, 0x08, 0x44, 0x6e, - 0x77, 0x33, 0x7e, 0x82, 0x62, 0xd5, 0xf7, 0x3c, 0x97, 0x12, 0x97, 0x8e, 0xa8, 0x3a, 0x26, 0x94, - 0x41, 0xdf, 0x06, 0xbd, 0x37, 0xc0, 0xb6, 0x6b, 0xda, 0x96, 0xb0, 0x3b, 0xdb, 0xcc, 0xdd, 0xbc, - 0xde, 0xca, 0xec, 0x71, 0x5a, 0x6b, 0xdf, 0xc8, 0x08, 0x66, 0xcb, 0x42, 0xeb, 0xb0, 0x38, 0x20, - 0x76, 0x7f, 0xc0, 0x84, 0x1f, 0x49, 0x43, 0x3d, 0xa1, 0x1f, 0x40, 0x8a, 0x67, 0xb0, 0x94, 0x12, - 0x67, 0x97, 0xeb, 0x32, 0xbd, 0xf5, 0x30, 0xbd, 0xf5, 0xd3, 0x30, 0xbd, 0x4d, 0x9d, 0x1f, 0xfc, - 0xea, 0xef, 0x5b, 0x9a, 0x21, 0x24, 0xd0, 0x1e, 0x14, 0x1c, 0x4c, 0x99, 0xd9, 0xe5, 0x7e, 0xf2, - 0xe3, 0xd3, 0x42, 0xc5, 0x46, 0xfd, 0x76, 0x25, 0xd5, 0x55, 0x24, 0x94, 0xe9, 0x39, 0x2e, 0x25, - 0x49, 0x16, 0xda, 0x86, 0xa2, 0x50, 0xd2, 0xf3, 0x86, 0x43, 0x9b, 0x99, 0x22, 0x50, 0x8b, 0x22, - 0x50, 0x4b, 0x9c, 0xbe, 0x27, 0xc8, 0x4f, 0x31, 0x1d, 0xa0, 0xef, 0x43, 0xc9, 0x1d, 0x0d, 0x4d, - 0x2f, 0xb0, 0xfb, 0xb6, 0x8b, 0x1d, 0xd3, 0xc2, 0x0c, 0x9b, 0x74, 0x80, 0x03, 0x42, 0x4b, 0x99, - 0xaa, 0xb6, 0x9d, 0x32, 0xd6, 0xdc, 0xd1, 0xf0, 0x44, 0xb1, 0xf7, 0x31, 0xc3, 0x1d, 0xc1, 0x44, - 0x0f, 0x21, 0x2b, 0xb0, 0x42, 0xb7, 0x2e, 0x74, 0xeb, 0x9c, 0x20, 0xb4, 0xbe, 0x03, 0xcb, 0x51, - 0x7d, 0x51, 0x09, 0xc9, 0xca, 0xe3, 0xc7, 0x64, 0x01, 0x7c, 0x0c, 0xab, 0x2e, 0xb9, 0x60, 0xe6, - 0x6d, 0x34, 0x08, 0x34, 0xe2, 0xbc, 0xb3, 0x49, 0x89, 0x6f, 0xc1, 0x52, 0x2f, 0xcc, 0x9a, 0xc4, - 0xe6, 0x04, 0xb6, 0x10, 0x51, 0x05, 0x6c, 0x03, 0x74, 0xec, 0xfb, 0x12, 0x90, 0x17, 0x80, 0x0c, - 0xf6, 0x7d, 0xc1, 0x7a, 0x0f, 0x56, 0x44, 0x70, 0x02, 0x42, 0x47, 0x0e, 0x53, 0x4a, 0x0a, 0x02, - 0xb3, 0xcc, 0x19, 0x86, 0xa4, 0x0b, 0xec, 0x37, 0xa0, 0x40, 0xce, 0x6d, 0x8b, 0xb8, 0x3d, 0x22, - 0x71, 0x4b, 0x02, 0x97, 0x0f, 0x89, 0x02, 0xf4, 0x2e, 0x14, 0xfd, 0xc0, 0xf3, 0x3d, 0x4a, 0x02, - 0x13, 0x5b, 0x56, 0x40, 0x28, 0x2d, 0x2d, 0x4b, 0x7d, 0x21, 0xbd, 0x21, 0xc9, 0xb5, 0x5f, 0x26, - 0x20, 0xc5, 0x83, 0x88, 0x8a, 0x90, 0x64, 0x17, 0xb4, 0xa4, 0x55, 0x93, 0xdb, 0x79, 0x83, 0xff, - 0x45, 0x03, 0x28, 0xd9, 0x2e, 0x23, 0xc1, 0x90, 0x58, 0x36, 0x66, 0xc4, 0xa4, 0x8c, 0xff, 0x06, - 0x9e, 0xc7, 0x64, 0xeb, 0xe4, 0x76, 0xb7, 0xa7, 0x6b, 0xa0, 0x15, 0x93, 0xe8, 0x70, 0x01, 0x83, - 0xe3, 0x55, 0x49, 0xac, 0xdb, 0x33, 0xb9, 0xe8, 0x53, 0xd0, 0x43, 0xfb, 0x55, 0xfb, 0x55, 0xa6, - 0x35, 0x1f, 0x28, 0xc4, 0xa1, 0x4d, 0x99, 0xd2, 0x17, 0x49, 0xa1, 0x8f, 0x41, 0x1f, 0x12, 0x4a, - 0x71, 0x9f, 0xd0, 0xa8, 0xc4, 0xa7, 0x34, 0x1c, 0x29, 0x44, 0x28, 0x1d, 0x4a, 0xd4, 0xfe, 0xa9, - 0x81, 0x1e, 0xaa, 0x47, 0x18, 0x1e, 0x58, 0x23, 0xdf, 0xb1, 0x7b, 0xdc, 0xdb, 0x73, 0x8f, 0x11, - 0x33, 0xb2, 0x4d, 0x36, 0xee, 0x3b, 0xd3, 0x9a, 0xf7, 0x43, 0x81, 0x33, 0x8f, 0x91, 0x50, 0xd3, - 0xd3, 0x05, 0x63, 0xcd, 0x9a, 0xc5, 0x40, 0x2e, 0x3c, 0x72, 0x78, 0x57, 0x9a, 0x3d, 0xc7, 0x26, - 0x2e, 0x33, 0x31, 0x63, 0xb8, 0xf7, 0x7c, 0x7c, 0x8e, 0x8c, 0xee, 0xfb, 0xd3, 0xe7, 0x1c, 0x72, - 0xa9, 0x3d, 0x21, 0xd4, 0x10, 0x32, 0xb1, 0xb3, 0x36, 0x9c, 0x79, 0xcc, 0x66, 0x1a, 0x92, 0x74, - 0x34, 0xac, 0xbd, 0x4a, 0xc0, 0xda, 0x4c, 0x4b, 0xd1, 0x87, 0xb0, 0x28, 0x3c, 0xc5, 0xca, 0xc5, - 0xf5, 0xe9, 0xa3, 0x39, 0xde, 0x48, 0x73, 0x54, 0x23, 0x82, 0x77, 0x95, 0xa5, 0x6f, 0x85, 0x37, - 0xd1, 0x07, 0x80, 0xc4, 0xac, 0xe6, 0xd1, 0xb4, 0xdd, 0xbe, 0xe9, 0x7b, 0x2f, 0x48, 0xa0, 0xe6, - 0x53, 0x51, 0x70, 0xce, 0x04, 0xa3, 0xcd, 0xe9, 0x13, 0xad, 0xaa, 0xa0, 0x29, 0x01, 0x1d, 0xb7, - 0xaa, 0x04, 0x36, 0x21, 0x1b, 0x5d, 0x4a, 0x6a, 0x28, 0x7d, 0xbd, 0xb9, 0x36, 0x16, 0xab, 0xfd, - 0x31, 0x01, 0x1b, 0x73, 0x83, 0x8a, 0x5a, 0xb0, 0xd2, 0xf3, 0xdc, 0x67, 0x8e, 0xdd, 0x13, 0x76, - 0x8b, 0x09, 0xa8, 0x22, 0xf4, 0x68, 0x4e, 0x72, 0xc4, 0xc0, 0x33, 0x8a, 0x31, 0x31, 0x41, 0xe1, - 0x7d, 0xcb, 0x67, 0x9f, 0xe7, 0x9a, 0x6a, 0x3c, 0x27, 0x84, 0x4f, 0x79, 0x49, 0x7c, 0x2a, 0x87, - 0xf4, 0x31, 0xac, 0x76, 0x2f, 0x5f, 0x62, 0x97, 0xd9, 0x2e, 0x89, 0x4d, 0xa0, 0x52, 0xb2, 0x9a, - 0xdc, 0xce, 0xed, 0x3e, 0x9c, 0x11, 0xe5, 0x10, 0x63, 0xfc, 0x5f, 0x24, 0x38, 0x1e, 0x4f, 0x73, - 0x02, 0x9f, 0x9a, 0x13, 0xf8, 0xfb, 0x88, 0xe7, 0x21, 0xe4, 0xe3, 0x7d, 0xca, 0xfb, 0x32, 0xd6, - 0x3d, 0xc9, 0xd9, 0x7d, 0x19, 0xd5, 0xe9, 0xad, 0xae, 0xae, 0x7d, 0x02, 0xeb, 0xb3, 0xe7, 0x09, - 0xfa, 0x26, 0x2c, 0x05, 0xf8, 0x85, 0x1c, 0x46, 0xa6, 0x63, 0x53, 0xa6, 0x06, 0x57, 0x3e, 0xc0, - 0x2f, 0x04, 0x82, 0x9f, 0x5e, 0xfb, 0x31, 0xe8, 0x61, 0xcf, 0xa3, 0x4f, 0xa0, 0x10, 0xf6, 0xfb, - 0x58, 0x60, 0xe6, 0x35, 0xa6, 0x44, 0x8c, 0x7c, 0x88, 0x17, 0xba, 0x3e, 0x85, 0x8c, 0x62, 0xa0, - 0xff, 0x87, 0xbc, 0x8b, 0x87, 0x84, 0xfa, 0xb8, 0x47, 0xf8, 0x85, 0x28, 0x6f, 0xfc, 0x5c, 0x44, - 0x6b, 0x59, 0x7c, 0x19, 0xe0, 0x77, 0x4f, 0xb8, 0x95, 0xf0, 0xff, 0xb5, 0x9f, 0xc2, 0x3a, 0x9f, - 0xb4, 0x8d, 0x73, 0x6c, 0x3b, 0xb8, 0x6b, 0x3b, 0x36, 0xbb, 0x54, 0xbb, 0xc1, 0x43, 0xc8, 0x06, - 0x9e, 0xf2, 0x46, 0x39, 0xa2, 0x07, 0x9e, 0x74, 0x84, 0x9f, 0xd6, 0xf3, 0x9c, 0xd1, 0xd0, 0x8d, - 0x46, 0x2f, 0xe7, 0xe7, 0x24, 0x4d, 0x40, 0x6a, 0x7f, 0x48, 0x42, 0x8a, 0x37, 0x1c, 0xfa, 0x08, - 0x52, 0xdc, 0x07, 0x61, 0xd1, 0xd2, 0xee, 0xd6, 0xb4, 0x6f, 0x1d, 0xbb, 0xef, 0x12, 0xeb, 0x88, - 0xf6, 0x4f, 0x2f, 0x7d, 0x62, 0x08, 0x70, 0x6c, 0x65, 0x48, 0x4c, 0xac, 0x0c, 0xab, 0x90, 0x0e, - 0xbc, 0x91, 0x6b, 0x89, 0x4e, 0x4d, 0x1b, 0xf2, 0x01, 0x1d, 0x80, 0x1e, 0x6d, 0x02, 0xa9, 0xff, - 0xb4, 0x09, 0x2c, 0xf3, 0x84, 0xf2, 0x3d, 0x45, 0x11, 0x8c, 0x4c, 0x57, 0x2d, 0x04, 0xf7, 0x50, - 0x6c, 0xe8, 0x7d, 0x58, 0x19, 0x4f, 0x8a, 0xf0, 0x9e, 0x93, 0x5b, 0x45, 0x31, 0x62, 0xa8, 0x8b, - 0x6e, 0x72, 0xac, 0xc8, 0xad, 0x30, 0x23, 0xfc, 0x1a, 0x8f, 0x95, 0x96, 0x58, 0x0f, 0x1f, 0x41, - 0x96, 0xda, 0x7d, 0x17, 0xb3, 0x51, 0x40, 0xd4, 0x1e, 0x31, 0x26, 0xa0, 0x27, 0xb0, 0xec, 0xe3, - 0x80, 0x99, 0x94, 0x30, 0x73, 0x20, 0xb2, 0x27, 0x16, 0x89, 0xdc, 0xac, 0x60, 0x4f, 0xac, 0xaf, - 0x46, 0xc1, 0x8f, 0x3f, 0xd6, 0x7e, 0x9f, 0x80, 0x45, 0xb9, 0xf6, 0xc4, 0x12, 0xa0, 0xcd, 0x4e, - 0x40, 0x62, 0x5e, 0x02, 0x92, 0x77, 0x4f, 0x40, 0x03, 0x20, 0xf2, 0x8a, 0xdf, 0x99, 0x73, 0x26, - 0x8c, 0x34, 0xb1, 0x63, 0xf7, 0x55, 0x73, 0xc6, 0x84, 0xd0, 0x16, 0xe4, 0x64, 0x08, 0xe4, 0x26, - 0x92, 0x16, 0xb1, 0x02, 0x49, 0x12, 0x7b, 0xc8, 0x8c, 0x60, 0x2d, 0xde, 0x29, 0x58, 0x7f, 0xd3, - 0x20, 0x1b, 0x59, 0x82, 0x1a, 0x50, 0x08, 0x23, 0x60, 0x3e, 0x73, 0x70, 0x5f, 0x95, 0xfb, 0xe6, - 0xdc, 0x30, 0x7c, 0xe6, 0xe0, 0xbe, 0x91, 0x53, 0x9e, 0xf3, 0x87, 0xd9, 0xa5, 0x93, 0x98, 0x53, - 0x3a, 0x13, 0xb5, 0x9a, 0xbc, 0x5b, 0xad, 0x4e, 0x54, 0x55, 0xea, 0x56, 0x55, 0xd5, 0xfe, 0x94, - 0x04, 0xbd, 0x2d, 0x36, 0x33, 0xec, 0xfc, 0x2f, 0x9a, 0xf8, 0x21, 0x64, 0x7d, 0xcf, 0x31, 0x25, - 0x27, 0x25, 0x38, 0xba, 0xef, 0x39, 0xc6, 0x54, 0x81, 0xa5, 0xef, 0xa9, 0xc3, 0x17, 0xef, 0x21, - 0x6a, 0x99, 0xdb, 0xbd, 0xd8, 0xe1, 0x1b, 0x7f, 0x58, 0x58, 0xfa, 0xbc, 0x8d, 0x74, 0xf6, 0xcc, - 0x6d, 0xe6, 0x6f, 0x5e, 0x6f, 0xe9, 0xfb, 0x0d, 0x55, 0x6f, 0xba, 0x85, 0xd5, 0x2c, 0xbe, 0xb7, - 0x06, 0x0f, 0x20, 0x2f, 0x13, 0xa5, 0x14, 0x3f, 0xe6, 0x19, 0x12, 0xfa, 0xb4, 0xe9, 0x37, 0x4c, - 0xa9, 0x4f, 0x29, 0x52, 0x38, 0x2e, 0x21, 0xdf, 0x97, 0xd4, 0x9a, 0x55, 0x9a, 0xd7, 0x9e, 0x86, - 0xc2, 0xd5, 0xfe, 0xa5, 0x01, 0x8c, 0xd7, 0x10, 0xfe, 0xea, 0x46, 0x85, 0x09, 0xe6, 0xc4, 0xc9, - 0x95, 0x79, 0x25, 0xa5, 0xce, 0xcf, 0xd3, 0xb8, 0xdd, 0x7b, 0x50, 0x18, 0xb7, 0x0a, 0x25, 0xa1, - 0x31, 0x95, 0xb7, 0x6c, 0x23, 0x1d, 0xc2, 0x8c, 0xfc, 0x79, 0xec, 0x69, 0x32, 0x55, 0xc9, 0xfb, - 0x49, 0x55, 0xed, 0xcf, 0x09, 0xc8, 0x0a, 0x47, 0x8f, 0x08, 0xc3, 0x13, 0x65, 0xab, 0xdd, 0xbd, - 0x6c, 0x37, 0x01, 0xa4, 0x1a, 0x6a, 0xbf, 0x24, 0xaa, 0x99, 0xb2, 0x82, 0xd2, 0xb1, 0x5f, 0x12, - 0xf4, 0xbd, 0x28, 0x8b, 0xc9, 0xb7, 0x67, 0x51, 0xcd, 0xcb, 0x30, 0x97, 0x0f, 0x20, 0xc3, 0x5f, - 0x6b, 0xf9, 0x2b, 0x96, 0xdc, 0xbf, 0x16, 0xdd, 0xd1, 0xf0, 0xf4, 0x82, 0xa2, 0x83, 0x78, 0x64, - 0xd2, 0xff, 0x5d, 0x64, 0xde, 0x5e, 0xb6, 0x77, 0x1b, 0xb5, 0xbf, 0x80, 0xcc, 0xe9, 0x85, 0xf8, - 0xd2, 0x21, 0xd7, 0x12, 0x4f, 0xbd, 0xad, 0xcb, 0x25, 0x47, 0xe7, 0x04, 0x31, 0xdb, 0x67, 0x6c, - 0x38, 0xa8, 0xfe, 0x35, 0xbf, 0xa1, 0xa8, 0xaf, 0x27, 0xef, 0xfd, 0x45, 0x83, 0x5c, 0x6c, 0x44, - 0xa3, 0xef, 0xc0, 0x5a, 0xf3, 0xf0, 0x64, 0xef, 0x73, 0xb3, 0xb5, 0x6f, 0x7e, 0x76, 0xd8, 0x78, - 0x62, 0x7e, 0x71, 0xfc, 0xf9, 0xf1, 0xc9, 0x4f, 0x8e, 0x8b, 0x0b, 0xe5, 0xf5, 0xab, 0xeb, 0x2a, - 0x8a, 0x61, 0xbf, 0x70, 0x9f, 0xbb, 0xde, 0x0b, 0x17, 0xed, 0xc0, 0xea, 0xa4, 0x48, 0xa3, 0xd9, - 0x39, 0x38, 0x3e, 0x2d, 0x6a, 0xe5, 0xb5, 0xab, 0xeb, 0xea, 0x4a, 0x4c, 0xa2, 0xd1, 0xa5, 0xc4, - 0x65, 0xd3, 0x02, 0x7b, 0x27, 0x47, 0x47, 0xad, 0xd3, 0x62, 0x62, 0x4a, 0x40, 0xdd, 0xce, 0xef, - 0xc2, 0xca, 0xa4, 0xc0, 0x71, 0xeb, 0xb0, 0x98, 0x2c, 0xa3, 0xab, 0xeb, 0xea, 0x52, 0x0c, 0x7d, - 0x6c, 0x3b, 0x65, 0xfd, 0x57, 0xbf, 0xa9, 0x2c, 0xfc, 0xee, 0xb7, 0x15, 0x8d, 0x7b, 0x56, 0x98, - 0x18, 0xd3, 0xe8, 0x03, 0x78, 0xd0, 0x69, 0x3d, 0x39, 0x3e, 0xd8, 0x37, 0x8f, 0x3a, 0x4f, 0xcc, - 0xd3, 0x9f, 0xb5, 0x0f, 0x62, 0xde, 0x2d, 0x5f, 0x5d, 0x57, 0x73, 0xca, 0xa5, 0x79, 0xe8, 0xb6, - 0x71, 0x70, 0x76, 0x72, 0x7a, 0x50, 0xd4, 0x24, 0xba, 0x1d, 0x10, 0xfe, 0x76, 0x25, 0xd0, 0x8f, - 0x61, 0x63, 0x06, 0x3a, 0x72, 0x6c, 0xe5, 0xea, 0xba, 0x5a, 0x68, 0x07, 0x44, 0x0e, 0x09, 0x21, - 0x51, 0x87, 0xd2, 0xb4, 0xc4, 0x49, 0xfb, 0xa4, 0xd3, 0x38, 0x2c, 0x56, 0xcb, 0xc5, 0xab, 0xeb, - 0x6a, 0x3e, 0xbc, 0x8f, 0x38, 0x7e, 0xec, 0x59, 0xf3, 0xec, 0xcb, 0x9b, 0x8a, 0xf6, 0xd5, 0x4d, - 0x45, 0xfb, 0xc7, 0x4d, 0x45, 0x7b, 0xf5, 0xa6, 0xb2, 0xf0, 0xd5, 0x9b, 0xca, 0xc2, 0x5f, 0xdf, - 0x54, 0x16, 0x7e, 0xfe, 0x71, 0xdf, 0x66, 0x83, 0x51, 0xb7, 0xde, 0xf3, 0x86, 0x3b, 0x0e, 0x7e, - 0x79, 0xe9, 0x10, 0xab, 0x4f, 0x82, 0xd8, 0xdf, 0x0f, 0x7b, 0x5e, 0xa0, 0xbe, 0x28, 0xee, 0xdc, - 0xfe, 0xfc, 0xd7, 0x5d, 0x14, 0xf4, 0x8f, 0xfe, 0x1d, 0x00, 0x00, 0xff, 0xff, 0x09, 0x91, 0xde, - 0x4a, 0xbf, 0x14, 0x00, 0x00, + // 1910 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x58, 0x4b, 0x73, 0xdb, 0xc8, + 0x11, 0x16, 0xf8, 0x66, 0x93, 0x94, 0xa8, 0x89, 0x24, 0x53, 0xb2, 0x45, 0x31, 0xcc, 0x63, 0xb5, + 0x2f, 0xca, 0xf1, 0xa6, 0xf2, 0xa8, 0xda, 0x6c, 0x2d, 0x29, 0x69, 0x6d, 0x66, 0xf5, 0x60, 0x81, + 0x5a, 0xe5, 0x71, 0x41, 0x0d, 0x89, 0x31, 0x89, 0x18, 0x04, 0x58, 0xc0, 0x50, 0x96, 0x7c, 0xcc, + 0x29, 0xa5, 0x93, 0xff, 0x80, 0x4e, 0xc9, 0x21, 0x95, 0x5b, 0xfe, 0xc5, 0x5e, 0x52, 0xb5, 0xc9, + 0x25, 0xb9, 0xc4, 0x49, 0xc9, 0xb9, 0xe5, 0x94, 0x7f, 0x90, 0x9a, 0x9e, 0x01, 0x08, 0x8a, 0xa4, + 0xe3, 0xa8, 0x54, 0x7b, 0x61, 0x11, 0xdd, 0x5f, 0xf7, 0xf4, 0x7b, 0x1a, 0x80, 0x07, 0x9c, 0x39, + 0x26, 0xf3, 0x06, 0x96, 0xc3, 0x77, 0xf8, 0xc5, 0x90, 0xf9, 0xf2, 0xb7, 0x36, 0xf4, 0x5c, 0xee, + 0x92, 0xe2, 0x98, 0x5b, 0x43, 0xfa, 0xc6, 0x4a, 0xcf, 0xed, 0xb9, 0xc8, 0xdc, 0x11, 0xff, 0x24, + 0x6e, 0x63, 0xab, 0xe7, 0xba, 0x3d, 0x9b, 0xed, 0xe0, 0x53, 0x67, 0xf4, 0x74, 0x87, 0x5b, 0x03, + 0xe6, 0x73, 0x3a, 0x18, 0x2a, 0xc0, 0x66, 0xe4, 0x98, 0xae, 0x77, 0x31, 0xe4, 0xae, 0xc0, 0xba, + 0x4f, 0x15, 0xbb, 0x1c, 0x61, 0x9f, 0x31, 0xcf, 0xb7, 0x5c, 0x27, 0x6a, 0xc7, 0x46, 0x65, 0xca, + 0xca, 0x33, 0x6a, 0x5b, 0x26, 0xe5, 0xae, 0x27, 0x11, 0xd5, 0x1f, 0x43, 0xa1, 0x45, 0x3d, 0xde, + 0x66, 0xfc, 0x09, 0xa3, 0x26, 0xf3, 0xc8, 0x0a, 0x24, 0xb9, 0xcb, 0xa9, 0x5d, 0xd2, 0x2a, 0xda, + 0x76, 0x41, 0x97, 0x0f, 0x84, 0x40, 0xa2, 0x4f, 0xfd, 0x7e, 0x29, 0x56, 0xd1, 0xb6, 0xf3, 0x3a, + 0xfe, 0xaf, 0xf6, 0x21, 0x21, 0x44, 0x85, 0x84, 0xe5, 0x98, 0xec, 0x3c, 0x90, 0xc0, 0x07, 0x41, + 0xed, 0x5c, 0x70, 0xe6, 0x2b, 0x11, 0xf9, 0x40, 0xbe, 0x0f, 0x49, 0xb4, 0xbf, 0x14, 0xaf, 0x68, + 0xdb, 0xb9, 0x47, 0xa5, 0x5a, 0x24, 0x50, 0xd2, 0xbf, 0x5a, 0x4b, 0xf0, 0x1b, 0x89, 0x2f, 0x5f, + 0x6d, 0x2d, 0xe8, 0x12, 0x5c, 0xdd, 0x84, 0x74, 0xc3, 0x76, 0xbb, 0xcf, 0x9a, 0x7b, 0xa1, 0x21, + 0x5a, 0xc4, 0x90, 0xff, 0x24, 0x21, 0xa5, 0xac, 0xff, 0x09, 0xa4, 0x55, 0x1c, 0x10, 0x91, 0x7b, + 0xb4, 0x19, 0x3d, 0x41, 0xb1, 0x6a, 0xbb, 0xae, 0xe3, 0x33, 0xc7, 0x1f, 0xf9, 0xea, 0x98, 0x40, + 0x86, 0x7c, 0x17, 0x32, 0xdd, 0x3e, 0xb5, 0x1c, 0xc3, 0x32, 0xd1, 0xee, 0x6c, 0x23, 0x77, 0xfd, + 0x6a, 0x2b, 0xbd, 0x2b, 0x68, 0xcd, 0x3d, 0x3d, 0x8d, 0xcc, 0xa6, 0x49, 0xd6, 0x20, 0xd5, 0x67, + 0x56, 0xaf, 0xcf, 0xd1, 0x8f, 0xb8, 0xae, 0x9e, 0xc8, 0x8f, 0x20, 0x21, 0x32, 0x58, 0x4a, 0xe0, + 0xd9, 0x1b, 0x35, 0x99, 0xde, 0x5a, 0x90, 0xde, 0xda, 0x49, 0x90, 0xde, 0x46, 0x46, 0x1c, 0xfc, + 0xf2, 0x1f, 0x5b, 0x9a, 0x8e, 0x12, 0x64, 0x17, 0x0a, 0x36, 0xf5, 0xb9, 0xd1, 0x11, 0x7e, 0x8a, + 0xe3, 0x93, 0xa8, 0x62, 0xbd, 0x76, 0xb3, 0x92, 0x6a, 0x2a, 0x12, 0xca, 0xf4, 0x9c, 0x90, 0x92, + 0x24, 0x93, 0xb4, 0x60, 0x05, 0x95, 0x0c, 0xa9, 0xc7, 0x0d, 0x9f, 0x71, 0xa3, 0x8f, 0x51, 0x29, + 0xa5, 0x50, 0xd7, 0xd6, 0xb4, 0xae, 0x89, 0xd4, 0xeb, 0xcb, 0x42, 0x78, 0xb2, 0x1a, 0xb6, 0xa1, + 0x88, 0x1a, 0xbb, 0xee, 0x60, 0x60, 0x71, 0x03, 0x43, 0x9f, 0xc6, 0xd0, 0x2f, 0x0a, 0xfa, 0x2e, + 0x92, 0x9f, 0x50, 0xbf, 0x4f, 0x7e, 0x08, 0x25, 0x67, 0x34, 0x30, 0x5c, 0xcf, 0xea, 0x59, 0x0e, + 0xb5, 0x0d, 0x93, 0x72, 0x6a, 0xf8, 0x7d, 0xea, 0x31, 0xbf, 0x94, 0xa9, 0x68, 0xdb, 0x09, 0x7d, + 0xd5, 0x19, 0x0d, 0x8e, 0x15, 0x7b, 0x8f, 0x72, 0xda, 0x46, 0x26, 0xb9, 0x0f, 0x59, 0xc4, 0xa2, + 0xee, 0x2c, 0xea, 0xce, 0x08, 0x02, 0x6a, 0x7d, 0x07, 0x96, 0xc2, 0x8a, 0xf5, 0x25, 0x04, 0xe4, + 0xf1, 0x63, 0x32, 0x02, 0x1f, 0xc2, 0x8a, 0xc3, 0xce, 0xb9, 0x71, 0x13, 0x9d, 0x43, 0x34, 0x11, + 0xbc, 0xd3, 0x49, 0x89, 0xef, 0xc0, 0x62, 0x37, 0xa8, 0x03, 0x89, 0xcd, 0x23, 0xb6, 0x10, 0x52, + 0x11, 0xb6, 0x0e, 0x19, 0x3a, 0x1c, 0x4a, 0x40, 0x01, 0x01, 0x69, 0x3a, 0x1c, 0x22, 0xeb, 0x3d, + 0xc0, 0x88, 0x19, 0x1e, 0xf3, 0x47, 0x36, 0x57, 0x4a, 0x16, 0x11, 0xb3, 0x24, 0x18, 0xba, 0xa4, + 0x23, 0xf6, 0x5b, 0x50, 0x60, 0x67, 0x96, 0xc9, 0x9c, 0x2e, 0x93, 0xb8, 0x25, 0xc4, 0xe5, 0x03, + 0x22, 0x82, 0xde, 0x85, 0xe2, 0xd0, 0x73, 0x87, 0xae, 0xcf, 0x3c, 0x83, 0x9a, 0xa6, 0xc7, 0x7c, + 0xbf, 0x54, 0x94, 0xfa, 0x02, 0x7a, 0x5d, 0x92, 0xab, 0xbf, 0x8e, 0x41, 0x42, 0x04, 0x91, 0x14, + 0x21, 0xce, 0xcf, 0xfd, 0x92, 0x56, 0x89, 0x6f, 0xe7, 0x75, 0xf1, 0x97, 0xf4, 0xa1, 0x64, 0x39, + 0x9c, 0x79, 0x03, 0x66, 0x5a, 0x94, 0x33, 0xc3, 0xe7, 0xe2, 0xd7, 0x73, 0x5d, 0x2e, 0x9b, 0x31, + 0xf7, 0x68, 0x7b, 0xba, 0x12, 0x9a, 0x11, 0x89, 0xb6, 0x10, 0xd0, 0x05, 0x5e, 0x15, 0xd9, 0x9a, + 0x35, 0x93, 0x4b, 0x3e, 0x85, 0x4c, 0x60, 0xbf, 0x6a, 0xe8, 0xf2, 0xb4, 0xe6, 0x7d, 0x85, 0x38, + 0xb0, 0x7c, 0xae, 0xf4, 0x85, 0x52, 0xe4, 0x63, 0xc8, 0x0c, 0x98, 0xef, 0xd3, 0x1e, 0xf3, 0xc3, + 0xa6, 0x99, 0xd2, 0x70, 0xa8, 0x10, 0x81, 0x74, 0x20, 0x51, 0xfd, 0x97, 0x06, 0x99, 0x40, 0x3d, + 0xa1, 0x70, 0xcf, 0x1c, 0x0d, 0x6d, 0xab, 0x2b, 0xbc, 0x3d, 0x73, 0x39, 0x33, 0x42, 0xdb, 0xe4, + 0x28, 0x78, 0x67, 0x5a, 0xf3, 0x5e, 0x20, 0x70, 0xea, 0x72, 0x16, 0x68, 0x7a, 0xb2, 0xa0, 0xaf, + 0x9a, 0xb3, 0x18, 0xc4, 0x81, 0x07, 0xb6, 0xe8, 0x73, 0xa3, 0x6b, 0x5b, 0xcc, 0xe1, 0x06, 0xe5, + 0x9c, 0x76, 0x9f, 0x8d, 0xcf, 0x91, 0xd1, 0x7d, 0x7f, 0xfa, 0x9c, 0x03, 0x21, 0xb5, 0x8b, 0x42, + 0x75, 0x94, 0x89, 0x9c, 0xb5, 0x6e, 0xcf, 0x63, 0x36, 0x92, 0x10, 0xf7, 0x47, 0x83, 0xea, 0xcb, + 0x18, 0xac, 0xce, 0xb4, 0x94, 0x7c, 0x08, 0x29, 0xf4, 0x94, 0x2a, 0x17, 0xd7, 0xa6, 0x8f, 0x16, + 0x78, 0x3d, 0x29, 0x50, 0xf5, 0x10, 0xde, 0x51, 0x96, 0xbe, 0x11, 0xde, 0x20, 0x1f, 0x00, 0xc1, + 0xe9, 0x2f, 0xa2, 0x69, 0x39, 0x3d, 0x63, 0xe8, 0x3e, 0x67, 0x9e, 0x9a, 0x78, 0x45, 0xe4, 0x9c, + 0x22, 0xa3, 0x25, 0xe8, 0x13, 0xad, 0xaa, 0xa0, 0x09, 0x84, 0x8e, 0x5b, 0x55, 0x02, 0x1b, 0x90, + 0x0d, 0xaf, 0x39, 0x35, 0xe6, 0xde, 0x6e, 0x52, 0x8e, 0xc5, 0xaa, 0x7f, 0x8a, 0xc1, 0xfa, 0xdc, + 0xa0, 0x92, 0x26, 0x2c, 0x77, 0x5d, 0xe7, 0xa9, 0x6d, 0x75, 0xd1, 0x6e, 0x9c, 0xa9, 0x2a, 0x42, + 0x0f, 0xe6, 0x24, 0x07, 0x47, 0xa8, 0x5e, 0x8c, 0x88, 0x21, 0x45, 0xf4, 0xad, 0x98, 0x7d, 0xae, + 0x63, 0xa8, 0x81, 0x1f, 0x43, 0x9f, 0xf2, 0x92, 0xf8, 0x44, 0x8e, 0xfd, 0x23, 0x58, 0xe9, 0x5c, + 0xbc, 0xa0, 0x0e, 0xb7, 0x1c, 0x16, 0x99, 0x40, 0xa5, 0x78, 0x25, 0xbe, 0x9d, 0x7b, 0x74, 0x7f, + 0x46, 0x94, 0x03, 0x8c, 0xfe, 0x8d, 0x50, 0x70, 0x3c, 0x9e, 0xe6, 0x04, 0x3e, 0x31, 0x27, 0xf0, + 0x77, 0x11, 0xcf, 0x03, 0xc8, 0x47, 0xfb, 0x54, 0xf4, 0x65, 0xa4, 0x7b, 0xe2, 0xb3, 0xfb, 0x32, + 0xac, 0xd3, 0x1b, 0x5d, 0x5d, 0xfd, 0x04, 0xd6, 0x66, 0xcf, 0x13, 0xf2, 0x6d, 0x58, 0xf4, 0xe8, + 0x73, 0x39, 0x8c, 0x0c, 0xdb, 0xf2, 0xb9, 0x1a, 0x5c, 0x79, 0x8f, 0x3e, 0x47, 0x84, 0x38, 0xbd, + 0xfa, 0x53, 0xc8, 0x04, 0x3d, 0x4f, 0x3e, 0x81, 0x42, 0xd0, 0xef, 0x63, 0x81, 0x99, 0x17, 0xa3, + 0x12, 0xd1, 0xf3, 0x01, 0x1e, 0x75, 0x7d, 0x0a, 0x69, 0xc5, 0x20, 0xdf, 0x84, 0xbc, 0x43, 0x07, + 0xcc, 0x1f, 0xd2, 0x2e, 0x13, 0x57, 0xac, 0xdc, 0x21, 0x72, 0x21, 0xad, 0x69, 0x8a, 0xf5, 0x42, + 0xdc, 0x3d, 0xc1, 0x9e, 0x23, 0xfe, 0x57, 0x7f, 0x0e, 0x6b, 0x62, 0xd2, 0xd6, 0xcf, 0xa8, 0x65, + 0xd3, 0x8e, 0x65, 0x5b, 0xfc, 0x42, 0xdd, 0x8e, 0xf7, 0x21, 0xeb, 0xb9, 0xca, 0x1b, 0xe5, 0x48, + 0xc6, 0x73, 0xa5, 0x23, 0xe2, 0xb4, 0xae, 0x6b, 0x8f, 0x06, 0x4e, 0x38, 0x7a, 0x05, 0x3f, 0x27, + 0x69, 0x08, 0xa9, 0xfe, 0x31, 0x0e, 0x09, 0xd1, 0x70, 0xe4, 0x23, 0x48, 0x08, 0x1f, 0xd0, 0xa2, + 0xc5, 0x59, 0x17, 0x75, 0xdb, 0xea, 0x39, 0xcc, 0x3c, 0xf4, 0x7b, 0x27, 0x17, 0x43, 0xa6, 0x23, + 0x38, 0xb2, 0x84, 0xc4, 0x26, 0x96, 0x90, 0x15, 0x48, 0x7a, 0xee, 0xc8, 0x31, 0xb1, 0x53, 0x93, + 0xba, 0x7c, 0x20, 0xfb, 0x90, 0x09, 0x77, 0x8b, 0xc4, 0xff, 0xda, 0x2d, 0x96, 0x44, 0x42, 0xc5, + 0xe6, 0xa3, 0x08, 0x7a, 0xba, 0xa3, 0x56, 0x8c, 0x3b, 0x28, 0x36, 0xf2, 0x3e, 0x2c, 0x8f, 0x27, + 0x45, 0x70, 0xcf, 0xa5, 0x30, 0xe2, 0xc5, 0x90, 0xa1, 0x2e, 0xba, 0xc9, 0xb1, 0x22, 0xf7, 0xcc, + 0x34, 0xfa, 0x35, 0x1e, 0x2b, 0x4d, 0x5c, 0x38, 0x1f, 0x40, 0xd6, 0xb7, 0x7a, 0x0e, 0xe5, 0x23, + 0x8f, 0xe1, 0xc6, 0x91, 0xd7, 0xc7, 0x04, 0xf2, 0x18, 0x96, 0x6e, 0x6e, 0x45, 0xd9, 0xb7, 0xdb, + 0x8a, 0x0a, 0xc3, 0xe8, 0x63, 0xf5, 0x0f, 0x31, 0x48, 0xc9, 0xb5, 0x27, 0x92, 0x00, 0x6d, 0x76, + 0x02, 0x62, 0xf3, 0x12, 0x10, 0xbf, 0x7d, 0x02, 0xea, 0x00, 0xa1, 0x57, 0xe2, 0xce, 0x9c, 0x33, + 0x61, 0xa4, 0x89, 0x6d, 0xab, 0xa7, 0x9a, 0x33, 0x22, 0x44, 0xb6, 0x20, 0x27, 0x43, 0x20, 0x37, + 0x91, 0x24, 0xc6, 0x0a, 0x24, 0x09, 0xf7, 0x90, 0x19, 0xc1, 0x4a, 0xdd, 0x2a, 0x58, 0x7f, 0xd7, + 0x20, 0x1b, 0x5a, 0x42, 0xea, 0x50, 0x08, 0x22, 0x60, 0x3c, 0xb5, 0x69, 0x4f, 0x95, 0xfb, 0xe6, + 0xdc, 0x30, 0x7c, 0x66, 0xd3, 0x9e, 0x9e, 0x53, 0x9e, 0x8b, 0x87, 0xd9, 0xa5, 0x13, 0x9b, 0x53, + 0x3a, 0x13, 0xb5, 0x1a, 0xbf, 0x5d, 0xad, 0x4e, 0x54, 0x55, 0xe2, 0x46, 0x55, 0x55, 0xff, 0x1c, + 0x87, 0x4c, 0x0b, 0x37, 0x33, 0x6a, 0x7f, 0x1d, 0x4d, 0x7c, 0x1f, 0xb2, 0x43, 0xd7, 0x36, 0x24, + 0x27, 0x81, 0x9c, 0xcc, 0xd0, 0xb5, 0xf5, 0xa9, 0x02, 0x4b, 0xde, 0x51, 0x87, 0xa7, 0xee, 0x20, + 0x6a, 0xe9, 0x9b, 0xbd, 0xd8, 0x16, 0x1b, 0x7f, 0x50, 0x58, 0x99, 0x79, 0x1b, 0xe9, 0xec, 0x99, + 0xdb, 0xc8, 0x5f, 0xbf, 0xda, 0xca, 0xec, 0xd5, 0x55, 0xbd, 0x65, 0x4c, 0xaa, 0x66, 0xf1, 0x9d, + 0x35, 0xb8, 0x07, 0x79, 0x99, 0x28, 0xa5, 0xf8, 0xa1, 0xc8, 0x10, 0xea, 0xd3, 0xa6, 0xdf, 0x59, + 0xa5, 0x3e, 0xa5, 0x48, 0xe1, 0x84, 0x84, 0x7c, 0x5f, 0x52, 0x6b, 0x56, 0x69, 0x5e, 0x7b, 0xea, + 0x0a, 0x57, 0xfd, 0xb7, 0x06, 0x30, 0x5e, 0x43, 0xc4, 0xcb, 0xa0, 0x8f, 0x26, 0x18, 0x13, 0x27, + 0x97, 0xe7, 0x95, 0x94, 0x3a, 0x3f, 0xef, 0x47, 0xed, 0xde, 0x85, 0xc2, 0xb8, 0x55, 0x7c, 0x16, + 0x18, 0x53, 0x7e, 0xc3, 0x36, 0xd2, 0x66, 0x5c, 0xcf, 0x9f, 0x45, 0x9e, 0x26, 0x53, 0x15, 0xbf, + 0x9b, 0x54, 0x55, 0xff, 0x12, 0x83, 0x2c, 0x3a, 0x7a, 0xc8, 0x38, 0x9d, 0x28, 0x5b, 0xed, 0xf6, + 0x65, 0xbb, 0x09, 0x20, 0xd5, 0xf8, 0xd6, 0x0b, 0xa6, 0x9a, 0x29, 0x8b, 0x94, 0xb6, 0xf5, 0x82, + 0x91, 0x1f, 0x84, 0x59, 0x8c, 0xbf, 0x39, 0x8b, 0x6a, 0x5e, 0x06, 0xb9, 0xbc, 0x07, 0x69, 0xf1, + 0x5a, 0x2b, 0x5e, 0xb1, 0xe4, 0xfe, 0x95, 0x72, 0x46, 0x83, 0x93, 0x73, 0x9f, 0xec, 0x47, 0x23, + 0x93, 0xfc, 0xff, 0x22, 0xf3, 0xe6, 0xb2, 0xbd, 0xdd, 0xa8, 0xfd, 0x15, 0xa4, 0x4f, 0xce, 0xf1, + 0xdb, 0x89, 0x5c, 0x4b, 0x5c, 0xf5, 0xb6, 0x2e, 0x97, 0x9c, 0x8c, 0x20, 0xe0, 0x6c, 0x9f, 0xb1, + 0xe1, 0x90, 0xda, 0x5b, 0x7e, 0x95, 0x51, 0xdf, 0x63, 0xde, 0xfb, 0xab, 0x06, 0xb9, 0xc8, 0x88, + 0x26, 0xdf, 0x83, 0xd5, 0xc6, 0xc1, 0xf1, 0xee, 0xe7, 0x46, 0x73, 0xcf, 0xf8, 0xec, 0xa0, 0xfe, + 0xd8, 0xf8, 0xe2, 0xe8, 0xf3, 0xa3, 0xe3, 0x9f, 0x1d, 0x15, 0x17, 0x36, 0xd6, 0x2e, 0xaf, 0x2a, + 0x24, 0x82, 0xfd, 0xc2, 0x79, 0xe6, 0xb8, 0xcf, 0x1d, 0xb2, 0x03, 0x2b, 0x93, 0x22, 0xf5, 0x46, + 0x7b, 0xff, 0xe8, 0xa4, 0xa8, 0x6d, 0xac, 0x5e, 0x5e, 0x55, 0x96, 0x23, 0x12, 0xf5, 0x8e, 0xcf, + 0x1c, 0x3e, 0x2d, 0xb0, 0x7b, 0x7c, 0x78, 0xd8, 0x3c, 0x29, 0xc6, 0xa6, 0x04, 0xd4, 0xed, 0xfc, + 0x2e, 0x2c, 0x4f, 0x0a, 0x1c, 0x35, 0x0f, 0x8a, 0xf1, 0x0d, 0x72, 0x79, 0x55, 0x59, 0x8c, 0xa0, + 0x8f, 0x2c, 0x7b, 0x23, 0xf3, 0x9b, 0xdf, 0x96, 0x17, 0x7e, 0xff, 0xbb, 0xb2, 0x26, 0x3c, 0x2b, + 0x4c, 0x8c, 0x69, 0xf2, 0x01, 0xdc, 0x6b, 0x37, 0x1f, 0x1f, 0xed, 0xef, 0x19, 0x87, 0xed, 0xc7, + 0xc6, 0xc9, 0x2f, 0x5a, 0xfb, 0x11, 0xef, 0x96, 0x2e, 0xaf, 0x2a, 0x39, 0xe5, 0xd2, 0x3c, 0x74, + 0x4b, 0xdf, 0x3f, 0x3d, 0x3e, 0xd9, 0x2f, 0x6a, 0x12, 0xdd, 0xf2, 0x98, 0x78, 0xbb, 0x42, 0xf4, + 0x43, 0x58, 0x9f, 0x81, 0x0e, 0x1d, 0x5b, 0xbe, 0xbc, 0xaa, 0x14, 0x5a, 0x1e, 0x93, 0x43, 0x02, + 0x25, 0x6a, 0x50, 0x9a, 0x96, 0x38, 0x6e, 0x1d, 0xb7, 0xeb, 0x07, 0xc5, 0xca, 0x46, 0xf1, 0xf2, + 0xaa, 0x92, 0x0f, 0xee, 0x23, 0x81, 0x1f, 0x7b, 0xd6, 0x38, 0xfd, 0xf2, 0xba, 0xac, 0x7d, 0x75, + 0x5d, 0xd6, 0xfe, 0x79, 0x5d, 0xd6, 0x5e, 0xbe, 0x2e, 0x2f, 0x7c, 0xf5, 0xba, 0xbc, 0xf0, 0xb7, + 0xd7, 0xe5, 0x85, 0x5f, 0x7e, 0xdc, 0xb3, 0x78, 0x7f, 0xd4, 0xa9, 0x75, 0xdd, 0xc1, 0x8e, 0x4d, + 0x5f, 0x5c, 0xd8, 0xcc, 0xec, 0x31, 0x2f, 0xf2, 0xf7, 0xc3, 0xae, 0xeb, 0xa9, 0x6f, 0x94, 0x3b, + 0x37, 0x3f, 0x28, 0x76, 0x52, 0x48, 0xff, 0xe8, 0xbf, 0x01, 0x00, 0x00, 0xff, 0xff, 0x0c, 0x11, + 0x7f, 0xd5, 0x11, 0x15, 0x00, 0x00, } func (m *PartSetHeader) Marshal() (dAtA []byte, err error) { @@ -1889,67 +1898,81 @@ func (m *Header) MarshalToSizedBuffer(dAtA []byte) (int, error) { copy(dAtA[i:], m.ProposerAddress) i = encodeVarintTypes(dAtA, i, uint64(len(m.ProposerAddress))) i-- - dAtA[i] = 0x7a + dAtA[i] = 0x1 + i-- + dAtA[i] = 0x82 } if len(m.EvidenceHash) > 0 { i -= len(m.EvidenceHash) copy(dAtA[i:], m.EvidenceHash) i = encodeVarintTypes(dAtA, i, uint64(len(m.EvidenceHash))) i-- - dAtA[i] = 0x72 + dAtA[i] = 0x7a } if len(m.LastResultsHash) > 0 { i -= len(m.LastResultsHash) copy(dAtA[i:], m.LastResultsHash) i = encodeVarintTypes(dAtA, i, uint64(len(m.LastResultsHash))) i-- - dAtA[i] = 0x6a + dAtA[i] = 0x72 } if len(m.AppHash) > 0 { i -= len(m.AppHash) copy(dAtA[i:], m.AppHash) i = encodeVarintTypes(dAtA, i, uint64(len(m.AppHash))) i-- - dAtA[i] = 0x62 + dAtA[i] = 0x6a } if len(m.ConsensusHash) > 0 { i -= len(m.ConsensusHash) copy(dAtA[i:], m.ConsensusHash) i = encodeVarintTypes(dAtA, i, uint64(len(m.ConsensusHash))) i-- - dAtA[i] = 0x5a + dAtA[i] = 0x62 } if len(m.NextValidatorsHash) > 0 { i -= len(m.NextValidatorsHash) copy(dAtA[i:], m.NextValidatorsHash) i = encodeVarintTypes(dAtA, i, uint64(len(m.NextValidatorsHash))) i-- - dAtA[i] = 0x52 + dAtA[i] = 0x5a } if len(m.ValidatorsHash) > 0 { i -= len(m.ValidatorsHash) copy(dAtA[i:], m.ValidatorsHash) i = encodeVarintTypes(dAtA, i, uint64(len(m.ValidatorsHash))) i-- - dAtA[i] = 0x4a + dAtA[i] = 0x52 } if len(m.DataHash) > 0 { i -= len(m.DataHash) copy(dAtA[i:], m.DataHash) i = encodeVarintTypes(dAtA, i, uint64(len(m.DataHash))) i-- - dAtA[i] = 0x42 + dAtA[i] = 0x4a } if m.NumOriginalDataShares != 0 { i = encodeVarintTypes(dAtA, i, uint64(m.NumOriginalDataShares)) i-- - dAtA[i] = 0x38 + dAtA[i] = 0x40 } if len(m.LastCommitHash) > 0 { i -= len(m.LastCommitHash) copy(dAtA[i:], m.LastCommitHash) i = encodeVarintTypes(dAtA, i, uint64(len(m.LastCommitHash))) i-- + dAtA[i] = 0x3a + } + if m.LastPartSetHeader != nil { + { + size, err := m.LastPartSetHeader.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintTypes(dAtA, i, uint64(size)) + } + i-- dAtA[i] = 0x32 } { @@ -1962,12 +1985,12 @@ func (m *Header) MarshalToSizedBuffer(dAtA []byte) (int, error) { } i-- dAtA[i] = 0x2a - n3, err3 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Time, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Time):]) - if err3 != nil { - return 0, err3 + n4, err4 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Time, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Time):]) + if err4 != nil { + return 0, err4 } - i -= n3 - i = encodeVarintTypes(dAtA, i, uint64(n3)) + i -= n4 + i = encodeVarintTypes(dAtA, i, uint64(n4)) i-- dAtA[i] = 0x22 if m.Height != 0 { @@ -2151,12 +2174,12 @@ func (m *DuplicateVoteEvidence) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l - n10, err10 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) - if err10 != nil { - return 0, err10 + n11, err11 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) + if err11 != nil { + return 0, err11 } - i -= n10 - i = encodeVarintTypes(dAtA, i, uint64(n10)) + i -= n11 + i = encodeVarintTypes(dAtA, i, uint64(n11)) i-- dAtA[i] = 0x2a if m.ValidatorPower != 0 { @@ -2216,12 +2239,12 @@ func (m *LightClientAttackEvidence) MarshalToSizedBuffer(dAtA []byte) (int, erro _ = i var l int _ = l - n13, err13 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) - if err13 != nil { - return 0, err13 + n14, err14 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) + if err14 != nil { + return 0, err14 } - i -= n13 - i = encodeVarintTypes(dAtA, i, uint64(n13)) + i -= n14 + i = encodeVarintTypes(dAtA, i, uint64(n14)) i-- dAtA[i] = 0x2a if m.TotalVotingPower != 0 { @@ -2498,12 +2521,12 @@ func (m *Vote) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x32 } - n16, err16 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) - if err16 != nil { - return 0, err16 + n17, err17 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) + if err17 != nil { + return 0, err17 } - i -= n16 - i = encodeVarintTypes(dAtA, i, uint64(n16)) + i -= n17 + i = encodeVarintTypes(dAtA, i, uint64(n17)) i-- dAtA[i] = 0x2a { @@ -2637,12 +2660,12 @@ func (m *CommitSig) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x22 } - n20, err20 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) - if err20 != nil { - return 0, err20 + n21, err21 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) + if err21 != nil { + return 0, err21 } - i -= n20 - i = encodeVarintTypes(dAtA, i, uint64(n20)) + i -= n21 + i = encodeVarintTypes(dAtA, i, uint64(n21)) i-- dAtA[i] = 0x1a if len(m.ValidatorAddress) > 0 { @@ -2711,12 +2734,12 @@ func (m *Proposal) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x3a } - n23, err23 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) - if err23 != nil { - return 0, err23 + n24, err24 := github_com_gogo_protobuf_types.StdTimeMarshalTo(m.Timestamp, dAtA[i-github_com_gogo_protobuf_types.SizeOfStdTime(m.Timestamp):]) + if err24 != nil { + return 0, err24 } - i -= n23 - i = encodeVarintTypes(dAtA, i, uint64(n23)) + i -= n24 + i = encodeVarintTypes(dAtA, i, uint64(n24)) i-- dAtA[i] = 0x32 { @@ -3061,6 +3084,10 @@ func (m *Header) Size() (n int) { n += 1 + l + sovTypes(uint64(l)) l = m.LastBlockId.Size() n += 1 + l + sovTypes(uint64(l)) + if m.LastPartSetHeader != nil { + l = m.LastPartSetHeader.Size() + n += 1 + l + sovTypes(uint64(l)) + } l = len(m.LastCommitHash) if l > 0 { n += 1 + l + sovTypes(uint64(l)) @@ -3098,7 +3125,7 @@ func (m *Header) Size() (n int) { } l = len(m.ProposerAddress) if l > 0 { - n += 1 + l + sovTypes(uint64(l)) + n += 2 + l + sovTypes(uint64(l)) } return n } @@ -4017,6 +4044,42 @@ func (m *Header) Unmarshal(dAtA []byte) error { } iNdEx = postIndex case 6: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LastPartSetHeader", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTypes + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthTypes + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthTypes + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.LastPartSetHeader == nil { + m.LastPartSetHeader = &PartSetHeader{} + } + if err := m.LastPartSetHeader.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 7: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field LastCommitHash", wireType) } @@ -4050,7 +4113,7 @@ func (m *Header) Unmarshal(dAtA []byte) error { m.LastCommitHash = []byte{} } iNdEx = postIndex - case 7: + case 8: if wireType != 0 { return fmt.Errorf("proto: wrong wireType = %d for field NumOriginalDataShares", wireType) } @@ -4069,7 +4132,7 @@ func (m *Header) Unmarshal(dAtA []byte) error { break } } - case 8: + case 9: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field DataHash", wireType) } @@ -4103,7 +4166,7 @@ func (m *Header) Unmarshal(dAtA []byte) error { m.DataHash = []byte{} } iNdEx = postIndex - case 9: + case 10: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field ValidatorsHash", wireType) } @@ -4137,7 +4200,7 @@ func (m *Header) Unmarshal(dAtA []byte) error { m.ValidatorsHash = []byte{} } iNdEx = postIndex - case 10: + case 11: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field NextValidatorsHash", wireType) } @@ -4171,7 +4234,7 @@ func (m *Header) Unmarshal(dAtA []byte) error { m.NextValidatorsHash = []byte{} } iNdEx = postIndex - case 11: + case 12: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field ConsensusHash", wireType) } @@ -4205,7 +4268,7 @@ func (m *Header) Unmarshal(dAtA []byte) error { m.ConsensusHash = []byte{} } iNdEx = postIndex - case 12: + case 13: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field AppHash", wireType) } @@ -4239,7 +4302,7 @@ func (m *Header) Unmarshal(dAtA []byte) error { m.AppHash = []byte{} } iNdEx = postIndex - case 13: + case 14: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field LastResultsHash", wireType) } @@ -4273,7 +4336,7 @@ func (m *Header) Unmarshal(dAtA []byte) error { m.LastResultsHash = []byte{} } iNdEx = postIndex - case 14: + case 15: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field EvidenceHash", wireType) } @@ -4307,7 +4370,7 @@ func (m *Header) Unmarshal(dAtA []byte) error { m.EvidenceHash = []byte{} } iNdEx = postIndex - case 15: + case 16: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field ProposerAddress", wireType) } diff --git a/proto/tendermint/types/types.proto b/proto/tendermint/types/types.proto index a809aeb56a..e290222e96 100644 --- a/proto/tendermint/types/types.proto +++ b/proto/tendermint/types/types.proto @@ -63,22 +63,23 @@ message Header { // prev block info BlockID last_block_id = 5 [(gogoproto.nullable) = false]; + PartSetHeader last_part_set_header = 6; // hashes of block data - bytes last_commit_hash = 6; // commit from validators from the last block - uint64 num_original_data_shares = 7; // number of shares used in the original data square - bytes data_hash = 8; // transactions + bytes last_commit_hash = 7; // commit from validators from the last block + uint64 num_original_data_shares = 8; // number of shares used in the original data square + bytes data_hash = 9; // transactions // hashes from the app output from the prev block - bytes validators_hash = 9; // validators for the current block - bytes next_validators_hash = 10; // validators for the next block - bytes consensus_hash = 11; // consensus params for current block - bytes app_hash = 12; // state after txs from the previous block - bytes last_results_hash = 13; // root hash of all results from the txs from the previous block + bytes validators_hash = 10; // validators for the current block + bytes next_validators_hash = 11; // validators for the next block + bytes consensus_hash = 12; // consensus params for current block + bytes app_hash = 13; // state after txs from the previous block + bytes last_results_hash = 14; // root hash of all results from the txs from the previous block // consensus info - bytes evidence_hash = 14; // evidence included in the block - bytes proposer_address = 15; // original proposer of the block + bytes evidence_hash = 15; // evidence included in the block + bytes proposer_address = 16; // original proposer of the block } // Data contains the set of transactions included in the block diff --git a/state/state.go b/state/state.go index db5ed26ecf..ab91764e02 100644 --- a/state/state.go +++ b/state/state.go @@ -268,7 +268,7 @@ func (state State) MakeBlock( // Fill rest of header with state data. block.Header.Populate( state.Version.Consensus, state.ChainID, - timestamp, state.LastBlockID, + timestamp, state.LastBlockID, state.LastPartSetHeader, state.Validators.Hash(), state.NextValidators.Hash(), types.HashConsensusParams(state.ConsensusParams), state.AppHash, state.LastResultsHash, proposerAddress, diff --git a/state/tx_filter_test.go b/state/tx_filter_test.go index 4ae7279839..f9464702be 100644 --- a/state/tx_filter_test.go +++ b/state/tx_filter_test.go @@ -14,7 +14,7 @@ import ( func TestTxFilter(t *testing.T) { genDoc := randomGenesisDoc() - genDoc.ConsensusParams.Block.MaxBytes = 3000 + genDoc.ConsensusParams.Block.MaxBytes = 3001 genDoc.ConsensusParams.Evidence.MaxBytes = 1500 // Max size of Txs is much smaller than size of block, @@ -24,7 +24,7 @@ func TestTxFilter(t *testing.T) { isErr bool }{ {types.Tx(tmrand.Bytes(2139)), false}, - {types.Tx(tmrand.Bytes(2190)), true}, + {types.Tx(tmrand.Bytes(2150)), true}, {types.Tx(tmrand.Bytes(3000)), true}, } diff --git a/state/validation.go b/state/validation.go index 80c9d58037..741777e984 100644 --- a/state/validation.go +++ b/state/validation.go @@ -49,6 +49,13 @@ func validateBlock(state State, block *types.Block) error { ) } + if !block.LastPartSetHeader.Equals(state.LastPartSetHeader) { + return fmt.Errorf("wrong Block.Header.LastPartSetHeader. Expected %v, got %v", + state.LastPartSetHeader, + block.LastPartSetHeader, + ) + } + // Validate app info if !bytes.Equal(block.AppHash, state.AppHash) { return fmt.Errorf("wrong Block.Header.AppHash. Expected %X, got %v", diff --git a/state/validation_test.go b/state/validation_test.go index faeb8015f7..6f6886e2b6 100644 --- a/state/validation_test.go +++ b/state/validation_test.go @@ -57,6 +57,7 @@ func TestValidateBlockHeader(t *testing.T) { {"Time wrong", func(block *types.Block) { block.Time = block.Time.Add(-time.Second * 1) }}, {"Time wrong 2", func(block *types.Block) { block.Time = block.Time.Add(time.Second * 1) }}, + {"LastBlockID wrong", func(block *types.Block) { block.LastPartSetHeader.Total += 10 }}, {"LastCommitHash wrong", func(block *types.Block) { block.LastCommitHash = wrongHash }}, {"DataHash wrong", func(block *types.Block) { block.DataHash = wrongHash }}, diff --git a/types/block.go b/types/block.go index 33a058a5f8..780ab0ff93 100644 --- a/types/block.go +++ b/types/block.go @@ -32,7 +32,7 @@ const ( // MaxHeaderBytes is a maximum header size. // NOTE: Because app hash can be of arbitrary size, the header is therefore not // capped in size and thus this number should be seen as a soft max - MaxHeaderBytes int64 = 594 + MaxHeaderBytes int64 = 637 // MaxOverheadForBlock - maximum overhead to encode a block (up to // MaxBlockSizeBytes in size) not including it's parts except Data. @@ -513,7 +513,8 @@ type Header struct { Time time.Time `json:"time"` // prev block info - LastBlockID BlockID `json:"last_block_id"` + LastBlockID BlockID `json:"last_block_id"` + LastPartSetHeader PartSetHeader `json:"last_part_set_header"` // hashes of block data LastCommitHash tmbytes.HexBytes `json:"last_commit_hash"` // commit from validators from the last block @@ -543,6 +544,7 @@ func (h *Header) Populate( chainID string, timestamp time.Time, lastBlockID BlockID, + lastPartSetHeader PartSetHeader, valHash, nextValHash []byte, consensusHash, appHash, lastResultsHash []byte, proposerAddress Address, @@ -550,6 +552,7 @@ func (h *Header) Populate( h.Version = version h.ChainID = chainID h.Time = timestamp + h.LastPartSetHeader = lastPartSetHeader h.LastBlockID = lastBlockID h.ValidatorsHash = valHash h.NextValidatorsHash = nextValHash @@ -581,6 +584,10 @@ func (h Header) ValidateBasic() error { return fmt.Errorf("wrong LastBlockID: %w", err) } + if err := h.LastPartSetHeader.ValidateBasic(); err != nil { + return fmt.Errorf("wrong PartSetHeader: %w", err) + } + if err := ValidateHash(h.LastCommitHash); err != nil { return fmt.Errorf("wrong LastCommitHash: %v", err) } @@ -645,12 +652,19 @@ func (h *Header) Hash() tmbytes.HexBytes { return nil } + pbpsh := h.LastPartSetHeader.ToProto() + bzpsh, err := pbpsh.Marshal() + if err != nil { + return nil + } + return merkle.HashFromByteSlices([][]byte{ hbz, cdcEncode(h.ChainID), cdcEncode(h.Height), pbt, bzbi, + bzpsh, cdcEncode(h.LastCommitHash), cdcEncode(h.DataHash), cdcEncode(h.NumOriginalDataShares), @@ -675,6 +689,7 @@ func (h *Header) StringIndented(indent string) string { %s Height: %v %s Time: %v %s LastBlockID: %v +%s LastPartSetHeader: %v %s LastCommit: %v %s Data: %v %s Validators: %v @@ -690,6 +705,7 @@ func (h *Header) StringIndented(indent string) string { indent, h.Height, indent, h.Time, indent, h.LastBlockID, + indent, h.LastPartSetHeader, indent, h.LastCommitHash, indent, h.DataHash, indent, h.ValidatorsHash, @@ -708,12 +724,15 @@ func (h *Header) ToProto() *tmproto.Header { return nil } + ppsh := h.LastPartSetHeader.ToProto() + return &tmproto.Header{ Version: h.Version, ChainID: h.ChainID, Height: h.Height, Time: h.Time, LastBlockId: h.LastBlockID.ToProto(), + LastPartSetHeader: &ppsh, ValidatorsHash: h.ValidatorsHash, NextValidatorsHash: h.NextValidatorsHash, ConsensusHash: h.ConsensusHash, @@ -741,12 +760,18 @@ func HeaderFromProto(ph *tmproto.Header) (Header, error) { return Header{}, err } + lpsh, err := PartSetHeaderFromProto(ph.LastPartSetHeader) + if err != nil { + return Header{}, err + } + h.Version = ph.Version h.ChainID = ph.ChainID h.Height = ph.Height h.Time = ph.Time h.Height = ph.Height h.LastBlockID = *bi + h.LastPartSetHeader = *lpsh h.ValidatorsHash = ph.ValidatorsHash h.NextValidatorsHash = ph.NextValidatorsHash h.ConsensusHash = ph.ConsensusHash diff --git a/types/block_test.go b/types/block_test.go index 214ef1fbcd..47f5021b07 100644 --- a/types/block_test.go +++ b/types/block_test.go @@ -351,6 +351,7 @@ func TestHeaderHash(t *testing.T) { Height: 3, Time: time.Date(2019, 10, 13, 16, 14, 44, 0, time.UTC), LastBlockID: makeBlockID(make([]byte, tmhash.Size)), + LastPartSetHeader: makePartSetHeader(6, make([]byte, tmhash.Size)), LastCommitHash: tmhash.Sum([]byte("last_commit_hash")), DataHash: tmhash.Sum([]byte("data_hash")), NumOriginalDataShares: 4, @@ -361,7 +362,7 @@ func TestHeaderHash(t *testing.T) { LastResultsHash: tmhash.Sum([]byte("last_results_hash")), EvidenceHash: tmhash.Sum([]byte("evidence_hash")), ProposerAddress: crypto.AddressHash([]byte("proposer_address")), - }, hexBytesFromString("0E5747B09FE96A3F1DC58DBB137A82825B6E046A753D52FBB0F4C692D5F6F57E")}, + }, hexBytesFromString("CBE1A9A83217E1EEDE92B9F85B6519B6DA2B2AC8BF69421A1CB0227C5CD3B353")}, {"nil header yields nil", nil, nil}, {"nil ValidatorsHash yields nil", &Header{ Version: tmversion.Consensus{Block: 1, App: 2}, @@ -369,6 +370,7 @@ func TestHeaderHash(t *testing.T) { Height: 3, Time: time.Date(2019, 10, 13, 16, 14, 44, 0, time.UTC), LastBlockID: makeBlockID(make([]byte, tmhash.Size)), + LastPartSetHeader: makePartSetHeader(6, make([]byte, tmhash.Size)), LastCommitHash: tmhash.Sum([]byte("last_commit_hash")), DataHash: tmhash.Sum([]byte("data_hash")), ValidatorsHash: nil, @@ -449,6 +451,7 @@ func TestMaxHeaderBytes(t *testing.T) { Height: math.MaxInt64, Time: timestamp, LastBlockID: makeBlockID(make([]byte, tmhash.Size)), + LastPartSetHeader: makePartSetHeader(math.MaxInt32, make([]byte, tmhash.Size)), LastCommitHash: tmhash.Sum([]byte("last_commit_hash")), DataHash: tmhash.Sum([]byte("data_hash")), NumOriginalDataShares: math.MaxInt64, @@ -497,11 +500,11 @@ func TestBlockMaxDataBytes(t *testing.T) { }{ 0: {-10, 1, 0, true, 0}, 1: {10, 1, 0, true, 0}, - 2: {808, 1, 0, true, 0}, - 3: {810, 1, 0, false, 0}, - 4: {811, 1, 0, false, 1}, - 5: {922, 2, 0, false, 1}, - 6: {1021, 2, 100, false, 0}, + 2: {851, 1, 0, true, 0}, + 3: {853, 1, 0, false, 0}, + 4: {854, 1, 0, false, 1}, + 5: {965, 2, 0, false, 1}, + 6: {1064, 2, 100, false, 0}, } for i, tc := range testCases { @@ -528,9 +531,9 @@ func TestBlockMaxDataBytesNoEvidence(t *testing.T) { }{ 0: {-10, 1, true, 0}, 1: {10, 1, true, 0}, - 2: {808, 1, true, 0}, - 3: {810, 1, false, 0}, - 4: {811, 1, false, 1}, + 2: {851, 1, true, 0}, + 3: {853, 1, false, 0}, + 4: {854, 1, false, 1}, } for i, tc := range testCases { @@ -1026,6 +1029,21 @@ func TestHeader_ValidateBasic(t *testing.T) { }, true, "wrong Hash", }, + { + "invalid block ID parts header hash", + Header{ + Version: tmversion.Consensus{Block: version.BlockProtocol}, + ChainID: string(make([]byte, MaxChainIDLen)), + Height: 1, + LastBlockID: BlockID{ + Hash: make([]byte, tmhash.Size), + }, + LastPartSetHeader: PartSetHeader{ + Hash: make([]byte, tmhash.Size+1), + }, + }, + true, "wrong PartSetHeader", + }, { "invalid last commit hash", Header{ @@ -1035,6 +1053,9 @@ func TestHeader_ValidateBasic(t *testing.T) { LastBlockID: BlockID{ Hash: make([]byte, tmhash.Size), }, + LastPartSetHeader: PartSetHeader{ + Hash: make([]byte, tmhash.Size), + }, LastCommitHash: make([]byte, tmhash.Size+1), }, true, "wrong LastCommitHash", @@ -1048,6 +1069,9 @@ func TestHeader_ValidateBasic(t *testing.T) { LastBlockID: BlockID{ Hash: make([]byte, tmhash.Size), }, + LastPartSetHeader: PartSetHeader{ + Hash: make([]byte, tmhash.Size), + }, LastCommitHash: make([]byte, tmhash.Size), DataHash: make([]byte, tmhash.Size+1), }, @@ -1062,6 +1086,9 @@ func TestHeader_ValidateBasic(t *testing.T) { LastBlockID: BlockID{ Hash: make([]byte, tmhash.Size), }, + LastPartSetHeader: PartSetHeader{ + Hash: make([]byte, tmhash.Size), + }, LastCommitHash: make([]byte, tmhash.Size), DataHash: make([]byte, tmhash.Size), EvidenceHash: make([]byte, tmhash.Size+1), @@ -1077,6 +1104,9 @@ func TestHeader_ValidateBasic(t *testing.T) { LastBlockID: BlockID{ Hash: make([]byte, tmhash.Size), }, + LastPartSetHeader: PartSetHeader{ + Hash: make([]byte, tmhash.Size), + }, LastCommitHash: make([]byte, tmhash.Size), DataHash: make([]byte, tmhash.Size), EvidenceHash: make([]byte, tmhash.Size), @@ -1093,6 +1123,9 @@ func TestHeader_ValidateBasic(t *testing.T) { LastBlockID: BlockID{ Hash: make([]byte, tmhash.Size), }, + LastPartSetHeader: PartSetHeader{ + Hash: make([]byte, tmhash.Size), + }, LastCommitHash: make([]byte, tmhash.Size), DataHash: make([]byte, tmhash.Size), EvidenceHash: make([]byte, tmhash.Size), @@ -1110,6 +1143,9 @@ func TestHeader_ValidateBasic(t *testing.T) { LastBlockID: BlockID{ Hash: make([]byte, tmhash.Size), }, + LastPartSetHeader: PartSetHeader{ + Hash: make([]byte, tmhash.Size), + }, LastCommitHash: make([]byte, tmhash.Size), DataHash: make([]byte, tmhash.Size), EvidenceHash: make([]byte, tmhash.Size), @@ -1128,6 +1164,9 @@ func TestHeader_ValidateBasic(t *testing.T) { LastBlockID: BlockID{ Hash: make([]byte, tmhash.Size), }, + LastPartSetHeader: PartSetHeader{ + Hash: make([]byte, tmhash.Size), + }, LastCommitHash: make([]byte, tmhash.Size), DataHash: make([]byte, tmhash.Size), EvidenceHash: make([]byte, tmhash.Size), @@ -1147,6 +1186,9 @@ func TestHeader_ValidateBasic(t *testing.T) { LastBlockID: BlockID{ Hash: make([]byte, tmhash.Size), }, + LastPartSetHeader: PartSetHeader{ + Hash: make([]byte, tmhash.Size), + }, LastCommitHash: make([]byte, tmhash.Size), DataHash: make([]byte, tmhash.Size), EvidenceHash: make([]byte, tmhash.Size), @@ -1167,6 +1209,9 @@ func TestHeader_ValidateBasic(t *testing.T) { LastBlockID: BlockID{ Hash: make([]byte, tmhash.Size), }, + LastPartSetHeader: PartSetHeader{ + Hash: make([]byte, tmhash.Size), + }, LastCommitHash: make([]byte, tmhash.Size), DataHash: make([]byte, tmhash.Size), EvidenceHash: make([]byte, tmhash.Size), diff --git a/types/canonical.go b/types/canonical.go index 945c80de3a..321d78b542 100644 --- a/types/canonical.go +++ b/types/canonical.go @@ -56,13 +56,15 @@ func CanonicalizeProposal(chainID string, proposal *tmproto.Proposal) tmproto.Ca // CanonicalizeVote transforms the given Vote to a CanonicalVote, which does // not contain ValidatorIndex and ValidatorAddress fields. func CanonicalizeVote(chainID string, vote *tmproto.Vote) tmproto.CanonicalVote { + cppsh := CanonicalizePartSetHeader(*vote.PartSetHeader) return tmproto.CanonicalVote{ - Type: vote.Type, - Height: vote.Height, // encoded as sfixed64 - Round: int64(vote.Round), // encoded as sfixed64 - BlockID: CanonicalizeBlockID(vote.BlockID), - Timestamp: vote.Timestamp, - ChainID: chainID, + Type: vote.Type, + Height: vote.Height, // encoded as sfixed64 + Round: int64(vote.Round), // encoded as sfixed64 + BlockID: CanonicalizeBlockID(vote.BlockID), + Timestamp: vote.Timestamp, + ChainID: chainID, + PartSetHeader: &cppsh, } } diff --git a/types/evidence_test.go b/types/evidence_test.go index d538ccb56d..cb49d669a5 100644 --- a/types/evidence_test.go +++ b/types/evidence_test.go @@ -256,6 +256,7 @@ func makeHeaderRandom() *Header { Height: int64(mrand.Uint32() + 1), Time: time.Now(), LastBlockID: makeBlockIDRandom(), + LastPartSetHeader: makePartSetHeaderRandom(), LastCommitHash: crypto.CRandBytes(tmhash.Size), DataHash: crypto.CRandBytes(tmhash.Size), ValidatorsHash: crypto.CRandBytes(tmhash.Size), diff --git a/types/protobuf.go b/types/protobuf.go index 74c7a43490..51bbcb4bc1 100644 --- a/types/protobuf.go +++ b/types/protobuf.go @@ -33,13 +33,15 @@ var TM2PB = tm2pb{} type tm2pb struct{} func (tm2pb) Header(header *Header) tmproto.Header { + lpsh := header.LastPartSetHeader.ToProto() return tmproto.Header{ Version: header.Version, ChainID: header.ChainID, Height: header.Height, Time: header.Time, - LastBlockId: header.LastBlockID.ToProto(), + LastBlockId: header.LastBlockID.ToProto(), + LastPartSetHeader: &lpsh, LastCommitHash: header.LastCommitHash, DataHash: header.DataHash, diff --git a/types/vote.go b/types/vote.go index 6bf2dbe1d6..1c82e4fbe1 100644 --- a/types/vote.go +++ b/types/vote.go @@ -180,10 +180,6 @@ func (vote *Vote) ValidateBasic() error { return fmt.Errorf("wrong PartSetHeader: %v", err) } - if err := vote.PartSetHeader.ValidateBasic(); err != nil { - return fmt.Errorf("wrong PartSetHeader: %v", err) - } - // BlockID.ValidateBasic would not err if we for instance have an empty hash but a // non-empty PartsSetHeader: if !vote.BlockID.IsZero() && !vote.BlockID.IsComplete() { diff --git a/types/vote_test.go b/types/vote_test.go index ae6207001a..b91bc79f20 100644 --- a/types/vote_test.go +++ b/types/vote_test.go @@ -67,13 +67,13 @@ func TestVoteSignBytesTestVectors(t *testing.T) { 0: { "", &Vote{}, // NOTE: Height and Round are skipped here. This case needs to be considered while parsing. - []byte{0xd, 0x2a, 0xb, 0x8, 0x80, 0x92, 0xb8, 0xc3, 0x98, 0xfe, 0xff, 0xff, 0xff, 0x1}, + []byte{0xf, 0x2a, 0xb, 0x8, 0x80, 0x92, 0xb8, 0xc3, 0x98, 0xfe, 0xff, 0xff, 0xff, 0x1, 0x3a, 0x0}, }, // with proper (fixed size) height and round (PreCommit): 1: { "", &Vote{Height: 1, Round: 1, Type: tmproto.PrecommitType}, []byte{ - 0x21, // length + 0x23, // length 0x8, // (field_number << 3) | wire_type 0x2, // PrecommitType 0x11, // (field_number << 3) | wire_type @@ -82,13 +82,13 @@ func TestVoteSignBytesTestVectors(t *testing.T) { 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, // round 0x2a, // (field_number << 3) | wire_type // remaining fields (timestamp): - 0xb, 0x8, 0x80, 0x92, 0xb8, 0xc3, 0x98, 0xfe, 0xff, 0xff, 0xff, 0x1}, + 0xb, 0x8, 0x80, 0x92, 0xb8, 0xc3, 0x98, 0xfe, 0xff, 0xff, 0xff, 0x1, 0x3a, 0x0}, }, // with proper (fixed size) height and round (PreVote): 2: { "", &Vote{Height: 1, Round: 1, Type: tmproto.PrevoteType}, []byte{ - 0x21, // length + 0x23, // length 0x8, // (field_number << 3) | wire_type 0x1, // PrevoteType 0x11, // (field_number << 3) | wire_type @@ -97,25 +97,25 @@ func TestVoteSignBytesTestVectors(t *testing.T) { 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, // round 0x2a, // (field_number << 3) | wire_type // remaining fields (timestamp): - 0xb, 0x8, 0x80, 0x92, 0xb8, 0xc3, 0x98, 0xfe, 0xff, 0xff, 0xff, 0x1}, + 0xb, 0x8, 0x80, 0x92, 0xb8, 0xc3, 0x98, 0xfe, 0xff, 0xff, 0xff, 0x1, 0x3a, 0x0}, }, 3: { "", &Vote{Height: 1, Round: 1}, []byte{ - 0x1f, // length + 0x21, // length 0x11, // (field_number << 3) | wire_type 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, // height 0x19, // (field_number << 3) | wire_type 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, // round // remaining fields (timestamp): 0x2a, - 0xb, 0x8, 0x80, 0x92, 0xb8, 0xc3, 0x98, 0xfe, 0xff, 0xff, 0xff, 0x1}, + 0xb, 0x8, 0x80, 0x92, 0xb8, 0xc3, 0x98, 0xfe, 0xff, 0xff, 0xff, 0x1, 0x3a, 0x0}, }, // containing non-empty chain_id: 4: { "test_chain_id", &Vote{Height: 1, Round: 1}, []byte{ - 0x2e, // length + 0x30, // length 0x11, // (field_number << 3) | wire_type 0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, // height 0x19, // (field_number << 3) | wire_type @@ -125,7 +125,7 @@ func TestVoteSignBytesTestVectors(t *testing.T) { 0xb, 0x8, 0x80, 0x92, 0xb8, 0xc3, 0x98, 0xfe, 0xff, 0xff, 0xff, 0x1, // timestamp // (field_number << 3) | wire_type 0x32, - 0xd, 0x74, 0x65, 0x73, 0x74, 0x5f, 0x63, 0x68, 0x61, 0x69, 0x6e, 0x5f, 0x69, 0x64}, // chainID + 0xd, 0x74, 0x65, 0x73, 0x74, 0x5f, 0x63, 0x68, 0x61, 0x69, 0x6e, 0x5f, 0x69, 0x64, 0x3a, 0x0}, // chainID }, } for i, tc := range tests { @@ -294,23 +294,3 @@ func TestVoteProtobuf(t *testing.T) { } } } - -// TestDoNotSignOverPartSetHeader simply ensures that the partset header is not signed over while voting. -func TestDoNotSignOverPartSetHeader(t *testing.T) { - pv := NewMockPV() - pubKey, err := pv.GetPubKey() - require.NoError(t, err) - blockID := randBlockID() - psh := randPartSetHeader() - currentTime := time.Now() - voteA := makeMockVote(1, 0, 0, pubKey.Address(), blockID, psh, currentTime).ToProto() - voteB := makeMockVote(1, 0, 0, pubKey.Address(), blockID, PartSetHeader{}, currentTime).ToProto() - - err = pv.SignVote("test", voteA) - require.NoError(t, err) - err = pv.SignVote("test", voteB) - require.NoError(t, err) - - require.Equal(t, voteA.Signature, voteB.Signature) - -}