From af6d72946f05c323e2c1ceb34af5b7bd4bd03113 Mon Sep 17 00:00:00 2001 From: Henrik Hautakoski Date: Tue, 9 May 2023 13:13:03 +0200 Subject: [PATCH] api/go.mod: wwitch github.com/shamaton/msgpack/v2 to github.com/ugorji/go/codec --- api/go.mod | 3 +- api/go.sum | 7 +- api/message/msgpack/codec.go | 26 +- api/message/msgpack/codec_test.go | 119 ++- api/message/msgpack/msgpack.go | 1149 ----------------------------- 5 files changed, 80 insertions(+), 1224 deletions(-) delete mode 100644 api/message/msgpack/msgpack.go diff --git a/api/go.mod b/api/go.mod index 80e82b7..44c82f2 100644 --- a/api/go.mod +++ b/api/go.mod @@ -7,9 +7,8 @@ require ( github.com/go-redis/redis/v8 v8.11.5 github.com/go-redis/redismock/v8 v8.11.5 github.com/liamylian/jsontime/v2 v2.0.0 - github.com/shamaton/msgpack/v2 v2.1.0 - github.com/shamaton/msgpackgen v0.3.0 github.com/stretchr/testify v1.8.2 + github.com/ugorji/go/codec v1.2.11 ) require ( diff --git a/api/go.sum b/api/go.sum index 850d379..b978952 100644 --- a/api/go.sum +++ b/api/go.sum @@ -7,7 +7,6 @@ github.com/cespare/xxhash/v2 v2.1.2/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XL github.com/chzyer/logex v1.1.10/go.mod h1:+Ywpsq7O8HXn0nuIou7OrIPyXbp3wmkHB+jjWRnGsAI= github.com/chzyer/readline v0.0.0-20180603132655-2972be24d48e/go.mod h1:nSuG5e5PlCu98SY8svDHJxuZscDgtXS6KTTbou5AhLI= github.com/chzyer/test v0.0.0-20180213035817-a1ea475d72b1/go.mod h1:Q3SI9o4m/ZMnBNeIyt5eFwwo7qiLfzFZmjNmxjkiQlU= -github.com/dave/jennifer v1.4.1/go.mod h1:7jEdnm+qBcxl8PC0zyp7vxcpSRnzXSt9r39tpTVGlwA= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= @@ -64,10 +63,6 @@ github.com/onsi/gomega v1.18.1 h1:M1GfJqGRrBrrGGsbxzV5dqM2U2ApXefZCQpkukxYRLE= github.com/onsi/gomega v1.18.1/go.mod h1:0q+aL8jAiMXy9hbwj2mr5GziHiwhAIQpFmmtT5hitRs= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= -github.com/shamaton/msgpack/v2 v2.1.0 h1:9jJ2eGZw2Wa9KExPX3KaDDckVjgr4zhXGFCfWagUWqg= -github.com/shamaton/msgpack/v2 v2.1.0/go.mod h1:aTUEmh31ziGX1Ml7wMPLVY0f4vT3CRsCvZRoSCs+VGg= -github.com/shamaton/msgpackgen v0.3.0 h1:q6o7prOEJFdF9BAPgkOtfzJbs55pQi7g44RUnEVUxtM= -github.com/shamaton/msgpackgen v0.3.0/go.mod h1:fd99fDDuxuTiWzkHC59uEGzrt/WDu+ltGZTbEWwVXIc= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= @@ -77,6 +72,8 @@ github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/ github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= github.com/stretchr/testify v1.8.2 h1:+h33VjcLVPDHtOdpUCuF+7gSuG3yGIftsP1YvFihtJ8= github.com/stretchr/testify v1.8.2/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= +github.com/ugorji/go/codec v1.2.11 h1:BMaWp1Bb6fHwEtbplGBGJ498wD+LKlNSl25MjdZY4dU= +github.com/ugorji/go/codec v1.2.11/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/gopher-lua v1.1.0 h1:BojcDhfyDWgU2f2TOzYK/g5p2gxMrku8oupLDqlnSqE= github.com/yuin/gopher-lua v1.1.0/go.mod h1:GBR0iDaNXjAgGg9zfCvksxSRnQx76gclCIb7kdAd1Pw= diff --git a/api/message/msgpack/codec.go b/api/message/msgpack/codec.go index b237a24..783635c 100644 --- a/api/message/msgpack/codec.go +++ b/api/message/msgpack/codec.go @@ -1,18 +1,34 @@ package msgpack import ( - "github.com/shamaton/msgpack/v2" + "reflect" + + "github.com/ugorji/go/codec" "github.com/eosswedenorg/thalos/api/message" ) -//go:generate msgpackgen -v -input-file ../types.go -output-file msgpack.go +var mh codec.MsgpackHandle + +func encode(a any) ([]byte, error) { + var b []byte + return b, codec.NewEncoderBytes(&b, &mh).Encode(a) +} + +func decode(b []byte, a any) error { + return codec.NewDecoderBytes(b, &mh).Decode(a) +} func init() { - RegisterGeneratedResolver() + mh.MapType = reflect.TypeOf(map[string]any(nil)) + mh.Canonical = true + + // Wierd name but this is needed for the newest version of msgpack + // that has support for time and string datatypes etc. + mh.WriteExt = true message.RegisterCodec("msgpack", message.Codec{ - Encoder: msgpack.Marshal, - Decoder: msgpack.Unmarshal, + Encoder: encode, + Decoder: decode, }) } diff --git a/api/message/msgpack/codec_test.go b/api/message/msgpack/codec_test.go index 60f5a6a..6f7b566 100644 --- a/api/message/msgpack/codec_test.go +++ b/api/message/msgpack/codec_test.go @@ -6,13 +6,10 @@ import ( "time" "github.com/eosswedenorg/thalos/api/message" - "github.com/shamaton/msgpack/v2" "github.com/stretchr/testify/assert" ) func TestMsgpack_EncodeActionTrace(t *testing.T) { - RegisterGeneratedResolver() - dataJson, err := json.Marshal(map[string]interface{}{ "item": map[string]interface{}{ "id": "2131242", @@ -45,69 +42,67 @@ func TestMsgpack_EncodeActionTrace(t *testing.T) { Return: []byte{0xde, 0xad, 0xbe, 0xef}, } - data, err := msgpack.Marshal(msg) + data, err := encode(msg) assert.NoError(t, err) expected := []byte{ - 0x8b, 0xa5, 0x74, 0x78, 0x5f, 0x69, 0x64, 0xd9, - 0x40, 0x65, 0x64, 0x63, 0x30, 0x36, 0x64, 0x63, - 0x65, 0x36, 0x33, 0x32, 0x30, 0x34, 0x35, 0x39, - 0x66, 0x64, 0x36, 0x34, 0x34, 0x37, 0x35, 0x36, - 0x39, 0x37, 0x32, 0x30, 0x34, 0x38, 0x64, 0x61, - 0x34, 0x35, 0x33, 0x62, 0x32, 0x38, 0x31, 0x36, - 0x62, 0x30, 0x61, 0x34, 0x33, 0x34, 0x63, 0x33, - 0x37, 0x64, 0x64, 0x66, 0x66, 0x64, 0x65, 0x33, - 0x36, 0x37, 0x37, 0x38, 0x64, 0x63, 0x61, 0x62, - 0x33, 0xa8, 0x62, 0x6c, 0x6f, 0x63, 0x6b, 0x6e, - 0x75, 0x6d, 0xcd, 0x30, 0x39, 0xae, 0x62, 0x6c, - 0x6f, 0x63, 0x6b, 0x74, 0x69, 0x6d, 0x65, 0x73, - 0x74, 0x61, 0x6d, 0x70, 0xd7, 0xff, 0x77, 0x35, - 0x94, 0x00, 0x65, 0x4e, 0x19, 0xff, 0xa4, 0x6e, - 0x61, 0x6d, 0x65, 0xa8, 0x73, 0x65, 0x6c, 0x6c, - 0x69, 0x74, 0x65, 0x6d, 0xa8, 0x63, 0x6f, 0x6e, - 0x74, 0x72, 0x61, 0x63, 0x74, 0xa6, 0x6d, 0x79, - 0x67, 0x61, 0x6d, 0x65, 0xa8, 0x72, 0x65, 0x63, - 0x65, 0x69, 0x76, 0x65, 0x72, 0xa5, 0x65, 0x6f, - 0x73, 0x69, 0x6f, 0xa4, 0x64, 0x61, 0x74, 0x61, - 0xc4, 0x9b, 0x7b, 0x22, 0x61, 0x6d, 0x6f, 0x75, - 0x6e, 0x74, 0x22, 0x3a, 0x22, 0x31, 0x30, 0x30, - 0x30, 0x2e, 0x30, 0x30, 0x30, 0x30, 0x20, 0x53, - 0x43, 0x41, 0x4d, 0x22, 0x2c, 0x22, 0x66, 0x72, - 0x6f, 0x6d, 0x22, 0x3a, 0x22, 0x61, 0x63, 0x63, - 0x6f, 0x75, 0x6e, 0x74, 0x31, 0x22, 0x2c, 0x22, - 0x69, 0x74, 0x65, 0x6d, 0x22, 0x3a, 0x7b, 0x22, - 0x61, 0x67, 0x69, 0x22, 0x3a, 0x22, 0x32, 0x30, - 0x22, 0x2c, 0x22, 0x64, 0x75, 0x72, 0x22, 0x3a, - 0x22, 0x31, 0x30, 0x30, 0x22, 0x2c, 0x22, 0x69, - 0x64, 0x22, 0x3a, 0x22, 0x32, 0x31, 0x33, 0x31, - 0x32, 0x34, 0x32, 0x22, 0x2c, 0x22, 0x6e, 0x61, - 0x6d, 0x65, 0x22, 0x3a, 0x22, 0x47, 0x72, 0x65, - 0x61, 0x74, 0x20, 0x53, 0x77, 0x6f, 0x72, 0x64, - 0x22, 0x2c, 0x22, 0x71, 0x75, 0x61, 0x6c, 0x22, - 0x3a, 0x22, 0x65, 0x70, 0x69, 0x63, 0x22, 0x2c, - 0x22, 0x73, 0x74, 0x72, 0x22, 0x3a, 0x22, 0x31, - 0x30, 0x30, 0x22, 0x7d, 0x2c, 0x22, 0x74, 0x6f, - 0x22, 0x3a, 0x22, 0x61, 0x63, 0x63, 0x6f, 0x75, - 0x6e, 0x74, 0x32, 0x22, 0x7d, 0xad, 0x61, 0x75, - 0x74, 0x68, 0x6f, 0x72, 0x69, 0x7a, 0x61, 0x74, - 0x69, 0x6f, 0x6e, 0x91, 0x82, 0xa5, 0x61, 0x63, - 0x74, 0x6f, 0x72, 0xa6, 0x6d, 0x79, 0x67, 0x61, - 0x6d, 0x65, 0xaa, 0x70, 0x65, 0x72, 0x6d, 0x69, - 0x73, 0x73, 0x69, 0x6f, 0x6e, 0xa6, 0x61, 0x63, - 0x74, 0x69, 0x76, 0x65, 0xa6, 0x65, 0x78, 0x63, - 0x65, 0x70, 0x74, 0xa6, 0x65, 0x72, 0x72, 0x73, - 0x74, 0x72, 0xa5, 0x65, 0x72, 0x72, 0x6f, 0x72, - 0x02, 0xa6, 0x72, 0x65, 0x74, 0x75, 0x72, 0x6e, - 0xc4, 0x04, 0xde, 0xad, 0xbe, 0xef, + 0x8b, 0xad, 0x61, 0x75, 0x74, 0x68, 0x6f, 0x72, + 0x69, 0x7a, 0x61, 0x74, 0x69, 0x6f, 0x6e, 0x91, + 0x82, 0xa5, 0x61, 0x63, 0x74, 0x6f, 0x72, 0xa6, + 0x6d, 0x79, 0x67, 0x61, 0x6d, 0x65, 0xaa, 0x70, + 0x65, 0x72, 0x6d, 0x69, 0x73, 0x73, 0x69, 0x6f, + 0x6e, 0xa6, 0x61, 0x63, 0x74, 0x69, 0x76, 0x65, + 0xa8, 0x62, 0x6c, 0x6f, 0x63, 0x6b, 0x6e, 0x75, + 0x6d, 0xcd, 0x30, 0x39, 0xae, 0x62, 0x6c, 0x6f, + 0x63, 0x6b, 0x74, 0x69, 0x6d, 0x65, 0x73, 0x74, + 0x61, 0x6d, 0x70, 0xd7, 0xff, 0x77, 0x35, 0x94, + 0x00, 0x65, 0x4e, 0x19, 0xff, 0xa8, 0x63, 0x6f, + 0x6e, 0x74, 0x72, 0x61, 0x63, 0x74, 0xa6, 0x6d, + 0x79, 0x67, 0x61, 0x6d, 0x65, 0xa4, 0x64, 0x61, + 0x74, 0x61, 0xc4, 0x9b, 0x7b, 0x22, 0x61, 0x6d, + 0x6f, 0x75, 0x6e, 0x74, 0x22, 0x3a, 0x22, 0x31, + 0x30, 0x30, 0x30, 0x2e, 0x30, 0x30, 0x30, 0x30, + 0x20, 0x53, 0x43, 0x41, 0x4d, 0x22, 0x2c, 0x22, + 0x66, 0x72, 0x6f, 0x6d, 0x22, 0x3a, 0x22, 0x61, + 0x63, 0x63, 0x6f, 0x75, 0x6e, 0x74, 0x31, 0x22, + 0x2c, 0x22, 0x69, 0x74, 0x65, 0x6d, 0x22, 0x3a, + 0x7b, 0x22, 0x61, 0x67, 0x69, 0x22, 0x3a, 0x22, + 0x32, 0x30, 0x22, 0x2c, 0x22, 0x64, 0x75, 0x72, + 0x22, 0x3a, 0x22, 0x31, 0x30, 0x30, 0x22, 0x2c, + 0x22, 0x69, 0x64, 0x22, 0x3a, 0x22, 0x32, 0x31, + 0x33, 0x31, 0x32, 0x34, 0x32, 0x22, 0x2c, 0x22, + 0x6e, 0x61, 0x6d, 0x65, 0x22, 0x3a, 0x22, 0x47, + 0x72, 0x65, 0x61, 0x74, 0x20, 0x53, 0x77, 0x6f, + 0x72, 0x64, 0x22, 0x2c, 0x22, 0x71, 0x75, 0x61, + 0x6c, 0x22, 0x3a, 0x22, 0x65, 0x70, 0x69, 0x63, + 0x22, 0x2c, 0x22, 0x73, 0x74, 0x72, 0x22, 0x3a, + 0x22, 0x31, 0x30, 0x30, 0x22, 0x7d, 0x2c, 0x22, + 0x74, 0x6f, 0x22, 0x3a, 0x22, 0x61, 0x63, 0x63, + 0x6f, 0x75, 0x6e, 0x74, 0x32, 0x22, 0x7d, 0xa5, + 0x65, 0x72, 0x72, 0x6f, 0x72, 0x02, 0xa6, 0x65, + 0x78, 0x63, 0x65, 0x70, 0x74, 0xa6, 0x65, 0x72, + 0x72, 0x73, 0x74, 0x72, 0xa4, 0x6e, 0x61, 0x6d, + 0x65, 0xa8, 0x73, 0x65, 0x6c, 0x6c, 0x69, 0x74, + 0x65, 0x6d, 0xa8, 0x72, 0x65, 0x63, 0x65, 0x69, + 0x76, 0x65, 0x72, 0xa5, 0x65, 0x6f, 0x73, 0x69, + 0x6f, 0xa6, 0x72, 0x65, 0x74, 0x75, 0x72, 0x6e, + 0xc4, 0x04, 0xde, 0xad, 0xbe, 0xef, 0xa5, 0x74, + 0x78, 0x5f, 0x69, 0x64, 0xd9, 0x40, 0x65, 0x64, + 0x63, 0x30, 0x36, 0x64, 0x63, 0x65, 0x36, 0x33, + 0x32, 0x30, 0x34, 0x35, 0x39, 0x66, 0x64, 0x36, + 0x34, 0x34, 0x37, 0x35, 0x36, 0x39, 0x37, 0x32, + 0x30, 0x34, 0x38, 0x64, 0x61, 0x34, 0x35, 0x33, + 0x62, 0x32, 0x38, 0x31, 0x36, 0x62, 0x30, 0x61, + 0x34, 0x33, 0x34, 0x63, 0x33, 0x37, 0x64, 0x64, + 0x66, 0x66, 0x64, 0x65, 0x33, 0x36, 0x37, 0x37, + 0x38, 0x64, 0x63, 0x61, 0x62, 0x33, } assert.Equal(t, expected, data) } func TestMsgpack_Decode(t *testing.T) { - RegisterGeneratedResolver() - - data := []byte("\x8b\xa5tx_id\xd9@edc06dce6320459fd644756972048da453b2816b0a434c37ddffde36778dcab3\xa8blocknum\xce\x00\x85F7\xaeblocktimestamp\xd6\xffH\xf1U\x1f\xa4name\xa4drop\xa8contract\xa6mygame\xa8receiver\xa8account1\xa4dataċ{\"dropped_from_id\":674562,\"item\":{\"dur\":145,\"id\":49623,\"name\":\"Shadowmourne\",\"qual\":\"legendary\",\"sta\":198,\"str\":223},\"receiver\":\"account1\"}\xadauthorization\x91\x82\xa5actor\xa6mygame\xaapermission\xa6active\xa6except\xa6errstr\xa5error\x02\xa6return\xc4\x04ޭ\xbe\xef") + data := []byte("\x8b\xadauthorization\x91\x82\xa5actor\xa6mygame\xaapermission\xa6active\xa8blocknum\xce\x00\x85F7\xaeblocktimestamp\xd6\xffH\xf1U\x1f\xa8contract\xa6mygame\xa4dataċ{\"dropped_from_id\":674562,\"item\":{\"dur\":145,\"id\":49623,\"name\":\"Shadowmourne\",\"qual\":\"legendary\",\"sta\":198,\"str\":223},\"receiver\":\"account1\"}\xa5error\x02\xa6except\xa6errstr\xa4name\xa4drop\xa8receiver\xa8account1\xa6return\xc4\x04ޭ\xbe\xef\xa5tx_id\xd9@edc06dce6320459fd644756972048da453b2816b0a434c37ddffde36778dcab3") dataJson, err := json.Marshal(map[string]interface{}{ "item": map[string]interface{}{ @@ -127,7 +122,7 @@ func TestMsgpack_Decode(t *testing.T) { expected := message.ActionTrace{ TxID: "edc06dce6320459fd644756972048da453b2816b0a434c37ddffde36778dcab3", BlockNum: 8734263, - Timestamp: time.Unix(1223775519, 0), + Timestamp: time.Unix(1223775519, 0).UTC(), Name: "drop", Contract: "mygame", Receiver: "account1", @@ -141,22 +136,20 @@ func TestMsgpack_Decode(t *testing.T) { } res := message.ActionTrace{} - err = msgpack.Unmarshal(data, &res) + err = decode(data, &res) assert.NoError(t, err) assert.Equal(t, expected, res) } func TestMsgpack_EncodeHeartbeat(t *testing.T) { - RegisterGeneratedResolver() - msg := message.HeartBeat{ BlockNum: 1234, HeadBlockNum: 1235, LastIrreversibleBlockNum: 1236, } - data, err := msgpack.Marshal(msg) + data, err := encode(msg) assert.NoError(t, err) assert.Equal(t, data, []byte{0x83, 0xa8, 0x62, 0x6c, 0x6f, 0x63, 0x6b, 0x6e, 0x75, 0x6d, 0xcd, 0x4, 0xd2, 0xad, 0x68, 0x65, 0x61, 0x64, 0x5f, 0x62, 0x6c, 0x6f, 0x63, 0x6b, 0x6e, 0x75, 0x6d, 0xcd, 0x4, 0xd3, 0xba, 0x6c, 0x61, 0x73, 0x74, 0x5f, 0x69, 0x72, 0x72, 0x65, 0x76, 0x65, 0x72, 0x73, 0x69, 0x62, 0x6c, 0x65, 0x5f, 0x62, 0x6c, 0x6f, 0x63, 0x6b, 0x6e, 0x75, 0x6d, 0xcd, 0x4, 0xd4}) @@ -172,7 +165,7 @@ func TestMsgpack_DecodeHeartbeat(t *testing.T) { } msg := message.HeartBeat{} - err := msgpack.Unmarshal(data, &msg) + err := decode(data, &msg) assert.NoError(t, err) assert.Equal(t, expected, msg) } diff --git a/api/message/msgpack/msgpack.go b/api/message/msgpack/msgpack.go deleted file mode 100644 index 227c9ea..0000000 --- a/api/message/msgpack/msgpack.go +++ /dev/null @@ -1,1149 +0,0 @@ -// Code generated by msgpackgen. DO NOT EDIT. - -package msgpack - -import ( - "fmt" - message "github.com/eosswedenorg/thalos/api/message" - msgpack "github.com/shamaton/msgpackgen/msgpack" - dec "github.com/shamaton/msgpackgen/msgpack/dec" - enc "github.com/shamaton/msgpackgen/msgpack/enc" - "time" -) - -// RegisterGeneratedResolver registers generated resolver. -func RegisterGeneratedResolver() { - msgpack.SetResolver(___encodeAsMap, ___encodeAsArray, ___decodeAsMap, ___decodeAsArray) -} - -// encode -func ___encode(i interface{}) ([]byte, error) { - if msgpack.StructAsArray() { - return ___encodeAsArray(i) - } else { - return ___encodeAsMap(i) - } -} - -// encodeAsArray -func ___encodeAsArray(i interface{}) ([]byte, error) { - switch v := i.(type) { - case message.HeartBeat: - encoder := enc.NewEncoder() - size, err := ___calcArraySizeHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeArrayHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.HeartBeat", size, offset) - } - return b, err - case *message.HeartBeat: - encoder := enc.NewEncoder() - size, err := ___calcArraySizeHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeArrayHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.HeartBeat", size, offset) - } - return b, err - case message.PermissionLevel: - encoder := enc.NewEncoder() - size, err := ___calcArraySizePermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeArrayPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.PermissionLevel", size, offset) - } - return b, err - case *message.PermissionLevel: - encoder := enc.NewEncoder() - size, err := ___calcArraySizePermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeArrayPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.PermissionLevel", size, offset) - } - return b, err - case message.ActionTrace: - encoder := enc.NewEncoder() - size, err := ___calcArraySizeActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeArrayActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.ActionTrace", size, offset) - } - return b, err - case *message.ActionTrace: - encoder := enc.NewEncoder() - size, err := ___calcArraySizeActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeArrayActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.ActionTrace", size, offset) - } - return b, err - } - return nil, nil -} - -// encodeAsMap -func ___encodeAsMap(i interface{}) ([]byte, error) { - switch v := i.(type) { - case message.HeartBeat: - encoder := enc.NewEncoder() - size, err := ___calcMapSizeHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeMapHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.HeartBeat", size, offset) - } - return b, err - case *message.HeartBeat: - encoder := enc.NewEncoder() - size, err := ___calcMapSizeHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeMapHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.HeartBeat", size, offset) - } - return b, err - case message.PermissionLevel: - encoder := enc.NewEncoder() - size, err := ___calcMapSizePermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeMapPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.PermissionLevel", size, offset) - } - return b, err - case *message.PermissionLevel: - encoder := enc.NewEncoder() - size, err := ___calcMapSizePermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeMapPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.PermissionLevel", size, offset) - } - return b, err - case message.ActionTrace: - encoder := enc.NewEncoder() - size, err := ___calcMapSizeActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeMapActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.ActionTrace", size, offset) - } - return b, err - case *message.ActionTrace: - encoder := enc.NewEncoder() - size, err := ___calcMapSizeActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder) - if err != nil { - return nil, err - } - encoder.MakeBytes(size) - b, offset, err := ___encodeMapActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, encoder, 0) - if err != nil { - return nil, err - } - if size != offset { - return nil, fmt.Errorf("%s size / offset different %d : %d", "github.com/eosswedenorg/thalos/api/message.ActionTrace", size, offset) - } - return b, err - } - return nil, nil -} - -// decode -func ___decode(data []byte, i interface{}) (bool, error) { - if msgpack.StructAsArray() { - return ___decodeAsArray(data, i) - } else { - return ___decodeAsMap(data, i) - } -} - -// decodeAsArray -func ___decodeAsArray(data []byte, i interface{}) (bool, error) { - switch v := i.(type) { - case *message.HeartBeat: - decoder := dec.NewDecoder(data) - offset, err := ___decodeArrayHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - case **message.HeartBeat: - decoder := dec.NewDecoder(data) - offset, err := ___decodeArrayHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - case *message.PermissionLevel: - decoder := dec.NewDecoder(data) - offset, err := ___decodeArrayPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - case **message.PermissionLevel: - decoder := dec.NewDecoder(data) - offset, err := ___decodeArrayPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - case *message.ActionTrace: - decoder := dec.NewDecoder(data) - offset, err := ___decodeArrayActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - case **message.ActionTrace: - decoder := dec.NewDecoder(data) - offset, err := ___decodeArrayActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - } - return false, nil -} - -// decodeAsMap -func ___decodeAsMap(data []byte, i interface{}) (bool, error) { - switch v := i.(type) { - case *message.HeartBeat: - decoder := dec.NewDecoder(data) - offset, err := ___decodeMapHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - case **message.HeartBeat: - decoder := dec.NewDecoder(data) - offset, err := ___decodeMapHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - case *message.PermissionLevel: - decoder := dec.NewDecoder(data) - offset, err := ___decodeMapPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - case **message.PermissionLevel: - decoder := dec.NewDecoder(data) - offset, err := ___decodeMapPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - case *message.ActionTrace: - decoder := dec.NewDecoder(data) - offset, err := ___decodeMapActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - case **message.ActionTrace: - decoder := dec.NewDecoder(data) - offset, err := ___decodeMapActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(*v, decoder, 0) - if err == nil && offset != decoder.Len() { - return true, fmt.Errorf("read length is different [%d] [%d] ", offset, decoder.Len()) - } - return true, err - } - return false, nil -} - -// calculate size from github.com/eosswedenorg/thalos/api/message.HeartBeat -func ___calcArraySizeHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.HeartBeat, encoder *enc.Encoder) (int, error) { - size := 0 - size += encoder.CalcStructHeaderFix(3) - size += encoder.CalcUint32(v.BlockNum) - size += encoder.CalcUint32(v.HeadBlockNum) - size += encoder.CalcUint32(v.LastIrreversibleBlockNum) - return size, nil -} - -// calculate size from github.com/eosswedenorg/thalos/api/message.HeartBeat -func ___calcMapSizeHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.HeartBeat, encoder *enc.Encoder) (int, error) { - size := 0 - size += encoder.CalcStructHeaderFix(3) - size += encoder.CalcStringFix(8) - size += encoder.CalcUint32(v.BlockNum) - size += encoder.CalcStringFix(13) - size += encoder.CalcUint32(v.HeadBlockNum) - size += encoder.CalcStringFix(26) - size += encoder.CalcUint32(v.LastIrreversibleBlockNum) - return size, nil -} - -// encode from github.com/eosswedenorg/thalos/api/message.HeartBeat -func ___encodeArrayHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.HeartBeat, encoder *enc.Encoder, offset int) ([]byte, int, error) { - var err error - offset = encoder.WriteStructHeaderFixAsArray(3, offset) - offset = encoder.WriteUint32(v.BlockNum, offset) - offset = encoder.WriteUint32(v.HeadBlockNum, offset) - offset = encoder.WriteUint32(v.LastIrreversibleBlockNum, offset) - return encoder.EncodedBytes(), offset, err -} - -// encode from github.com/eosswedenorg/thalos/api/message.HeartBeat -func ___encodeMapHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.HeartBeat, encoder *enc.Encoder, offset int) ([]byte, int, error) { - var err error - offset = encoder.WriteStructHeaderFixAsMap(3, offset) - offset = encoder.WriteStringFix("blocknum", 8, offset) - offset = encoder.WriteUint32(v.BlockNum, offset) - offset = encoder.WriteStringFix("head_blocknum", 13, offset) - offset = encoder.WriteUint32(v.HeadBlockNum, offset) - offset = encoder.WriteStringFix("last_irreversible_blocknum", 26, offset) - offset = encoder.WriteUint32(v.LastIrreversibleBlockNum, offset) - return encoder.EncodedBytes(), offset, err -} - -// decode to github.com/eosswedenorg/thalos/api/message.HeartBeat -func ___decodeArrayHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v *message.HeartBeat, decoder *dec.Decoder, offset int) (int, error) { - offset, err := decoder.CheckStructHeader(3, offset) - if err != nil { - return 0, err - } - { - var vv uint32 - vv, offset, err = decoder.AsUint32(offset) - if err != nil { - return 0, err - } - v.BlockNum = vv - } - { - var vv uint32 - vv, offset, err = decoder.AsUint32(offset) - if err != nil { - return 0, err - } - v.HeadBlockNum = vv - } - { - var vv uint32 - vv, offset, err = decoder.AsUint32(offset) - if err != nil { - return 0, err - } - v.LastIrreversibleBlockNum = vv - } - return offset, err -} - -// decode to github.com/eosswedenorg/thalos/api/message.HeartBeat -func ___decodeMapHeartBeat_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v *message.HeartBeat, decoder *dec.Decoder, offset int) (int, error) { - keys := [][]byte{ - {uint8(0x62), uint8(0x6c), uint8(0x6f), uint8(0x63), uint8(0x6b), uint8(0x6e), uint8(0x75), uint8(0x6d)}, // blocknum - {uint8(0x68), uint8(0x65), uint8(0x61), uint8(0x64), uint8(0x5f), uint8(0x62), uint8(0x6c), uint8(0x6f), uint8(0x63), uint8(0x6b), uint8(0x6e), uint8(0x75), uint8(0x6d)}, // head_blocknum - {uint8(0x6c), uint8(0x61), uint8(0x73), uint8(0x74), uint8(0x5f), uint8(0x69), uint8(0x72), uint8(0x72), uint8(0x65), uint8(0x76), uint8(0x65), uint8(0x72), uint8(0x73), uint8(0x69), uint8(0x62), uint8(0x6c), uint8(0x65), uint8(0x5f), uint8(0x62), uint8(0x6c), uint8(0x6f), uint8(0x63), uint8(0x6b), uint8(0x6e), uint8(0x75), uint8(0x6d)}, // last_irreversible_blocknum - } - offset, err := decoder.CheckStructHeader(3, offset) - if err != nil { - return 0, err - } - count := 0 - for count < 3 { - var dataKey []byte - dataKey, offset, err = decoder.AsStringBytes(offset) - if err != nil { - return 0, err - } - fieldIndex := -1 - for i, key := range keys { - if len(dataKey) != len(key) { - continue - } - fieldIndex = i - for dataKeyIndex := range dataKey { - if dataKey[dataKeyIndex] != key[dataKeyIndex] { - fieldIndex = -1 - break - } - } - if fieldIndex >= 0 { - break - } - } - switch fieldIndex { - case 0: - { - var vv uint32 - vv, offset, err = decoder.AsUint32(offset) - if err != nil { - return 0, err - } - v.BlockNum = vv - } - count++ - case 1: - { - var vv uint32 - vv, offset, err = decoder.AsUint32(offset) - if err != nil { - return 0, err - } - v.HeadBlockNum = vv - } - count++ - case 2: - { - var vv uint32 - vv, offset, err = decoder.AsUint32(offset) - if err != nil { - return 0, err - } - v.LastIrreversibleBlockNum = vv - } - count++ - default: - return 0, fmt.Errorf("unknown key[%s] found", string(dataKey)) - } - } - return offset, err -} - -// calculate size from github.com/eosswedenorg/thalos/api/message.PermissionLevel -func ___calcArraySizePermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.PermissionLevel, encoder *enc.Encoder) (int, error) { - size := 0 - size += encoder.CalcStructHeaderFix(2) - size += encoder.CalcString(v.Actor) - size += encoder.CalcString(v.Permission) - return size, nil -} - -// calculate size from github.com/eosswedenorg/thalos/api/message.PermissionLevel -func ___calcMapSizePermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.PermissionLevel, encoder *enc.Encoder) (int, error) { - size := 0 - size += encoder.CalcStructHeaderFix(2) - size += encoder.CalcStringFix(5) - size += encoder.CalcString(v.Actor) - size += encoder.CalcStringFix(10) - size += encoder.CalcString(v.Permission) - return size, nil -} - -// encode from github.com/eosswedenorg/thalos/api/message.PermissionLevel -func ___encodeArrayPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.PermissionLevel, encoder *enc.Encoder, offset int) ([]byte, int, error) { - var err error - offset = encoder.WriteStructHeaderFixAsArray(2, offset) - offset = encoder.WriteString(v.Actor, offset) - offset = encoder.WriteString(v.Permission, offset) - return encoder.EncodedBytes(), offset, err -} - -// encode from github.com/eosswedenorg/thalos/api/message.PermissionLevel -func ___encodeMapPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.PermissionLevel, encoder *enc.Encoder, offset int) ([]byte, int, error) { - var err error - offset = encoder.WriteStructHeaderFixAsMap(2, offset) - offset = encoder.WriteStringFix("actor", 5, offset) - offset = encoder.WriteString(v.Actor, offset) - offset = encoder.WriteStringFix("permission", 10, offset) - offset = encoder.WriteString(v.Permission, offset) - return encoder.EncodedBytes(), offset, err -} - -// decode to github.com/eosswedenorg/thalos/api/message.PermissionLevel -func ___decodeArrayPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v *message.PermissionLevel, decoder *dec.Decoder, offset int) (int, error) { - offset, err := decoder.CheckStructHeader(2, offset) - if err != nil { - return 0, err - } - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Actor = vv - } - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Permission = vv - } - return offset, err -} - -// decode to github.com/eosswedenorg/thalos/api/message.PermissionLevel -func ___decodeMapPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v *message.PermissionLevel, decoder *dec.Decoder, offset int) (int, error) { - keys := [][]byte{ - {uint8(0x61), uint8(0x63), uint8(0x74), uint8(0x6f), uint8(0x72)}, // actor - {uint8(0x70), uint8(0x65), uint8(0x72), uint8(0x6d), uint8(0x69), uint8(0x73), uint8(0x73), uint8(0x69), uint8(0x6f), uint8(0x6e)}, // permission - } - offset, err := decoder.CheckStructHeader(2, offset) - if err != nil { - return 0, err - } - count := 0 - for count < 2 { - var dataKey []byte - dataKey, offset, err = decoder.AsStringBytes(offset) - if err != nil { - return 0, err - } - fieldIndex := -1 - for i, key := range keys { - if len(dataKey) != len(key) { - continue - } - fieldIndex = i - for dataKeyIndex := range dataKey { - if dataKey[dataKeyIndex] != key[dataKeyIndex] { - fieldIndex = -1 - break - } - } - if fieldIndex >= 0 { - break - } - } - switch fieldIndex { - case 0: - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Actor = vv - } - count++ - case 1: - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Permission = vv - } - count++ - default: - return 0, fmt.Errorf("unknown key[%s] found", string(dataKey)) - } - } - return offset, err -} - -// calculate size from github.com/eosswedenorg/thalos/api/message.ActionTrace -func ___calcArraySizeActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.ActionTrace, encoder *enc.Encoder) (int, error) { - size := 0 - size += encoder.CalcStructHeaderFix(11) - size += encoder.CalcString(v.TxID) - size += encoder.CalcUint32(v.BlockNum) - size += encoder.CalcTime(v.Timestamp) - size += encoder.CalcString(v.Name) - size += encoder.CalcString(v.Contract) - size += encoder.CalcString(v.Receiver) - if v.Data != nil { - s, err := encoder.CalcSliceLength(len(v.Data), true) - if err != nil { - return 0, err - } - size += s - for _, vv := range v.Data { - size += encoder.CalcByte(vv) - } - } else { - size += encoder.CalcNil() - } - if v.Authorization != nil { - s, err := encoder.CalcSliceLength(len(v.Authorization), false) - if err != nil { - return 0, err - } - size += s - for _, vv := range v.Authorization { - size_vv, err := ___calcArraySizePermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(vv, encoder) - if err != nil { - return 0, err - } - size += size_vv - } - } else { - size += encoder.CalcNil() - } - size += encoder.CalcString(v.Except) - size += encoder.CalcUint64(v.Error) - if v.Return != nil { - s, err := encoder.CalcSliceLength(len(v.Return), true) - if err != nil { - return 0, err - } - size += s - for _, vv := range v.Return { - size += encoder.CalcByte(vv) - } - } else { - size += encoder.CalcNil() - } - return size, nil -} - -// calculate size from github.com/eosswedenorg/thalos/api/message.ActionTrace -func ___calcMapSizeActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.ActionTrace, encoder *enc.Encoder) (int, error) { - size := 0 - size += encoder.CalcStructHeaderFix(11) - size += encoder.CalcStringFix(5) - size += encoder.CalcString(v.TxID) - size += encoder.CalcStringFix(8) - size += encoder.CalcUint32(v.BlockNum) - size += encoder.CalcStringFix(14) - size += encoder.CalcTime(v.Timestamp) - size += encoder.CalcStringFix(4) - size += encoder.CalcString(v.Name) - size += encoder.CalcStringFix(8) - size += encoder.CalcString(v.Contract) - size += encoder.CalcStringFix(8) - size += encoder.CalcString(v.Receiver) - size += encoder.CalcStringFix(4) - if v.Data != nil { - s, err := encoder.CalcSliceLength(len(v.Data), true) - if err != nil { - return 0, err - } - size += s - for _, vv := range v.Data { - size += encoder.CalcByte(vv) - } - } else { - size += encoder.CalcNil() - } - size += encoder.CalcStringFix(13) - if v.Authorization != nil { - s, err := encoder.CalcSliceLength(len(v.Authorization), false) - if err != nil { - return 0, err - } - size += s - for _, vv := range v.Authorization { - size_vv, err := ___calcMapSizePermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(vv, encoder) - if err != nil { - return 0, err - } - size += size_vv - } - } else { - size += encoder.CalcNil() - } - size += encoder.CalcStringFix(6) - size += encoder.CalcString(v.Except) - size += encoder.CalcStringFix(5) - size += encoder.CalcUint64(v.Error) - size += encoder.CalcStringFix(6) - if v.Return != nil { - s, err := encoder.CalcSliceLength(len(v.Return), true) - if err != nil { - return 0, err - } - size += s - for _, vv := range v.Return { - size += encoder.CalcByte(vv) - } - } else { - size += encoder.CalcNil() - } - return size, nil -} - -// encode from github.com/eosswedenorg/thalos/api/message.ActionTrace -func ___encodeArrayActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.ActionTrace, encoder *enc.Encoder, offset int) ([]byte, int, error) { - var err error - offset = encoder.WriteStructHeaderFixAsArray(11, offset) - offset = encoder.WriteString(v.TxID, offset) - offset = encoder.WriteUint32(v.BlockNum, offset) - offset = encoder.WriteTime(v.Timestamp, offset) - offset = encoder.WriteString(v.Name, offset) - offset = encoder.WriteString(v.Contract, offset) - offset = encoder.WriteString(v.Receiver, offset) - if v.Data != nil { - offset = encoder.WriteSliceLength(len(v.Data), offset, true) - for _, vv := range v.Data { - offset = encoder.WriteByte(vv, offset) - } - } else { - offset = encoder.WriteNil(offset) - } - if v.Authorization != nil { - offset = encoder.WriteSliceLength(len(v.Authorization), offset, false) - for _, vv := range v.Authorization { - _, offset, err = ___encodeArrayPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(vv, encoder, offset) - if err != nil { - return nil, 0, err - } - } - } else { - offset = encoder.WriteNil(offset) - } - offset = encoder.WriteString(v.Except, offset) - offset = encoder.WriteUint64(v.Error, offset) - if v.Return != nil { - offset = encoder.WriteSliceLength(len(v.Return), offset, true) - for _, vv := range v.Return { - offset = encoder.WriteByte(vv, offset) - } - } else { - offset = encoder.WriteNil(offset) - } - return encoder.EncodedBytes(), offset, err -} - -// encode from github.com/eosswedenorg/thalos/api/message.ActionTrace -func ___encodeMapActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v message.ActionTrace, encoder *enc.Encoder, offset int) ([]byte, int, error) { - var err error - offset = encoder.WriteStructHeaderFixAsMap(11, offset) - offset = encoder.WriteStringFix("tx_id", 5, offset) - offset = encoder.WriteString(v.TxID, offset) - offset = encoder.WriteStringFix("blocknum", 8, offset) - offset = encoder.WriteUint32(v.BlockNum, offset) - offset = encoder.WriteStringFix("blocktimestamp", 14, offset) - offset = encoder.WriteTime(v.Timestamp, offset) - offset = encoder.WriteStringFix("name", 4, offset) - offset = encoder.WriteString(v.Name, offset) - offset = encoder.WriteStringFix("contract", 8, offset) - offset = encoder.WriteString(v.Contract, offset) - offset = encoder.WriteStringFix("receiver", 8, offset) - offset = encoder.WriteString(v.Receiver, offset) - offset = encoder.WriteStringFix("data", 4, offset) - if v.Data != nil { - offset = encoder.WriteSliceLength(len(v.Data), offset, true) - for _, vv := range v.Data { - offset = encoder.WriteByte(vv, offset) - } - } else { - offset = encoder.WriteNil(offset) - } - offset = encoder.WriteStringFix("authorization", 13, offset) - if v.Authorization != nil { - offset = encoder.WriteSliceLength(len(v.Authorization), offset, false) - for _, vv := range v.Authorization { - _, offset, err = ___encodeMapPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(vv, encoder, offset) - if err != nil { - return nil, 0, err - } - } - } else { - offset = encoder.WriteNil(offset) - } - offset = encoder.WriteStringFix("except", 6, offset) - offset = encoder.WriteString(v.Except, offset) - offset = encoder.WriteStringFix("error", 5, offset) - offset = encoder.WriteUint64(v.Error, offset) - offset = encoder.WriteStringFix("return", 6, offset) - if v.Return != nil { - offset = encoder.WriteSliceLength(len(v.Return), offset, true) - for _, vv := range v.Return { - offset = encoder.WriteByte(vv, offset) - } - } else { - offset = encoder.WriteNil(offset) - } - return encoder.EncodedBytes(), offset, err -} - -// decode to github.com/eosswedenorg/thalos/api/message.ActionTrace -func ___decodeArrayActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v *message.ActionTrace, decoder *dec.Decoder, offset int) (int, error) { - offset, err := decoder.CheckStructHeader(11, offset) - if err != nil { - return 0, err - } - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.TxID = vv - } - { - var vv uint32 - vv, offset, err = decoder.AsUint32(offset) - if err != nil { - return 0, err - } - v.BlockNum = vv - } - { - var vv time.Time - vv, offset, err = decoder.AsDateTime(offset) - if err != nil { - return 0, err - } - v.Timestamp = vv - } - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Name = vv - } - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Contract = vv - } - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Receiver = vv - } - if !decoder.IsCodeNil(offset) { - var vv []byte - var vvl int - vvl, offset, err = decoder.SliceLength(offset) - if err != nil { - return 0, err - } - vv = make([]byte, vvl) - for vvi := range vv { - var vvv byte - vvv, offset, err = decoder.AsByte(offset) - if err != nil { - return 0, err - } - vv[vvi] = vvv - } - v.Data = vv - } else { - offset++ - } - if !decoder.IsCodeNil(offset) { - var vv []message.PermissionLevel - var vvl int - vvl, offset, err = decoder.SliceLength(offset) - if err != nil { - return 0, err - } - vv = make([]message.PermissionLevel, vvl) - for vvi := range vv { - var vvv message.PermissionLevel - offset, err = ___decodeArrayPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(&vvv, decoder, offset) - if err != nil { - return 0, err - } - vv[vvi] = vvv - } - v.Authorization = vv - } else { - offset++ - } - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Except = vv - } - { - var vv uint64 - vv, offset, err = decoder.AsUint64(offset) - if err != nil { - return 0, err - } - v.Error = vv - } - if !decoder.IsCodeNil(offset) { - var vv []byte - var vvl int - vvl, offset, err = decoder.SliceLength(offset) - if err != nil { - return 0, err - } - vv = make([]byte, vvl) - for vvi := range vv { - var vvv byte - vvv, offset, err = decoder.AsByte(offset) - if err != nil { - return 0, err - } - vv[vvi] = vvv - } - v.Return = vv - } else { - offset++ - } - return offset, err -} - -// decode to github.com/eosswedenorg/thalos/api/message.ActionTrace -func ___decodeMapActionTrace_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(v *message.ActionTrace, decoder *dec.Decoder, offset int) (int, error) { - keys := [][]byte{ - {uint8(0x74), uint8(0x78), uint8(0x5f), uint8(0x69), uint8(0x64)}, // tx_id - {uint8(0x62), uint8(0x6c), uint8(0x6f), uint8(0x63), uint8(0x6b), uint8(0x6e), uint8(0x75), uint8(0x6d)}, // blocknum - {uint8(0x62), uint8(0x6c), uint8(0x6f), uint8(0x63), uint8(0x6b), uint8(0x74), uint8(0x69), uint8(0x6d), uint8(0x65), uint8(0x73), uint8(0x74), uint8(0x61), uint8(0x6d), uint8(0x70)}, // blocktimestamp - {uint8(0x6e), uint8(0x61), uint8(0x6d), uint8(0x65)}, // name - {uint8(0x63), uint8(0x6f), uint8(0x6e), uint8(0x74), uint8(0x72), uint8(0x61), uint8(0x63), uint8(0x74)}, // contract - {uint8(0x72), uint8(0x65), uint8(0x63), uint8(0x65), uint8(0x69), uint8(0x76), uint8(0x65), uint8(0x72)}, // receiver - {uint8(0x64), uint8(0x61), uint8(0x74), uint8(0x61)}, // data - {uint8(0x61), uint8(0x75), uint8(0x74), uint8(0x68), uint8(0x6f), uint8(0x72), uint8(0x69), uint8(0x7a), uint8(0x61), uint8(0x74), uint8(0x69), uint8(0x6f), uint8(0x6e)}, // authorization - {uint8(0x65), uint8(0x78), uint8(0x63), uint8(0x65), uint8(0x70), uint8(0x74)}, // except - {uint8(0x65), uint8(0x72), uint8(0x72), uint8(0x6f), uint8(0x72)}, // error - {uint8(0x72), uint8(0x65), uint8(0x74), uint8(0x75), uint8(0x72), uint8(0x6e)}, // return - } - offset, err := decoder.CheckStructHeader(11, offset) - if err != nil { - return 0, err - } - count := 0 - for count < 11 { - var dataKey []byte - dataKey, offset, err = decoder.AsStringBytes(offset) - if err != nil { - return 0, err - } - fieldIndex := -1 - for i, key := range keys { - if len(dataKey) != len(key) { - continue - } - fieldIndex = i - for dataKeyIndex := range dataKey { - if dataKey[dataKeyIndex] != key[dataKeyIndex] { - fieldIndex = -1 - break - } - } - if fieldIndex >= 0 { - break - } - } - switch fieldIndex { - case 0: - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.TxID = vv - } - count++ - case 1: - { - var vv uint32 - vv, offset, err = decoder.AsUint32(offset) - if err != nil { - return 0, err - } - v.BlockNum = vv - } - count++ - case 2: - { - var vv time.Time - vv, offset, err = decoder.AsDateTime(offset) - if err != nil { - return 0, err - } - v.Timestamp = vv - } - count++ - case 3: - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Name = vv - } - count++ - case 4: - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Contract = vv - } - count++ - case 5: - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Receiver = vv - } - count++ - case 6: - if !decoder.IsCodeNil(offset) { - var vv []byte - var vvl int - vvl, offset, err = decoder.SliceLength(offset) - if err != nil { - return 0, err - } - vv = make([]byte, vvl) - for vvi := range vv { - var vvv byte - vvv, offset, err = decoder.AsByte(offset) - if err != nil { - return 0, err - } - vv[vvi] = vvv - } - v.Data = vv - } else { - offset++ - } - count++ - case 7: - if !decoder.IsCodeNil(offset) { - var vv []message.PermissionLevel - var vvl int - vvl, offset, err = decoder.SliceLength(offset) - if err != nil { - return 0, err - } - vv = make([]message.PermissionLevel, vvl) - for vvi := range vv { - var vvv message.PermissionLevel - offset, err = ___decodeMapPermissionLevel_27424f445a2085e7723342fb0df638c626b43c59240988bc64f2d60167ee4080(&vvv, decoder, offset) - if err != nil { - return 0, err - } - vv[vvi] = vvv - } - v.Authorization = vv - } else { - offset++ - } - count++ - case 8: - { - var vv string - vv, offset, err = decoder.AsString(offset) - if err != nil { - return 0, err - } - v.Except = vv - } - count++ - case 9: - { - var vv uint64 - vv, offset, err = decoder.AsUint64(offset) - if err != nil { - return 0, err - } - v.Error = vv - } - count++ - case 10: - if !decoder.IsCodeNil(offset) { - var vv []byte - var vvl int - vvl, offset, err = decoder.SliceLength(offset) - if err != nil { - return 0, err - } - vv = make([]byte, vvl) - for vvi := range vv { - var vvv byte - vvv, offset, err = decoder.AsByte(offset) - if err != nil { - return 0, err - } - vv[vvi] = vvv - } - v.Return = vv - } else { - offset++ - } - count++ - default: - return 0, fmt.Errorf("unknown key[%s] found", string(dataKey)) - } - } - return offset, err -}