From 758c366def0670a96374e53fa539fcad5148657f Mon Sep 17 00:00:00 2001 From: kevinssgh <79858682+kevinssgh@users.noreply.github.com> Date: Tue, 19 Sep 2023 14:10:37 -0400 Subject: [PATCH 1/5] fix: some data race warnings in zetaclient (#1100) * fixed some data race issues in zetaclient * refactored fix * cleanup extra spaces and comments. --- Makefile | 4 ++-- contrib/localnet/orchestrator/smoketest/main.go | 6 ++++-- zetaclient/broadcast.go | 10 ++++------ zetaclient/tss_signer.go | 1 + zetaclient/zetabridge.go | 6 +++++- 5 files changed, 16 insertions(+), 11 deletions(-) diff --git a/Makefile b/Makefile index ec328166c6..99f64d7951 100644 --- a/Makefile +++ b/Makefile @@ -82,8 +82,8 @@ build-testnet-ubuntu: go.sum install: go.sum @echo "--> Installing zetacored & zetaclientd" - @go install -mod=readonly $(BUILD_FLAGS) ./cmd/zetacored - @go install -mod=readonly $(BUILD_FLAGS) ./cmd/zetaclientd + @go install -race -mod=readonly $(BUILD_FLAGS) ./cmd/zetacored + @go install -race -mod=readonly $(BUILD_FLAGS) ./cmd/zetaclientd install-zetaclient: go.sum @echo "--> Installing zetaclientd" diff --git a/contrib/localnet/orchestrator/smoketest/main.go b/contrib/localnet/orchestrator/smoketest/main.go index 5608bfca90..c08b04d3ac 100644 --- a/contrib/localnet/orchestrator/smoketest/main.go +++ b/contrib/localnet/orchestrator/smoketest/main.go @@ -148,6 +148,9 @@ func LocalSmokeTest(_ *cobra.Command, _ []string) { bankClient := banktypes.NewQueryClient(grpcConn) observerClient := observertypes.NewQueryClient(grpcConn) + //Wait for Genesis + time.Sleep(20 * time.Second) + // initialize client to send messages to ZetaChain zetaTxServer, err := NewZetaTxServer( "http://zetacore0:26657", @@ -158,8 +161,7 @@ func LocalSmokeTest(_ *cobra.Command, _ []string) { panic(err) } - // Wait for Genesis and keygen to be completed. ~ height 30 - time.Sleep(20 * time.Second) + //Wait for keygen to be completed. ~ height 30 for { time.Sleep(5 * time.Second) response, err := cctxClient.LastZetaHeight(context.Background(), &crosschaintypes.QueryLastZetaHeightRequest{}) diff --git a/zetaclient/broadcast.go b/zetaclient/broadcast.go index a9c9c91b3c..70f1ce0739 100644 --- a/zetaclient/broadcast.go +++ b/zetaclient/broadcast.go @@ -13,7 +13,6 @@ import ( authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" flag "github.com/spf13/pflag" rpchttp "github.com/tendermint/tendermint/rpc/client/http" - "github.com/zeta-chain/zetacore/app" ) // Broadcast Broadcasts tx to metachain. Returns txHash and error @@ -119,11 +118,10 @@ func (b *ZetaCoreBridge) GetContext() client.Context { ctx = ctx.WithFromAddress(addr) ctx = ctx.WithBroadcastMode("sync") - encodingConfig := app.MakeEncodingConfig() - ctx = ctx.WithCodec(encodingConfig.Codec) - ctx = ctx.WithInterfaceRegistry(encodingConfig.InterfaceRegistry) - ctx = ctx.WithTxConfig(encodingConfig.TxConfig) - ctx = ctx.WithLegacyAmino(encodingConfig.Amino) + ctx = ctx.WithCodec(b.encodingCfg.Codec) + ctx = ctx.WithInterfaceRegistry(b.encodingCfg.InterfaceRegistry) + ctx = ctx.WithTxConfig(b.encodingCfg.TxConfig) + ctx = ctx.WithLegacyAmino(b.encodingCfg.Amino) ctx = ctx.WithAccountRetriever(authtypes.AccountRetriever{}) remote := b.cfg.ChainRPC diff --git a/zetaclient/tss_signer.go b/zetaclient/tss_signer.go index d0e540017d..d171c74ff9 100644 --- a/zetaclient/tss_signer.go +++ b/zetaclient/tss_signer.go @@ -173,6 +173,7 @@ func (tss *TSS) SignBatch(digests [][]byte, height uint64, chain *common.Chain) digestBase64[i] = base64.StdEncoding.EncodeToString(digest) } keysignReq := keysign.NewRequest(tssPubkey, digestBase64, int64(height), nil, "0.14.0") + ksRes, err := tss.Server.KeySign(keysignReq) if err != nil { log.Warn().Err(err).Msg("keysign fail") diff --git a/zetaclient/zetabridge.go b/zetaclient/zetabridge.go index 64a7a565bd..6e4c625ec2 100644 --- a/zetaclient/zetabridge.go +++ b/zetaclient/zetabridge.go @@ -4,6 +4,8 @@ import ( "fmt" "time" + "github.com/cosmos/cosmos-sdk/simapp/params" + "github.com/zeta-chain/zetacore/common" "sync" @@ -32,6 +34,7 @@ import ( //"strconv" //"strings" + "github.com/zeta-chain/zetacore/app" crosschaintypes "github.com/zeta-chain/zetacore/x/crosschain/types" observertypes "github.com/zeta-chain/zetacore/x/observer/types" "github.com/zeta-chain/zetacore/zetaclient/config" @@ -46,6 +49,7 @@ type ZetaCoreBridge struct { grpcConn *grpc.ClientConn httpClient *retryablehttp.Client cfg config.ClientConfiguration + encodingCfg params.EncodingConfig keys *Keys broadcastLock *sync.RWMutex zetaChainID string @@ -92,6 +96,7 @@ func NewZetaCoreBridge(k *Keys, chainIP string, signerName string, chainID strin accountNumber: accountsMap, seqNumber: seqMap, cfg: cfg, + encodingCfg: app.MakeEncodingConfig(), keys: k, broadcastLock: &sync.RWMutex{}, lastOutTxReportTime: map[string]time.Time{}, @@ -194,7 +199,6 @@ func (b *ZetaCoreBridge) UpdateConfigFromCore(cfg *config.Config, init bool) err } cfg.UpdateCoreParams(keyGen, newChains, newEVMParams, newBTCParams, init, b.logger) - cfg.Keygen = *keyGen tss, err := b.GetCurrentTss() if err != nil { b.logger.Error().Err(err).Msg("Unable to fetch TSS from zetacore") From de85c7faa88d9ef49b4bf8336d2d0cf7fa25c30e Mon Sep 17 00:00:00 2001 From: Lucas Bertrand Date: Wed, 20 Sep 2023 16:58:55 +0200 Subject: [PATCH 2/5] fix(`rpc`): reduce Ethereum rpc API and improve websocket API (#1106) * disable debug and personal * disable eth not secure * goimports * set message limit * set limit to 32MB * Update rpc/websockets.go --------- Co-authored-by: Charlie Chen <34498985+ws4charlie@users.noreply.github.com> --- rpc/apis.go | 129 +++++++++--------- rpc/namespaces/ethereum/debug/api.go | 10 +- rpc/namespaces/ethereum/eth/api.go | 60 ++++---- rpc/namespaces/ethereum/eth/filters/api.go | 14 +- .../ethereum/eth/filters/filter_system.go | 16 +-- .../ethereum/eth/filters/filters.go | 12 +- rpc/namespaces/ethereum/miner/api.go | 3 - rpc/namespaces/ethereum/personal/api.go | 13 +- rpc/namespaces/ethereum/txpool/api.go | 4 +- rpc/namespaces/ethereum/web3/api.go | 3 +- rpc/websockets.go | 17 ++- 11 files changed, 127 insertions(+), 154 deletions(-) diff --git a/rpc/apis.go b/rpc/apis.go index 3256f42d77..da130ad0a1 100644 --- a/rpc/apis.go +++ b/rpc/apis.go @@ -20,21 +20,14 @@ import ( "github.com/cosmos/cosmos-sdk/client" "github.com/cosmos/cosmos-sdk/server" - "github.com/ethereum/go-ethereum/rpc" - ethermint "github.com/evmos/ethermint/types" + rpcclient "github.com/tendermint/tendermint/rpc/jsonrpc/client" "github.com/zeta-chain/zetacore/rpc/backend" - "github.com/zeta-chain/zetacore/rpc/namespaces/ethereum/debug" "github.com/zeta-chain/zetacore/rpc/namespaces/ethereum/eth" "github.com/zeta-chain/zetacore/rpc/namespaces/ethereum/eth/filters" - "github.com/zeta-chain/zetacore/rpc/namespaces/ethereum/miner" "github.com/zeta-chain/zetacore/rpc/namespaces/ethereum/net" - "github.com/zeta-chain/zetacore/rpc/namespaces/ethereum/personal" - "github.com/zeta-chain/zetacore/rpc/namespaces/ethereum/txpool" "github.com/zeta-chain/zetacore/rpc/namespaces/ethereum/web3" - - rpcclient "github.com/tendermint/tendermint/rpc/jsonrpc/client" ) // RPC namespaces and API version @@ -47,8 +40,8 @@ const ( Web3Namespace = "web3" EthNamespace = "eth" - PersonalNamespace = "personal" NetNamespace = "net" + PersonalNamespace = "personal" TxPoolNamespace = "txpool" DebugNamespace = "debug" MinerNamespace = "miner" @@ -112,64 +105,66 @@ func init() { }, } }, - PersonalNamespace: func(ctx *server.Context, - clientCtx client.Context, - _ *rpcclient.WSClient, - allowUnprotectedTxs bool, - indexer ethermint.EVMTxIndexer, - ) []rpc.API { - evmBackend := backend.NewBackend(ctx, ctx.Logger, clientCtx, allowUnprotectedTxs, indexer) - return []rpc.API{ - { - Namespace: PersonalNamespace, - Version: apiVersion, - Service: personal.NewAPI(ctx.Logger, evmBackend), - Public: false, - }, - } - }, - TxPoolNamespace: func(ctx *server.Context, _ client.Context, _ *rpcclient.WSClient, _ bool, _ ethermint.EVMTxIndexer) []rpc.API { - return []rpc.API{ - { - Namespace: TxPoolNamespace, - Version: apiVersion, - Service: txpool.NewPublicAPI(ctx.Logger), - Public: true, - }, - } - }, - DebugNamespace: func(ctx *server.Context, - clientCtx client.Context, - _ *rpcclient.WSClient, - allowUnprotectedTxs bool, - indexer ethermint.EVMTxIndexer, - ) []rpc.API { - evmBackend := backend.NewBackend(ctx, ctx.Logger, clientCtx, allowUnprotectedTxs, indexer) - return []rpc.API{ - { - Namespace: DebugNamespace, - Version: apiVersion, - Service: debug.NewAPI(ctx, evmBackend), - Public: true, - }, - } - }, - MinerNamespace: func(ctx *server.Context, - clientCtx client.Context, - _ *rpcclient.WSClient, - allowUnprotectedTxs bool, - indexer ethermint.EVMTxIndexer, - ) []rpc.API { - evmBackend := backend.NewBackend(ctx, ctx.Logger, clientCtx, allowUnprotectedTxs, indexer) - return []rpc.API{ - { - Namespace: MinerNamespace, - Version: apiVersion, - Service: miner.NewPrivateAPI(ctx, evmBackend), - Public: false, - }, - } - }, + // Disabled + // NOTE: Public field of API is deprecated and defined only for compatibility. + //PersonalNamespace: func(ctx *server.Context, + // clientCtx client.Context, + // _ *rpcclient.WSClient, + // allowUnprotectedTxs bool, + // indexer ethermint.EVMTxIndexer, + //) []rpc.API { + // evmBackend := backend.NewBackend(ctx, ctx.Logger, clientCtx, allowUnprotectedTxs, indexer) + // return []rpc.API{ + // { + // Namespace: PersonalNamespace, + // Version: apiVersion, + // Service: personal.NewAPI(ctx.Logger, evmBackend), + // Public: false, + // }, + // } + //}, + //TxPoolNamespace: func(ctx *server.Context, _ client.Context, _ *rpcclient.WSClient, _ bool, _ ethermint.EVMTxIndexer) []rpc.API { + // return []rpc.API{ + // { + // Namespace: TxPoolNamespace, + // Version: apiVersion, + // Service: txpool.NewPublicAPI(ctx.Logger), + // Public: true, + // }, + // } + //}, + //DebugNamespace: func(ctx *server.Context, + // clientCtx client.Context, + // _ *rpcclient.WSClient, + // allowUnprotectedTxs bool, + // indexer ethermint.EVMTxIndexer, + //) []rpc.API { + // evmBackend := backend.NewBackend(ctx, ctx.Logger, clientCtx, allowUnprotectedTxs, indexer) + // return []rpc.API{ + // { + // Namespace: DebugNamespace, + // Version: apiVersion, + // Service: debug.NewAPI(ctx, evmBackend), + // Public: true, + // }, + // } + //}, + //MinerNamespace: func(ctx *server.Context, + // clientCtx client.Context, + // _ *rpcclient.WSClient, + // allowUnprotectedTxs bool, + // indexer ethermint.EVMTxIndexer, + //) []rpc.API { + // evmBackend := backend.NewBackend(ctx, ctx.Logger, clientCtx, allowUnprotectedTxs, indexer) + // return []rpc.API{ + // { + // Namespace: MinerNamespace, + // Version: apiVersion, + // Service: miner.NewPrivateAPI(ctx, evmBackend), + // Public: false, + // }, + // } + //}, } } diff --git a/rpc/namespaces/ethereum/debug/api.go b/rpc/namespaces/ethereum/debug/api.go index 0620b67be0..94f771ab39 100644 --- a/rpc/namespaces/ethereum/debug/api.go +++ b/rpc/namespaces/ethereum/debug/api.go @@ -27,18 +27,14 @@ import ( "sync" "time" - "github.com/davecgh/go-spew/spew" - - evmtypes "github.com/evmos/ethermint/x/evm/types" - - stderrors "github.com/pkg/errors" - "github.com/cosmos/cosmos-sdk/server" - + "github.com/davecgh/go-spew/spew" "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/common/hexutil" "github.com/ethereum/go-ethereum/consensus/ethash" "github.com/ethereum/go-ethereum/rlp" + evmtypes "github.com/evmos/ethermint/x/evm/types" + stderrors "github.com/pkg/errors" "github.com/tendermint/tendermint/libs/log" "github.com/zeta-chain/zetacore/rpc/backend" rpctypes "github.com/zeta-chain/zetacore/rpc/types" diff --git a/rpc/namespaces/ethereum/eth/api.go b/rpc/namespaces/ethereum/eth/api.go index d62ddbe18c..7d05848b91 100644 --- a/rpc/namespaces/ethereum/eth/api.go +++ b/rpc/namespaces/ethereum/eth/api.go @@ -18,20 +18,14 @@ package eth import ( "context" - "github.com/ethereum/go-ethereum/signer/core/apitypes" - - "github.com/ethereum/go-ethereum/rpc" - - "github.com/tendermint/tendermint/libs/log" - "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/common/hexutil" ethtypes "github.com/ethereum/go-ethereum/core/types" - - "github.com/zeta-chain/zetacore/rpc/backend" - + "github.com/ethereum/go-ethereum/rpc" ethermint "github.com/evmos/ethermint/types" evmtypes "github.com/evmos/ethermint/x/evm/types" + "github.com/tendermint/tendermint/libs/log" + "github.com/zeta-chain/zetacore/rpc/backend" rpctypes "github.com/zeta-chain/zetacore/rpc/types" ) @@ -67,7 +61,6 @@ type EthereumAPI interface { // Allows developers to both send ETH from one address to another, write data // on-chain, and interact with smart contracts. SendRawTransaction(data hexutil.Bytes) (common.Hash, error) - SendTransaction(args evmtypes.TransactionArgs) (common.Hash, error) // eth_sendPrivateTransaction // eth_cancel PrivateTransaction @@ -111,9 +104,7 @@ type EthereumAPI interface { // Other Syncing() (interface{}, error) Coinbase() (string, error) - Sign(address common.Address, data hexutil.Bytes) (hexutil.Bytes, error) GetTransactionLogs(txHash common.Hash) ([]*ethtypes.Log, error) - SignTypedData(address common.Address, typedData apitypes.TypedData) (hexutil.Bytes, error) FillTransaction(args evmtypes.TransactionArgs) (*rpctypes.SignTransactionResult, error) Resend(ctx context.Context, args evmtypes.TransactionArgs, gasPrice *hexutil.Big, gasLimit *hexutil.Uint64) (common.Hash, error) GetPendingTransactions() ([]*rpctypes.RPCTransaction, error) @@ -125,6 +116,11 @@ type EthereumAPI interface { // eth_getWork (on Ethereum.org) // eth_submitWork (on Ethereum.org) // eth_submitHashrate (on Ethereum.org) + + // Disabled APIs for security reasons + //SendTransaction(args evmtypes.TransactionArgs) (common.Hash, error) + //Sign(address common.Address, data hexutil.Bytes) (hexutil.Bytes, error) + //SignTypedData(address common.Address, typedData apitypes.TypedData) (hexutil.Bytes, error) } var _ EthereumAPI = (*PublicAPI)(nil) @@ -230,12 +226,6 @@ func (e *PublicAPI) SendRawTransaction(data hexutil.Bytes) (common.Hash, error) return e.backend.SendRawTransaction(data) } -// SendTransaction sends an Ethereum transaction. -func (e *PublicAPI) SendTransaction(args evmtypes.TransactionArgs) (common.Hash, error) { - e.logger.Debug("eth_sendTransaction", "args", args.String()) - return e.backend.SendTransaction(args) -} - /////////////////////////////////////////////////////////////////////////////// /// Account Information /// /////////////////////////////////////////////////////////////////////////////// @@ -416,12 +406,6 @@ func (e *PublicAPI) Coinbase() (string, error) { return ethAddr.Hex(), nil } -// Sign signs the provided data using the private key of address via Geth's signature standard. -func (e *PublicAPI) Sign(address common.Address, data hexutil.Bytes) (hexutil.Bytes, error) { - e.logger.Debug("eth_sign", "address", address.Hex(), "data", common.Bytes2Hex(data)) - return e.backend.Sign(address, data) -} - // GetTransactionLogs returns the logs given a transaction hash. func (e *PublicAPI) GetTransactionLogs(txHash common.Hash) ([]*ethtypes.Log, error) { e.logger.Debug("eth_getTransactionLogs", "hash", txHash) @@ -448,12 +432,6 @@ func (e *PublicAPI) GetTransactionLogs(txHash common.Hash) ([]*ethtypes.Log, err return backend.TxLogsFromEvents(resBlockResult.TxsResults[res.TxIndex].Events, int(res.MsgIndex)) } -// SignTypedData signs EIP-712 conformant typed data -func (e *PublicAPI) SignTypedData(address common.Address, typedData apitypes.TypedData) (hexutil.Bytes, error) { - e.logger.Debug("eth_signTypedData", "address", address.Hex(), "data", typedData) - return e.backend.SignTypedData(address, typedData) -} - // FillTransaction fills the defaults (nonce, gas, gasPrice or 1559 fields) // on a given unsigned transaction, and returns it to the caller for further // processing (signing + broadcast). @@ -527,3 +505,25 @@ func (e *PublicAPI) GetPendingTransactions() ([]*rpctypes.RPCTransaction, error) return result, nil } + +/////////////////////////////////////////////////////////////////////////////// +/// Disabled /// +/////////////////////////////////////////////////////////////////////////////// + +//// SendTransaction sends an Ethereum transaction. +//func (e *PublicAPI) SendTransaction(args evmtypes.TransactionArgs) (common.Hash, error) { +// e.logger.Debug("eth_sendTransaction", "args", args.String()) +// return e.backend.SendTransaction(args) +//} +// +//// Sign signs the provided data using the private key of address via Geth's signature standard. +//func (e *PublicAPI) Sign(address common.Address, data hexutil.Bytes) (hexutil.Bytes, error) { +// e.logger.Debug("eth_sign", "address", address.Hex(), "data", common.Bytes2Hex(data)) +// return e.backend.Sign(address, data) +//} +// +//// SignTypedData signs EIP-712 conformant typed data +//func (e *PublicAPI) SignTypedData(address common.Address, typedData apitypes.TypedData) (hexutil.Bytes, error) { +// e.logger.Debug("eth_signTypedData", "address", address.Hex(), "data", typedData) +// return e.backend.SignTypedData(address, typedData) +//} diff --git a/rpc/namespaces/ethereum/eth/filters/api.go b/rpc/namespaces/ethereum/eth/filters/api.go index f6a9135a16..0268c7217d 100644 --- a/rpc/namespaces/ethereum/eth/filters/api.go +++ b/rpc/namespaces/ethereum/eth/filters/api.go @@ -22,20 +22,16 @@ import ( "time" "github.com/cosmos/cosmos-sdk/client" - "github.com/zeta-chain/zetacore/rpc/types" - - "github.com/tendermint/tendermint/libs/log" - - coretypes "github.com/tendermint/tendermint/rpc/core/types" - rpcclient "github.com/tendermint/tendermint/rpc/jsonrpc/client" - tmtypes "github.com/tendermint/tendermint/types" - "github.com/ethereum/go-ethereum/common" ethtypes "github.com/ethereum/go-ethereum/core/types" "github.com/ethereum/go-ethereum/eth/filters" "github.com/ethereum/go-ethereum/rpc" - evmtypes "github.com/evmos/ethermint/x/evm/types" + "github.com/tendermint/tendermint/libs/log" + coretypes "github.com/tendermint/tendermint/rpc/core/types" + rpcclient "github.com/tendermint/tendermint/rpc/jsonrpc/client" + tmtypes "github.com/tendermint/tendermint/types" + "github.com/zeta-chain/zetacore/rpc/types" ) // FilterAPI gathers diff --git a/rpc/namespaces/ethereum/eth/filters/filter_system.go b/rpc/namespaces/ethereum/eth/filters/filter_system.go index ac69cfc53d..ba203cf685 100644 --- a/rpc/namespaces/ethereum/eth/filters/filter_system.go +++ b/rpc/namespaces/ethereum/eth/filters/filter_system.go @@ -21,23 +21,19 @@ import ( "sync" "time" + sdk "github.com/cosmos/cosmos-sdk/types" + "github.com/ethereum/go-ethereum/common" + ethtypes "github.com/ethereum/go-ethereum/core/types" + "github.com/ethereum/go-ethereum/eth/filters" + "github.com/ethereum/go-ethereum/rpc" + evmtypes "github.com/evmos/ethermint/x/evm/types" "github.com/pkg/errors" - tmjson "github.com/tendermint/tendermint/libs/json" "github.com/tendermint/tendermint/libs/log" tmquery "github.com/tendermint/tendermint/libs/pubsub/query" coretypes "github.com/tendermint/tendermint/rpc/core/types" rpcclient "github.com/tendermint/tendermint/rpc/jsonrpc/client" tmtypes "github.com/tendermint/tendermint/types" - - "github.com/ethereum/go-ethereum/common" - ethtypes "github.com/ethereum/go-ethereum/core/types" - "github.com/ethereum/go-ethereum/eth/filters" - "github.com/ethereum/go-ethereum/rpc" - - sdk "github.com/cosmos/cosmos-sdk/types" - - evmtypes "github.com/evmos/ethermint/x/evm/types" "github.com/zeta-chain/zetacore/rpc/ethereum/pubsub" ) diff --git a/rpc/namespaces/ethereum/eth/filters/filters.go b/rpc/namespaces/ethereum/eth/filters/filters.go index 7bcb08fd75..4355182001 100644 --- a/rpc/namespaces/ethereum/eth/filters/filters.go +++ b/rpc/namespaces/ethereum/eth/filters/filters.go @@ -21,17 +21,15 @@ import ( "fmt" "math/big" - "github.com/zeta-chain/zetacore/rpc/backend" - "github.com/zeta-chain/zetacore/rpc/types" - - "github.com/pkg/errors" - "github.com/tendermint/tendermint/libs/log" - tmrpctypes "github.com/tendermint/tendermint/rpc/core/types" - "github.com/ethereum/go-ethereum/common" ethtypes "github.com/ethereum/go-ethereum/core/types" "github.com/ethereum/go-ethereum/crypto" "github.com/ethereum/go-ethereum/eth/filters" + "github.com/pkg/errors" + "github.com/tendermint/tendermint/libs/log" + tmrpctypes "github.com/tendermint/tendermint/rpc/core/types" + "github.com/zeta-chain/zetacore/rpc/backend" + "github.com/zeta-chain/zetacore/rpc/types" ) // BloomIV represents the bit indexes and value inside the bloom filter that belong diff --git a/rpc/namespaces/ethereum/miner/api.go b/rpc/namespaces/ethereum/miner/api.go index 901c567a46..9d5e8fc556 100644 --- a/rpc/namespaces/ethereum/miner/api.go +++ b/rpc/namespaces/ethereum/miner/api.go @@ -17,12 +17,9 @@ package miner import ( "github.com/cosmos/cosmos-sdk/server" - "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/common/hexutil" - "github.com/tendermint/tendermint/libs/log" - "github.com/zeta-chain/zetacore/rpc/backend" ) diff --git a/rpc/namespaces/ethereum/personal/api.go b/rpc/namespaces/ethereum/personal/api.go index 49b654c8dc..fa182c4759 100644 --- a/rpc/namespaces/ethereum/personal/api.go +++ b/rpc/namespaces/ethereum/personal/api.go @@ -21,22 +21,17 @@ import ( "os" "time" - "github.com/zeta-chain/zetacore/rpc/backend" - - "github.com/evmos/ethermint/crypto/hd" - ethermint "github.com/evmos/ethermint/types" - - "github.com/tendermint/tendermint/libs/log" - "github.com/cosmos/cosmos-sdk/crypto/keyring" sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/ethereum/go-ethereum/accounts" "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/common/hexutil" "github.com/ethereum/go-ethereum/crypto" - + "github.com/evmos/ethermint/crypto/hd" + ethermint "github.com/evmos/ethermint/types" evmtypes "github.com/evmos/ethermint/x/evm/types" + "github.com/tendermint/tendermint/libs/log" + "github.com/zeta-chain/zetacore/rpc/backend" ) // PrivateAccountAPI is the personal_ prefixed set of APIs in the Web3 JSON-RPC spec. diff --git a/rpc/namespaces/ethereum/txpool/api.go b/rpc/namespaces/ethereum/txpool/api.go index e8320b6655..89fb056bde 100644 --- a/rpc/namespaces/ethereum/txpool/api.go +++ b/rpc/namespaces/ethereum/txpool/api.go @@ -16,10 +16,8 @@ package txpool import ( - "github.com/tendermint/tendermint/libs/log" - "github.com/ethereum/go-ethereum/common/hexutil" - + "github.com/tendermint/tendermint/libs/log" "github.com/zeta-chain/zetacore/rpc/types" ) diff --git a/rpc/namespaces/ethereum/web3/api.go b/rpc/namespaces/ethereum/web3/api.go index 47f522785d..46e09d9637 100644 --- a/rpc/namespaces/ethereum/web3/api.go +++ b/rpc/namespaces/ethereum/web3/api.go @@ -19,10 +19,9 @@ import ( "fmt" "runtime" - "github.com/zeta-chain/zetacore/common" - "github.com/ethereum/go-ethereum/common/hexutil" "github.com/ethereum/go-ethereum/crypto" + "github.com/zeta-chain/zetacore/common" ) // PublicAPI is the web3_ prefixed set of APIs in the Web3 JSON-RPC spec. diff --git a/rpc/websockets.go b/rpc/websockets.go index c76a028ea3..ba0419efcc 100644 --- a/rpc/websockets.go +++ b/rpc/websockets.go @@ -27,27 +27,28 @@ import ( "sync" "github.com/cosmos/cosmos-sdk/client" - "github.com/gorilla/mux" - "github.com/gorilla/websocket" - "github.com/pkg/errors" - "github.com/ethereum/go-ethereum/common" ethtypes "github.com/ethereum/go-ethereum/core/types" "github.com/ethereum/go-ethereum/eth/filters" "github.com/ethereum/go-ethereum/params" "github.com/ethereum/go-ethereum/rpc" - + evmtypes "github.com/evmos/ethermint/x/evm/types" + "github.com/gorilla/mux" + "github.com/gorilla/websocket" + "github.com/pkg/errors" "github.com/tendermint/tendermint/libs/log" rpcclient "github.com/tendermint/tendermint/rpc/jsonrpc/client" tmtypes "github.com/tendermint/tendermint/types" - - evmtypes "github.com/evmos/ethermint/x/evm/types" "github.com/zeta-chain/zetacore/rpc/ethereum/pubsub" rpcfilters "github.com/zeta-chain/zetacore/rpc/namespaces/ethereum/eth/filters" "github.com/zeta-chain/zetacore/rpc/types" "github.com/zeta-chain/zetacore/server/config" ) +const ( + messageSizeLimit = 32 * 1024 * 1024 // 32MB +) + type WebsocketsServer interface { Start() } @@ -139,6 +140,8 @@ func (s *websocketsServer) ServeHTTP(w http.ResponseWriter, r *http.Request) { return } + conn.SetReadLimit(messageSizeLimit) + s.readLoop(&wsConn{ mux: new(sync.Mutex), conn: conn, From b896e3cb08ff3c88bede89149d3a28e1f866d2f8 Mon Sep 17 00:00:00 2001 From: Lucas Bertrand Date: Wed, 20 Sep 2023 17:57:25 +0200 Subject: [PATCH 3/5] refactor: generic `Header` and `Proof` (#1145) * update proto * proto, remove pointers * add header type * fix zeta client * update message * move header to common * implement generic proof * refactor grpc * make mocks * fix zetaclient * goimports * fix lint * fix smoke test * change pointer proof --- common/common.pb.go | 990 ++++++++++++++++-- common/headers.go | 68 ++ common/proof.go | 61 ++ common/proof_test.go | 15 + .../smoketest/test_deposit_eth.go | 2 +- docs/openapi/openapi.swagger.yaml | 57 +- docs/spec/crosschain/messages.md | 13 +- docs/spec/observer/messages.md | 6 +- proto/common/common.proto | 23 +- proto/crosschain/tx.proto | 4 +- proto/observer/headers.proto | 15 - proto/observer/query.proto | 12 +- proto/observer/tx.proto | 5 +- testutil/keeper/mocks/crosschain/account.go | 2 +- testutil/keeper/mocks/crosschain/bank.go | 2 +- testutil/keeper/mocks/crosschain/fungible.go | 2 +- testutil/keeper/mocks/crosschain/observer.go | 12 +- testutil/keeper/mocks/crosschain/staking.go | 2 +- testutil/keeper/mocks/fungible/account.go | 2 +- testutil/keeper/mocks/fungible/bank.go | 2 +- testutil/keeper/mocks/fungible/evm.go | 2 +- testutil/keeper/mocks/fungible/observer.go | 2 +- x/crosschain/keeper/keeper_out_tx_tracker.go | 40 +- x/crosschain/types/expected_keepers.go | 2 +- .../types/message_add_to_out_tx_tracker.go | 12 +- x/crosschain/types/tx.pb.go | 193 ++-- ...keeper_block_header.go => block_header.go} | 22 +- x/observer/keeper/grpc_query_prove.go | 14 +- .../keeper/msg_server_add_block_header.go | 35 +- x/observer/types/errors.go | 41 +- x/observer/types/headers.pb.go | 500 --------- x/observer/types/messages_add_block_header.go | 60 +- x/observer/types/query.pb.go | 270 +++-- x/observer/types/tx.pb.go | 188 ++-- zetaclient/evm_client.go | 8 +- zetaclient/query.go | 3 +- zetaclient/tx.go | 6 +- 37 files changed, 1583 insertions(+), 1110 deletions(-) create mode 100644 common/headers.go create mode 100644 common/proof.go create mode 100644 common/proof_test.go delete mode 100644 proto/observer/headers.proto rename x/observer/keeper/{keeper_block_header.go => block_header.go} (80%) delete mode 100644 x/observer/types/headers.pb.go diff --git a/common/common.pb.go b/common/common.pb.go index 683a844041..4277cc8dc6 100644 --- a/common/common.pb.go +++ b/common/common.pb.go @@ -11,6 +11,7 @@ import ( _ "github.com/cosmos/gogoproto/gogoproto" proto "github.com/gogo/protobuf/proto" + ethereum "github.com/zeta-chain/zetacore/common/ethereum" ) // Reference imports to suppress errors if they are not otherwise used. @@ -255,48 +256,284 @@ func (m *Chain) GetChainId() int64 { return 0 } +type BlockHeader struct { + Height int64 `protobuf:"varint,1,opt,name=height,proto3" json:"height,omitempty"` + Hash []byte `protobuf:"bytes,2,opt,name=hash,proto3" json:"hash,omitempty"` + ParentHash []byte `protobuf:"bytes,3,opt,name=parent_hash,json=parentHash,proto3" json:"parent_hash,omitempty"` + ChainId int64 `protobuf:"varint,4,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` + // chain specific header + Header HeaderData `protobuf:"bytes,5,opt,name=header,proto3" json:"header"` +} + +func (m *BlockHeader) Reset() { *m = BlockHeader{} } +func (m *BlockHeader) String() string { return proto.CompactTextString(m) } +func (*BlockHeader) ProtoMessage() {} +func (*BlockHeader) Descriptor() ([]byte, []int) { + return fileDescriptor_8f954d82c0b891f6, []int{2} +} +func (m *BlockHeader) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *BlockHeader) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_BlockHeader.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *BlockHeader) XXX_Merge(src proto.Message) { + xxx_messageInfo_BlockHeader.Merge(m, src) +} +func (m *BlockHeader) XXX_Size() int { + return m.Size() +} +func (m *BlockHeader) XXX_DiscardUnknown() { + xxx_messageInfo_BlockHeader.DiscardUnknown(m) +} + +var xxx_messageInfo_BlockHeader proto.InternalMessageInfo + +func (m *BlockHeader) GetHeight() int64 { + if m != nil { + return m.Height + } + return 0 +} + +func (m *BlockHeader) GetHash() []byte { + if m != nil { + return m.Hash + } + return nil +} + +func (m *BlockHeader) GetParentHash() []byte { + if m != nil { + return m.ParentHash + } + return nil +} + +func (m *BlockHeader) GetChainId() int64 { + if m != nil { + return m.ChainId + } + return 0 +} + +func (m *BlockHeader) GetHeader() HeaderData { + if m != nil { + return m.Header + } + return HeaderData{} +} + +type HeaderData struct { + // Types that are valid to be assigned to Data: + // + // *HeaderData_EthereumHeader + Data isHeaderData_Data `protobuf_oneof:"data"` +} + +func (m *HeaderData) Reset() { *m = HeaderData{} } +func (m *HeaderData) String() string { return proto.CompactTextString(m) } +func (*HeaderData) ProtoMessage() {} +func (*HeaderData) Descriptor() ([]byte, []int) { + return fileDescriptor_8f954d82c0b891f6, []int{3} +} +func (m *HeaderData) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *HeaderData) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_HeaderData.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *HeaderData) XXX_Merge(src proto.Message) { + xxx_messageInfo_HeaderData.Merge(m, src) +} +func (m *HeaderData) XXX_Size() int { + return m.Size() +} +func (m *HeaderData) XXX_DiscardUnknown() { + xxx_messageInfo_HeaderData.DiscardUnknown(m) +} + +var xxx_messageInfo_HeaderData proto.InternalMessageInfo + +type isHeaderData_Data interface { + isHeaderData_Data() + MarshalTo([]byte) (int, error) + Size() int +} + +type HeaderData_EthereumHeader struct { + EthereumHeader []byte `protobuf:"bytes,1,opt,name=ethereum_header,json=ethereumHeader,proto3,oneof" json:"ethereum_header,omitempty"` +} + +func (*HeaderData_EthereumHeader) isHeaderData_Data() {} + +func (m *HeaderData) GetData() isHeaderData_Data { + if m != nil { + return m.Data + } + return nil +} + +func (m *HeaderData) GetEthereumHeader() []byte { + if x, ok := m.GetData().(*HeaderData_EthereumHeader); ok { + return x.EthereumHeader + } + return nil +} + +// XXX_OneofWrappers is for the internal use of the proto package. +func (*HeaderData) XXX_OneofWrappers() []interface{} { + return []interface{}{ + (*HeaderData_EthereumHeader)(nil), + } +} + +type Proof struct { + // Types that are valid to be assigned to Proof: + // + // *Proof_EthereumProof + Proof isProof_Proof `protobuf_oneof:"proof"` +} + +func (m *Proof) Reset() { *m = Proof{} } +func (m *Proof) String() string { return proto.CompactTextString(m) } +func (*Proof) ProtoMessage() {} +func (*Proof) Descriptor() ([]byte, []int) { + return fileDescriptor_8f954d82c0b891f6, []int{4} +} +func (m *Proof) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *Proof) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_Proof.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *Proof) XXX_Merge(src proto.Message) { + xxx_messageInfo_Proof.Merge(m, src) +} +func (m *Proof) XXX_Size() int { + return m.Size() +} +func (m *Proof) XXX_DiscardUnknown() { + xxx_messageInfo_Proof.DiscardUnknown(m) +} + +var xxx_messageInfo_Proof proto.InternalMessageInfo + +type isProof_Proof interface { + isProof_Proof() + MarshalTo([]byte) (int, error) + Size() int +} + +type Proof_EthereumProof struct { + EthereumProof *ethereum.Proof `protobuf:"bytes,1,opt,name=ethereum_proof,json=ethereumProof,proto3,oneof" json:"ethereum_proof,omitempty"` +} + +func (*Proof_EthereumProof) isProof_Proof() {} + +func (m *Proof) GetProof() isProof_Proof { + if m != nil { + return m.Proof + } + return nil +} + +func (m *Proof) GetEthereumProof() *ethereum.Proof { + if x, ok := m.GetProof().(*Proof_EthereumProof); ok { + return x.EthereumProof + } + return nil +} + +// XXX_OneofWrappers is for the internal use of the proto package. +func (*Proof) XXX_OneofWrappers() []interface{} { + return []interface{}{ + (*Proof_EthereumProof)(nil), + } +} + func init() { proto.RegisterEnum("common.ReceiveStatus", ReceiveStatus_name, ReceiveStatus_value) proto.RegisterEnum("common.CoinType", CoinType_name, CoinType_value) proto.RegisterEnum("common.ChainName", ChainName_name, ChainName_value) proto.RegisterType((*PubKeySet)(nil), "common.PubKeySet") proto.RegisterType((*Chain)(nil), "common.Chain") + proto.RegisterType((*BlockHeader)(nil), "common.BlockHeader") + proto.RegisterType((*HeaderData)(nil), "common.HeaderData") + proto.RegisterType((*Proof)(nil), "common.Proof") } func init() { proto.RegisterFile("common/common.proto", fileDescriptor_8f954d82c0b891f6) } var fileDescriptor_8f954d82c0b891f6 = []byte{ - // 476 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x4c, 0x92, 0x41, 0x8b, 0xd3, 0x40, - 0x14, 0xc7, 0x93, 0x76, 0x9b, 0x34, 0xaf, 0x6b, 0x3b, 0xce, 0x0a, 0xae, 0x7b, 0xc8, 0xca, 0xa2, - 0x20, 0x0b, 0x6e, 0x77, 0x2b, 0x55, 0xc4, 0x83, 0xb0, 0x41, 0x45, 0x04, 0x91, 0x74, 0x4f, 0x7b, - 0x29, 0x93, 0xc9, 0x23, 0x09, 0x26, 0x99, 0x90, 0x4c, 0x84, 0xfa, 0x29, 0xfc, 0x0a, 0x82, 0x07, - 0x3f, 0x8a, 0xc7, 0x3d, 0x7a, 0x5a, 0xa4, 0xfd, 0x16, 0x9e, 0x64, 0x26, 0x4d, 0xea, 0x29, 0x6f, - 0x7e, 0xf3, 0x7b, 0xf3, 0xfe, 0x64, 0x06, 0x0e, 0xb8, 0xc8, 0x32, 0x91, 0x4f, 0x9b, 0xcf, 0x59, - 0x51, 0x0a, 0x29, 0xa8, 0xd5, 0xac, 0x8e, 0xee, 0x45, 0x22, 0x12, 0x1a, 0x4d, 0x55, 0xd5, 0xec, - 0x9e, 0xc4, 0xe0, 0x7c, 0xaa, 0x83, 0x0f, 0xb8, 0x5a, 0xa0, 0xa4, 0x73, 0x70, 0x2a, 0xe4, 0xc5, - 0x6c, 0xfe, 0xfc, 0xf3, 0xc5, 0xa1, 0xf9, 0xd0, 0x7c, 0xe2, 0x5c, 0xde, 0x5f, 0xdf, 0x1e, 0x3b, - 0x8b, 0x16, 0xfe, 0xbd, 0x3d, 0xb6, 0x1a, 0xdd, 0xdf, 0x99, 0xf4, 0x11, 0xd8, 0x18, 0xce, 0xe6, - 0xf3, 0x8b, 0x97, 0x87, 0x3d, 0xdd, 0x04, 0xff, 0x79, 0xed, 0xd6, 0xc9, 0x15, 0x0c, 0xbc, 0x98, - 0x25, 0x39, 0x3d, 0x07, 0xe0, 0xaa, 0x58, 0xe6, 0x2c, 0x43, 0x3d, 0x66, 0x3c, 0xbb, 0x7b, 0xb6, - 0xcd, 0xac, 0x95, 0x8f, 0x2c, 0x43, 0xdf, 0xe1, 0x6d, 0x49, 0x1f, 0xc0, 0xb0, 0xe9, 0x48, 0x42, - 0x3d, 0xa1, 0xef, 0xdb, 0x7a, 0xfd, 0x3e, 0x3c, 0x7d, 0x05, 0x77, 0x7c, 0xe4, 0x98, 0x7c, 0xc1, - 0x85, 0x64, 0xb2, 0xae, 0xe8, 0x08, 0x6c, 0xaf, 0x44, 0x26, 0x31, 0x24, 0x86, 0x5a, 0x2c, 0x6a, - 0xce, 0xb1, 0xaa, 0x88, 0x49, 0x01, 0xac, 0xb7, 0x2c, 0x49, 0x31, 0x24, 0xbd, 0xa3, 0xbd, 0x9f, - 0x3f, 0x5c, 0xf3, 0xf4, 0x05, 0x0c, 0x3d, 0x91, 0xe4, 0x57, 0xab, 0x02, 0xe9, 0x10, 0xf6, 0xae, - 0x51, 0x32, 0x62, 0x50, 0x1b, 0xfa, 0xef, 0x98, 0x6a, 0x70, 0x60, 0xf0, 0xc6, 0xf7, 0x66, 0xe7, - 0xa4, 0xa7, 0x98, 0x97, 0x85, 0xa4, 0xbf, 0x6d, 0xfc, 0xde, 0x03, 0xa7, 0x4b, 0xaa, 0x3c, 0xcc, - 0x0a, 0xb9, 0x22, 0x06, 0x9d, 0xc0, 0x08, 0x65, 0xbc, 0xcc, 0x58, 0x92, 0xe7, 0x28, 0x89, 0x49, - 0x09, 0xec, 0x7f, 0x45, 0xc9, 0x3a, 0xd2, 0x53, 0x4a, 0x20, 0x79, 0x07, 0xfa, 0xf4, 0x00, 0x26, - 0x85, 0x48, 0x57, 0x91, 0xc8, 0x3b, 0xb8, 0xa7, 0xad, 0x6a, 0x67, 0x0d, 0x28, 0x85, 0x71, 0x24, - 0xb0, 0x4c, 0x93, 0xa5, 0xc4, 0x4a, 0x2a, 0x66, 0x29, 0x96, 0xd5, 0x59, 0xc0, 0x76, 0xcc, 0x56, - 0xa7, 0x45, 0x2c, 0x67, 0x3c, 0xc6, 0x0e, 0x0e, 0x95, 0x18, 0x30, 0x11, 0xb0, 0xa0, 0x63, 0x4e, - 0x3b, 0xa1, 0x05, 0xd0, 0x45, 0x6d, 0xc9, 0xa8, 0x8d, 0xda, 0x82, 0x7d, 0x7d, 0x78, 0x13, 0x22, - 0x15, 0x9c, 0xa5, 0x0a, 0x8e, 0x5b, 0xab, 0xc4, 0x48, 0x89, 0x64, 0xd2, 0xfc, 0xa3, 0xcb, 0xd7, - 0xbf, 0xd6, 0xae, 0x79, 0xb3, 0x76, 0xcd, 0x3f, 0x6b, 0xd7, 0xfc, 0xb6, 0x71, 0x8d, 0x9b, 0x8d, - 0x6b, 0xfc, 0xde, 0xb8, 0xc6, 0xf5, 0xe3, 0x28, 0x91, 0x71, 0x1d, 0xa8, 0x2b, 0x9f, 0xaa, 0x89, - 0x4f, 0xf5, 0x65, 0xea, 0x92, 0x8b, 0x12, 0xb7, 0xcf, 0x37, 0xb0, 0xf4, 0x0b, 0x7d, 0xf6, 0x2f, - 0x00, 0x00, 0xff, 0xff, 0xba, 0x90, 0x73, 0x66, 0xd6, 0x02, 0x00, 0x00, + // 639 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x54, 0x94, 0xcb, 0x6a, 0xdb, 0x4c, + 0x14, 0x80, 0x25, 0x5f, 0x64, 0xeb, 0xc8, 0xb1, 0xf5, 0x4f, 0x7e, 0xfe, 0x3f, 0xcd, 0x42, 0x0e, + 0xa6, 0x85, 0x34, 0xd0, 0x5c, 0x5c, 0xdc, 0x0b, 0x5d, 0x04, 0xec, 0x5e, 0xdc, 0x16, 0x4a, 0x90, + 0xb3, 0xca, 0xc6, 0x8c, 0xa4, 0x53, 0x49, 0xc4, 0xd2, 0x08, 0x69, 0x5c, 0x70, 0x9f, 0xa2, 0xaf, + 0x50, 0x28, 0xb4, 0x8f, 0x92, 0x65, 0x96, 0x5d, 0x85, 0xe2, 0xbc, 0x45, 0x57, 0x65, 0x46, 0x17, + 0xa7, 0x2b, 0x9f, 0xf9, 0xce, 0x77, 0x2e, 0xf2, 0xc8, 0x86, 0x6d, 0x97, 0x45, 0x11, 0x8b, 0x8f, + 0xf2, 0x8f, 0xc3, 0x24, 0x65, 0x9c, 0x11, 0x2d, 0x3f, 0xed, 0x5a, 0x45, 0x12, 0x79, 0x80, 0x29, + 0x2e, 0xa3, 0x2a, 0xc8, 0xbd, 0xdd, 0x7f, 0x7d, 0xe6, 0x33, 0x19, 0x1e, 0x89, 0x28, 0xa7, 0x83, + 0x00, 0xf4, 0xb3, 0xa5, 0xf3, 0x1e, 0x57, 0x33, 0xe4, 0x64, 0x04, 0x7a, 0x86, 0x6e, 0x32, 0x1c, + 0x3d, 0xb9, 0x3c, 0xd9, 0x51, 0xf7, 0xd4, 0x7d, 0x7d, 0xfc, 0xff, 0xfa, 0xa6, 0xaf, 0xcf, 0x4a, + 0xf8, 0xfb, 0xa6, 0xaf, 0xe5, 0xba, 0xbd, 0x31, 0xc9, 0x7d, 0x68, 0xa1, 0x37, 0x1c, 0x8d, 0x4e, + 0x9e, 0xef, 0xd4, 0x64, 0x11, 0xdc, 0xf1, 0xca, 0xd4, 0xe0, 0x1c, 0x9a, 0x93, 0x80, 0x86, 0x31, + 0x39, 0x06, 0x70, 0x45, 0x30, 0x8f, 0x69, 0x84, 0x72, 0x4c, 0x77, 0xf8, 0xcf, 0x61, 0xf1, 0x4c, + 0x52, 0xf9, 0x40, 0x23, 0xb4, 0x75, 0xb7, 0x0c, 0xc9, 0x3d, 0x68, 0xe7, 0x15, 0xa1, 0x27, 0x27, + 0xd4, 0xed, 0x96, 0x3c, 0xbf, 0xf5, 0x06, 0xdf, 0x55, 0x30, 0xc6, 0x0b, 0xe6, 0x5e, 0x4e, 0x91, + 0x7a, 0x98, 0x92, 0xff, 0x40, 0x0b, 0x30, 0xf4, 0x03, 0x2e, 0x1b, 0xd7, 0xed, 0xe2, 0x44, 0x08, + 0x34, 0x02, 0x9a, 0x05, 0xb2, 0xbc, 0x63, 0xcb, 0x98, 0xf4, 0xc1, 0x48, 0x68, 0x8a, 0x31, 0x9f, + 0xcb, 0x54, 0x5d, 0xa6, 0x20, 0x47, 0x53, 0x21, 0xdc, 0x9d, 0xdb, 0xf8, 0x6b, 0x2e, 0x39, 0x16, + 0x73, 0xc4, 0xc4, 0x9d, 0xe6, 0x9e, 0xba, 0x6f, 0x0c, 0x49, 0xf9, 0x00, 0xf9, 0x1e, 0x2f, 0x29, + 0xa7, 0xe3, 0xc6, 0xd5, 0x4d, 0x5f, 0xb1, 0x0b, 0x6f, 0x70, 0x0a, 0xb0, 0xc9, 0x91, 0x87, 0xd0, + 0x2b, 0xef, 0x67, 0x5e, 0x34, 0x12, 0x0b, 0x77, 0xa6, 0x8a, 0xdd, 0x2d, 0x13, 0xb9, 0x3e, 0xd6, + 0xa0, 0xe1, 0x51, 0x4e, 0x07, 0xef, 0xa0, 0x79, 0x96, 0x32, 0xf6, 0x91, 0x3c, 0x83, 0x4a, 0x99, + 0x27, 0x82, 0xc8, 0x52, 0x63, 0xd8, 0x3b, 0xac, 0xae, 0x5c, 0x8a, 0x53, 0xc5, 0xde, 0x2a, 0x89, + 0x04, 0xe3, 0x16, 0x34, 0x65, 0xc1, 0xc1, 0x0b, 0xd8, 0xb2, 0xd1, 0xc5, 0xf0, 0x13, 0xce, 0x38, + 0xe5, 0xcb, 0x8c, 0x18, 0xd0, 0x9a, 0xa4, 0x48, 0x39, 0x7a, 0xa6, 0x22, 0x0e, 0xb3, 0xa5, 0xeb, + 0x62, 0x96, 0x99, 0x2a, 0x01, 0xd0, 0x5e, 0xd3, 0x70, 0x81, 0x9e, 0x59, 0xdb, 0x6d, 0xfc, 0xf8, + 0x66, 0xa9, 0x07, 0x4f, 0xa1, 0x3d, 0x61, 0x61, 0x7c, 0xbe, 0x4a, 0x90, 0xb4, 0xa1, 0x71, 0x81, + 0x9c, 0x9a, 0x0a, 0x69, 0x41, 0xfd, 0x0d, 0x15, 0x05, 0x3a, 0x34, 0x5f, 0xd9, 0x93, 0xe1, 0xb1, + 0x59, 0x13, 0x6c, 0x12, 0x79, 0x66, 0xbd, 0x28, 0xfc, 0x5a, 0x03, 0xbd, 0xba, 0x60, 0xe1, 0x61, + 0x94, 0xf0, 0x95, 0xa9, 0x90, 0x1e, 0x18, 0xc8, 0x83, 0x79, 0x44, 0xc3, 0x38, 0x46, 0x6e, 0xaa, + 0xc4, 0x84, 0xce, 0x67, 0xe4, 0xb4, 0x22, 0x35, 0xa1, 0x38, 0xdc, 0xad, 0x40, 0x9d, 0x6c, 0x43, + 0x2f, 0x61, 0x8b, 0x95, 0xcf, 0xe2, 0x0a, 0x36, 0xa4, 0x95, 0x6d, 0xac, 0x26, 0x21, 0xd0, 0xf5, + 0x19, 0xa6, 0x8b, 0x70, 0xce, 0x31, 0xe3, 0x82, 0x69, 0x82, 0x45, 0xcb, 0xc8, 0xa1, 0x1b, 0xd6, + 0x12, 0xdd, 0x7c, 0x1a, 0x53, 0x37, 0xc0, 0x0a, 0xb6, 0x85, 0xe8, 0x50, 0xe6, 0x50, 0xa7, 0x62, + 0x7a, 0x39, 0xa1, 0x04, 0x50, 0xad, 0x5a, 0x12, 0xa3, 0x5c, 0xb5, 0x04, 0x1d, 0xd9, 0x3c, 0x5f, + 0x62, 0xc1, 0x5c, 0xba, 0x10, 0xb0, 0x5b, 0x5a, 0x29, 0xfa, 0x42, 0x34, 0x7b, 0xf9, 0x77, 0x34, + 0x3e, 0xbd, 0x5a, 0x5b, 0xea, 0xf5, 0xda, 0x52, 0x7f, 0xad, 0x2d, 0xf5, 0xcb, 0xad, 0xa5, 0x5c, + 0xdf, 0x5a, 0xca, 0xcf, 0x5b, 0x4b, 0xb9, 0x78, 0xe0, 0x87, 0x3c, 0x58, 0x3a, 0xe2, 0x45, 0x3b, + 0x12, 0x13, 0x1f, 0xc9, 0x77, 0x51, 0x86, 0x2e, 0x4b, 0xb1, 0xf8, 0x57, 0x70, 0x34, 0xf9, 0xc3, + 0x7e, 0xfc, 0x27, 0x00, 0x00, 0xff, 0xff, 0x2e, 0x3c, 0x8a, 0x97, 0x2d, 0x04, 0x00, 0x00, } func (m *PubKeySet) Marshal() (dAtA []byte, err error) { @@ -369,6 +606,164 @@ func (m *Chain) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } +func (m *BlockHeader) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *BlockHeader) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *BlockHeader) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.Header.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintCommon(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + if m.ChainId != 0 { + i = encodeVarintCommon(dAtA, i, uint64(m.ChainId)) + i-- + dAtA[i] = 0x20 + } + if len(m.ParentHash) > 0 { + i -= len(m.ParentHash) + copy(dAtA[i:], m.ParentHash) + i = encodeVarintCommon(dAtA, i, uint64(len(m.ParentHash))) + i-- + dAtA[i] = 0x1a + } + if len(m.Hash) > 0 { + i -= len(m.Hash) + copy(dAtA[i:], m.Hash) + i = encodeVarintCommon(dAtA, i, uint64(len(m.Hash))) + i-- + dAtA[i] = 0x12 + } + if m.Height != 0 { + i = encodeVarintCommon(dAtA, i, uint64(m.Height)) + i-- + dAtA[i] = 0x8 + } + return len(dAtA) - i, nil +} + +func (m *HeaderData) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *HeaderData) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *HeaderData) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.Data != nil { + { + size := m.Data.Size() + i -= size + if _, err := m.Data.MarshalTo(dAtA[i:]); err != nil { + return 0, err + } + } + } + return len(dAtA) - i, nil +} + +func (m *HeaderData_EthereumHeader) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *HeaderData_EthereumHeader) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + if m.EthereumHeader != nil { + i -= len(m.EthereumHeader) + copy(dAtA[i:], m.EthereumHeader) + i = encodeVarintCommon(dAtA, i, uint64(len(m.EthereumHeader))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} +func (m *Proof) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *Proof) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *Proof) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.Proof != nil { + { + size := m.Proof.Size() + i -= size + if _, err := m.Proof.MarshalTo(dAtA[i:]); err != nil { + return 0, err + } + } + } + return len(dAtA) - i, nil +} + +func (m *Proof_EthereumProof) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *Proof_EthereumProof) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + if m.EthereumProof != nil { + { + size, err := m.EthereumProof.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintCommon(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} func encodeVarintCommon(dAtA []byte, offset int, v uint64) int { offset -= sovCommon(v) base := offset @@ -394,31 +789,307 @@ func (m *PubKeySet) Size() (n int) { if l > 0 { n += 1 + l + sovCommon(uint64(l)) } - return n -} + return n +} + +func (m *Chain) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.ChainName != 0 { + n += 1 + sovCommon(uint64(m.ChainName)) + } + if m.ChainId != 0 { + n += 1 + sovCommon(uint64(m.ChainId)) + } + return n +} + +func (m *BlockHeader) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.Height != 0 { + n += 1 + sovCommon(uint64(m.Height)) + } + l = len(m.Hash) + if l > 0 { + n += 1 + l + sovCommon(uint64(l)) + } + l = len(m.ParentHash) + if l > 0 { + n += 1 + l + sovCommon(uint64(l)) + } + if m.ChainId != 0 { + n += 1 + sovCommon(uint64(m.ChainId)) + } + l = m.Header.Size() + n += 1 + l + sovCommon(uint64(l)) + return n +} + +func (m *HeaderData) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.Data != nil { + n += m.Data.Size() + } + return n +} + +func (m *HeaderData_EthereumHeader) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.EthereumHeader != nil { + l = len(m.EthereumHeader) + n += 1 + l + sovCommon(uint64(l)) + } + return n +} +func (m *Proof) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.Proof != nil { + n += m.Proof.Size() + } + return n +} + +func (m *Proof_EthereumProof) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.EthereumProof != nil { + l = m.EthereumProof.Size() + n += 1 + l + sovCommon(uint64(l)) + } + return n +} + +func sovCommon(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozCommon(x uint64) (n int) { + return sovCommon(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (m *PubKeySet) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCommon + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: PubKeySet: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: PubKeySet: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Secp256k1", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCommon + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthCommon + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthCommon + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Secp256k1 = PubKey(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Ed25519", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCommon + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthCommon + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthCommon + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Ed25519 = PubKey(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipCommon(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthCommon + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *Chain) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCommon + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: Chain: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: Chain: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ChainName", wireType) + } + m.ChainName = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCommon + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ChainName |= ChainName(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType) + } + m.ChainId = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCommon + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ChainId |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipCommon(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthCommon + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } -func (m *Chain) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.ChainName != 0 { - n += 1 + sovCommon(uint64(m.ChainName)) - } - if m.ChainId != 0 { - n += 1 + sovCommon(uint64(m.ChainId)) + if iNdEx > l { + return io.ErrUnexpectedEOF } - return n -} - -func sovCommon(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozCommon(x uint64) (n int) { - return sovCommon(uint64((x << 1) ^ uint64((int64(x) >> 63)))) + return nil } -func (m *PubKeySet) Unmarshal(dAtA []byte) error { +func (m *BlockHeader) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -441,17 +1112,36 @@ func (m *PubKeySet) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: PubKeySet: wiretype end group for non-group") + return fmt.Errorf("proto: BlockHeader: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: PubKeySet: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: BlockHeader: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Height", wireType) + } + m.Height = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCommon + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Height |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Secp256k1", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field Hash", wireType) } - var stringLen uint64 + var byteLen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowCommon @@ -461,29 +1151,31 @@ func (m *PubKeySet) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - stringLen |= uint64(b&0x7F) << shift + byteLen |= int(b&0x7F) << shift if b < 0x80 { break } } - intStringLen := int(stringLen) - if intStringLen < 0 { + if byteLen < 0 { return ErrInvalidLengthCommon } - postIndex := iNdEx + intStringLen + postIndex := iNdEx + byteLen if postIndex < 0 { return ErrInvalidLengthCommon } if postIndex > l { return io.ErrUnexpectedEOF } - m.Secp256k1 = PubKey(dAtA[iNdEx:postIndex]) + m.Hash = append(m.Hash[:0], dAtA[iNdEx:postIndex]...) + if m.Hash == nil { + m.Hash = []byte{} + } iNdEx = postIndex - case 2: + case 3: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Ed25519", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field ParentHash", wireType) } - var stringLen uint64 + var byteLen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowCommon @@ -493,23 +1185,77 @@ func (m *PubKeySet) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - stringLen |= uint64(b&0x7F) << shift + byteLen |= int(b&0x7F) << shift if b < 0x80 { break } } - intStringLen := int(stringLen) - if intStringLen < 0 { + if byteLen < 0 { return ErrInvalidLengthCommon } - postIndex := iNdEx + intStringLen + postIndex := iNdEx + byteLen if postIndex < 0 { return ErrInvalidLengthCommon } if postIndex > l { return io.ErrUnexpectedEOF } - m.Ed25519 = PubKey(dAtA[iNdEx:postIndex]) + m.ParentHash = append(m.ParentHash[:0], dAtA[iNdEx:postIndex]...) + if m.ParentHash == nil { + m.ParentHash = []byte{} + } + iNdEx = postIndex + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType) + } + m.ChainId = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCommon + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ChainId |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Header", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCommon + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthCommon + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthCommon + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Header.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } iNdEx = postIndex default: iNdEx = preIndex @@ -532,7 +1278,7 @@ func (m *PubKeySet) Unmarshal(dAtA []byte) error { } return nil } -func (m *Chain) Unmarshal(dAtA []byte) error { +func (m *HeaderData) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -555,17 +1301,17 @@ func (m *Chain) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: Chain: wiretype end group for non-group") + return fmt.Errorf("proto: HeaderData: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: Chain: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: HeaderData: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field ChainName", wireType) + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field EthereumHeader", wireType) } - m.ChainName = 0 + var byteLen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowCommon @@ -575,16 +1321,80 @@ func (m *Chain) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.ChainName |= ChainName(b&0x7F) << shift + byteLen |= int(b&0x7F) << shift if b < 0x80 { break } } - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType) + if byteLen < 0 { + return ErrInvalidLengthCommon } - m.ChainId = 0 + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthCommon + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + v := make([]byte, postIndex-iNdEx) + copy(v, dAtA[iNdEx:postIndex]) + m.Data = &HeaderData_EthereumHeader{v} + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipCommon(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthCommon + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *Proof) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowCommon + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: Proof: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: Proof: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field EthereumProof", wireType) + } + var msglen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowCommon @@ -594,11 +1404,27 @@ func (m *Chain) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.ChainId |= int64(b&0x7F) << shift + msglen |= int(b&0x7F) << shift if b < 0x80 { break } } + if msglen < 0 { + return ErrInvalidLengthCommon + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthCommon + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + v := ðereum.Proof{} + if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + m.Proof = &Proof_EthereumProof{v} + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipCommon(dAtA[iNdEx:]) diff --git a/common/headers.go b/common/headers.go new file mode 100644 index 0000000000..e05a3f0c18 --- /dev/null +++ b/common/headers.go @@ -0,0 +1,68 @@ +package common + +import ( + "bytes" + "encoding/hex" + "errors" + "fmt" + + ethtypes "github.com/ethereum/go-ethereum/core/types" + "github.com/ethereum/go-ethereum/rlp" +) + +// NewEthereumHeader returns a new HeaderData containing an Ethereum header +func NewEthereumHeader(header []byte) HeaderData { + return HeaderData{ + Data: &HeaderData_EthereumHeader{ + EthereumHeader: header, + }, + } +} + +// ParentHash extracts the parent hash from the header +func (h HeaderData) ParentHash() ([]byte, error) { + switch data := h.Data.(type) { + case *HeaderData_EthereumHeader: + var header ethtypes.Header + if err := rlp.DecodeBytes(data.EthereumHeader, &header); err != nil { + return nil, err + } + return header.ParentHash.Bytes(), nil + default: + return nil, errors.New("unrecognized header type") + } +} + +// Validate performs a basic validation of the HeaderData +func (h HeaderData) Validate(blockHash []byte, height int64) error { + switch data := h.Data.(type) { + case *HeaderData_EthereumHeader: + return validateEthereumHeader(data.EthereumHeader, blockHash, height) + default: + return errors.New("unrecognized header type") + } +} + +// validateEthereumHeader performs a basic validation of the Ethereum header +func validateEthereumHeader(headerBytes []byte, blockHash []byte, height int64) error { + // on ethereum the block header is ~538 bytes in RLP encoding + if len(headerBytes) > 1024 { + return fmt.Errorf("header too long (%d)", len(headerBytes)) + } + + // RLP encoded block header + var header ethtypes.Header + if err := rlp.DecodeBytes(headerBytes, &header); err != nil { + return fmt.Errorf("cannot decode RLP (%s)", err) + } + if err := header.SanityCheck(); err != nil { + return fmt.Errorf("sanity check failed (%s)", err) + } + if bytes.Compare(blockHash, header.Hash().Bytes()) != 0 { + return fmt.Errorf("tx hash mismatch (%s) vs (%s)", hex.EncodeToString(blockHash), header.Hash().Hex()) + } + if height != header.Number.Int64() { + return fmt.Errorf("height mismatch (%d) vs (%d)", height, header.Number.Int64()) + } + return nil +} diff --git a/common/proof.go b/common/proof.go new file mode 100644 index 0000000000..615c39b1f5 --- /dev/null +++ b/common/proof.go @@ -0,0 +1,61 @@ +package common + +import ( + "errors" + + ethtypes "github.com/ethereum/go-ethereum/core/types" + "github.com/ethereum/go-ethereum/rlp" + "github.com/zeta-chain/zetacore/common/ethereum" +) + +// ErrInvalidProof is a error type for invalid proofs embedding the underlying error +type ErrInvalidProof struct { + Err error +} + +func NewErrInvalidProof(err error) ErrInvalidProof { + return ErrInvalidProof{ + Err: err, + } +} + +func (e ErrInvalidProof) Error() string { + return e.Err.Error() +} + +// IsErrorInvalidProof returns true if the error is an ErrInvalidProof +func IsErrorInvalidProof(err error) bool { + return errors.As(err, &ErrInvalidProof{}) +} + +// NewEthereumProof returns a new Proof containing an Ethereum proof +func NewEthereumProof(proof *ethereum.Proof) *Proof { + return &Proof{ + Proof: &Proof_EthereumProof{ + EthereumProof: proof, + }, + } +} + +// Verify verifies the proof against the header +func (p Proof) Verify(headerData HeaderData, txIndex int) ([]byte, error) { + switch proof := p.Proof.(type) { + case *Proof_EthereumProof: + ethHeaderBytes := headerData.GetEthereumHeader() + if ethHeaderBytes == nil { + return nil, errors.New("can't verify ethereum proof against non-ethereum header") + } + var ethHeader ethtypes.Header + err := rlp.DecodeBytes(ethHeaderBytes, ðHeader) + if err != nil { + return nil, err + } + val, err := proof.EthereumProof.Verify(ethHeader.TxHash, txIndex) + if err != nil { + return nil, NewErrInvalidProof(err) + } + return val, nil + default: + return nil, errors.New("unrecognized proof type") + } +} diff --git a/common/proof_test.go b/common/proof_test.go new file mode 100644 index 0000000000..0615407684 --- /dev/null +++ b/common/proof_test.go @@ -0,0 +1,15 @@ +package common_test + +import ( + "errors" + "testing" + + "github.com/stretchr/testify/require" + "github.com/zeta-chain/zetacore/common" +) + +func Test_IsErrorInvalidProof(t *testing.T) { + require.False(t, common.IsErrorInvalidProof(nil)) + require.False(t, common.IsErrorInvalidProof(errors.New("foo"))) + require.True(t, common.IsErrorInvalidProof(common.NewErrInvalidProof(errors.New("foo")))) +} diff --git a/contrib/localnet/orchestrator/smoketest/test_deposit_eth.go b/contrib/localnet/orchestrator/smoketest/test_deposit_eth.go index e79b23feb5..cea789d273 100644 --- a/contrib/localnet/orchestrator/smoketest/test_deposit_eth.go +++ b/contrib/localnet/orchestrator/smoketest/test_deposit_eth.go @@ -123,7 +123,7 @@ func (sm *SmokeTest) TestDepositEtherIntoZRC20() { BlockHash: blockHash.Hex(), TxIndex: int64(txIndex), TxHash: txHash.Hex(), - Proof: txProof, + Proof: common.NewEthereumProof(txProof), ChainId: 0, }) if err != nil { diff --git a/docs/openapi/openapi.swagger.yaml b/docs/openapi/openapi.swagger.yaml index 3294b7827a..50af221fae 100644 --- a/docs/openapi/openapi.swagger.yaml +++ b/docs/openapi/openapi.swagger.yaml @@ -27590,7 +27590,7 @@ paths: in: query required: false type: string - - name: proof.keys + - name: proof.ethereum_proof.keys in: query required: false type: array @@ -27598,7 +27598,7 @@ paths: type: string format: byte collectionFormat: multi - - name: proof.values + - name: proof.ethereum_proof.values in: query required: false type: array @@ -50182,6 +50182,24 @@ definitions: - VOTE_OPTION_ABSTAIN: VOTE_OPTION_ABSTAIN defines an abstain vote option. - VOTE_OPTION_NO: VOTE_OPTION_NO defines a no vote option. - VOTE_OPTION_NO_WITH_VETO: VOTE_OPTION_NO_WITH_VETO defines a no with veto vote option. + commonBlockHeader: + type: object + properties: + height: + type: string + format: int64 + hash: + type: string + format: byte + parent_hash: + type: string + format: byte + chain_id: + type: string + format: int64 + header: + $ref: '#/definitions/commonHeaderData' + title: chain specific header commonChain: type: object properties: @@ -50227,6 +50245,18 @@ definitions: - Gas: Ether, BNB, Matic, Klay, BTC, etc - ERC20: ERC20 token - Cmd: not a real coin, rather a command + commonHeaderData: + type: object + properties: + ethereum_header: + type: string + format: byte + title: binary encoded headers; RLP for ethereum + commonProof: + type: object + properties: + ethereum_proof: + $ref: '#/definitions/ethereumProof' commonPubKeySet: type: object properties: @@ -50824,25 +50854,6 @@ definitions: items: type: object $ref: '#/definitions/observerNode' - observerBlockHeader: - type: object - properties: - header: - type: string - format: byte - title: binary encoded headers; RLP for ethereum - height: - type: string - format: int64 - hash: - type: string - format: byte - parentHash: - type: string - format: byte - chain_id: - type: string - format: int64 observerCoreParams: type: object properties: @@ -51022,7 +51033,7 @@ definitions: type: array items: type: object - $ref: '#/definitions/observerBlockHeader' + $ref: '#/definitions/commonBlockHeader' pagination: $ref: '#/definitions/v1beta1PageResponse' observerQueryAllNodeAccountResponse: @@ -51066,7 +51077,7 @@ definitions: type: object properties: block_header: - $ref: '#/definitions/observerBlockHeader' + $ref: '#/definitions/commonBlockHeader' observerQueryGetCoreParamsForChainResponse: type: object properties: diff --git a/docs/spec/crosschain/messages.md b/docs/spec/crosschain/messages.md index 21a3916c8d..a64c725032 100644 --- a/docs/spec/crosschain/messages.md +++ b/docs/spec/crosschain/messages.md @@ -2,10 +2,8 @@ ## MsgAddToOutTxTracker -Adds a new record to the outbound transaction tracker. - -Only the admin policy account and the observer validators are authorized to -broadcast this message. +AddToOutTxTracker adds a new record to the outbound transaction tracker. +only the admin policy account and the observer validators are authorized to broadcast this message. ```proto message MsgAddToOutTxTracker { @@ -13,7 +11,7 @@ message MsgAddToOutTxTracker { int64 chain_id = 2; uint64 nonce = 3; string tx_hash = 4; - ethereum.Proof proof = 5; + common.Proof proof = 5; string block_hash = 6; int64 tx_index = 7; } @@ -21,9 +19,8 @@ message MsgAddToOutTxTracker { ## MsgRemoveFromOutTxTracker -Removes a record from the outbound transaction tracker by chain ID and nonce. - -Only the admin policy account is authorized to broadcast this message. +RemoveFromOutTxTracker removes a record from the outbound transaction tracker by chain ID and nonce. +only the admin policy account is authorized to broadcast this message. ```proto message MsgRemoveFromOutTxTracker { diff --git a/docs/spec/observer/messages.md b/docs/spec/observer/messages.md index 4a34d7779b..2ae574f73a 100644 --- a/docs/spec/observer/messages.md +++ b/docs/spec/observer/messages.md @@ -72,15 +72,15 @@ message MsgUpdateKeygen { ## MsgAddBlockHeader -MsgAddBlockHeader handles adding a block header to the store, through majority voting of observers +AddBlockHeader handles adding a block header to the store, through majority voting of observers ```proto message MsgAddBlockHeader { string creator = 1; int64 chain_id = 2; bytes block_hash = 3; - bytes block_header = 4; - int64 height = 5; + int64 height = 4; + common.HeaderData header = 5; } ``` diff --git a/proto/common/common.proto b/proto/common/common.proto index 936d542bba..161f533034 100644 --- a/proto/common/common.proto +++ b/proto/common/common.proto @@ -1,10 +1,10 @@ syntax = "proto3"; package common; +import "common/ethereum/ethereum.proto"; //option (gogoproto.goproto_stringer_all) = false; //option (gogoproto.stringer_all) = false; //option (gogoproto.goproto_getters_all) = false; - import "gogoproto/gogo.proto"; option go_package = "github.com/zeta-chain/zetacore/common"; @@ -62,3 +62,24 @@ message Chain { ChainName chain_name = 1; int64 chain_id = 2; } + +message BlockHeader { + int64 height = 1; + bytes hash = 2; + bytes parent_hash = 3; + int64 chain_id = 4; + // chain specific header + HeaderData header = 5 [(gogoproto.nullable) = false]; +} + +message HeaderData { + oneof data { + bytes ethereum_header = 1; // binary encoded headers; RLP for ethereum + } +} + +message Proof { + oneof proof { + ethereum.Proof ethereum_proof = 1; + } +} diff --git a/proto/crosschain/tx.proto b/proto/crosschain/tx.proto index 033d2d83cd..417b899787 100644 --- a/proto/crosschain/tx.proto +++ b/proto/crosschain/tx.proto @@ -2,7 +2,6 @@ syntax = "proto3"; package zetachain.zetacore.crosschain; import "common/common.proto"; -import "common/ethereum/ethereum.proto"; import "gogoproto/gogo.proto"; option go_package = "github.com/zeta-chain/zetacore/x/crosschain/types"; @@ -27,6 +26,7 @@ message MsgUpdateTssAddress { } message MsgUpdateTssAddressResponse {} + message MsgWhitelistERC20 { string creator = 1; string erc20_address = 2; @@ -44,7 +44,7 @@ message MsgAddToOutTxTracker { int64 chain_id = 2; uint64 nonce = 3; string tx_hash = 4; - ethereum.Proof proof = 5; + common.Proof proof = 5; string block_hash = 6; int64 tx_index = 7; } diff --git a/proto/observer/headers.proto b/proto/observer/headers.proto deleted file mode 100644 index af1544c4f7..0000000000 --- a/proto/observer/headers.proto +++ /dev/null @@ -1,15 +0,0 @@ -syntax = "proto3"; -package zetachain.zetacore.observer; - -import "gogoproto/gogo.proto"; -import "observer/observer.proto"; - -option go_package = "github.com/zeta-chain/zetacore/x/observer/types"; - -message BlockHeader { - bytes header = 1; // binary encoded headers; RLP for ethereum - int64 height = 2; - bytes hash = 3; - bytes parentHash = 4; - int64 chain_id = 5; -} diff --git a/proto/observer/query.proto b/proto/observer/query.proto index a989c2c2a5..f210f5e84c 100644 --- a/proto/observer/query.proto +++ b/proto/observer/query.proto @@ -2,13 +2,11 @@ syntax = "proto3"; package zetachain.zetacore.observer; import "common/common.proto"; -import "common/ethereum/ethereum.proto"; import "cosmos/base/query/v1beta1/pagination.proto"; import "gogoproto/gogo.proto"; import "google/api/annotations.proto"; import "observer/ballot.proto"; import "observer/blame.proto"; -import "observer/headers.proto"; import "observer/keygen.proto"; import "observer/node_account.proto"; import "observer/observer.proto"; @@ -99,9 +97,9 @@ service Query { message QueryProveRequest { uint64 chain_id = 1; string tx_hash = 2; - ethereum.Proof proof = 5; - string block_hash = 6; - int64 tx_index = 7; + common.Proof proof = 3; + string block_hash = 4; + int64 tx_index = 5; } message QueryProveResponse { @@ -218,7 +216,7 @@ message QueryAllBlockHeaderRequest { } message QueryAllBlockHeaderResponse { - repeated BlockHeader block_headers = 1; + repeated common.BlockHeader block_headers = 1; cosmos.base.query.v1beta1.PageResponse pagination = 2; } @@ -227,5 +225,5 @@ message QueryGetBlockHeaderByHashRequest { } message QueryGetBlockHeaderByHashResponse { - BlockHeader block_header = 1; + common.BlockHeader block_header = 1; } diff --git a/proto/observer/tx.proto b/proto/observer/tx.proto index 589030dc74..368af443b5 100644 --- a/proto/observer/tx.proto +++ b/proto/observer/tx.proto @@ -4,7 +4,6 @@ package zetachain.zetacore.observer; import "common/common.proto"; import "gogoproto/gogo.proto"; import "observer/blame.proto"; -import "observer/headers.proto"; import "observer/observer.proto"; import "observer/params.proto"; @@ -24,8 +23,8 @@ message MsgAddBlockHeader { string creator = 1; int64 chain_id = 2; bytes block_hash = 3; - bytes block_header = 4; - int64 height = 5; + int64 height = 4; + common.HeaderData header = 5 [(gogoproto.nullable) = false]; } message MsgAddBlockHeaderResponse {} diff --git a/testutil/keeper/mocks/crosschain/account.go b/testutil/keeper/mocks/crosschain/account.go index 9044c1009c..626900da83 100644 --- a/testutil/keeper/mocks/crosschain/account.go +++ b/testutil/keeper/mocks/crosschain/account.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.33.2. DO NOT EDIT. +// Code generated by mockery v2.33.3. DO NOT EDIT. package mocks diff --git a/testutil/keeper/mocks/crosschain/bank.go b/testutil/keeper/mocks/crosschain/bank.go index 8fef8170d5..cdf1e371ef 100644 --- a/testutil/keeper/mocks/crosschain/bank.go +++ b/testutil/keeper/mocks/crosschain/bank.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.33.2. DO NOT EDIT. +// Code generated by mockery v2.33.3. DO NOT EDIT. package mocks diff --git a/testutil/keeper/mocks/crosschain/fungible.go b/testutil/keeper/mocks/crosschain/fungible.go index 7b8b6884a3..ccd55ffa06 100644 --- a/testutil/keeper/mocks/crosschain/fungible.go +++ b/testutil/keeper/mocks/crosschain/fungible.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.33.2. DO NOT EDIT. +// Code generated by mockery v2.33.3. DO NOT EDIT. package mocks diff --git a/testutil/keeper/mocks/crosschain/observer.go b/testutil/keeper/mocks/crosschain/observer.go index 252c36e1cf..5811d9ba4d 100644 --- a/testutil/keeper/mocks/crosschain/observer.go +++ b/testutil/keeper/mocks/crosschain/observer.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.33.2. DO NOT EDIT. +// Code generated by mockery v2.33.3. DO NOT EDIT. package mocks @@ -173,18 +173,18 @@ func (_m *CrosschainObserverKeeper) GetBallot(ctx types.Context, index string) ( } // GetBlockHeader provides a mock function with given fields: ctx, hash -func (_m *CrosschainObserverKeeper) GetBlockHeader(ctx types.Context, hash []byte) (observertypes.BlockHeader, bool) { +func (_m *CrosschainObserverKeeper) GetBlockHeader(ctx types.Context, hash []byte) (common.BlockHeader, bool) { ret := _m.Called(ctx, hash) - var r0 observertypes.BlockHeader + var r0 common.BlockHeader var r1 bool - if rf, ok := ret.Get(0).(func(types.Context, []byte) (observertypes.BlockHeader, bool)); ok { + if rf, ok := ret.Get(0).(func(types.Context, []byte) (common.BlockHeader, bool)); ok { return rf(ctx, hash) } - if rf, ok := ret.Get(0).(func(types.Context, []byte) observertypes.BlockHeader); ok { + if rf, ok := ret.Get(0).(func(types.Context, []byte) common.BlockHeader); ok { r0 = rf(ctx, hash) } else { - r0 = ret.Get(0).(observertypes.BlockHeader) + r0 = ret.Get(0).(common.BlockHeader) } if rf, ok := ret.Get(1).(func(types.Context, []byte) bool); ok { diff --git a/testutil/keeper/mocks/crosschain/staking.go b/testutil/keeper/mocks/crosschain/staking.go index f35ad1190d..3027f516b1 100644 --- a/testutil/keeper/mocks/crosschain/staking.go +++ b/testutil/keeper/mocks/crosschain/staking.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.33.2. DO NOT EDIT. +// Code generated by mockery v2.33.3. DO NOT EDIT. package mocks diff --git a/testutil/keeper/mocks/fungible/account.go b/testutil/keeper/mocks/fungible/account.go index d94cae3a4f..8ca9535cad 100644 --- a/testutil/keeper/mocks/fungible/account.go +++ b/testutil/keeper/mocks/fungible/account.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.33.2. DO NOT EDIT. +// Code generated by mockery v2.33.3. DO NOT EDIT. package mocks diff --git a/testutil/keeper/mocks/fungible/bank.go b/testutil/keeper/mocks/fungible/bank.go index 3d78731354..a061b091f4 100644 --- a/testutil/keeper/mocks/fungible/bank.go +++ b/testutil/keeper/mocks/fungible/bank.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.33.2. DO NOT EDIT. +// Code generated by mockery v2.33.3. DO NOT EDIT. package mocks diff --git a/testutil/keeper/mocks/fungible/evm.go b/testutil/keeper/mocks/fungible/evm.go index 42e3917ec1..8f6884d536 100644 --- a/testutil/keeper/mocks/fungible/evm.go +++ b/testutil/keeper/mocks/fungible/evm.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.33.2. DO NOT EDIT. +// Code generated by mockery v2.33.3. DO NOT EDIT. package mocks diff --git a/testutil/keeper/mocks/fungible/observer.go b/testutil/keeper/mocks/fungible/observer.go index 3dee529922..13f419d80a 100644 --- a/testutil/keeper/mocks/fungible/observer.go +++ b/testutil/keeper/mocks/fungible/observer.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.33.2. DO NOT EDIT. +// Code generated by mockery v2.33.3. DO NOT EDIT. package mocks diff --git a/x/crosschain/keeper/keeper_out_tx_tracker.go b/x/crosschain/keeper/keeper_out_tx_tracker.go index 75b6e9cd1d..f0ed81f469 100644 --- a/x/crosschain/keeper/keeper_out_tx_tracker.go +++ b/x/crosschain/keeper/keeper_out_tx_tracker.go @@ -5,15 +5,16 @@ import ( "fmt" "strings" + cosmoserrors "cosmossdk.io/errors" + "github.com/cosmos/cosmos-sdk/store/prefix" sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" "github.com/cosmos/cosmos-sdk/types/query" eth "github.com/ethereum/go-ethereum/common" ethtypes "github.com/ethereum/go-ethereum/core/types" - "github.com/ethereum/go-ethereum/rlp" + "github.com/zeta-chain/zetacore/common" "github.com/zeta-chain/zetacore/x/crosschain/types" - zetaObserverTypes "github.com/zeta-chain/zetacore/x/observer/types" + observertypes "github.com/zeta-chain/zetacore/x/observer/types" "google.golang.org/grpc/codes" "google.golang.org/grpc/status" ) @@ -159,29 +160,27 @@ func (k Keeper) OutTxTracker(c context.Context, req *types.QueryGetOutTxTrackerR // Messages -// Adds a new record to the outbound transaction tracker. -// -// Only the admin policy account and the observer validators are authorized to -// broadcast this message. +// AddToOutTxTracker adds a new record to the outbound transaction tracker. +// only the admin policy account and the observer validators are authorized to broadcast this message. func (k msgServer) AddToOutTxTracker(goCtx context.Context, msg *types.MsgAddToOutTxTracker) (*types.MsgAddToOutTxTrackerResponse, error) { ctx := sdk.UnwrapSDKContext(goCtx) chain := k.zetaObserverKeeper.GetParams(ctx).GetChainFromChainID(msg.ChainId) if chain == nil { - return nil, zetaObserverTypes.ErrSupportedChains + return nil, observertypes.ErrSupportedChains } if msg.Proof == nil { // without proof, only certain accounts can send this message - adminPolicyAccount := k.zetaObserverKeeper.GetParams(ctx).GetAdminPolicyAccount(zetaObserverTypes.Policy_Type_out_tx_tracker) + adminPolicyAccount := k.zetaObserverKeeper.GetParams(ctx).GetAdminPolicyAccount(observertypes.Policy_Type_out_tx_tracker) isAdmin := msg.Creator == adminPolicyAccount isObserver, err := k.zetaObserverKeeper.IsAuthorized(ctx, msg.Creator, chain) if err != nil { ctx.Logger().Error("Error while checking if the account is an observer", err) - return nil, sdkerrors.Wrap(zetaObserverTypes.ErrNotAuthorized, fmt.Sprintf("error IsAuthorized %s", msg.Creator)) + return nil, cosmoserrors.Wrap(observertypes.ErrNotAuthorized, fmt.Sprintf("error IsAuthorized %s", msg.Creator)) } // Sender needs to be either the admin policy account or an observer if !(isAdmin || isObserver) { - return nil, sdkerrors.Wrap(zetaObserverTypes.ErrNotAuthorized, fmt.Sprintf("Creator %s", msg.Creator)) + return nil, cosmoserrors.Wrap(observertypes.ErrNotAuthorized, fmt.Sprintf("Creator %s", msg.Creator)) } } @@ -190,14 +189,14 @@ func (k msgServer) AddToOutTxTracker(goCtx context.Context, msg *types.MsgAddToO blockHash := eth.HexToHash(msg.BlockHash) res, found := k.zetaObserverKeeper.GetBlockHeader(ctx, blockHash.Bytes()) if !found { - return nil, sdkerrors.Wrap(zetaObserverTypes.ErrBlockHeaderNotFound, fmt.Sprintf("block header not found %s", msg.BlockHash)) + return nil, cosmoserrors.Wrap(observertypes.ErrBlockHeaderNotFound, fmt.Sprintf("block header not found %s", msg.BlockHash)) } - var header ethtypes.Header - err := rlp.DecodeBytes(res.Header, &header) - if err != nil { + + // verify and process the proof + val, err := msg.Proof.Verify(res.Header, int(msg.TxIndex)) + if err != nil && !common.IsErrorInvalidProof(err) { return nil, err } - val, err := msg.Proof.Verify(header.TxHash, int(msg.TxIndex)) if err == nil { var txx ethtypes.Transaction err = txx.UnmarshalBinary(val) @@ -272,13 +271,12 @@ func (k msgServer) AddToOutTxTracker(goCtx context.Context, msg *types.MsgAddToO return &types.MsgAddToOutTxTrackerResponse{}, nil } -// Removes a record from the outbound transaction tracker by chain ID and nonce. -// -// Only the admin policy account is authorized to broadcast this message. +// RemoveFromOutTxTracker removes a record from the outbound transaction tracker by chain ID and nonce. +// only the admin policy account is authorized to broadcast this message. func (k msgServer) RemoveFromOutTxTracker(goCtx context.Context, msg *types.MsgRemoveFromOutTxTracker) (*types.MsgRemoveFromOutTxTrackerResponse, error) { ctx := sdk.UnwrapSDKContext(goCtx) - if msg.Creator != k.zetaObserverKeeper.GetParams(ctx).GetAdminPolicyAccount(zetaObserverTypes.Policy_Type_out_tx_tracker) { - return &types.MsgRemoveFromOutTxTrackerResponse{}, zetaObserverTypes.ErrNotAuthorizedPolicy + if msg.Creator != k.zetaObserverKeeper.GetParams(ctx).GetAdminPolicyAccount(observertypes.Policy_Type_out_tx_tracker) { + return &types.MsgRemoveFromOutTxTrackerResponse{}, observertypes.ErrNotAuthorizedPolicy } k.RemoveOutTxTracker(ctx, msg.ChainId, msg.Nonce) diff --git a/x/crosschain/types/expected_keepers.go b/x/crosschain/types/expected_keepers.go index 53a540c927..f6f31365b2 100644 --- a/x/crosschain/types/expected_keepers.go +++ b/x/crosschain/types/expected_keepers.go @@ -66,7 +66,7 @@ type ZetaObserverKeeper interface { IsAuthorized(ctx sdk.Context, address string, chain *common.Chain) (bool, error) FindBallot(ctx sdk.Context, index string, chain *common.Chain, observationType zetaObserverTypes.ObservationType) (ballot zetaObserverTypes.Ballot, isNew bool, err error) AddBallotToList(ctx sdk.Context, ballot zetaObserverTypes.Ballot) - GetBlockHeader(ctx sdk.Context, hash []byte) (val zetaObserverTypes.BlockHeader, found bool) + GetBlockHeader(ctx sdk.Context, hash []byte) (val common.BlockHeader, found bool) } type FungibleKeeper interface { diff --git a/x/crosschain/types/message_add_to_out_tx_tracker.go b/x/crosschain/types/message_add_to_out_tx_tracker.go index dffccbb32b..06716762a1 100644 --- a/x/crosschain/types/message_add_to_out_tx_tracker.go +++ b/x/crosschain/types/message_add_to_out_tx_tracker.go @@ -3,14 +3,22 @@ package types import ( sdk "github.com/cosmos/cosmos-sdk/types" sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/zeta-chain/zetacore/common/ethereum" + "github.com/zeta-chain/zetacore/common" ) const TypeMsgAddToOutTxTracker = "AddToTracker" var _ sdk.Msg = &MsgAddToOutTxTracker{} -func NewMsgAddToOutTxTracker(creator string, chain int64, nonce uint64, txHash string, proof *ethereum.Proof, blockHash string, txIndex int64) *MsgAddToOutTxTracker { +func NewMsgAddToOutTxTracker( + creator string, + chain int64, + nonce uint64, + txHash string, + proof *common.Proof, + blockHash string, + txIndex int64, +) *MsgAddToOutTxTracker { return &MsgAddToOutTxTracker{ Creator: creator, ChainId: chain, diff --git a/x/crosschain/types/tx.pb.go b/x/crosschain/types/tx.pb.go index a27cf5db9f..f255d88bc9 100644 --- a/x/crosschain/types/tx.pb.go +++ b/x/crosschain/types/tx.pb.go @@ -15,7 +15,6 @@ import ( grpc1 "github.com/gogo/protobuf/grpc" proto "github.com/gogo/protobuf/proto" common "github.com/zeta-chain/zetacore/common" - ethereum "github.com/zeta-chain/zetacore/common/ethereum" grpc "google.golang.org/grpc" codes "google.golang.org/grpc/codes" status "google.golang.org/grpc/status" @@ -249,13 +248,13 @@ func (m *MsgWhitelistERC20Response) XXX_DiscardUnknown() { var xxx_messageInfo_MsgWhitelistERC20Response proto.InternalMessageInfo type MsgAddToOutTxTracker struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` - ChainId int64 `protobuf:"varint,2,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` - Nonce uint64 `protobuf:"varint,3,opt,name=nonce,proto3" json:"nonce,omitempty"` - TxHash string `protobuf:"bytes,4,opt,name=tx_hash,json=txHash,proto3" json:"tx_hash,omitempty"` - Proof *ethereum.Proof `protobuf:"bytes,5,opt,name=proof,proto3" json:"proof,omitempty"` - BlockHash string `protobuf:"bytes,6,opt,name=block_hash,json=blockHash,proto3" json:"block_hash,omitempty"` - TxIndex int64 `protobuf:"varint,7,opt,name=tx_index,json=txIndex,proto3" json:"tx_index,omitempty"` + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + ChainId int64 `protobuf:"varint,2,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` + Nonce uint64 `protobuf:"varint,3,opt,name=nonce,proto3" json:"nonce,omitempty"` + TxHash string `protobuf:"bytes,4,opt,name=tx_hash,json=txHash,proto3" json:"tx_hash,omitempty"` + Proof *common.Proof `protobuf:"bytes,5,opt,name=proof,proto3" json:"proof,omitempty"` + BlockHash string `protobuf:"bytes,6,opt,name=block_hash,json=blockHash,proto3" json:"block_hash,omitempty"` + TxIndex int64 `protobuf:"varint,7,opt,name=tx_index,json=txIndex,proto3" json:"tx_index,omitempty"` } func (m *MsgAddToOutTxTracker) Reset() { *m = MsgAddToOutTxTracker{} } @@ -319,7 +318,7 @@ func (m *MsgAddToOutTxTracker) GetTxHash() string { return "" } -func (m *MsgAddToOutTxTracker) GetProof() *ethereum.Proof { +func (m *MsgAddToOutTxTracker) GetProof() *common.Proof { if m != nil { return m.Proof } @@ -1231,93 +1230,93 @@ func init() { func init() { proto.RegisterFile("crosschain/tx.proto", fileDescriptor_81d6d611190b7635) } var fileDescriptor_81d6d611190b7635 = []byte{ - // 1375 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x58, 0x4f, 0x6f, 0x1b, 0x45, - 0x14, 0xcf, 0x36, 0x89, 0x63, 0xbf, 0xc4, 0x69, 0x32, 0x49, 0x9b, 0xed, 0xa6, 0x75, 0xda, 0x2d, - 0x2d, 0x15, 0x6a, 0xec, 0xe2, 0x82, 0x28, 0x85, 0x03, 0x4d, 0x54, 0xd2, 0x50, 0x9c, 0x44, 0x1b, - 0x17, 0xa4, 0x5e, 0xac, 0xf5, 0xee, 0x64, 0xbd, 0x8a, 0x77, 0xc7, 0xda, 0x19, 0x47, 0x76, 0xc5, - 0x09, 0x89, 0x03, 0x37, 0x0e, 0x48, 0x20, 0xbe, 0x00, 0x5f, 0xa5, 0xdc, 0x2a, 0x4e, 0xfc, 0x91, - 0x2a, 0x68, 0xbe, 0x01, 0x9f, 0x00, 0xcd, 0x9f, 0xdd, 0x78, 0x9d, 0xd8, 0x4e, 0x82, 0x38, 0x79, - 0xde, 0x9b, 0xf7, 0xe7, 0xf7, 0xe6, 0xbd, 0x37, 0xf3, 0xd6, 0xb0, 0xe0, 0x44, 0x84, 0x52, 0xa7, - 0x61, 0xfb, 0x61, 0x89, 0x75, 0x8a, 0xad, 0x88, 0x30, 0x82, 0xae, 0xbd, 0xc0, 0xcc, 0x16, 0xbc, - 0xa2, 0x58, 0x91, 0x08, 0x17, 0x8f, 0xe4, 0x8c, 0x05, 0x87, 0x04, 0x01, 0x09, 0x4b, 0xf2, 0x47, - 0xea, 0x18, 0x05, 0xc5, 0xc4, 0xac, 0x81, 0x23, 0xdc, 0x0e, 0x92, 0x85, 0xda, 0x5f, 0xf4, 0x88, - 0x47, 0xc4, 0xb2, 0xc4, 0x57, 0x92, 0x6b, 0x6e, 0xc1, 0x42, 0x85, 0x7a, 0xcf, 0x5a, 0xae, 0xcd, - 0x70, 0x95, 0xd2, 0x47, 0xae, 0x1b, 0x61, 0x4a, 0x91, 0x0e, 0x53, 0x4e, 0x84, 0x6d, 0x46, 0x22, - 0x5d, 0xbb, 0xae, 0xdd, 0xc9, 0x59, 0x31, 0x89, 0xae, 0x01, 0x30, 0x4a, 0x6b, 0xad, 0x76, 0x7d, - 0x1f, 0x77, 0xf5, 0x0b, 0x62, 0x33, 0xc7, 0x28, 0xdd, 0x11, 0x0c, 0xf3, 0x1a, 0x2c, 0x9f, 0x60, - 0xcf, 0xc2, 0xb4, 0x45, 0x42, 0x8a, 0xcd, 0x5f, 0x35, 0x98, 0xaf, 0x50, 0xef, 0xcb, 0x86, 0xcf, - 0x70, 0xd3, 0xa7, 0xec, 0xb1, 0xb5, 0x5e, 0xbe, 0x37, 0xc4, 0xdb, 0x4d, 0xc8, 0xe3, 0xc8, 0x29, - 0xdf, 0xab, 0xd9, 0xd2, 0x90, 0x72, 0x38, 0x23, 0x98, 0x31, 0xd8, 0x2b, 0x90, 0x15, 0xe7, 0x52, - 0xf3, 0x5d, 0x7d, 0xfc, 0xba, 0x76, 0x67, 0xdc, 0x9a, 0x12, 0xf4, 0xa6, 0x8b, 0x10, 0x4c, 0x84, - 0x76, 0x80, 0xf5, 0x09, 0xa1, 0x26, 0xd6, 0xe8, 0x32, 0x64, 0x68, 0x37, 0xa8, 0x93, 0xa6, 0x3e, - 0x29, 0xb8, 0x8a, 0x42, 0x06, 0x64, 0x5d, 0xec, 0xf8, 0x81, 0xdd, 0xa4, 0x7a, 0xe6, 0xba, 0x76, - 0x27, 0x6f, 0x25, 0x34, 0x5a, 0x86, 0x9c, 0x67, 0xd3, 0x5a, 0xd3, 0x0f, 0x7c, 0xa6, 0x4f, 0x09, - 0x1f, 0x59, 0xcf, 0xa6, 0x9f, 0x73, 0xda, 0x5c, 0x86, 0x2b, 0xc7, 0x62, 0x4a, 0x22, 0xfe, 0x53, - 0x83, 0xc5, 0x0a, 0xf5, 0x1e, 0xb9, 0x6e, 0x95, 0x6c, 0xb7, 0x59, 0xb5, 0x53, 0x8d, 0x6c, 0x67, - 0x1f, 0x47, 0x43, 0x82, 0xee, 0x8d, 0xe7, 0x42, 0x3a, 0x9e, 0x45, 0x98, 0x0c, 0x49, 0xe8, 0x60, - 0x11, 0xe7, 0x84, 0x25, 0x09, 0xb4, 0x04, 0x53, 0xac, 0x53, 0x6b, 0xd8, 0xb4, 0xa1, 0x02, 0xcd, - 0xb0, 0xce, 0x13, 0x9b, 0x36, 0xd0, 0x2d, 0x98, 0x6c, 0x45, 0x84, 0xec, 0x89, 0x48, 0xa7, 0xcb, - 0x17, 0x8b, 0x49, 0x4d, 0xec, 0x70, 0xb6, 0x25, 0x77, 0x79, 0x4e, 0xeb, 0x4d, 0xe2, 0xec, 0x4b, - 0x13, 0x19, 0x99, 0x53, 0xc1, 0x11, 0x56, 0xae, 0x40, 0x96, 0x75, 0x6a, 0x7e, 0xe8, 0xe2, 0x8e, - 0x8a, 0x7d, 0x8a, 0x75, 0x36, 0x39, 0x69, 0x16, 0xe0, 0xea, 0x49, 0xc1, 0x25, 0xd1, 0xef, 0x89, - 0xa3, 0xb1, 0x70, 0x40, 0x0e, 0xf0, 0xa7, 0x11, 0x09, 0xfe, 0xa7, 0x13, 0x30, 0x6f, 0xc2, 0x8d, - 0x81, 0x7e, 0x12, 0x30, 0x3f, 0xcb, 0xe2, 0x5b, 0xe7, 0x4e, 0x70, 0x75, 0x77, 0xf7, 0x0b, 0xc2, - 0x86, 0xa2, 0x18, 0x5e, 0xea, 0xe8, 0x1d, 0x98, 0xdb, 0xc7, 0xdd, 0x0d, 0x1c, 0x3e, 0xc7, 0xcc, - 0x7e, 0x82, 0x7d, 0xaf, 0xc1, 0x54, 0xf9, 0x1d, 0xe3, 0xa3, 0x55, 0xc8, 0x50, 0x66, 0xb3, 0x36, - 0x15, 0x09, 0x9a, 0x2d, 0x5f, 0x2a, 0xaa, 0xde, 0xb5, 0xb0, 0x83, 0xfd, 0x03, 0xbc, 0x2b, 0x36, - 0x2d, 0x25, 0xa4, 0x2a, 0x2a, 0x0d, 0x34, 0x09, 0xe3, 0x47, 0x0d, 0xe6, 0x2a, 0xd4, 0xdb, 0xb0, - 0xe9, 0x4e, 0xe4, 0x3b, 0x78, 0x54, 0x14, 0xc3, 0xcf, 0xb2, 0xc5, 0x4d, 0xc4, 0x67, 0x29, 0x08, - 0x74, 0x03, 0x66, 0x64, 0x35, 0x84, 0xed, 0xa0, 0x8e, 0x23, 0x81, 0x78, 0xc2, 0x9a, 0x16, 0xbc, - 0x2d, 0xc1, 0x12, 0x2d, 0xd4, 0x6e, 0xb5, 0x9a, 0xdd, 0xa4, 0x85, 0x04, 0x65, 0x1a, 0xa0, 0xf7, - 0x23, 0x4b, 0x60, 0x3f, 0x87, 0x7c, 0x85, 0x7a, 0x5b, 0x3c, 0x5d, 0xff, 0x0d, 0xf2, 0x09, 0xe9, - 0x5f, 0x82, 0x4b, 0x29, 0xdb, 0x89, 0xd3, 0xdf, 0x27, 0xc5, 0x7d, 0xc4, 0x99, 0xdb, 0xe1, 0x76, - 0x9d, 0xe2, 0xe8, 0x00, 0xbb, 0xdb, 0x6d, 0x56, 0x27, 0xed, 0xd0, 0xad, 0x76, 0x86, 0x60, 0x58, - 0x86, 0x9c, 0xe3, 0xc4, 0x5d, 0x25, 0x73, 0x9f, 0xe5, 0x0c, 0xd1, 0x11, 0x45, 0x58, 0x20, 0xca, - 0x58, 0x8d, 0xf0, 0x52, 0x93, 0x62, 0xe3, 0x42, 0x6c, 0x9e, 0x1c, 0xf9, 0xa9, 0x4a, 0xf9, 0x8f, - 0xc1, 0xe8, 0x93, 0x97, 0xdd, 0x25, 0x8b, 0x46, 0x1e, 0xb0, 0x9e, 0x52, 0x5b, 0x3b, 0xda, 0x47, - 0xef, 0xc3, 0x52, 0x9f, 0x36, 0xbf, 0x8b, 0xda, 0x14, 0xbb, 0x3a, 0x08, 0xd5, 0xc5, 0x94, 0xea, - 0x86, 0x4d, 0x9f, 0x51, 0xec, 0xa2, 0x17, 0x60, 0xf6, 0xa9, 0xe1, 0xbd, 0x3d, 0xec, 0x30, 0xff, - 0x00, 0x0b, 0x03, 0x32, 0xf5, 0xd3, 0x1c, 0xf3, 0x5a, 0xf1, 0xe5, 0xeb, 0x95, 0xb1, 0x3f, 0x5e, - 0xaf, 0xdc, 0xf6, 0x7c, 0xd6, 0x68, 0xd7, 0x79, 0x75, 0x96, 0x1c, 0x42, 0x03, 0x42, 0xd5, 0xcf, - 0x2a, 0x75, 0xf7, 0x4b, 0xac, 0xdb, 0xc2, 0xb4, 0xb8, 0x19, 0x32, 0xab, 0x90, 0xf2, 0xf8, 0x38, - 0xb6, 0x1b, 0x67, 0x1e, 0x7d, 0x36, 0xc2, 0xb7, 0xbc, 0x48, 0x67, 0x04, 0xfa, 0xc1, 0xb6, 0xc4, - 0xf5, 0x8a, 0x08, 0xcc, 0x1e, 0xd8, 0xcd, 0x36, 0xae, 0x45, 0xb2, 0x57, 0x5c, 0x59, 0x74, 0x6b, - 0x4f, 0x14, 0xe6, 0xb7, 0x4f, 0x81, 0xf9, 0x99, 0x1f, 0xb2, 0x7f, 0x5e, 0xaf, 0x5c, 0xea, 0xda, - 0x41, 0xf3, 0xa1, 0x99, 0x36, 0x67, 0x5a, 0x79, 0xc1, 0x50, 0xad, 0xe8, 0xf6, 0x34, 0x6b, 0xe6, - 0x14, 0xcd, 0x8a, 0x56, 0x60, 0x5a, 0x86, 0x28, 0x6a, 0x54, 0xdd, 0x90, 0x20, 0x58, 0xeb, 0x9c, - 0x83, 0x6e, 0xc3, 0x45, 0x29, 0xc0, 0x6f, 0x13, 0x59, 0xbd, 0x59, 0x11, 0x79, 0x5e, 0xb0, 0xab, - 0x94, 0x8a, 0xca, 0x45, 0xab, 0x90, 0x73, 0x88, 0x1f, 0xd6, 0x38, 0x64, 0x3d, 0x27, 0x5c, 0xcf, - 0xc5, 0xae, 0xd7, 0x89, 0x1f, 0x56, 0xbb, 0x2d, 0x6c, 0x65, 0x1d, 0xb5, 0x32, 0x6f, 0xc1, 0xcd, - 0x21, 0xa5, 0x9d, 0xb4, 0xc0, 0xdf, 0xe3, 0x60, 0x1c, 0x93, 0xdb, 0x0c, 0x47, 0x77, 0x00, 0x6f, - 0x72, 0x1c, 0xba, 0x38, 0x52, 0xe5, 0xaf, 0x28, 0x1e, 0x8e, 0x5c, 0xd5, 0xfa, 0x5e, 0xdd, 0xbc, - 0x64, 0xaf, 0xab, 0x56, 0x35, 0x20, 0xab, 0x8e, 0x38, 0x52, 0xcf, 0x52, 0x42, 0xa3, 0x5b, 0x30, - 0x1b, 0xaf, 0xd5, 0xb1, 0x4d, 0x4a, 0x13, 0x31, 0x57, 0x9e, 0xdc, 0x06, 0x64, 0xec, 0x80, 0xb4, - 0x43, 0x26, 0x1f, 0xa5, 0xb5, 0xd2, 0x19, 0x53, 0x6e, 0x29, 0x75, 0x1e, 0x65, 0x80, 0x29, 0xb5, - 0x3d, 0x79, 0xf4, 0x39, 0x2b, 0x26, 0xd1, 0x55, 0x00, 0x7e, 0xe4, 0xaa, 0x83, 0x73, 0x12, 0xa7, - 0x1f, 0xaa, 0xc6, 0xbd, 0x0d, 0x17, 0xfd, 0xb0, 0xa6, 0x1e, 0x47, 0xd9, 0xad, 0xb2, 0xe5, 0xf2, - 0x7e, 0xd8, 0xdb, 0xa2, 0xa9, 0xf9, 0x60, 0x5a, 0x48, 0x24, 0xf3, 0x41, 0x3a, 0xaf, 0x33, 0xa3, - 0xf2, 0xca, 0x6d, 0xb1, 0x4e, 0x8d, 0x44, 0xbe, 0xe7, 0x87, 0x7a, 0x5e, 0x02, 0x62, 0x9d, 0x6d, - 0x41, 0xf3, 0xfb, 0xcf, 0xa6, 0x14, 0x33, 0x7d, 0x56, 0x6c, 0x48, 0xc2, 0x7c, 0x0b, 0xcc, 0xc1, - 0x29, 0x4e, 0x2a, 0xe1, 0x5b, 0x0d, 0x66, 0x2b, 0xd4, 0xdb, 0xc5, 0x6c, 0x8b, 0xb8, 0xf8, 0x29, - 0xee, 0x0e, 0x9b, 0xf3, 0x4a, 0x90, 0x93, 0x0f, 0xdf, 0x2e, 0x66, 0xa2, 0x00, 0xa6, 0xcb, 0xf3, - 0x31, 0xe8, 0x9d, 0x76, 0xfd, 0xa9, 0xd8, 0xb0, 0x8e, 0x64, 0xd0, 0x5d, 0x40, 0xbc, 0xbe, 0xa9, - 0xef, 0x85, 0x38, 0xaa, 0xa9, 0xd9, 0x4c, 0x5d, 0x89, 0x73, 0x8c, 0xd2, 0x5d, 0xb1, 0xa1, 0xf8, - 0xa6, 0x0e, 0x97, 0xd3, 0x50, 0x62, 0x94, 0xe5, 0x5f, 0x72, 0x30, 0x5e, 0xa1, 0x1e, 0xfa, 0x46, - 0x83, 0xf9, 0xe3, 0x53, 0xd3, 0xfd, 0xe2, 0xd0, 0xd1, 0xb8, 0x78, 0xd2, 0x34, 0x62, 0x7c, 0x74, - 0x0e, 0xa5, 0x18, 0x0f, 0xfa, 0x5e, 0x83, 0xcb, 0x03, 0x06, 0x98, 0x07, 0xa3, 0xed, 0x9e, 0xac, - 0x69, 0x7c, 0x72, 0x5e, 0xcd, 0x04, 0xd6, 0x57, 0x30, 0xdb, 0x37, 0xc8, 0xdc, 0x1b, 0x6d, 0x33, - 0xad, 0x61, 0x3c, 0x38, 0xab, 0x46, 0xe2, 0xbd, 0x0b, 0xf9, 0xf4, 0xfc, 0x51, 0x1a, 0x6d, 0x2a, - 0xa5, 0x60, 0x7c, 0x70, 0x46, 0x85, 0xc4, 0x75, 0x0b, 0xa0, 0x67, 0x88, 0xb8, 0x3b, 0xda, 0xcc, - 0x91, 0xb4, 0xf1, 0xde, 0x59, 0xa4, 0x13, 0x8f, 0x3f, 0x69, 0xa0, 0x0f, 0x9c, 0x20, 0x1e, 0x8e, - 0x36, 0x39, 0x48, 0xd7, 0x58, 0x3b, 0xbf, 0x6e, 0x02, 0xee, 0x07, 0x0d, 0x96, 0x06, 0xdd, 0xed, - 0x1f, 0x9e, 0xd5, 0x7e, 0xa2, 0x6a, 0x3c, 0x3a, 0xb7, 0x6a, 0x6f, 0x85, 0xf6, 0x7d, 0xe7, 0x9d, - 0xa2, 0x42, 0xd3, 0x1a, 0xa7, 0xa9, 0xd0, 0x93, 0xbf, 0xbb, 0xd0, 0xd7, 0x1a, 0xcc, 0x1d, 0xfb, - 0xac, 0x2d, 0x8f, 0x36, 0xd7, 0xaf, 0x63, 0x3c, 0x3c, 0xbb, 0x4e, 0x0c, 0x62, 0xed, 0xe9, 0xcb, - 0x37, 0x05, 0xed, 0xd5, 0x9b, 0x82, 0xf6, 0xd7, 0x9b, 0x82, 0xf6, 0xdd, 0x61, 0x61, 0xec, 0xd5, - 0x61, 0x61, 0xec, 0xb7, 0xc3, 0xc2, 0xd8, 0xf3, 0x77, 0x7b, 0x5e, 0x30, 0x6e, 0x75, 0x55, 0xfe, - 0x03, 0x10, 0x3b, 0x28, 0x75, 0x4a, 0xbd, 0xff, 0x0b, 0xf0, 0x07, 0xad, 0x9e, 0x11, 0x5f, 0xec, - 0xf7, 0xff, 0x0d, 0x00, 0x00, 0xff, 0xff, 0xc9, 0xb3, 0x25, 0xb5, 0x32, 0x10, 0x00, 0x00, + // 1361 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x57, 0xcd, 0x6e, 0xdb, 0xc6, + 0x13, 0x37, 0x63, 0x5b, 0x96, 0xc6, 0x96, 0x63, 0xaf, 0x9d, 0x98, 0xa1, 0x13, 0x39, 0xa1, 0xff, + 0xc9, 0x3f, 0x28, 0x62, 0x29, 0x75, 0x5a, 0x34, 0x4d, 0x7b, 0x68, 0x6c, 0xa4, 0x8e, 0x9b, 0xca, + 0x0e, 0x68, 0xa5, 0x05, 0x72, 0x21, 0x28, 0x72, 0x4d, 0x11, 0x16, 0xb9, 0x02, 0x77, 0x65, 0x48, + 0x41, 0x4f, 0x05, 0x7a, 0xe8, 0xad, 0x87, 0x02, 0x2d, 0xfa, 0x02, 0x7d, 0x95, 0xf4, 0x16, 0xf4, + 0xd4, 0xf6, 0x10, 0xb4, 0xc9, 0x1b, 0xf4, 0x09, 0x8a, 0xfd, 0x20, 0x2d, 0xca, 0x96, 0x64, 0xbb, + 0xe8, 0x89, 0x3b, 0xb3, 0xf3, 0xf1, 0x9b, 0x9d, 0x99, 0xdd, 0x21, 0x2c, 0xb8, 0x31, 0xa1, 0xd4, + 0x6d, 0x38, 0x41, 0x54, 0x61, 0x9d, 0x72, 0x2b, 0x26, 0x8c, 0xa0, 0x6b, 0x2f, 0x30, 0x73, 0x04, + 0xaf, 0x2c, 0x56, 0x24, 0xc6, 0xe5, 0x23, 0x39, 0x63, 0xc1, 0x25, 0x61, 0x48, 0xa2, 0x8a, 0xfc, + 0x48, 0x1d, 0x63, 0xd1, 0x27, 0x3e, 0x11, 0xcb, 0x0a, 0x5f, 0x49, 0xae, 0xb9, 0x03, 0x0b, 0x55, + 0xea, 0x3f, 0x6b, 0x79, 0x0e, 0xc3, 0x35, 0x4a, 0x1f, 0x7a, 0x5e, 0x8c, 0x29, 0x45, 0x3a, 0x4c, + 0xb9, 0x31, 0x76, 0x18, 0x89, 0x75, 0xed, 0xba, 0x76, 0xbb, 0x60, 0x25, 0x24, 0xba, 0x06, 0xc0, + 0x28, 0xb5, 0x5b, 0xed, 0xfa, 0x01, 0xee, 0xea, 0x17, 0xc4, 0x66, 0x81, 0x51, 0xfa, 0x54, 0x30, + 0xcc, 0x6b, 0xb0, 0x7c, 0x82, 0x3d, 0x0b, 0xd3, 0x16, 0x89, 0x28, 0x36, 0x7f, 0xd5, 0x60, 0xbe, + 0x4a, 0xfd, 0x2f, 0x1b, 0x01, 0xc3, 0xcd, 0x80, 0xb2, 0x47, 0xd6, 0xe6, 0xfa, 0xdd, 0x21, 0xde, + 0x56, 0xa1, 0x88, 0x63, 0x77, 0xfd, 0xae, 0xed, 0x48, 0x43, 0xca, 0xe1, 0x8c, 0x60, 0x26, 0x60, + 0xaf, 0x40, 0x5e, 0xc4, 0x6d, 0x07, 0x9e, 0x3e, 0x7e, 0x5d, 0xbb, 0x3d, 0x6e, 0x4d, 0x09, 0x7a, + 0xdb, 0x43, 0x08, 0x26, 0x22, 0x27, 0xc4, 0xfa, 0x84, 0x50, 0x13, 0x6b, 0x74, 0x19, 0x72, 0xb4, + 0x1b, 0xd6, 0x49, 0x53, 0x9f, 0x14, 0x5c, 0x45, 0x21, 0x03, 0xf2, 0x1e, 0x76, 0x83, 0xd0, 0x69, + 0x52, 0x3d, 0x77, 0x5d, 0xbb, 0x5d, 0xb4, 0x52, 0x1a, 0x2d, 0x43, 0xc1, 0x77, 0xa8, 0xdd, 0x0c, + 0xc2, 0x80, 0xe9, 0x53, 0xc2, 0x47, 0xde, 0x77, 0xe8, 0xe7, 0x9c, 0x36, 0x97, 0xe1, 0xca, 0xb1, + 0x98, 0xd2, 0x88, 0x7f, 0xd7, 0x60, 0xb1, 0x4a, 0xfd, 0x87, 0x9e, 0x57, 0x23, 0xbb, 0x6d, 0x56, + 0xeb, 0xd4, 0x62, 0xc7, 0x3d, 0xc0, 0xf1, 0x90, 0xa0, 0x7b, 0xe3, 0xb9, 0x90, 0x8d, 0x67, 0x11, + 0x26, 0x23, 0x12, 0xb9, 0x58, 0xc4, 0x39, 0x61, 0x49, 0x02, 0x2d, 0xc1, 0x14, 0xeb, 0xd8, 0x0d, + 0x87, 0x36, 0x54, 0xa0, 0x39, 0xd6, 0x79, 0xec, 0xd0, 0x06, 0x5a, 0x85, 0xc9, 0x56, 0x4c, 0xc8, + 0xbe, 0x88, 0x74, 0x7a, 0xbd, 0x58, 0x56, 0x15, 0xf1, 0x94, 0x33, 0x2d, 0xb9, 0xc7, 0x33, 0x5a, + 0x6f, 0x12, 0xf7, 0x40, 0x1a, 0xc8, 0xc9, 0x8c, 0x0a, 0x8e, 0xb0, 0x71, 0x05, 0xf2, 0xac, 0x63, + 0x07, 0x91, 0x87, 0x3b, 0x2a, 0xf2, 0x29, 0xd6, 0xd9, 0xe6, 0xa4, 0x59, 0x82, 0xab, 0x27, 0x85, + 0x96, 0xc6, 0xbe, 0x2f, 0x0e, 0xc6, 0xc2, 0x21, 0x39, 0xc4, 0x9f, 0xc6, 0x24, 0xfc, 0x8f, 0xe2, + 0x37, 0x57, 0xe1, 0xc6, 0x40, 0x3f, 0x29, 0x98, 0x9f, 0x65, 0xe9, 0x6d, 0x72, 0x27, 0xb8, 0xb6, + 0xb7, 0xf7, 0x05, 0x61, 0x43, 0x51, 0x0c, 0x2f, 0x74, 0xf4, 0x0e, 0xcc, 0x1d, 0xe0, 0xee, 0x16, + 0x8e, 0x9e, 0x63, 0xe6, 0x3c, 0xc6, 0x81, 0xdf, 0x60, 0xaa, 0xf8, 0x8e, 0xf1, 0xd1, 0x1a, 0xe4, + 0x28, 0x73, 0x58, 0x9b, 0x8a, 0xf4, 0xcc, 0xae, 0x5f, 0x4a, 0xf2, 0x60, 0x61, 0x17, 0x07, 0x87, + 0x78, 0x4f, 0x6c, 0x5a, 0x4a, 0x48, 0xd5, 0x53, 0x16, 0x68, 0x1a, 0xc6, 0x8f, 0x1a, 0xcc, 0x55, + 0xa9, 0xbf, 0xe5, 0xd0, 0xa7, 0x71, 0xe0, 0xe2, 0x51, 0x51, 0x0c, 0x3f, 0xcb, 0x16, 0x37, 0x91, + 0x9c, 0xa5, 0x20, 0xd0, 0x0d, 0x98, 0x91, 0xd5, 0x10, 0xb5, 0xc3, 0x3a, 0x8e, 0x05, 0xe2, 0x09, + 0x6b, 0x5a, 0xf0, 0x76, 0x04, 0x4b, 0x34, 0x50, 0xbb, 0xd5, 0x6a, 0x76, 0xd3, 0x06, 0x12, 0x94, + 0x69, 0x80, 0xde, 0x8f, 0x2c, 0x85, 0xfd, 0x1c, 0x8a, 0x55, 0xea, 0xef, 0xf0, 0x74, 0xfd, 0x3b, + 0xc8, 0x27, 0xa4, 0x7f, 0x09, 0x2e, 0x65, 0x6c, 0x1f, 0xf5, 0xde, 0xa4, 0xb8, 0x8d, 0x38, 0x73, + 0x37, 0xda, 0xad, 0x53, 0x1c, 0x1f, 0x62, 0x6f, 0xb7, 0xcd, 0xea, 0xa4, 0x1d, 0x79, 0xb5, 0xce, + 0x10, 0x0c, 0xcb, 0x50, 0x70, 0xdd, 0xa4, 0xa7, 0x64, 0xee, 0xf3, 0x9c, 0x21, 0x3a, 0xa2, 0x0c, + 0x0b, 0x44, 0x19, 0xb3, 0x09, 0x2f, 0x35, 0x29, 0x36, 0x2e, 0xc4, 0xe6, 0xc9, 0x91, 0x9f, 0x9a, + 0x94, 0xff, 0x18, 0x8c, 0x3e, 0x79, 0xd9, 0x5d, 0xb2, 0x68, 0xe4, 0x01, 0xeb, 0x19, 0xb5, 0x8d, + 0xa3, 0x7d, 0xf4, 0x3e, 0x2c, 0xf5, 0x69, 0xf3, 0x9b, 0xa8, 0x4d, 0xb1, 0xa7, 0x83, 0x50, 0x5d, + 0xcc, 0xa8, 0x6e, 0x39, 0xf4, 0x19, 0xc5, 0x1e, 0x7a, 0x01, 0x66, 0x9f, 0x1a, 0xde, 0xdf, 0xc7, + 0x2e, 0x0b, 0x0e, 0xb1, 0x30, 0x20, 0x53, 0x3f, 0xcd, 0x31, 0x6f, 0x94, 0x5f, 0xbe, 0x5e, 0x19, + 0xfb, 0xe3, 0xf5, 0xca, 0x2d, 0x3f, 0x60, 0x8d, 0x76, 0x9d, 0x57, 0x67, 0xc5, 0x25, 0x34, 0x24, + 0x54, 0x7d, 0xd6, 0xa8, 0x77, 0x50, 0x61, 0xdd, 0x16, 0xa6, 0xe5, 0xed, 0x88, 0x59, 0xa5, 0x8c, + 0xc7, 0x47, 0x89, 0xdd, 0x24, 0xf3, 0xe8, 0xb3, 0x11, 0xbe, 0xe5, 0x35, 0x3a, 0x23, 0xd0, 0x0f, + 0xb6, 0x25, 0x2e, 0x57, 0x44, 0x60, 0xf6, 0xd0, 0x69, 0xb6, 0xb1, 0x1d, 0xcb, 0x5e, 0xf1, 0x64, + 0xd1, 0x6d, 0x3c, 0x56, 0x98, 0xff, 0x7f, 0x0a, 0xcc, 0xcf, 0x82, 0x88, 0xfd, 0xfd, 0x7a, 0xe5, + 0x52, 0xd7, 0x09, 0x9b, 0x0f, 0xcc, 0xac, 0x39, 0xd3, 0x2a, 0x0a, 0x86, 0x6a, 0x45, 0xaf, 0xa7, + 0x59, 0x73, 0xa7, 0x68, 0x56, 0xb4, 0x02, 0xd3, 0x32, 0x44, 0x51, 0xa3, 0xea, 0x86, 0x04, 0xc1, + 0xda, 0xe4, 0x1c, 0x74, 0x0b, 0x2e, 0x4a, 0x01, 0x7e, 0x9b, 0xc8, 0xea, 0xcd, 0x8b, 0xc8, 0x8b, + 0x82, 0x5d, 0xa3, 0x54, 0x54, 0x2e, 0x5a, 0x83, 0x82, 0x4b, 0x82, 0xc8, 0xe6, 0x90, 0xf5, 0x82, + 0x70, 0x3d, 0x97, 0xb8, 0xde, 0x24, 0x41, 0x54, 0xeb, 0xb6, 0xb0, 0x95, 0x77, 0xd5, 0xca, 0xbc, + 0x09, 0xab, 0x43, 0x4a, 0x3b, 0x6d, 0x81, 0xbf, 0xc6, 0xc1, 0x38, 0x26, 0xb7, 0x1d, 0x8d, 0xee, + 0x00, 0xde, 0xe4, 0x38, 0xf2, 0x70, 0xac, 0xca, 0x5f, 0x51, 0x3c, 0x1c, 0xb9, 0xb2, 0xfb, 0xde, + 0xdc, 0xa2, 0x64, 0x6f, 0xaa, 0x56, 0x35, 0x20, 0xaf, 0x8e, 0x38, 0x56, 0x8f, 0x52, 0x4a, 0xa3, + 0x9b, 0x30, 0x9b, 0xac, 0xd5, 0xb1, 0x4d, 0x4a, 0x13, 0x09, 0x57, 0x9e, 0xdc, 0x16, 0xe4, 0x9c, + 0x90, 0xb4, 0x23, 0x26, 0x1f, 0xa5, 0x8d, 0xca, 0x19, 0x53, 0x6e, 0x29, 0x75, 0x1e, 0x65, 0x88, + 0x29, 0x75, 0x7c, 0x79, 0xf4, 0x05, 0x2b, 0x21, 0xd1, 0x55, 0x00, 0x7e, 0xe4, 0xaa, 0x83, 0x0b, + 0x12, 0x67, 0x10, 0xa9, 0xc6, 0xbd, 0x05, 0x17, 0x83, 0xc8, 0x56, 0x8f, 0xa3, 0xec, 0x56, 0xd9, + 0x72, 0xc5, 0x20, 0xea, 0x6d, 0xd1, 0xcc, 0x74, 0x30, 0x2d, 0x24, 0xd2, 0xe9, 0x20, 0x9b, 0xd7, + 0x99, 0x51, 0x79, 0xe5, 0xb6, 0x58, 0xc7, 0x26, 0x71, 0xe0, 0x07, 0x91, 0x5e, 0x94, 0x80, 0x58, + 0x67, 0x57, 0xd0, 0xfc, 0xfe, 0x73, 0x28, 0xc5, 0x4c, 0x9f, 0x15, 0x1b, 0x92, 0x30, 0xff, 0x07, + 0xe6, 0xe0, 0x14, 0xa7, 0x95, 0xf0, 0xad, 0x06, 0xb3, 0x55, 0xea, 0xef, 0x61, 0xb6, 0x43, 0x3c, + 0xfc, 0x04, 0x77, 0x87, 0x4d, 0x79, 0x15, 0x28, 0xc8, 0x87, 0x6f, 0x0f, 0x33, 0x51, 0x00, 0xd3, + 0xeb, 0xf3, 0xe9, 0xf0, 0xd0, 0xae, 0x3f, 0x11, 0x1b, 0xd6, 0x91, 0x0c, 0xba, 0x03, 0x88, 0xd7, + 0x37, 0x0d, 0xfc, 0x08, 0xc7, 0xb6, 0x9a, 0xcc, 0xd4, 0x95, 0x38, 0xc7, 0x28, 0xdd, 0x13, 0x1b, + 0x8a, 0x6f, 0xea, 0x70, 0x39, 0x0b, 0x25, 0x41, 0xb9, 0xfe, 0x4b, 0x01, 0xc6, 0xab, 0xd4, 0x47, + 0xdf, 0x68, 0x30, 0x7f, 0x7c, 0x66, 0xba, 0x57, 0x1e, 0x3a, 0xf8, 0x96, 0x4f, 0x9a, 0x46, 0x8c, + 0x8f, 0xce, 0xa1, 0x94, 0xe0, 0x41, 0xdf, 0x6b, 0x70, 0x79, 0xc0, 0x00, 0x73, 0x7f, 0xb4, 0xdd, + 0x93, 0x35, 0x8d, 0x4f, 0xce, 0xab, 0x99, 0xc2, 0xfa, 0x0a, 0x66, 0xfb, 0x06, 0x99, 0xbb, 0xa3, + 0x6d, 0x66, 0x35, 0x8c, 0xfb, 0x67, 0xd5, 0x48, 0xbd, 0x77, 0xa1, 0x98, 0x9d, 0x3f, 0x2a, 0xa3, + 0x4d, 0x65, 0x14, 0x8c, 0x0f, 0xce, 0xa8, 0x90, 0xba, 0x6e, 0x01, 0xf4, 0x0c, 0x11, 0x77, 0x46, + 0x9b, 0x39, 0x92, 0x36, 0xde, 0x3b, 0x8b, 0x74, 0xea, 0xf1, 0x27, 0x0d, 0xf4, 0x81, 0x13, 0xc4, + 0x83, 0xd1, 0x26, 0x07, 0xe9, 0x1a, 0x1b, 0xe7, 0xd7, 0x4d, 0xc1, 0xfd, 0xa0, 0xc1, 0xd2, 0xa0, + 0xbb, 0xfd, 0xc3, 0xb3, 0xda, 0x4f, 0x55, 0x8d, 0x87, 0xe7, 0x56, 0xed, 0xad, 0xd0, 0xbe, 0xbf, + 0xbc, 0x53, 0x54, 0x68, 0x56, 0xe3, 0x34, 0x15, 0x7a, 0xf2, 0x5f, 0x17, 0xfa, 0x5a, 0x83, 0xb9, + 0x63, 0x3f, 0xb5, 0xeb, 0xa3, 0xcd, 0xf5, 0xeb, 0x18, 0x0f, 0xce, 0xae, 0x93, 0x80, 0xd8, 0x78, + 0xf2, 0xf2, 0x4d, 0x49, 0x7b, 0xf5, 0xa6, 0xa4, 0xfd, 0xf9, 0xa6, 0xa4, 0x7d, 0xf7, 0xb6, 0x34, + 0xf6, 0xea, 0x6d, 0x69, 0xec, 0xb7, 0xb7, 0xa5, 0xb1, 0xe7, 0xef, 0xf6, 0xbc, 0x60, 0xdc, 0xea, + 0x9a, 0xfc, 0xbf, 0x4f, 0x1c, 0x54, 0x3a, 0x95, 0xde, 0xbf, 0x7e, 0xfe, 0xa0, 0xd5, 0x73, 0xe2, + 0x7f, 0xfd, 0xde, 0x3f, 0x01, 0x00, 0x00, 0xff, 0xff, 0xd7, 0x41, 0x25, 0x03, 0x10, 0x10, 0x00, + 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -3536,7 +3535,7 @@ func (m *MsgAddToOutTxTracker) Unmarshal(dAtA []byte) error { return io.ErrUnexpectedEOF } if m.Proof == nil { - m.Proof = ðereum.Proof{} + m.Proof = &common.Proof{} } if err := m.Proof.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err diff --git a/x/observer/keeper/keeper_block_header.go b/x/observer/keeper/block_header.go similarity index 80% rename from x/observer/keeper/keeper_block_header.go rename to x/observer/keeper/block_header.go index 36fba2ff14..6bd64b34e4 100644 --- a/x/observer/keeper/keeper_block_header.go +++ b/x/observer/keeper/block_header.go @@ -6,20 +6,21 @@ import ( "github.com/cosmos/cosmos-sdk/store/prefix" sdk "github.com/cosmos/cosmos-sdk/types" "github.com/cosmos/cosmos-sdk/types/query" + "github.com/zeta-chain/zetacore/common" "github.com/zeta-chain/zetacore/x/observer/types" "google.golang.org/grpc/codes" "google.golang.org/grpc/status" ) -// SetNodeAccount set a specific nodeAccount in the store from its index -func (k Keeper) SetBlockHeader(ctx sdk.Context, header types.BlockHeader) { +// SetBlockHeader set a specific block header in the store from its index +func (k Keeper) SetBlockHeader(ctx sdk.Context, header common.BlockHeader) { store := prefix.NewStore(ctx.KVStore(k.storeKey), types.KeyPrefix(types.BlockHeaderKey)) b := k.cdc.MustMarshal(&header) store.Set(header.Hash, b) } -// GetNodeAccount returns a nodeAccount from its index -func (k Keeper) GetBlockHeader(ctx sdk.Context, hash []byte) (val types.BlockHeader, found bool) { +// GetBlockHeader returns a block header from its hash +func (k Keeper) GetBlockHeader(ctx sdk.Context, hash []byte) (val common.BlockHeader, found bool) { store := prefix.NewStore(ctx.KVStore(k.storeKey), types.KeyPrefix(types.BlockHeaderKey)) b := store.Get(hash) @@ -31,13 +32,13 @@ func (k Keeper) GetBlockHeader(ctx sdk.Context, hash []byte) (val types.BlockHea return val, true } -// RemoveNodeAccount removes a nodeAccount from the store +// RemoveBlockHeader removes a block header from the store func (k Keeper) RemoveBlockHeader(ctx sdk.Context, hash []byte) { store := prefix.NewStore(ctx.KVStore(k.storeKey), types.KeyPrefix(types.BlockHeaderKey)) store.Delete(hash) } -// GRPC querier for block header +// GetAllBlockHeaders queries all for block header func (k Keeper) GetAllBlockHeaders(c context.Context, req *types.QueryAllBlockHeaderRequest) (*types.QueryAllBlockHeaderResponse, error) { if req == nil { return nil, status.Error(codes.InvalidArgument, "invalid request") @@ -46,9 +47,9 @@ func (k Keeper) GetAllBlockHeaders(c context.Context, req *types.QueryAllBlockHe store := ctx.KVStore(k.storeKey) blockHeaderStore := prefix.NewStore(store, types.KeyPrefix(types.BlockHeaderKey)) - var blockHeaders []*types.BlockHeader + var blockHeaders []*common.BlockHeader pageRes, err := query.Paginate(blockHeaderStore, req.Pagination, func(key []byte, value []byte) error { - var blockHeader types.BlockHeader + var blockHeader common.BlockHeader if err := k.cdc.Unmarshal(value, &blockHeader); err != nil { return err } @@ -62,15 +63,12 @@ func (k Keeper) GetAllBlockHeaders(c context.Context, req *types.QueryAllBlockHe return &types.QueryAllBlockHeaderResponse{BlockHeaders: blockHeaders, Pagination: pageRes}, nil } +// GetBlockHeaderByHash queries block header by hash func (k Keeper) GetBlockHeaderByHash(c context.Context, req *types.QueryGetBlockHeaderByHashRequest) (*types.QueryGetBlockHeaderByHashResponse, error) { if req == nil { return nil, status.Error(codes.InvalidArgument, "invalid request") } - if len(req.BlockHash) != 32 { - return nil, status.Error(codes.InvalidArgument, "invalid hash") - } - header, found := k.GetBlockHeader(sdk.UnwrapSDKContext(c), req.BlockHash) if !found { return nil, status.Error(codes.NotFound, "not found") diff --git a/x/observer/keeper/grpc_query_prove.go b/x/observer/keeper/grpc_query_prove.go index 99db2ae44a..e4880f4c2e 100644 --- a/x/observer/keeper/grpc_query_prove.go +++ b/x/observer/keeper/grpc_query_prove.go @@ -4,10 +4,11 @@ import ( "context" "fmt" + "github.com/zeta-chain/zetacore/common" + sdk "github.com/cosmos/cosmos-sdk/types" eth "github.com/ethereum/go-ethereum/common" ethtypes "github.com/ethereum/go-ethereum/core/types" - "github.com/ethereum/go-ethereum/rlp" "github.com/zeta-chain/zetacore/x/observer/types" "google.golang.org/grpc/codes" "google.golang.org/grpc/status" @@ -24,14 +25,13 @@ func (k Keeper) Prove(c context.Context, req *types.QueryProveRequest) (*types.Q if !found { return nil, status.Error(codes.NotFound, "block header not found") } - var header ethtypes.Header - err := rlp.DecodeBytes(res.Header, &header) - if err != nil { - return nil, status.Error(codes.Internal, fmt.Sprintf("failed to decode header: %s", err)) - } + proven := false - val, err := req.Proof.Verify(header.TxHash, int(req.TxIndex)) + val, err := req.Proof.Verify(res.Header, int(req.TxIndex)) + if err != nil && !common.IsErrorInvalidProof(err) { + return nil, status.Error(codes.Internal, err.Error()) + } if err == nil { var txx ethtypes.Transaction err = txx.UnmarshalBinary(val) diff --git a/x/observer/keeper/msg_server_add_block_header.go b/x/observer/keeper/msg_server_add_block_header.go index caf53cffe6..8ee4ffa5cd 100644 --- a/x/observer/keeper/msg_server_add_block_header.go +++ b/x/observer/keeper/msg_server_add_block_header.go @@ -2,57 +2,64 @@ package keeper import ( "context" - "fmt" + "encoding/hex" + + cosmoserrors "cosmossdk.io/errors" sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" "github.com/zeta-chain/zetacore/common" "github.com/zeta-chain/zetacore/x/observer/types" ) -// MsgAddBlockHeader handles adding a block header to the store, through majority voting of observers +// AddBlockHeader handles adding a block header to the store, through majority voting of observers func (k msgServer) AddBlockHeader(goCtx context.Context, msg *types.MsgAddBlockHeader) (*types.MsgAddBlockHeaderResponse, error) { ctx := sdk.UnwrapSDKContext(goCtx) - observationType := types.ObservationType_InBoundTx + + // check authorization for this chain chain := common.GetChainFromChainID(msg.ChainId) ok, err := k.IsAuthorized(ctx, msg.Creator, chain) if !ok { - return nil, err + return nil, cosmoserrors.Wrap(types.ErrNotAuthorizedPolicy, err.Error()) } - ballot, _, err := k.FindBallot(ctx, msg.Digest(), chain, observationType) + // add vote to ballot + ballot, _, err := k.FindBallot(ctx, msg.Digest(), chain, types.ObservationType_InBoundTx) if err != nil { - return nil, sdkerrors.Wrap(err, "failed to find ballot") + return nil, cosmoserrors.Wrap(err, "failed to find ballot") } ballot, err = k.AddVoteToBallot(ctx, ballot, msg.Creator, types.VoteType_SuccessObservation) if err != nil { - return nil, sdkerrors.Wrap(err, "failed to add vote to ballot") + return nil, cosmoserrors.Wrap(err, "failed to add vote to ballot") } _, isFinalized := k.CheckIfFinalizingVote(ctx, ballot) if !isFinalized { return &types.MsgAddBlockHeaderResponse{}, nil } + /** + * Vote finalized, add block header to store + */ _, found := k.GetBlockHeader(ctx, msg.BlockHash) if found { - return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidRequest, fmt.Sprintf("block header with hash %s already exists", msg.BlockHeader)) + return nil, cosmoserrors.Wrap(types.ErrBlockAlreadyExist, hex.EncodeToString(msg.BlockHash)) } - pHash, err := msg.ParentHash() // error is checked in BasicValidation in msg; check again for extra caution + // NOTE: error is checked in BasicValidation in msg; check again for extra caution + pHash, err := msg.Header.ParentHash() if err != nil { - return nil, sdkerrors.Wrap(sdkerrors.ErrInvalidRequest, fmt.Sprintf("failed to get parent hash: %s", err.Error())) + return nil, cosmoserrors.Wrap(types.ErrNoParentHash, err.Error()) } // TODO: add check for parent block header's existence here https://github.com/zeta-chain/node/issues/1133 - bh := types.BlockHeader{ - Header: msg.BlockHeader, + bh := common.BlockHeader{ + Header: msg.Header, Height: msg.Height, Hash: msg.BlockHash, ParentHash: pHash, ChainId: msg.ChainId, } - k.SetBlockHeader(ctx, bh) + return &types.MsgAddBlockHeaderResponse{}, nil } diff --git a/x/observer/types/errors.go b/x/observer/types/errors.go index 5df4dab889..afe8422699 100644 --- a/x/observer/types/errors.go +++ b/x/observer/types/errors.go @@ -7,25 +7,26 @@ import ( ) var ( - ErrUnableToAddVote = errorsmod.Register(ModuleName, 1100, "Unable to add vote ") - ErrParamsThreshold = errorsmod.Register(ModuleName, 1101, "Threshold cannot be more than 1") - ErrSupportedChains = errorsmod.Register(ModuleName, 1102, "Err chain not supported") - ErrInvalidStatus = errorsmod.Register(ModuleName, 1103, "Invalid Voting Status") + ErrUnableToAddVote = errorsmod.Register(ModuleName, 1100, "unable to add vote ") + ErrParamsThreshold = errorsmod.Register(ModuleName, 1101, "threshold cannot be more than 1") + ErrSupportedChains = errorsmod.Register(ModuleName, 1102, "chain not supported") + ErrInvalidStatus = errorsmod.Register(ModuleName, 1103, "invalid Voting Status") - ErrObserverNotPresent = errorsmod.Register(ModuleName, 1105, "Observer for type and observation does not exist") - ErrNotValidator = errorsmod.Register(ModuleName, 1106, "User needs to be a validator before applying to become an observer") - ErrValidatorStatus = errorsmod.Register(ModuleName, 1107, "Corresponding validator needs to be bonded and not jailerd") - ErrInvalidAddress = errorsmod.Register(ModuleName, 1108, "Invalid Address") - ErrSelfDelegation = errorsmod.Register(ModuleName, 1109, "Self Delegation for operator not found") - ErrCheckObserverDelegation = errorsmod.Register(ModuleName, 1110, "Observer delegation not sufficient") - ErrNotAuthorizedPolicy = errorsmod.Register(ModuleName, 1111, "Msg Sender is not the authorized policy") - ErrCoreParamsNotSet = errorsmod.Register(ModuleName, 1112, "Core params has not been set") - ErrKeygenNotFound = errorsmod.Register(ModuleName, 1113, "Err Keygen not found, Keygen block can only be updated,New keygen cannot be set") - ErrKeygenBlockTooLow = errorsmod.Register(ModuleName, 1114, "Please set a block number at-least 10 blocks higher than the current block number") - ErrKeygenCompleted = errorsmod.Register(ModuleName, 1115, "Keygen already completed") - ErrNotAuthorized = errorsmod.Register(ModuleName, 1116, "Err not authorized") - ErrInvalidCoinType = errorsmod.Register(ModuleName, 1117, "Invalid coin type") - ErrObserverCountNegative = errorsmod.Register(ModuleName, 1118, "Observer count cannot be negative") - ErrInvalidPubKey = errorsmod.Register(ModuleName, 1119, "Invalid PubKey") - ErrBlockHeaderNotFound = errorsmod.Register(ModuleName, 1120, "Block header not found") + ErrObserverNotPresent = errorsmod.Register(ModuleName, 1105, "observer for type and observation does not exist") + ErrNotValidator = errorsmod.Register(ModuleName, 1106, "user needs to be a validator before applying to become an observer") + ErrValidatorStatus = errorsmod.Register(ModuleName, 1107, "corresponding validator needs to be bonded and not jailerd") + ErrInvalidAddress = errorsmod.Register(ModuleName, 1108, "invalid Address") + ErrSelfDelegation = errorsmod.Register(ModuleName, 1109, "self Delegation for operator not found") + ErrCheckObserverDelegation = errorsmod.Register(ModuleName, 1110, "observer delegation not sufficient") + ErrNotAuthorizedPolicy = errorsmod.Register(ModuleName, 1111, "msg Sender is not the authorized policy") + ErrCoreParamsNotSet = errorsmod.Register(ModuleName, 1112, "core params has not been set") + ErrKeygenNotFound = errorsmod.Register(ModuleName, 1113, "Keygen not found, Keygen block can only be updated,New keygen cannot be set") + ErrKeygenBlockTooLow = errorsmod.Register(ModuleName, 1114, "please set a block number at-least 10 blocks higher than the current block number") + ErrKeygenCompleted = errorsmod.Register(ModuleName, 1115, "keygen already completed") + ErrNotAuthorized = errorsmod.Register(ModuleName, 1116, "not authorized") + + ErrBlockHeaderNotFound = errorsmod.Register(ModuleName, 1117, "block header not found") + ErrUnrecognizedBlockHeader = errorsmod.Register(ModuleName, 1118, "unrecognized block header") + ErrBlockAlreadyExist = errorsmod.Register(ModuleName, 1119, "block already exists") + ErrNoParentHash = errorsmod.Register(ModuleName, 1120, "no parent hash") ) diff --git a/x/observer/types/headers.pb.go b/x/observer/types/headers.pb.go deleted file mode 100644 index 63acd00960..0000000000 --- a/x/observer/types/headers.pb.go +++ /dev/null @@ -1,500 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: observer/headers.proto - -package types - -import ( - fmt "fmt" - io "io" - math "math" - math_bits "math/bits" - - _ "github.com/cosmos/gogoproto/gogoproto" - proto "github.com/gogo/protobuf/proto" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type BlockHeader struct { - Header []byte `protobuf:"bytes,1,opt,name=header,proto3" json:"header,omitempty"` - Height int64 `protobuf:"varint,2,opt,name=height,proto3" json:"height,omitempty"` - Hash []byte `protobuf:"bytes,3,opt,name=hash,proto3" json:"hash,omitempty"` - ParentHash []byte `protobuf:"bytes,4,opt,name=parentHash,proto3" json:"parentHash,omitempty"` - ChainId int64 `protobuf:"varint,5,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` -} - -func (m *BlockHeader) Reset() { *m = BlockHeader{} } -func (m *BlockHeader) String() string { return proto.CompactTextString(m) } -func (*BlockHeader) ProtoMessage() {} -func (*BlockHeader) Descriptor() ([]byte, []int) { - return fileDescriptor_2b67bad3a61a5de9, []int{0} -} -func (m *BlockHeader) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *BlockHeader) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_BlockHeader.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *BlockHeader) XXX_Merge(src proto.Message) { - xxx_messageInfo_BlockHeader.Merge(m, src) -} -func (m *BlockHeader) XXX_Size() int { - return m.Size() -} -func (m *BlockHeader) XXX_DiscardUnknown() { - xxx_messageInfo_BlockHeader.DiscardUnknown(m) -} - -var xxx_messageInfo_BlockHeader proto.InternalMessageInfo - -func (m *BlockHeader) GetHeader() []byte { - if m != nil { - return m.Header - } - return nil -} - -func (m *BlockHeader) GetHeight() int64 { - if m != nil { - return m.Height - } - return 0 -} - -func (m *BlockHeader) GetHash() []byte { - if m != nil { - return m.Hash - } - return nil -} - -func (m *BlockHeader) GetParentHash() []byte { - if m != nil { - return m.ParentHash - } - return nil -} - -func (m *BlockHeader) GetChainId() int64 { - if m != nil { - return m.ChainId - } - return 0 -} - -func init() { - proto.RegisterType((*BlockHeader)(nil), "zetachain.zetacore.observer.BlockHeader") -} - -func init() { proto.RegisterFile("observer/headers.proto", fileDescriptor_2b67bad3a61a5de9) } - -var fileDescriptor_2b67bad3a61a5de9 = []byte{ - // 245 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x12, 0xcb, 0x4f, 0x2a, 0x4e, - 0x2d, 0x2a, 0x4b, 0x2d, 0xd2, 0xcf, 0x48, 0x4d, 0x4c, 0x49, 0x2d, 0x2a, 0xd6, 0x2b, 0x28, 0xca, - 0x2f, 0xc9, 0x17, 0x92, 0xae, 0x4a, 0x2d, 0x49, 0x4c, 0xce, 0x48, 0xcc, 0xcc, 0xd3, 0x03, 0xb3, - 0xf2, 0x8b, 0x52, 0xf5, 0x60, 0x4a, 0xa5, 0x44, 0xd2, 0xf3, 0xd3, 0xf3, 0xc1, 0xea, 0xf4, 0x41, - 0x2c, 0x88, 0x16, 0x29, 0x71, 0xb8, 0x51, 0x30, 0x06, 0x44, 0x42, 0xa9, 0x87, 0x91, 0x8b, 0xdb, - 0x29, 0x27, 0x3f, 0x39, 0xdb, 0x03, 0x6c, 0x85, 0x90, 0x18, 0x17, 0x1b, 0xc4, 0x32, 0x09, 0x46, - 0x05, 0x46, 0x0d, 0x9e, 0x20, 0x28, 0x0f, 0x22, 0x9e, 0x99, 0x9e, 0x51, 0x22, 0xc1, 0xa4, 0xc0, - 0xa8, 0xc1, 0x1c, 0x04, 0xe5, 0x09, 0x09, 0x71, 0xb1, 0x64, 0x24, 0x16, 0x67, 0x48, 0x30, 0x83, - 0x55, 0x83, 0xd9, 0x42, 0x72, 0x5c, 0x5c, 0x05, 0x89, 0x45, 0xa9, 0x79, 0x25, 0x1e, 0x20, 0x19, - 0x16, 0xb0, 0x0c, 0x92, 0x88, 0x90, 0x24, 0x17, 0x07, 0xd8, 0xf5, 0xf1, 0x99, 0x29, 0x12, 0xac, - 0x60, 0xd3, 0xd8, 0xc1, 0x7c, 0xcf, 0x14, 0x27, 0xcf, 0x13, 0x8f, 0xe4, 0x18, 0x2f, 0x3c, 0x92, - 0x63, 0x7c, 0xf0, 0x48, 0x8e, 0x71, 0xc2, 0x63, 0x39, 0x86, 0x0b, 0x8f, 0xe5, 0x18, 0x6e, 0x3c, - 0x96, 0x63, 0x88, 0xd2, 0x4f, 0xcf, 0x2c, 0xc9, 0x28, 0x4d, 0xd2, 0x4b, 0xce, 0xcf, 0xd5, 0x07, - 0xf9, 0x5a, 0x17, 0xac, 0x45, 0x1f, 0x16, 0x00, 0xfa, 0x15, 0x70, 0x9f, 0xe9, 0x97, 0x54, 0x16, - 0xa4, 0x16, 0x27, 0xb1, 0x81, 0x3d, 0x68, 0x0c, 0x08, 0x00, 0x00, 0xff, 0xff, 0xba, 0x02, 0xb5, - 0x91, 0x46, 0x01, 0x00, 0x00, -} - -func (m *BlockHeader) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *BlockHeader) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *BlockHeader) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.ChainId != 0 { - i = encodeVarintHeaders(dAtA, i, uint64(m.ChainId)) - i-- - dAtA[i] = 0x28 - } - if len(m.ParentHash) > 0 { - i -= len(m.ParentHash) - copy(dAtA[i:], m.ParentHash) - i = encodeVarintHeaders(dAtA, i, uint64(len(m.ParentHash))) - i-- - dAtA[i] = 0x22 - } - if len(m.Hash) > 0 { - i -= len(m.Hash) - copy(dAtA[i:], m.Hash) - i = encodeVarintHeaders(dAtA, i, uint64(len(m.Hash))) - i-- - dAtA[i] = 0x1a - } - if m.Height != 0 { - i = encodeVarintHeaders(dAtA, i, uint64(m.Height)) - i-- - dAtA[i] = 0x10 - } - if len(m.Header) > 0 { - i -= len(m.Header) - copy(dAtA[i:], m.Header) - i = encodeVarintHeaders(dAtA, i, uint64(len(m.Header))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func encodeVarintHeaders(dAtA []byte, offset int, v uint64) int { - offset -= sovHeaders(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *BlockHeader) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Header) - if l > 0 { - n += 1 + l + sovHeaders(uint64(l)) - } - if m.Height != 0 { - n += 1 + sovHeaders(uint64(m.Height)) - } - l = len(m.Hash) - if l > 0 { - n += 1 + l + sovHeaders(uint64(l)) - } - l = len(m.ParentHash) - if l > 0 { - n += 1 + l + sovHeaders(uint64(l)) - } - if m.ChainId != 0 { - n += 1 + sovHeaders(uint64(m.ChainId)) - } - return n -} - -func sovHeaders(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozHeaders(x uint64) (n int) { - return sovHeaders(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *BlockHeader) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowHeaders - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: BlockHeader: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: BlockHeader: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Header", wireType) - } - var byteLen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowHeaders - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - byteLen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if byteLen < 0 { - return ErrInvalidLengthHeaders - } - postIndex := iNdEx + byteLen - if postIndex < 0 { - return ErrInvalidLengthHeaders - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Header = append(m.Header[:0], dAtA[iNdEx:postIndex]...) - if m.Header == nil { - m.Header = []byte{} - } - iNdEx = postIndex - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Height", wireType) - } - m.Height = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowHeaders - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Height |= int64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Hash", wireType) - } - var byteLen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowHeaders - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - byteLen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if byteLen < 0 { - return ErrInvalidLengthHeaders - } - postIndex := iNdEx + byteLen - if postIndex < 0 { - return ErrInvalidLengthHeaders - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Hash = append(m.Hash[:0], dAtA[iNdEx:postIndex]...) - if m.Hash == nil { - m.Hash = []byte{} - } - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ParentHash", wireType) - } - var byteLen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowHeaders - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - byteLen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if byteLen < 0 { - return ErrInvalidLengthHeaders - } - postIndex := iNdEx + byteLen - if postIndex < 0 { - return ErrInvalidLengthHeaders - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ParentHash = append(m.ParentHash[:0], dAtA[iNdEx:postIndex]...) - if m.ParentHash == nil { - m.ParentHash = []byte{} - } - iNdEx = postIndex - case 5: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType) - } - m.ChainId = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowHeaders - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.ChainId |= int64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipHeaders(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthHeaders - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipHeaders(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowHeaders - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowHeaders - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowHeaders - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthHeaders - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupHeaders - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthHeaders - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthHeaders = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowHeaders = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupHeaders = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/observer/types/messages_add_block_header.go b/x/observer/types/messages_add_block_header.go index d216494393..8db4410195 100644 --- a/x/observer/types/messages_add_block_header.go +++ b/x/observer/types/messages_add_block_header.go @@ -1,13 +1,11 @@ package types import ( - "bytes" + cosmoserrors "cosmossdk.io/errors" sdk "github.com/cosmos/cosmos-sdk/types" sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/ethereum/go-ethereum/core/types" "github.com/ethereum/go-ethereum/crypto" - "github.com/ethereum/go-ethereum/rlp" "github.com/zeta-chain/zetacore/common" ) @@ -17,13 +15,13 @@ const ( TypeMsgAddBlockHeader = "add_block_header" ) -func NewMsgAddBlockHeader(creator string, chainID int64, blockHash []byte, height int64, header []byte) *MsgAddBlockHeader { +func NewMsgAddBlockHeader(creator string, chainID int64, blockHash []byte, height int64, header common.HeaderData) *MsgAddBlockHeader { return &MsgAddBlockHeader{ - Creator: creator, - ChainId: chainID, - BlockHash: blockHash, - Height: height, - BlockHeader: header, + Creator: creator, + ChainId: chainID, + BlockHash: blockHash, + Height: height, + Header: header, } } @@ -51,33 +49,23 @@ func (msg *MsgAddBlockHeader) GetSignBytes() []byte { func (msg *MsgAddBlockHeader) ValidateBasic() error { _, err := sdk.AccAddressFromBech32(msg.Creator) if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) + return cosmoserrors.Wrapf(sdkerrors.ErrInvalidAddress, err.Error()) } - if len(msg.BlockHash) > 32 { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid msg.txhash; too long (%d)", len(msg.BlockHash)) - } - if len(msg.BlockHeader) > 1024 { // on ethereum the block header is ~538 bytes in RLP encoding - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid msg.blockheader; too long (%d)", len(msg.BlockHeader)) - } if common.IsEthereum(msg.ChainId) { - // RLP encoded block header - var header types.Header - err = rlp.DecodeBytes(msg.BlockHeader, &header) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid block header; cannot decode RLP (%s)", err) - } - if err = header.SanityCheck(); err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid block header; sanity check failed (%s)", err) - } - if bytes.Compare(msg.BlockHash, header.Hash().Bytes()) != 0 { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid block header; tx hash mismatch") - } - if msg.Height != header.Number.Int64() { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid block header; height mismatch") + if len(msg.BlockHash) > 32 { + return cosmoserrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid msg.txhash; too long (%d)", len(msg.BlockHash)) } } else { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid chain id (%d)", msg.ChainId) + return cosmoserrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid chain id (%d)", msg.ChainId) + } + + if err := msg.Header.Validate(msg.BlockHash, msg.Height); err != nil { + return cosmoserrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid block header (%s)", err) + } + + if _, err := msg.Header.ParentHash(); err != nil { + return cosmoserrors.Wrapf(sdkerrors.ErrInvalidRequest, "can't get parent hash (%s)", err) } return nil @@ -89,13 +77,3 @@ func (msg *MsgAddBlockHeader) Digest() string { hash := crypto.Keccak256Hash([]byte(m.String())) return hash.Hex() } - -func (msg *MsgAddBlockHeader) ParentHash() ([]byte, error) { - var header types.Header - err := rlp.DecodeBytes(msg.BlockHeader, &header) - if err != nil { - return nil, err - } - - return header.ParentHash.Bytes(), nil -} diff --git a/x/observer/types/query.pb.go b/x/observer/types/query.pb.go index 91ff1026cf..d1e116394d 100644 --- a/x/observer/types/query.pb.go +++ b/x/observer/types/query.pb.go @@ -15,7 +15,6 @@ import ( grpc1 "github.com/gogo/protobuf/grpc" proto "github.com/gogo/protobuf/proto" common "github.com/zeta-chain/zetacore/common" - ethereum "github.com/zeta-chain/zetacore/common/ethereum" _ "google.golang.org/genproto/googleapis/api/annotations" grpc "google.golang.org/grpc" codes "google.golang.org/grpc/codes" @@ -34,11 +33,11 @@ var _ = math.Inf const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package type QueryProveRequest struct { - ChainId uint64 `protobuf:"varint,1,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` - TxHash string `protobuf:"bytes,2,opt,name=tx_hash,json=txHash,proto3" json:"tx_hash,omitempty"` - Proof *ethereum.Proof `protobuf:"bytes,5,opt,name=proof,proto3" json:"proof,omitempty"` - BlockHash string `protobuf:"bytes,6,opt,name=block_hash,json=blockHash,proto3" json:"block_hash,omitempty"` - TxIndex int64 `protobuf:"varint,7,opt,name=tx_index,json=txIndex,proto3" json:"tx_index,omitempty"` + ChainId uint64 `protobuf:"varint,1,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` + TxHash string `protobuf:"bytes,2,opt,name=tx_hash,json=txHash,proto3" json:"tx_hash,omitempty"` + Proof *common.Proof `protobuf:"bytes,3,opt,name=proof,proto3" json:"proof,omitempty"` + BlockHash string `protobuf:"bytes,4,opt,name=block_hash,json=blockHash,proto3" json:"block_hash,omitempty"` + TxIndex int64 `protobuf:"varint,5,opt,name=tx_index,json=txIndex,proto3" json:"tx_index,omitempty"` } func (m *QueryProveRequest) Reset() { *m = QueryProveRequest{} } @@ -88,7 +87,7 @@ func (m *QueryProveRequest) GetTxHash() string { return "" } -func (m *QueryProveRequest) GetProof() *ethereum.Proof { +func (m *QueryProveRequest) GetProof() *common.Proof { if m != nil { return m.Proof } @@ -1452,8 +1451,8 @@ func (m *QueryAllBlockHeaderRequest) GetPagination() *query.PageRequest { } type QueryAllBlockHeaderResponse struct { - BlockHeaders []*BlockHeader `protobuf:"bytes,1,rep,name=block_headers,json=blockHeaders,proto3" json:"block_headers,omitempty"` - Pagination *query.PageResponse `protobuf:"bytes,2,opt,name=pagination,proto3" json:"pagination,omitempty"` + BlockHeaders []*common.BlockHeader `protobuf:"bytes,1,rep,name=block_headers,json=blockHeaders,proto3" json:"block_headers,omitempty"` + Pagination *query.PageResponse `protobuf:"bytes,2,opt,name=pagination,proto3" json:"pagination,omitempty"` } func (m *QueryAllBlockHeaderResponse) Reset() { *m = QueryAllBlockHeaderResponse{} } @@ -1489,7 +1488,7 @@ func (m *QueryAllBlockHeaderResponse) XXX_DiscardUnknown() { var xxx_messageInfo_QueryAllBlockHeaderResponse proto.InternalMessageInfo -func (m *QueryAllBlockHeaderResponse) GetBlockHeaders() []*BlockHeader { +func (m *QueryAllBlockHeaderResponse) GetBlockHeaders() []*common.BlockHeader { if m != nil { return m.BlockHeaders } @@ -1548,7 +1547,7 @@ func (m *QueryGetBlockHeaderByHashRequest) GetBlockHash() []byte { } type QueryGetBlockHeaderByHashResponse struct { - BlockHeader *BlockHeader `protobuf:"bytes,1,opt,name=block_header,json=blockHeader,proto3" json:"block_header,omitempty"` + BlockHeader *common.BlockHeader `protobuf:"bytes,1,opt,name=block_header,json=blockHeader,proto3" json:"block_header,omitempty"` } func (m *QueryGetBlockHeaderByHashResponse) Reset() { *m = QueryGetBlockHeaderByHashResponse{} } @@ -1584,7 +1583,7 @@ func (m *QueryGetBlockHeaderByHashResponse) XXX_DiscardUnknown() { var xxx_messageInfo_QueryGetBlockHeaderByHashResponse proto.InternalMessageInfo -func (m *QueryGetBlockHeaderByHashResponse) GetBlockHeader() *BlockHeader { +func (m *QueryGetBlockHeaderByHashResponse) GetBlockHeader() *common.BlockHeader { if m != nil { return m.BlockHeader } @@ -1632,121 +1631,120 @@ func init() { func init() { proto.RegisterFile("observer/query.proto", fileDescriptor_dcb801e455adaee4) } var fileDescriptor_dcb801e455adaee4 = []byte{ - // 1823 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x59, 0xcd, 0x4f, 0x1b, 0x49, - 0x16, 0xa7, 0x21, 0x18, 0x78, 0x86, 0x00, 0x15, 0x92, 0x80, 0x01, 0xe3, 0xad, 0x2c, 0x89, 0x03, - 0x89, 0x1d, 0x1c, 0x69, 0xf3, 0x41, 0x20, 0xc2, 0x28, 0x21, 0xe4, 0x93, 0x75, 0x76, 0xb3, 0xab, - 0x95, 0x76, 0xad, 0xb6, 0x5d, 0xd8, 0x4e, 0xda, 0x5d, 0x4e, 0x77, 0x43, 0xf0, 0x46, 0x48, 0xab, - 0x3d, 0xef, 0x4a, 0x91, 0x56, 0xda, 0xbf, 0x61, 0x2e, 0x33, 0x87, 0x48, 0xa3, 0x39, 0x44, 0x73, - 0x99, 0xcb, 0xe4, 0x34, 0xca, 0x68, 0xa4, 0xd1, 0xcc, 0x61, 0x46, 0xa3, 0x64, 0xfe, 0x90, 0x51, - 0x57, 0x55, 0xb7, 0xcb, 0xed, 0x6e, 0xbb, 0x8d, 0x72, 0xa2, 0xeb, 0xe3, 0xbd, 0xf7, 0xfb, 0xbd, - 0xaa, 0x7a, 0xf5, 0x2b, 0x0c, 0x53, 0xb4, 0x60, 0x12, 0x63, 0x9f, 0x18, 0xe9, 0xe7, 0x7b, 0xc4, - 0x68, 0xa4, 0xea, 0x06, 0xb5, 0x28, 0x9a, 0xfd, 0x27, 0xb1, 0xd4, 0x62, 0x45, 0xad, 0xea, 0x29, - 0xf6, 0x45, 0x0d, 0x92, 0x72, 0x26, 0xc6, 0x4e, 0x14, 0x69, 0xad, 0x46, 0xf5, 0x34, 0xff, 0xc3, - 0x2d, 0x62, 0x71, 0xd1, 0x49, 0xac, 0x0a, 0x31, 0xc8, 0x5e, 0xcd, 0xfd, 0x10, 0xe3, 0x4b, 0x45, - 0x6a, 0xd6, 0xa8, 0x99, 0x2e, 0xa8, 0x26, 0xe1, 0xa1, 0xd2, 0xfb, 0x2b, 0x05, 0x62, 0xa9, 0x2b, - 0xe9, 0xba, 0x5a, 0xae, 0xea, 0xaa, 0x55, 0x75, 0x7d, 0x4d, 0x95, 0x69, 0x99, 0xb2, 0xcf, 0xb4, - 0xfd, 0x25, 0x7a, 0xe7, 0xca, 0x94, 0x96, 0x35, 0x92, 0x56, 0xeb, 0xd5, 0xb4, 0xaa, 0xeb, 0xd4, - 0x62, 0x26, 0xa6, 0x18, 0x3d, 0xe9, 0xf2, 0x28, 0xa8, 0x9a, 0x46, 0x2d, 0xc7, 0x55, 0xb3, 0x5b, - 0x53, 0x6b, 0x44, 0xf4, 0x9e, 0x72, 0x7b, 0x2b, 0x44, 0x2d, 0x11, 0xa3, 0xdd, 0xc9, 0x33, 0xd2, - 0x28, 0x13, 0x07, 0xcf, 0xac, 0xdb, 0xad, 0xd3, 0x12, 0xc9, 0xab, 0xc5, 0x22, 0xdd, 0xd3, 0x9d, - 0x08, 0xa7, 0xdd, 0x41, 0xe7, 0xa3, 0xcd, 0x59, 0x5d, 0x35, 0xd4, 0x9a, 0x13, 0x63, 0xa1, 0xd9, - 0x4d, 0x8c, 0x5a, 0xd5, 0x34, 0xab, 0x54, 0xcf, 0xef, 0x6a, 0x6a, 0x59, 0x4c, 0xc0, 0x9f, 0x28, - 0x30, 0xf9, 0x47, 0x3b, 0x41, 0x3b, 0x06, 0xdd, 0x27, 0x39, 0xf2, 0x7c, 0x8f, 0x98, 0x16, 0x9a, - 0x81, 0x61, 0xb6, 0x1e, 0xf9, 0x6a, 0x69, 0x5a, 0x49, 0x28, 0xc9, 0x63, 0xb9, 0x21, 0xd6, 0xde, - 0x2e, 0xa1, 0xd3, 0x30, 0x64, 0x1d, 0xe4, 0x2b, 0xaa, 0x59, 0x99, 0xee, 0x4f, 0x28, 0xc9, 0x91, - 0x5c, 0xc4, 0x3a, 0xb8, 0xa3, 0x9a, 0x15, 0xb4, 0x08, 0x83, 0x75, 0x83, 0xd2, 0xdd, 0xe9, 0xc1, - 0x84, 0x92, 0x8c, 0x66, 0xc6, 0x53, 0xee, 0x9a, 0xec, 0xd8, 0xdd, 0x39, 0x3e, 0x8a, 0xe6, 0x01, - 0x0a, 0x1a, 0x2d, 0x3e, 0xe3, 0x2e, 0x22, 0xcc, 0xc5, 0x08, 0xeb, 0x61, 0x5e, 0x66, 0x60, 0xd8, - 0x3a, 0xc8, 0x57, 0xf5, 0x12, 0x39, 0x98, 0x1e, 0x4a, 0x28, 0xc9, 0x81, 0xdc, 0x90, 0x75, 0xb0, - 0x6d, 0x37, 0xf1, 0x12, 0x20, 0x19, 0xa9, 0x59, 0xa7, 0xba, 0x49, 0xd0, 0x14, 0x0c, 0xee, 0xab, - 0x9a, 0xc0, 0x39, 0x9c, 0xe3, 0x0d, 0x3c, 0xe5, 0xcc, 0x65, 0xc9, 0x10, 0xb4, 0xf0, 0x5f, 0xe1, - 0x44, 0x4b, 0xaf, 0x70, 0xb1, 0x01, 0x11, 0x9e, 0x34, 0xe6, 0x23, 0x9a, 0x39, 0x93, 0xea, 0xb0, - 0x21, 0x53, 0xdc, 0x38, 0x7b, 0xec, 0xed, 0xcf, 0x0b, 0x7d, 0x39, 0x61, 0x88, 0x1f, 0x40, 0x9c, - 0x79, 0xce, 0xb2, 0xed, 0x90, 0x6d, 0x6c, 0x97, 0x88, 0x6e, 0x55, 0x77, 0xab, 0xc4, 0x70, 0x52, - 0xba, 0x0c, 0x93, 0x7c, 0xaf, 0xe4, 0xab, 0xee, 0x18, 0x8b, 0x37, 0x92, 0x9b, 0xe0, 0x03, 0x4d, - 0x1b, 0x6c, 0xc1, 0xc8, 0x13, 0x6a, 0x11, 0xe3, 0x7e, 0xd5, 0xb4, 0xd0, 0x19, 0x18, 0xdb, 0xb7, - 0x1b, 0x79, 0xb5, 0x54, 0x32, 0x88, 0x69, 0x0a, 0xab, 0x51, 0xd6, 0xb9, 0xc1, 0xfb, 0x50, 0x16, - 0x46, 0xec, 0x76, 0xde, 0x6a, 0xd4, 0x09, 0x5b, 0x98, 0xe3, 0x99, 0xc5, 0x8e, 0x34, 0x6c, 0xff, - 0x7f, 0x6a, 0xd4, 0x49, 0x6e, 0x78, 0x5f, 0x7c, 0xe1, 0x2f, 0xfa, 0x61, 0x21, 0x90, 0x85, 0xc8, - 0x55, 0x2f, 0x34, 0xd0, 0x3a, 0x44, 0x18, 0x48, 0x73, 0xba, 0x3f, 0x31, 0x90, 0x8c, 0x66, 0xce, - 0x76, 0x45, 0xc4, 0x18, 0xe7, 0x84, 0x15, 0xfa, 0x0b, 0x4c, 0xf0, 0x51, 0x76, 0xf8, 0x38, 0xb7, - 0x01, 0xc6, 0xed, 0x42, 0x47, 0x4f, 0x8f, 0x9a, 0x46, 0x8c, 0xe2, 0x38, 0x6d, 0xed, 0x40, 0x0f, - 0x61, 0x4c, 0xb0, 0x30, 0x2d, 0xd5, 0xda, 0x33, 0xa7, 0x8f, 0x31, 0xaf, 0xe7, 0x3b, 0x7a, 0xe5, - 0x59, 0x79, 0xcc, 0x0c, 0x72, 0xa3, 0x05, 0xa9, 0x85, 0xef, 0xc1, 0x1c, 0x4b, 0xdc, 0x23, 0x31, - 0xd7, 0xcc, 0x36, 0x36, 0x6d, 0x2f, 0xd2, 0xe2, 0xcb, 0x44, 0x58, 0x04, 0x27, 0x6b, 0xd2, 0x00, - 0xb3, 0xc1, 0x6b, 0x30, 0x1f, 0xe0, 0x4c, 0xac, 0xc1, 0x1c, 0x8c, 0x38, 0xa0, 0xec, 0xcd, 0x30, - 0x60, 0x9f, 0x20, 0xb7, 0x03, 0x27, 0xc4, 0x56, 0xdc, 0xd0, 0x34, 0xc7, 0xc3, 0x03, 0xb5, 0x5e, - 0x27, 0x86, 0x7b, 0x0c, 0x1a, 0x62, 0x99, 0xfd, 0x66, 0x88, 0x10, 0x4f, 0x9c, 0xcc, 0x13, 0x23, - 0x5f, 0xe3, 0x63, 0x2c, 0x52, 0x34, 0xb3, 0x1c, 0x22, 0xf3, 0x8e, 0x3f, 0x27, 0xf1, 0xae, 0x7f, - 0x7c, 0x0a, 0xa6, 0x58, 0xe8, 0xc7, 0x7b, 0xf5, 0x3a, 0x35, 0x2c, 0x52, 0x62, 0xcc, 0x4c, 0x7c, - 0x4b, 0x24, 0xd0, 0xd3, 0xef, 0xe2, 0x59, 0x84, 0x08, 0x0b, 0xe9, 0xa0, 0x18, 0x4b, 0x89, 0xfb, - 0x80, 0x67, 0x46, 0x0c, 0xe2, 0x75, 0xf8, 0x1d, 0x73, 0xb3, 0x45, 0xac, 0x4d, 0x6a, 0x10, 0x7e, - 0x54, 0x6f, 0x53, 0xa3, 0x65, 0x31, 0xbc, 0xc5, 0x6d, 0xc0, 0x2d, 0x6e, 0x58, 0x07, 0xdc, 0xc9, - 0x5e, 0x80, 0xb9, 0x03, 0x51, 0x9b, 0x75, 0xbe, 0xa5, 0x68, 0x9c, 0xeb, 0x98, 0x97, 0xa6, 0xb7, - 0x1c, 0x14, 0xdd, 0x6f, 0x3c, 0x0b, 0x33, 0xed, 0xf1, 0x9c, 0x65, 0x7a, 0x0a, 0x31, 0xbf, 0x41, - 0x01, 0xe2, 0xbe, 0x1f, 0x88, 0xe5, 0x90, 0x20, 0xd8, 0x29, 0x93, 0x81, 0x64, 0x9a, 0xb1, 0x1e, - 0xd2, 0x12, 0xd9, 0xe0, 0x97, 0x8e, 0x93, 0xb1, 0x29, 0x18, 0xe4, 0x15, 0x99, 0x6f, 0x59, 0xde, - 0xc0, 0x4f, 0x61, 0xd6, 0xd7, 0x46, 0x00, 0xbc, 0x07, 0xa3, 0xf2, 0x05, 0x26, 0x10, 0x26, 0x3b, - 0x22, 0x94, 0xfd, 0x44, 0xf5, 0x66, 0x03, 0x97, 0x04, 0xbe, 0x0d, 0x4d, 0xf3, 0xc1, 0x77, 0x1b, - 0xa0, 0x79, 0xad, 0x8b, 0x40, 0x67, 0x53, 0x5c, 0x03, 0xa4, 0x6c, 0x0d, 0x90, 0xe2, 0x72, 0x43, - 0x68, 0x80, 0xd4, 0x8e, 0x5a, 0x76, 0xae, 0xba, 0x9c, 0x64, 0x89, 0x5f, 0x2b, 0x82, 0x92, 0x37, - 0x8c, 0xa0, 0x74, 0x17, 0xa2, 0x52, 0xb7, 0xd8, 0x8a, 0x3d, 0x30, 0x92, 0x1a, 0x68, 0xab, 0x05, - 0x73, 0xbf, 0xd8, 0x43, 0xdd, 0x30, 0x73, 0x20, 0x2d, 0xa0, 0x9d, 0xf3, 0xbe, 0x45, 0xac, 0x1d, - 0xf7, 0x8e, 0xbf, 0x6d, 0x5f, 0xf1, 0xce, 0x46, 0xfa, 0x97, 0x22, 0x0e, 0xbc, 0xdf, 0x14, 0x41, - 0xed, 0xef, 0x30, 0xe1, 0x55, 0x08, 0x22, 0x91, 0x9d, 0x4b, 0xad, 0xc7, 0x9f, 0xb8, 0x16, 0xc7, - 0xeb, 0xad, 0xdd, 0xf8, 0x34, 0x9c, 0x74, 0x10, 0xdc, 0x63, 0x62, 0xc7, 0xc1, 0xf6, 0x67, 0x38, - 0xe5, 0x1d, 0x10, 0x88, 0x56, 0x21, 0xc2, 0x75, 0x51, 0xa8, 0x5b, 0x59, 0x18, 0x0b, 0x13, 0xbc, - 0x20, 0x6a, 0xe8, 0xe3, 0x0a, 0x7d, 0xe1, 0xd4, 0xa4, 0x4d, 0x69, 0xcb, 0xd8, 0x39, 0x89, 0x07, - 0xcd, 0x10, 0x00, 0xfe, 0x01, 0x27, 0x34, 0xd5, 0xb4, 0xf2, 0x6e, 0x21, 0x94, 0xf7, 0x71, 0xaa, - 0x23, 0x9a, 0xfb, 0xaa, 0x69, 0xb5, 0x3a, 0x9d, 0xd4, 0xbc, 0x5d, 0xf8, 0xae, 0xc0, 0x98, 0xb5, - 0xb5, 0xa2, 0x9f, 0x64, 0x38, 0x0f, 0x13, 0x4c, 0x47, 0xb6, 0x5f, 0xb5, 0xe3, 0xac, 0x5f, 0x12, - 0x0c, 0x45, 0x47, 0x7f, 0xb4, 0xfb, 0x72, 0x45, 0x0e, 0x08, 0x67, 0xfa, 0x2e, 0x15, 0x24, 0x70, - 0xe7, 0xfb, 0xce, 0x9e, 0x6e, 0x6b, 0x33, 0x3b, 0x94, 0xbe, 0x4b, 0xf1, 0x7c, 0xf3, 0x74, 0xf0, - 0x31, 0x52, 0xa4, 0x46, 0xc9, 0xdd, 0x66, 0xaa, 0xa8, 0xe1, 0x6d, 0xc3, 0x01, 0x08, 0x06, 0x7a, - 0x47, 0x20, 0x95, 0x81, 0x2c, 0x93, 0x8c, 0x4c, 0x50, 0x7f, 0xec, 0x32, 0xf0, 0xb9, 0x22, 0x13, - 0x95, 0xc2, 0x08, 0x22, 0x0f, 0x60, 0x4c, 0x48, 0x58, 0xae, 0xe7, 0x43, 0x15, 0x02, 0xd9, 0xd1, - 0x68, 0xa1, 0xd9, 0x30, 0x3f, 0x5e, 0x25, 0xd8, 0x80, 0x84, 0x73, 0x96, 0xa4, 0x68, 0xd9, 0x86, - 0x2d, 0xac, 0x9d, 0x1c, 0xb5, 0xca, 0x6f, 0x3b, 0x47, 0xa3, 0x92, 0xfc, 0xc6, 0xf5, 0xe6, 0x05, - 0xea, 0xe3, 0xa2, 0x59, 0xd9, 0x65, 0xfe, 0xa1, 0x2a, 0xbb, 0x4c, 0x3f, 0x2a, 0xd1, 0xcf, 0xfc, - 0x77, 0x06, 0x06, 0x59, 0x48, 0xf4, 0x4a, 0x81, 0x08, 0xbf, 0x8e, 0x50, 0xba, 0xa3, 0xaf, 0x76, - 0x65, 0x1f, 0xbb, 0x14, 0xde, 0x80, 0x93, 0xc0, 0x67, 0xfe, 0xfd, 0xdd, 0xaf, 0xff, 0xeb, 0x9f, - 0x47, 0xb3, 0x69, 0x7b, 0xfe, 0x45, 0x66, 0x9a, 0xf6, 0x3c, 0xa2, 0xd0, 0xf7, 0x0a, 0xa0, 0x76, - 0x31, 0x8c, 0x56, 0xbb, 0x47, 0x0b, 0x7c, 0x08, 0xc4, 0x6e, 0x1c, 0xcd, 0x58, 0xc0, 0xbe, 0xc5, - 0x60, 0xdf, 0x44, 0x6b, 0xbe, 0xb0, 0x85, 0xa8, 0x2d, 0x34, 0xa4, 0x92, 0x91, 0x7e, 0xd9, 0x26, - 0xd8, 0x0f, 0xd1, 0x37, 0x0a, 0x4c, 0x78, 0xf5, 0x25, 0xba, 0xd6, 0x1d, 0x59, 0x80, 0xc0, 0x8d, - 0x5d, 0x3f, 0x8a, 0xa9, 0xa0, 0xb4, 0xc9, 0x28, 0xad, 0xa1, 0x55, 0x5f, 0x4a, 0xae, 0xb0, 0xb5, - 0x59, 0xf1, 0xb1, 0x97, 0x6d, 0x5a, 0xfa, 0x10, 0x7d, 0xa5, 0x00, 0x6a, 0xd7, 0xb3, 0x61, 0x56, - 0x2a, 0x50, 0x27, 0x87, 0x59, 0xa9, 0x60, 0x09, 0x8d, 0x57, 0x18, 0xad, 0x65, 0x74, 0xde, 0x97, - 0x96, 0xaa, 0x69, 0x79, 0xaf, 0xc2, 0x46, 0x9f, 0x2a, 0x30, 0xee, 0x51, 0xc0, 0x68, 0xa5, 0x3b, - 0x08, 0x8f, 0x49, 0xec, 0x5a, 0xcf, 0x26, 0x2e, 0xe8, 0x0b, 0x0c, 0xf4, 0x59, 0xf4, 0x7b, 0x5f, - 0xd0, 0xa6, 0x07, 0xdb, 0x4f, 0x0a, 0x9c, 0xf4, 0x95, 0xca, 0x68, 0xbd, 0x3b, 0x84, 0x4e, 0x1a, - 0x3d, 0x76, 0xf3, 0xc8, 0xf6, 0xa1, 0x36, 0x55, 0x99, 0x58, 0xf9, 0xa2, 0x56, 0x25, 0xba, 0x25, - 0xf4, 0x73, 0x7e, 0x97, 0x1a, 0xce, 0xee, 0x72, 0x1e, 0x07, 0x87, 0xe8, 0x33, 0x05, 0xc6, 0x5a, - 0xc2, 0xa0, 0x3f, 0xf4, 0x88, 0xcb, 0xe1, 0x73, 0xa5, 0x67, 0xbb, 0x50, 0x0b, 0xc2, 0x78, 0x34, - 0x5f, 0x01, 0xe8, 0xb5, 0xd2, 0xa2, 0x50, 0x51, 0xb8, 0xb0, 0xed, 0x8a, 0x3a, 0x76, 0xb5, 0x77, - 0x43, 0x01, 0xf8, 0x12, 0x03, 0xbc, 0x84, 0x92, 0xbe, 0x80, 0x25, 0x4d, 0x9f, 0x7e, 0xc9, 0x9e, - 0x11, 0x87, 0xf6, 0xae, 0x3f, 0x2e, 0x79, 0xda, 0xd0, 0xb4, 0x30, 0xb8, 0x7d, 0x5f, 0x02, 0x61, - 0x70, 0xfb, 0x6b, 0x7b, 0x9c, 0x64, 0xb8, 0x31, 0x4a, 0x74, 0xc3, 0x8d, 0xde, 0x28, 0x30, 0xee, - 0x91, 0xbd, 0x61, 0xea, 0x4c, 0xa0, 0x3e, 0x0f, 0x53, 0x67, 0x82, 0x95, 0x3b, 0xbe, 0xc8, 0x80, - 0x9f, 0x43, 0x8b, 0xfe, 0x17, 0x99, 0x47, 0xd4, 0xa3, 0xff, 0x2b, 0x10, 0xe1, 0x62, 0x19, 0x65, - 0x42, 0xc5, 0x6d, 0xd1, 0xeb, 0xb1, 0xcb, 0x3d, 0xd9, 0x84, 0xba, 0x6b, 0xb9, 0x64, 0x47, 0x5f, - 0x2b, 0x30, 0xd9, 0x26, 0xc6, 0x51, 0x88, 0x8b, 0x25, 0x48, 0xe3, 0xc7, 0x56, 0x8f, 0x64, 0x2b, - 0x30, 0x5f, 0x63, 0x98, 0x2f, 0xa3, 0x15, 0x19, 0xb3, 0xe3, 0x45, 0x2a, 0x89, 0x15, 0xfa, 0xc2, - 0xf3, 0x42, 0x40, 0xdf, 0x2a, 0x30, 0xd9, 0x26, 0xc4, 0xc3, 0x30, 0x09, 0x7a, 0x09, 0x84, 0x61, - 0x12, 0xa8, 0xfc, 0xbb, 0x94, 0x42, 0x2e, 0xc9, 0xbd, 0x8a, 0xc1, 0xf3, 0xec, 0x38, 0x44, 0x5f, - 0x2a, 0x80, 0xb6, 0x88, 0xe5, 0xd1, 0xf6, 0x28, 0xdc, 0x79, 0xf3, 0x79, 0x2d, 0x84, 0xb9, 0xa4, - 0x02, 0x1e, 0x12, 0x38, 0xc3, 0x08, 0x5d, 0x40, 0x4b, 0x81, 0x35, 0xd1, 0xbe, 0x5d, 0x39, 0x07, - 0x43, 0x00, 0x7d, 0x23, 0xe1, 0x97, 0xb4, 0xf7, 0x95, 0x90, 0x28, 0xbc, 0x6f, 0x8d, 0xd8, 0xd5, - 0xde, 0x0d, 0x7b, 0x44, 0x2f, 0x3d, 0x30, 0xd0, 0x8f, 0x0a, 0x4c, 0xf9, 0x49, 0x72, 0xb4, 0x16, - 0xea, 0x38, 0x06, 0xbd, 0x06, 0x62, 0xeb, 0x47, 0x35, 0x17, 0x5c, 0xb2, 0x8c, 0xcb, 0x0d, 0x74, - 0x3d, 0x90, 0x8b, 0xcc, 0xc3, 0xde, 0x65, 0xf6, 0xb3, 0xc3, 0xde, 0x5f, 0xce, 0x13, 0xe4, 0x10, - 0xfd, 0x47, 0x81, 0x41, 0xf6, 0x2f, 0x7d, 0x94, 0x0a, 0x21, 0xe2, 0xa5, 0x5f, 0x29, 0x62, 0xe9, - 0xd0, 0xf3, 0x05, 0x5c, 0xcc, 0xe0, 0xce, 0xa1, 0x98, 0x7f, 0xa9, 0xb4, 0xe7, 0x66, 0xb7, 0xdf, - 0xbe, 0x8f, 0x2b, 0xef, 0xde, 0xc7, 0x95, 0x5f, 0xde, 0xc7, 0x95, 0x57, 0x1f, 0xe2, 0x7d, 0xef, - 0x3e, 0xc4, 0xfb, 0x7e, 0xf8, 0x10, 0xef, 0xfb, 0x5b, 0xba, 0x5c, 0xb5, 0x2a, 0x7b, 0x85, 0x54, - 0x91, 0xd6, 0x7c, 0x6b, 0xc2, 0x41, 0xd3, 0x95, 0xd5, 0xa8, 0x13, 0xb3, 0x10, 0x61, 0x3f, 0xb1, - 0x5c, 0xfe, 0x2d, 0x00, 0x00, 0xff, 0xff, 0xc6, 0x48, 0x99, 0x25, 0xf6, 0x1a, 0x00, 0x00, + // 1800 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x59, 0xcd, 0x4f, 0x1b, 0xcf, + 0x19, 0x66, 0x21, 0x38, 0xf0, 0x1a, 0x02, 0x0c, 0xe4, 0x17, 0x30, 0x60, 0xdc, 0xa1, 0x49, 0x1c, + 0x48, 0xec, 0xe0, 0x48, 0xf9, 0x22, 0x10, 0x61, 0x94, 0x10, 0xf2, 0x49, 0x9d, 0x36, 0xad, 0x5a, + 0xb5, 0xd6, 0xda, 0x1e, 0x8c, 0x93, 0x65, 0xc7, 0xd9, 0x5d, 0x08, 0x6e, 0x84, 0x54, 0xf5, 0xdc, + 0x4a, 0x91, 0x2a, 0xf5, 0xdc, 0x53, 0x6f, 0xed, 0x21, 0x97, 0x1e, 0xa2, 0x5e, 0x7a, 0x69, 0x4e, + 0x55, 0xaa, 0x4a, 0x55, 0x7b, 0x68, 0x55, 0x25, 0xfd, 0x43, 0x7e, 0xda, 0xf9, 0x58, 0x8f, 0xd7, + 0xbb, 0xf6, 0x1a, 0xe5, 0xc4, 0xce, 0xc7, 0xfb, 0xce, 0xf3, 0xbc, 0x33, 0xf3, 0xbe, 0xcf, 0x60, + 0x98, 0xa2, 0x25, 0x9b, 0x58, 0x87, 0xc4, 0xca, 0xbe, 0x3e, 0x20, 0x56, 0x23, 0x53, 0xb7, 0xa8, + 0x43, 0xd1, 0xec, 0xcf, 0x89, 0xa3, 0x97, 0xf7, 0xf4, 0x9a, 0x99, 0x61, 0x5f, 0xd4, 0x22, 0x19, + 0x39, 0x31, 0x31, 0x59, 0xa6, 0xfb, 0xfb, 0xd4, 0xcc, 0xf2, 0x3f, 0xdc, 0x22, 0xb1, 0x54, 0xa6, + 0xf6, 0x3e, 0xb5, 0xb3, 0x25, 0xdd, 0x26, 0xdc, 0x55, 0xf6, 0x70, 0xa5, 0x44, 0x1c, 0x7d, 0x25, + 0x5b, 0xd7, 0xab, 0x35, 0x53, 0x77, 0x6a, 0xde, 0xdc, 0xa9, 0x2a, 0xad, 0x52, 0xf6, 0x99, 0x75, + 0xbf, 0x44, 0xef, 0x5c, 0x95, 0xd2, 0xaa, 0x41, 0xb2, 0x7a, 0xbd, 0x96, 0xd5, 0x4d, 0x93, 0x3a, + 0xcc, 0xc4, 0x16, 0xa3, 0x67, 0x3d, 0x9c, 0x25, 0xdd, 0x30, 0xa8, 0x23, 0x5d, 0x35, 0xbb, 0x0d, + 0x7d, 0x9f, 0xb4, 0x4d, 0x7e, 0x45, 0x1a, 0x55, 0x22, 0xd7, 0x9d, 0xf5, 0xba, 0x4d, 0x5a, 0x21, + 0x45, 0xbd, 0x5c, 0xa6, 0x07, 0xa6, 0xf4, 0x74, 0xce, 0x1b, 0x94, 0x1f, 0x6d, 0xce, 0xea, 0xba, + 0xa5, 0xef, 0x4b, 0x40, 0x0b, 0xcd, 0x6e, 0x62, 0xed, 0xd7, 0x6c, 0xbb, 0x46, 0xcd, 0xe2, 0xae, + 0xa1, 0x57, 0xc5, 0x04, 0xfc, 0x7b, 0x0d, 0x26, 0xbe, 0xe7, 0x06, 0x62, 0xc7, 0xa2, 0x87, 0xa4, + 0x40, 0x5e, 0x1f, 0x10, 0xdb, 0x41, 0x33, 0x30, 0xc4, 0xe2, 0x5a, 0xac, 0x55, 0xa6, 0xb5, 0x94, + 0x96, 0x3e, 0x55, 0x38, 0xcd, 0xda, 0xdb, 0x15, 0x74, 0x0e, 0x4e, 0x3b, 0x47, 0xc5, 0x3d, 0xdd, + 0xde, 0x9b, 0xee, 0x4f, 0x69, 0xe9, 0xe1, 0x42, 0xcc, 0x39, 0x7a, 0xa0, 0xdb, 0x7b, 0x68, 0x11, + 0x06, 0xeb, 0x16, 0xa5, 0xbb, 0xd3, 0x03, 0x29, 0x2d, 0x1d, 0xcf, 0x8d, 0x66, 0x44, 0xe4, 0x77, + 0xdc, 0xce, 0x02, 0x1f, 0x43, 0xf3, 0x00, 0x25, 0x83, 0x96, 0x5f, 0x71, 0x07, 0xa7, 0x98, 0x83, + 0x61, 0xd6, 0xc3, 0x7c, 0xcc, 0xc0, 0x90, 0x73, 0x54, 0xac, 0x99, 0x15, 0x72, 0x34, 0x3d, 0x98, + 0xd2, 0xd2, 0x03, 0x85, 0xd3, 0xce, 0xd1, 0xb6, 0xdb, 0xc4, 0x4b, 0x80, 0x54, 0x9c, 0x76, 0x9d, + 0x9a, 0x36, 0x41, 0x53, 0x30, 0x78, 0xa8, 0x1b, 0x02, 0xe5, 0x50, 0x81, 0x37, 0xf0, 0x94, 0x9c, + 0xcb, 0x42, 0x21, 0x48, 0xe1, 0x1f, 0xc1, 0x64, 0x4b, 0xaf, 0x70, 0xb1, 0x01, 0x31, 0x1e, 0x32, + 0xe6, 0x23, 0x9e, 0x5b, 0xcc, 0x74, 0x38, 0x56, 0x19, 0x6e, 0x9c, 0x3f, 0xf5, 0xf1, 0xbf, 0x0b, + 0x7d, 0x05, 0x61, 0x88, 0x9f, 0x40, 0x92, 0x79, 0xce, 0xb3, 0x4d, 0xcf, 0x37, 0xb6, 0x2b, 0xc4, + 0x74, 0x6a, 0xbb, 0x35, 0x62, 0xc9, 0x80, 0x2e, 0xc3, 0x04, 0x3f, 0x11, 0xc5, 0x9a, 0x37, 0xc6, + 0xd6, 0x1b, 0x2e, 0x8c, 0xf3, 0x81, 0xa6, 0x0d, 0x76, 0x60, 0xf8, 0x05, 0x75, 0x88, 0xf5, 0xb8, + 0x66, 0x3b, 0x68, 0x11, 0x46, 0x0f, 0xdd, 0x46, 0x51, 0xaf, 0x54, 0x2c, 0x62, 0xdb, 0xc2, 0x6a, + 0x84, 0x75, 0x6e, 0xf0, 0x3e, 0x94, 0x87, 0x61, 0xb7, 0x5d, 0x74, 0x1a, 0x75, 0xc2, 0xb6, 0xe5, + 0x4c, 0xee, 0x7c, 0x47, 0x1a, 0xae, 0xff, 0xef, 0x37, 0xea, 0xa4, 0x30, 0x74, 0x28, 0xbe, 0xf0, + 0x9f, 0xfa, 0x61, 0x21, 0x94, 0x85, 0x88, 0x55, 0x2f, 0x34, 0xd0, 0x3a, 0xc4, 0x18, 0x48, 0x7b, + 0xba, 0x3f, 0x35, 0x90, 0x8e, 0xe7, 0x2e, 0x74, 0x45, 0xc4, 0x18, 0x17, 0x84, 0x15, 0xfa, 0x21, + 0x8c, 0xf3, 0x51, 0x76, 0xc5, 0x38, 0xb7, 0x01, 0xc6, 0xed, 0x72, 0x47, 0x4f, 0xcf, 0x9a, 0x46, + 0x8c, 0xe2, 0x18, 0x6d, 0xed, 0x40, 0x4f, 0x61, 0x54, 0xb0, 0xb0, 0x1d, 0xdd, 0x39, 0xb0, 0xd9, + 0x39, 0x3c, 0x93, 0xbb, 0xd4, 0xd1, 0x2b, 0x8f, 0xca, 0x73, 0x66, 0x50, 0x18, 0x29, 0x29, 0x2d, + 0xfc, 0x08, 0xe6, 0x58, 0xe0, 0x9e, 0x89, 0xb9, 0x76, 0xbe, 0xb1, 0xe9, 0x7a, 0x51, 0x36, 0x5f, + 0x25, 0xc2, 0x56, 0x90, 0x51, 0x53, 0x06, 0x98, 0x0d, 0x5e, 0x83, 0xf9, 0x10, 0x67, 0x62, 0x0f, + 0xe6, 0x60, 0x58, 0x82, 0x72, 0x0f, 0xc3, 0x80, 0x7b, 0x83, 0xbc, 0x0e, 0x9c, 0x12, 0x47, 0x71, + 0xc3, 0x30, 0xa4, 0x87, 0x27, 0x7a, 0xbd, 0x4e, 0x2c, 0xef, 0x1a, 0x34, 0xc4, 0x36, 0x07, 0xcd, + 0x10, 0x4b, 0xbc, 0x90, 0x91, 0x27, 0x56, 0x71, 0x9f, 0x8f, 0xb1, 0x95, 0xe2, 0xb9, 0xe5, 0x08, + 0x91, 0x97, 0xfe, 0x64, 0xe0, 0x3d, 0xff, 0xf8, 0x1b, 0x98, 0x62, 0x4b, 0x3f, 0x3f, 0xa8, 0xd7, + 0xa9, 0xe5, 0x90, 0x0a, 0x63, 0x66, 0xe3, 0x7b, 0x22, 0x80, 0xbe, 0x7e, 0x0f, 0xcf, 0x79, 0x88, + 0xb1, 0x25, 0x25, 0x0a, 0x2f, 0xb7, 0xf0, 0xc8, 0x88, 0x41, 0xbc, 0x0e, 0xdf, 0x61, 0x6e, 0xb6, + 0x88, 0xb3, 0x49, 0x2d, 0xc2, 0xaf, 0xea, 0x7d, 0x6a, 0xb5, 0x6c, 0x86, 0x3f, 0xb5, 0x0d, 0x78, + 0xa9, 0x0d, 0x9b, 0x80, 0x3b, 0xd9, 0x0b, 0x30, 0x0f, 0x20, 0xee, 0xb2, 0x2e, 0xb6, 0x24, 0x8d, + 0x8b, 0x1d, 0xe3, 0xd2, 0xf4, 0x56, 0x80, 0xb2, 0xf7, 0x8d, 0x67, 0x61, 0xa6, 0x7d, 0x3d, 0xb9, + 0x4d, 0x2f, 0x21, 0x11, 0x34, 0x28, 0x40, 0x3c, 0x0e, 0x02, 0xb1, 0x1c, 0x11, 0x04, 0xbb, 0x65, + 0x2a, 0x90, 0x5c, 0x73, 0xad, 0xa7, 0xb4, 0x42, 0x36, 0x78, 0xc9, 0x91, 0x11, 0x9b, 0x82, 0x41, + 0x9e, 0x91, 0xf9, 0x91, 0xe5, 0x0d, 0xfc, 0x12, 0x66, 0x03, 0x6d, 0x04, 0xc0, 0x47, 0x30, 0xa2, + 0x96, 0x2f, 0x81, 0x30, 0xdd, 0x11, 0xa1, 0xea, 0x27, 0x6e, 0x36, 0x1b, 0xb8, 0x22, 0xf0, 0x6d, + 0x18, 0x46, 0x00, 0xbe, 0xfb, 0x00, 0xcd, 0xe2, 0x2d, 0x16, 0xba, 0x90, 0xe1, 0x95, 0x3e, 0xe3, + 0x56, 0xfa, 0x0c, 0x17, 0x0d, 0xa2, 0xd2, 0x67, 0x76, 0xf4, 0xaa, 0x2c, 0x74, 0x05, 0xc5, 0x12, + 0xbf, 0xd7, 0x04, 0x25, 0xff, 0x32, 0x82, 0xd2, 0x43, 0x88, 0x2b, 0xdd, 0xe2, 0x28, 0xf6, 0xc0, + 0x48, 0x69, 0xa0, 0xad, 0x16, 0xcc, 0xfd, 0xe2, 0x0c, 0x75, 0xc3, 0xcc, 0x81, 0xb4, 0x80, 0x96, + 0xf7, 0x7d, 0x8b, 0x38, 0x3b, 0x5e, 0x85, 0xbf, 0xef, 0x16, 0x78, 0x79, 0x90, 0x7e, 0xa1, 0x89, + 0x0b, 0x1f, 0x34, 0x45, 0x50, 0xfb, 0x29, 0x8c, 0xfb, 0xf5, 0x81, 0x08, 0x64, 0xe7, 0x54, 0xeb, + 0xf3, 0x27, 0xca, 0xe2, 0x58, 0xbd, 0xb5, 0x1b, 0x9f, 0x83, 0xb3, 0x12, 0xc1, 0x23, 0x26, 0x75, + 0x24, 0xb6, 0x1f, 0xc0, 0x37, 0xfe, 0x01, 0x81, 0x68, 0x15, 0x62, 0x5c, 0x15, 0x45, 0xaa, 0xca, + 0xc2, 0x58, 0x98, 0xe0, 0x05, 0x91, 0x43, 0x9f, 0xef, 0xd1, 0x37, 0x32, 0x27, 0x6d, 0x2a, 0x47, + 0xc6, 0x8d, 0x49, 0x32, 0x6c, 0x86, 0x00, 0xf0, 0x33, 0x98, 0x34, 0x74, 0xdb, 0x29, 0x7a, 0x89, + 0x50, 0x3d, 0xc7, 0x99, 0x8e, 0x68, 0x1e, 0xeb, 0xb6, 0xd3, 0xea, 0x74, 0xc2, 0xf0, 0x77, 0xe1, + 0x87, 0x02, 0x63, 0xde, 0x55, 0x84, 0x41, 0x92, 0xe1, 0x12, 0x8c, 0x33, 0xb5, 0xd8, 0x5e, 0x6a, + 0xc7, 0x58, 0xbf, 0x22, 0x18, 0xca, 0x52, 0x7f, 0xb4, 0xfb, 0xf2, 0x44, 0x0e, 0x08, 0x67, 0xe6, + 0x2e, 0x15, 0x24, 0x70, 0xe7, 0x7a, 0xe7, 0x4e, 0x77, 0xb5, 0x99, 0xbb, 0x94, 0xb9, 0x4b, 0xf1, + 0x7c, 0xf3, 0x76, 0xf0, 0x31, 0x52, 0xa6, 0x56, 0xc5, 0x3b, 0x66, 0xba, 0xc8, 0xe1, 0x6d, 0xc3, + 0x21, 0x08, 0x06, 0x7a, 0x47, 0xa0, 0xa4, 0x81, 0x3c, 0x93, 0x8c, 0x44, 0xaf, 0x34, 0xe3, 0xf5, + 0xb5, 0xd2, 0xc0, 0xef, 0x34, 0x95, 0xa8, 0xb2, 0x8c, 0x20, 0x72, 0x13, 0x46, 0x85, 0x84, 0x65, + 0xfd, 0xb2, 0x26, 0x4d, 0xca, 0x9a, 0xa4, 0xda, 0x8c, 0x94, 0x9a, 0x0d, 0xfb, 0xeb, 0x5d, 0xfa, + 0x0d, 0x48, 0xc9, 0x6b, 0xa3, 0xac, 0x96, 0x6f, 0xb8, 0x1a, 0x5a, 0x86, 0xa3, 0x55, 0x69, 0xbb, + 0xe1, 0x18, 0x51, 0x94, 0x36, 0xfe, 0x49, 0xb3, 0x56, 0x06, 0xb8, 0x10, 0x54, 0xaf, 0xc3, 0x88, + 0x4a, 0x55, 0x04, 0x35, 0x90, 0x69, 0x5c, 0x61, 0x9a, 0xfb, 0xf5, 0x0c, 0x0c, 0x32, 0xef, 0xe8, + 0x9d, 0x06, 0x31, 0x5e, 0x64, 0x50, 0xb6, 0xe3, 0x66, 0xb7, 0xeb, 0xf5, 0xc4, 0xd5, 0xe8, 0x06, + 0x1c, 0x2f, 0x5e, 0xfc, 0xe5, 0x3f, 0xfe, 0xff, 0x9b, 0xfe, 0x79, 0x34, 0x9b, 0x75, 0xe7, 0x5f, + 0x61, 0xa6, 0x59, 0xdf, 0xc3, 0x08, 0xfd, 0x53, 0x03, 0xd4, 0x2e, 0x71, 0xd1, 0x6a, 0xf7, 0xd5, + 0x42, 0xe5, 0x7d, 0xe2, 0xce, 0xc9, 0x8c, 0x05, 0xec, 0x7b, 0x0c, 0xf6, 0x5d, 0xb4, 0x16, 0x08, + 0x5b, 0x48, 0xd5, 0x52, 0x43, 0x49, 0x04, 0xd9, 0xb7, 0x6d, 0x32, 0xfc, 0x18, 0xfd, 0x4d, 0x83, + 0x71, 0xbf, 0x6a, 0x44, 0xb7, 0xba, 0x23, 0x0b, 0x91, 0xad, 0x89, 0xdb, 0x27, 0x31, 0x15, 0x94, + 0x36, 0x19, 0xa5, 0x35, 0xb4, 0x1a, 0x48, 0xc9, 0x93, 0xab, 0x2e, 0x2b, 0x3e, 0xf6, 0xb6, 0x4d, + 0x21, 0x1f, 0xa3, 0xbf, 0x68, 0x80, 0xda, 0x55, 0x6a, 0x94, 0x9d, 0x0a, 0x55, 0xbf, 0x51, 0x76, + 0x2a, 0x5c, 0x18, 0xe3, 0x15, 0x46, 0x6b, 0x19, 0x5d, 0x0a, 0xa4, 0xa5, 0x1b, 0x46, 0xd1, 0xaf, + 0x9b, 0xd1, 0x1f, 0x34, 0x18, 0xf3, 0xe9, 0x5a, 0xb4, 0xd2, 0x1d, 0x84, 0xcf, 0x24, 0x71, 0xab, + 0x67, 0x13, 0x0f, 0xf4, 0x65, 0x06, 0xfa, 0x02, 0xfa, 0x6e, 0x20, 0x68, 0xdb, 0x87, 0xed, 0x3f, + 0x1a, 0x9c, 0x0d, 0x14, 0xc0, 0x68, 0xbd, 0x3b, 0x84, 0x4e, 0xca, 0x3b, 0x71, 0xf7, 0xc4, 0xf6, + 0x91, 0x0e, 0x55, 0x95, 0x38, 0xc5, 0xb2, 0x51, 0x23, 0xa6, 0x23, 0x54, 0x71, 0x71, 0x97, 0x5a, + 0xf2, 0x74, 0x49, 0xc9, 0x7f, 0x8c, 0xfe, 0xa8, 0xc1, 0x68, 0xcb, 0x32, 0xe8, 0x7a, 0x8f, 0xb8, + 0x24, 0x9f, 0x1b, 0x3d, 0xdb, 0x45, 0xda, 0x10, 0xc6, 0xa3, 0xa9, 0xed, 0xd1, 0x7b, 0xad, 0x45, + 0x77, 0xa2, 0x68, 0xcb, 0xb6, 0xeb, 0xe4, 0xc4, 0xcd, 0xde, 0x0d, 0x05, 0xe0, 0xab, 0x0c, 0xf0, + 0x12, 0x4a, 0x07, 0x02, 0x56, 0x94, 0x7a, 0xf6, 0x2d, 0x7b, 0x1c, 0x1c, 0xbb, 0xa7, 0xfe, 0x8c, + 0xe2, 0x69, 0xc3, 0x30, 0xa2, 0xe0, 0x0e, 0xd4, 0xf7, 0x51, 0x70, 0x07, 0x2b, 0x76, 0x9c, 0x66, + 0xb8, 0x31, 0x4a, 0x75, 0xc3, 0x8d, 0x3e, 0x68, 0x30, 0xe6, 0x13, 0xb3, 0x51, 0xf2, 0x4c, 0xa8, + 0xea, 0x8e, 0x92, 0x67, 0xc2, 0xf5, 0x38, 0xbe, 0xc2, 0x80, 0x5f, 0x44, 0xe7, 0x83, 0x0b, 0x99, + 0x4f, 0xaa, 0xa3, 0xdf, 0x6a, 0x10, 0xe3, 0x12, 0x18, 0xe5, 0x22, 0xad, 0xdb, 0xa2, 0xc2, 0x13, + 0xd7, 0x7a, 0xb2, 0x89, 0x54, 0x6b, 0xb9, 0x10, 0x47, 0x7f, 0xd5, 0x60, 0xa2, 0x4d, 0x62, 0xa3, + 0x08, 0x85, 0x25, 0x4c, 0xb9, 0x27, 0x56, 0x4f, 0x64, 0x2b, 0x30, 0xdf, 0x62, 0x98, 0xaf, 0xa1, + 0x15, 0x15, 0xb3, 0xf4, 0xa2, 0xa4, 0xc4, 0x3d, 0xfa, 0xc6, 0xa7, 0xfb, 0xd1, 0xdf, 0x35, 0x98, + 0x68, 0x93, 0xd7, 0x51, 0x98, 0x84, 0xe9, 0xfb, 0x28, 0x4c, 0x42, 0xf5, 0x7c, 0x97, 0x54, 0xc8, + 0x85, 0xb6, 0x5f, 0x31, 0xf8, 0x1e, 0x13, 0xc7, 0xe8, 0xcf, 0x1a, 0xa0, 0x2d, 0xe2, 0xf8, 0x14, + 0x3b, 0x8a, 0x76, 0xdf, 0x02, 0xde, 0x00, 0x51, 0x8a, 0x54, 0xc8, 0xf3, 0x00, 0xe7, 0x18, 0xa1, + 0xcb, 0x68, 0x29, 0x34, 0x27, 0xba, 0xd5, 0x95, 0x73, 0xb0, 0x04, 0xd0, 0x0f, 0x0a, 0x7e, 0x45, + 0x66, 0xdf, 0x88, 0x88, 0xc2, 0xff, 0x82, 0x48, 0xdc, 0xec, 0xdd, 0xb0, 0x47, 0xf4, 0xca, 0xb3, + 0x01, 0xfd, 0x5b, 0x83, 0xa9, 0x20, 0xf5, 0x8d, 0xd6, 0x22, 0x5d, 0xc7, 0x30, 0xe1, 0x9f, 0x58, + 0x3f, 0xa9, 0xb9, 0xe0, 0x92, 0x67, 0x5c, 0xee, 0xa0, 0xdb, 0xa1, 0x5c, 0x54, 0x1e, 0xee, 0x29, + 0x73, 0x5f, 0x18, 0xee, 0xf9, 0x92, 0xaf, 0x8d, 0x63, 0xf4, 0x2b, 0x0d, 0x06, 0xd9, 0x3f, 0xea, + 0x51, 0x26, 0x82, 0x88, 0x57, 0x7e, 0x79, 0x48, 0x64, 0x23, 0xcf, 0x17, 0x70, 0x31, 0x83, 0x3b, + 0x87, 0x12, 0xc1, 0xa9, 0xd2, 0x9d, 0x9b, 0xdf, 0xfe, 0xf8, 0x39, 0xa9, 0x7d, 0xfa, 0x9c, 0xd4, + 0xfe, 0xf7, 0x39, 0xa9, 0xbd, 0xfb, 0x92, 0xec, 0xfb, 0xf4, 0x25, 0xd9, 0xf7, 0xaf, 0x2f, 0xc9, + 0xbe, 0x1f, 0x67, 0xab, 0x35, 0x67, 0xef, 0xa0, 0xe4, 0xbe, 0x68, 0x02, 0x73, 0xc2, 0x51, 0xd3, + 0x95, 0xd3, 0xa8, 0x13, 0xbb, 0x14, 0x63, 0x3f, 0x9b, 0x5c, 0xfb, 0x36, 0x00, 0x00, 0xff, 0xff, + 0x2e, 0xac, 0xc8, 0xff, 0x92, 0x1a, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -2452,14 +2450,14 @@ func (m *QueryProveRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { if m.TxIndex != 0 { i = encodeVarintQuery(dAtA, i, uint64(m.TxIndex)) i-- - dAtA[i] = 0x38 + dAtA[i] = 0x28 } if len(m.BlockHash) > 0 { i -= len(m.BlockHash) copy(dAtA[i:], m.BlockHash) i = encodeVarintQuery(dAtA, i, uint64(len(m.BlockHash))) i-- - dAtA[i] = 0x32 + dAtA[i] = 0x22 } if m.Proof != nil { { @@ -2471,7 +2469,7 @@ func (m *QueryProveRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintQuery(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x2a + dAtA[i] = 0x1a } if len(m.TxHash) > 0 { i -= len(m.TxHash) @@ -4157,7 +4155,7 @@ func (m *QueryProveRequest) Unmarshal(dAtA []byte) error { } m.TxHash = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex - case 5: + case 3: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Proof", wireType) } @@ -4187,13 +4185,13 @@ func (m *QueryProveRequest) Unmarshal(dAtA []byte) error { return io.ErrUnexpectedEOF } if m.Proof == nil { - m.Proof = ðereum.Proof{} + m.Proof = &common.Proof{} } if err := m.Proof.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err } iNdEx = postIndex - case 6: + case 4: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field BlockHash", wireType) } @@ -4225,7 +4223,7 @@ func (m *QueryProveRequest) Unmarshal(dAtA []byte) error { } m.BlockHash = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex - case 7: + case 5: if wireType != 0 { return fmt.Errorf("proto: wrong wireType = %d for field TxIndex", wireType) } @@ -6753,7 +6751,7 @@ func (m *QueryAllBlockHeaderResponse) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - m.BlockHeaders = append(m.BlockHeaders, &BlockHeader{}) + m.BlockHeaders = append(m.BlockHeaders, &common.BlockHeader{}) if err := m.BlockHeaders[len(m.BlockHeaders)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err } @@ -6958,7 +6956,7 @@ func (m *QueryGetBlockHeaderByHashResponse) Unmarshal(dAtA []byte) error { return io.ErrUnexpectedEOF } if m.BlockHeader == nil { - m.BlockHeader = &BlockHeader{} + m.BlockHeader = &common.BlockHeader{} } if err := m.BlockHeader.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err diff --git a/x/observer/types/tx.pb.go b/x/observer/types/tx.pb.go index 8019e5dc5a..cb6f2df8f9 100644 --- a/x/observer/types/tx.pb.go +++ b/x/observer/types/tx.pb.go @@ -13,7 +13,7 @@ import ( _ "github.com/cosmos/gogoproto/gogoproto" grpc1 "github.com/gogo/protobuf/grpc" proto "github.com/gogo/protobuf/proto" - _ "github.com/zeta-chain/zetacore/common" + common "github.com/zeta-chain/zetacore/common" grpc "google.golang.org/grpc" codes "google.golang.org/grpc/codes" status "google.golang.org/grpc/status" @@ -31,11 +31,11 @@ var _ = math.Inf const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package type MsgAddBlockHeader struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` - ChainId int64 `protobuf:"varint,2,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` - BlockHash []byte `protobuf:"bytes,3,opt,name=block_hash,json=blockHash,proto3" json:"block_hash,omitempty"` - BlockHeader []byte `protobuf:"bytes,4,opt,name=block_header,json=blockHeader,proto3" json:"block_header,omitempty"` - Height int64 `protobuf:"varint,5,opt,name=height,proto3" json:"height,omitempty"` + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + ChainId int64 `protobuf:"varint,2,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` + BlockHash []byte `protobuf:"bytes,3,opt,name=block_hash,json=blockHash,proto3" json:"block_hash,omitempty"` + Height int64 `protobuf:"varint,4,opt,name=height,proto3" json:"height,omitempty"` + Header common.HeaderData `protobuf:"bytes,5,opt,name=header,proto3" json:"header"` } func (m *MsgAddBlockHeader) Reset() { *m = MsgAddBlockHeader{} } @@ -92,18 +92,18 @@ func (m *MsgAddBlockHeader) GetBlockHash() []byte { return nil } -func (m *MsgAddBlockHeader) GetBlockHeader() []byte { +func (m *MsgAddBlockHeader) GetHeight() int64 { if m != nil { - return m.BlockHeader + return m.Height } - return nil + return 0 } -func (m *MsgAddBlockHeader) GetHeight() int64 { +func (m *MsgAddBlockHeader) GetHeader() common.HeaderData { if m != nil { - return m.Height + return m.Header } - return 0 + return common.HeaderData{} } type MsgAddBlockHeaderResponse struct { @@ -632,53 +632,53 @@ func init() { func init() { proto.RegisterFile("observer/tx.proto", fileDescriptor_1bcd40fa296a2b1d) } var fileDescriptor_1bcd40fa296a2b1d = []byte{ - // 723 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x55, 0xcb, 0x6e, 0xd3, 0x4c, - 0x14, 0xae, 0xff, 0xfe, 0xbd, 0xe4, 0xa4, 0xea, 0xc5, 0xbd, 0x39, 0xa9, 0x1a, 0x05, 0x6f, 0x28, - 0x50, 0x62, 0x68, 0x01, 0x21, 0x24, 0x16, 0x29, 0x82, 0x36, 0x42, 0xa5, 0x95, 0x25, 0x58, 0xb0, - 0xb1, 0xc6, 0x9e, 0x53, 0xdb, 0x6a, 0x3c, 0x13, 0x79, 0x1c, 0x94, 0xb0, 0x60, 0xcf, 0x02, 0xc4, - 0x33, 0xf0, 0x2c, 0x2c, 0x58, 0x76, 0xc9, 0x12, 0xb5, 0x1b, 0x1e, 0x03, 0x65, 0x7c, 0x69, 0x2e, - 0x25, 0x4d, 0xba, 0xf2, 0xcc, 0x39, 0xdf, 0xf9, 0xce, 0x77, 0x2e, 0xd6, 0xc0, 0x12, 0xb7, 0x05, - 0x86, 0x1f, 0x30, 0x34, 0xa2, 0x56, 0xa5, 0x11, 0xf2, 0x88, 0xab, 0x1b, 0x1f, 0x31, 0x22, 0x8e, - 0x47, 0x7c, 0x56, 0x91, 0x27, 0x1e, 0x62, 0x25, 0x45, 0x15, 0x97, 0x1d, 0x1e, 0x04, 0x9c, 0x19, - 0xf1, 0x27, 0x8e, 0x28, 0xae, 0xb8, 0xdc, 0xe5, 0xf2, 0x68, 0x74, 0x4e, 0xa9, 0x35, 0xa3, 0xb6, - 0xeb, 0x24, 0xc0, 0xc4, 0xba, 0x96, 0x59, 0x3d, 0x24, 0x14, 0x43, 0x91, 0xd8, 0xd7, 0x33, 0x7b, - 0x7a, 0x48, 0x1c, 0xab, 0x99, 0xa3, 0x41, 0x42, 0x12, 0x24, 0x78, 0xfd, 0xbb, 0x02, 0x4b, 0x87, - 0xc2, 0xad, 0x52, 0xba, 0x57, 0xe7, 0xce, 0xe9, 0x81, 0x24, 0x53, 0x35, 0x98, 0x71, 0x42, 0x24, - 0x11, 0x0f, 0x35, 0xa5, 0xac, 0x6c, 0xe5, 0xcc, 0xf4, 0xaa, 0x16, 0x60, 0x56, 0xd6, 0x64, 0xf9, - 0x54, 0xfb, 0xaf, 0xac, 0x6c, 0x4d, 0x9a, 0x33, 0xf2, 0x5e, 0xa3, 0xea, 0x26, 0x80, 0xdd, 0xe1, - 0xb0, 0x3c, 0x22, 0x3c, 0x6d, 0xb2, 0xac, 0x6c, 0xcd, 0x99, 0x39, 0x69, 0x39, 0x20, 0xc2, 0x53, - 0x6f, 0xc1, 0x5c, 0xe2, 0x96, 0x39, 0xb4, 0xff, 0x25, 0x20, 0x6f, 0x77, 0xa5, 0x5d, 0x83, 0x69, - 0x0f, 0x7d, 0xd7, 0x8b, 0xb4, 0x29, 0x49, 0x9d, 0xdc, 0xf4, 0x0d, 0x28, 0x0c, 0x68, 0x34, 0x51, - 0x34, 0x38, 0x13, 0xa8, 0xb7, 0x60, 0xf9, 0x50, 0xb8, 0x6f, 0x1b, 0x94, 0x44, 0xf8, 0x82, 0x87, - 0x78, 0x2c, 0xcb, 0x1b, 0x52, 0xc2, 0x3e, 0x80, 0x93, 0xe1, 0x64, 0x11, 0xf9, 0x9d, 0xdb, 0x95, - 0x21, 0xd3, 0xaa, 0x5c, 0xd2, 0x9a, 0x5d, 0xa1, 0xfa, 0x26, 0x6c, 0x5c, 0x91, 0x39, 0x13, 0xf6, - 0x43, 0x81, 0xf9, 0x58, 0xf6, 0x51, 0x42, 0x34, 0x44, 0xd4, 0x1d, 0x58, 0x4c, 0xd3, 0x59, 0x84, - 0xd2, 0x10, 0x45, 0x2c, 0x2d, 0x67, 0x2e, 0xa4, 0xf6, 0x6a, 0x6c, 0x56, 0x9f, 0x41, 0x41, 0x4a, - 0xac, 0xfb, 0xc8, 0x22, 0xcb, 0x0d, 0x09, 0x8b, 0x10, 0xad, 0x46, 0xd3, 0x3e, 0xc5, 0xb6, 0x6c, - 0x7b, 0xce, 0x5c, 0xbf, 0x04, 0xec, 0xc7, 0xfe, 0x63, 0xe9, 0x56, 0x1f, 0xc2, 0x2a, 0xa1, 0xd4, - 0x62, 0x9c, 0xa2, 0x45, 0x1c, 0x87, 0x37, 0x59, 0x64, 0x71, 0x56, 0x6f, 0xcb, 0x69, 0xcc, 0x9a, - 0x2a, 0xa1, 0xf4, 0x0d, 0xa7, 0x58, 0x8d, 0x5d, 0x47, 0xac, 0xde, 0xd6, 0x35, 0x58, 0xeb, 0xad, - 0x22, 0x2b, 0xf0, 0xb3, 0x02, 0x0b, 0xe9, 0x5c, 0x48, 0x80, 0xef, 0x78, 0x84, 0x37, 0xdb, 0x9c, - 0x6a, 0x67, 0x73, 0x48, 0x80, 0x96, 0xcf, 0x4e, 0xb8, 0x2c, 0x21, 0xbf, 0xa3, 0x0f, 0x9d, 0x88, - 0x4c, 0xd8, 0xd9, 0x2e, 0x12, 0x60, 0x8d, 0x9d, 0x70, 0xbd, 0x00, 0xeb, 0x7d, 0x52, 0x32, 0x99, - 0x5f, 0x15, 0xd0, 0xb2, 0x39, 0x1d, 0x63, 0x18, 0xf8, 0x42, 0xf8, 0x9c, 0xbd, 0xaa, 0x13, 0x77, - 0xd8, 0x9a, 0xdc, 0x85, 0x45, 0x5f, 0xd4, 0x98, 0xcd, 0x9b, 0x8c, 0xbe, 0x64, 0xc4, 0xae, 0x23, - 0x95, 0xd2, 0x66, 0xcd, 0x01, 0xbb, 0xba, 0x0d, 0x4b, 0xbe, 0x38, 0x6a, 0x46, 0x3d, 0xe0, 0xb8, - 0xa5, 0x83, 0x0e, 0x5d, 0x87, 0xf2, 0xbf, 0xf4, 0x64, 0xa2, 0xab, 0xb2, 0xb5, 0x31, 0xe6, 0x35, - 0xb6, 0x5d, 0x64, 0x43, 0xa4, 0xae, 0xc0, 0x94, 0xfc, 0x8d, 0x92, 0xbe, 0xc6, 0x97, 0xa4, 0x25, - 0xdd, 0x14, 0x29, 0xfb, 0xce, 0x9f, 0x29, 0x98, 0x3c, 0x14, 0xae, 0xca, 0x21, 0xdf, 0xbd, 0x9e, - 0xf7, 0x86, 0xf6, 0xbc, 0x77, 0x0b, 0x8a, 0xbb, 0x63, 0x80, 0xd3, 0xc4, 0xea, 0x27, 0x58, 0x1c, - 0xf8, 0x53, 0x1f, 0x5c, 0x47, 0xd4, 0x1f, 0x51, 0x7c, 0x3a, 0x6e, 0x44, 0x96, 0x3f, 0x84, 0xb9, - 0x9e, 0x75, 0xdd, 0x1e, 0xa1, 0x88, 0x0c, 0x5d, 0x7c, 0x34, 0x0e, 0x3a, 0xcb, 0xf9, 0x45, 0x81, - 0xd5, 0xab, 0x97, 0xef, 0xf1, 0x68, 0x75, 0xf4, 0x85, 0x15, 0x9f, 0xdf, 0x28, 0xac, 0xbb, 0x07, - 0x3d, 0x7b, 0xb5, 0x3d, 0x1a, 0x5d, 0x8c, 0xbe, 0xbe, 0x07, 0x57, 0x2d, 0x9c, 0xda, 0x82, 0xf9, - 0xbe, 0x27, 0xa6, 0x32, 0x52, 0x2f, 0x33, 0x7c, 0xf1, 0xc9, 0x78, 0xf8, 0x34, 0xf3, 0x5e, 0xed, - 0xe7, 0x79, 0x49, 0x39, 0x3b, 0x2f, 0x29, 0xbf, 0xcf, 0x4b, 0xca, 0xb7, 0x8b, 0xd2, 0xc4, 0xd9, - 0x45, 0x69, 0xe2, 0xd7, 0x45, 0x69, 0xe2, 0xbd, 0xe1, 0xfa, 0x91, 0xd7, 0xb4, 0x2b, 0x0e, 0x0f, - 0x8c, 0x0e, 0xe3, 0x7d, 0x49, 0x6e, 0xa4, 0xe4, 0x46, 0xcb, 0xb8, 0x7c, 0xd4, 0xdb, 0x0d, 0x14, - 0xf6, 0xb4, 0x7c, 0x32, 0x77, 0xff, 0x06, 0x00, 0x00, 0xff, 0xff, 0xe6, 0x14, 0x0f, 0x4d, 0xed, - 0x07, 0x00, 0x00, + // 731 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x55, 0x49, 0x6f, 0xd3, 0x40, + 0x14, 0x8e, 0xe9, 0x9a, 0x97, 0xaa, 0x8b, 0xbb, 0x39, 0xa9, 0x1a, 0x22, 0x5f, 0x08, 0x50, 0xe2, + 0x92, 0x02, 0x42, 0x48, 0x1c, 0x52, 0x96, 0x36, 0x42, 0xa5, 0x95, 0x25, 0x38, 0x70, 0xb1, 0xc6, + 0x99, 0x57, 0xc7, 0x6a, 0x3c, 0x13, 0xd9, 0x0e, 0x4a, 0x38, 0x70, 0xe7, 0x00, 0xe2, 0xaf, 0xf0, + 0x1f, 0x38, 0xf4, 0xd8, 0x23, 0x27, 0x84, 0xda, 0x0b, 0x3f, 0x03, 0x79, 0xbc, 0x34, 0x4b, 0x49, + 0x93, 0x9e, 0x3c, 0xf3, 0xde, 0xf7, 0xbe, 0xf7, 0xbd, 0xc5, 0x1a, 0x58, 0xe2, 0xa6, 0x87, 0xee, + 0x47, 0x74, 0x35, 0xbf, 0x5d, 0x6a, 0xba, 0xdc, 0xe7, 0xf2, 0xc6, 0x27, 0xf4, 0x49, 0xad, 0x4e, + 0x6c, 0x56, 0x12, 0x27, 0xee, 0x62, 0x29, 0x46, 0xe5, 0x96, 0x6b, 0xdc, 0x71, 0x38, 0xd3, 0xc2, + 0x4f, 0x18, 0x91, 0x5b, 0xb1, 0xb8, 0xc5, 0xc5, 0x51, 0x0b, 0x4e, 0xb1, 0x35, 0xa1, 0x36, 0x1b, + 0xc4, 0xc1, 0xc8, 0xba, 0x9e, 0x58, 0xe3, 0x43, 0xe4, 0x58, 0x4d, 0x1c, 0x4d, 0xe2, 0x12, 0xc7, + 0x0b, 0xcd, 0xea, 0x0f, 0x09, 0x96, 0x0e, 0x3c, 0xab, 0x42, 0xe9, 0x6e, 0x83, 0xd7, 0x4e, 0xf6, + 0x91, 0x50, 0x74, 0x65, 0x05, 0x66, 0x6a, 0x2e, 0x12, 0x9f, 0xbb, 0x8a, 0x54, 0x90, 0x8a, 0x69, + 0x3d, 0xbe, 0xca, 0x59, 0x98, 0x15, 0xda, 0x0d, 0x9b, 0x2a, 0xb7, 0x0a, 0x52, 0x71, 0x42, 0x9f, + 0x11, 0xf7, 0x2a, 0x95, 0x37, 0x01, 0xcc, 0x80, 0xc3, 0xa8, 0x13, 0xaf, 0xae, 0x4c, 0x14, 0xa4, + 0xe2, 0x9c, 0x9e, 0x16, 0x96, 0x7d, 0xe2, 0xd5, 0xe5, 0x35, 0x98, 0xae, 0xa3, 0x6d, 0xd5, 0x7d, + 0x65, 0x52, 0xc4, 0x45, 0x37, 0x79, 0x3b, 0xb0, 0x07, 0x59, 0x95, 0xa9, 0x82, 0x54, 0xcc, 0x94, + 0xe5, 0x52, 0x54, 0x7c, 0xa8, 0xe5, 0x25, 0xf1, 0xc9, 0xee, 0xe4, 0xe9, 0xef, 0xdb, 0x29, 0x3d, + 0xc2, 0xa9, 0x1b, 0x90, 0x1d, 0x90, 0xac, 0xa3, 0xd7, 0xe4, 0xcc, 0x43, 0xb5, 0x0d, 0xcb, 0x07, + 0x9e, 0xf5, 0xae, 0x49, 0x89, 0x8f, 0x2f, 0xb8, 0x8b, 0x47, 0xa2, 0xda, 0x21, 0x15, 0xed, 0x01, + 0xd4, 0x12, 0x9c, 0xa8, 0x29, 0x53, 0xbe, 0x53, 0x1a, 0x32, 0xa4, 0xd2, 0x25, 0xad, 0xde, 0x15, + 0xaa, 0x6e, 0xc2, 0xc6, 0x15, 0x99, 0x13, 0x61, 0x3f, 0x25, 0x98, 0x0f, 0x65, 0x1f, 0x46, 0x44, + 0x43, 0x44, 0xdd, 0x85, 0xc5, 0x38, 0x9d, 0x41, 0x28, 0x75, 0xd1, 0x0b, 0xa5, 0xa5, 0xf5, 0x85, + 0xd8, 0x5e, 0x09, 0xcd, 0xf2, 0x33, 0xc8, 0x0a, 0x89, 0x0d, 0x1b, 0x99, 0x6f, 0x58, 0x2e, 0x61, + 0x3e, 0xa2, 0xd1, 0x6c, 0x99, 0x27, 0xd8, 0x11, 0x53, 0x48, 0xeb, 0xeb, 0x97, 0x80, 0xbd, 0xd0, + 0x7f, 0x24, 0xdc, 0xf2, 0x43, 0x58, 0x25, 0x94, 0x1a, 0x8c, 0x53, 0x34, 0x48, 0xad, 0xc6, 0x5b, + 0xcc, 0x37, 0x38, 0x6b, 0x74, 0xc4, 0x88, 0x66, 0x75, 0x99, 0x50, 0xfa, 0x96, 0x53, 0xac, 0x84, + 0xae, 0x43, 0xd6, 0xe8, 0xa8, 0x0a, 0xac, 0xf5, 0x56, 0x91, 0x14, 0xf8, 0x45, 0x82, 0x85, 0x78, + 0x2e, 0xc4, 0xc1, 0xf7, 0xdc, 0xc7, 0x9b, 0x2d, 0x52, 0x25, 0x58, 0x24, 0xe2, 0xa0, 0x61, 0xb3, + 0x63, 0x2e, 0x4a, 0xc8, 0x94, 0xd5, 0xa1, 0x13, 0x11, 0x09, 0x83, 0x65, 0x23, 0x0e, 0x56, 0xd9, + 0x31, 0x57, 0xb3, 0xb0, 0xde, 0x27, 0x25, 0x91, 0xf9, 0x4d, 0x02, 0x25, 0x99, 0xd3, 0x11, 0xba, + 0x8e, 0xed, 0x79, 0x36, 0x67, 0xaf, 0x1b, 0xc4, 0x1a, 0xb6, 0x26, 0xf7, 0x60, 0xd1, 0xf6, 0xaa, + 0xcc, 0xe4, 0x2d, 0x46, 0x5f, 0x31, 0x62, 0x36, 0x90, 0x0a, 0x69, 0xb3, 0xfa, 0x80, 0x5d, 0xde, + 0x82, 0x25, 0xdb, 0x3b, 0x6c, 0xf9, 0x3d, 0xe0, 0xb0, 0xa5, 0x83, 0x0e, 0x55, 0x85, 0xc2, 0xff, + 0xf4, 0x24, 0xa2, 0x2b, 0xa2, 0xb5, 0x21, 0xe6, 0x0d, 0x76, 0x2c, 0x64, 0x43, 0xa4, 0xae, 0xc0, + 0x94, 0xf8, 0xed, 0xa2, 0xbe, 0x86, 0x97, 0xa8, 0x25, 0xdd, 0x14, 0x31, 0x7b, 0xf9, 0xef, 0x14, + 0x4c, 0x1c, 0x78, 0x96, 0xcc, 0x21, 0xd3, 0xbd, 0x9e, 0xf7, 0x87, 0xf6, 0xbc, 0x77, 0x0b, 0x72, + 0x3b, 0x63, 0x80, 0xe3, 0xc4, 0xf2, 0x67, 0x58, 0x1c, 0xf8, 0x53, 0xb7, 0xaf, 0x23, 0xea, 0x8f, + 0xc8, 0x3d, 0x1d, 0x37, 0x22, 0xc9, 0xef, 0xc2, 0x5c, 0xcf, 0xba, 0x6e, 0x8d, 0x50, 0x44, 0x82, + 0xce, 0x3d, 0x1a, 0x07, 0x9d, 0xe4, 0xfc, 0x2a, 0xc1, 0xea, 0xd5, 0xcb, 0xf7, 0x78, 0xb4, 0x3a, + 0xfa, 0xc2, 0x72, 0xcf, 0x6f, 0x14, 0xd6, 0xdd, 0x83, 0x9e, 0xbd, 0xda, 0x1a, 0x8d, 0x2e, 0x44, + 0x5f, 0xdf, 0x83, 0xab, 0x16, 0x4e, 0x6e, 0xc3, 0x7c, 0xdf, 0x8b, 0x53, 0x1a, 0xa9, 0x97, 0x09, + 0x3e, 0xf7, 0x64, 0x3c, 0x7c, 0x9c, 0x79, 0xb7, 0x7a, 0x7a, 0x9e, 0x97, 0xce, 0xce, 0xf3, 0xd2, + 0x9f, 0xf3, 0xbc, 0xf4, 0xfd, 0x22, 0x9f, 0x3a, 0xbb, 0xc8, 0xa7, 0x7e, 0x5d, 0xe4, 0x53, 0x1f, + 0x34, 0xcb, 0xf6, 0xeb, 0x2d, 0x33, 0x78, 0x7d, 0xb4, 0x80, 0xf1, 0x81, 0x20, 0xd7, 0x62, 0x72, + 0xad, 0xad, 0x5d, 0xbe, 0xe5, 0x9d, 0x26, 0x7a, 0xe6, 0xb4, 0x78, 0x41, 0x77, 0xfe, 0x05, 0x00, + 0x00, 0xff, 0xff, 0xf9, 0x62, 0xcd, 0x1c, 0xe4, 0x07, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -961,17 +961,20 @@ func (m *MsgAddBlockHeader) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l + { + size, err := m.Header.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintTx(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a if m.Height != 0 { i = encodeVarintTx(dAtA, i, uint64(m.Height)) i-- - dAtA[i] = 0x28 - } - if len(m.BlockHeader) > 0 { - i -= len(m.BlockHeader) - copy(dAtA[i:], m.BlockHeader) - i = encodeVarintTx(dAtA, i, uint64(len(m.BlockHeader))) - i-- - dAtA[i] = 0x22 + dAtA[i] = 0x20 } if len(m.BlockHash) > 0 { i -= len(m.BlockHash) @@ -1389,13 +1392,11 @@ func (m *MsgAddBlockHeader) Size() (n int) { if l > 0 { n += 1 + l + sovTx(uint64(l)) } - l = len(m.BlockHeader) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } if m.Height != 0 { n += 1 + sovTx(uint64(m.Height)) } + l = m.Header.Size() + n += 1 + l + sovTx(uint64(l)) return n } @@ -1670,10 +1671,10 @@ func (m *MsgAddBlockHeader) Unmarshal(dAtA []byte) error { } iNdEx = postIndex case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field BlockHeader", wireType) + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Height", wireType) } - var byteLen int + m.Height = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -1683,31 +1684,16 @@ func (m *MsgAddBlockHeader) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - byteLen |= int(b&0x7F) << shift + m.Height |= int64(b&0x7F) << shift if b < 0x80 { break } } - if byteLen < 0 { - return ErrInvalidLengthTx - } - postIndex := iNdEx + byteLen - if postIndex < 0 { - return ErrInvalidLengthTx - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.BlockHeader = append(m.BlockHeader[:0], dAtA[iNdEx:postIndex]...) - if m.BlockHeader == nil { - m.BlockHeader = []byte{} - } - iNdEx = postIndex case 5: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Height", wireType) + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Header", wireType) } - m.Height = 0 + var msglen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -1717,11 +1703,25 @@ func (m *MsgAddBlockHeader) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.Height |= int64(b&0x7F) << shift + msglen |= int(b&0x7F) << shift if b < 0x80 { break } } + if msglen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.Header.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) diff --git a/zetaclient/evm_client.go b/zetaclient/evm_client.go index 0e95cb3bea..1d77e6fb5a 100644 --- a/zetaclient/evm_client.go +++ b/zetaclient/evm_client.go @@ -830,7 +830,13 @@ func (ob *EVMChainClient) observeInTX() error { ob.logger.ExternalChainWatcher.Error().Err(err).Msgf("error encoding block header: %d", bn) continue } - _, err = ob.zetaClient.PostAddBlockHeader(ob.chain.ChainId, block.Hash().Bytes(), block.Number().Int64(), headerRLP) + + _, err = ob.zetaClient.PostAddBlockHeader( + ob.chain.ChainId, + block.Hash().Bytes(), + block.Number().Int64(), + common.NewEthereumHeader(headerRLP), + ) if err != nil { ob.logger.ExternalChainWatcher.Error().Err(err).Msgf("error posting block header: %d", bn) continue diff --git a/zetaclient/query.go b/zetaclient/query.go index a93c52c5e4..9e00acab4c 100644 --- a/zetaclient/query.go +++ b/zetaclient/query.go @@ -12,7 +12,6 @@ import ( upgradetypes "github.com/cosmos/cosmos-sdk/x/upgrade/types" tmtypes "github.com/tendermint/tendermint/proto/tendermint/types" "github.com/zeta-chain/zetacore/common" - "github.com/zeta-chain/zetacore/common/ethereum" "github.com/zeta-chain/zetacore/x/crosschain/types" zetaObserverTypes "github.com/zeta-chain/zetacore/x/observer/types" "google.golang.org/grpc" @@ -299,7 +298,7 @@ func (b *ZetaCoreBridge) GetPendingNonces() (*types.QueryAllPendingNoncesRespons return resp, nil } -func (b *ZetaCoreBridge) Prove(blockHash string, txHash string, txIndex int64, proof *ethereum.Proof, chainID uint64) (bool, error) { +func (b *ZetaCoreBridge) Prove(blockHash string, txHash string, txIndex int64, proof *common.Proof, chainID uint64) (bool, error) { client := zetaObserverTypes.NewQueryClient(b.grpcConn) resp, err := client.Prove(context.Background(), &zetaObserverTypes.QueryProveRequest{ BlockHash: blockHash, diff --git a/zetaclient/tx.go b/zetaclient/tx.go index 5b23ef5a73..4e0b0b150c 100644 --- a/zetaclient/tx.go +++ b/zetaclient/tx.go @@ -8,7 +8,6 @@ import ( "cosmossdk.io/math" sdk "github.com/cosmos/cosmos-sdk/types" "github.com/cosmos/cosmos-sdk/x/authz" - "github.com/zeta-chain/zetacore/common/ethereum" "github.com/zeta-chain/zetacore/zetaclient/config" "gitlab.com/thorchain/tss/go-tss/blame" @@ -55,7 +54,7 @@ func (b *ZetaCoreBridge) PostGasPrice(chain common.Chain, gasPrice uint64, suppl return "", fmt.Errorf("post gasprice failed after %d retries", DefaultRetryInterval) } -func (b *ZetaCoreBridge) AddTxHashToOutTxTracker(chainID int64, nonce uint64, txHash string, proof *ethereum.Proof, blockHash string, txIndex int64) (string, error) { +func (b *ZetaCoreBridge) AddTxHashToOutTxTracker(chainID int64, nonce uint64, txHash string, proof *common.Proof, blockHash string, txIndex int64) (string, error) { signerAddress := b.keys.GetOperatorAddress().String() msg := types.NewMsgAddToOutTxTracker(signerAddress, chainID, nonce, txHash, proof, blockHash, txIndex) authzMsg, authzSigner := b.WrapMessageWithAuthz(msg) @@ -192,10 +191,11 @@ func (b *ZetaCoreBridge) PostBlameData(blame *blame.Blame, chainID int64, index return "", fmt.Errorf("post blame data failed after %d retries", DefaultRetryCount) } -func (b *ZetaCoreBridge) PostAddBlockHeader(chainID int64, txhash []byte, height int64, header []byte) (string, error) { +func (b *ZetaCoreBridge) PostAddBlockHeader(chainID int64, txhash []byte, height int64, header common.HeaderData) (string, error) { signerAddress := b.keys.GetOperatorAddress().String() msg := observerTypes.NewMsgAddBlockHeader(signerAddress, chainID, txhash, height, header) authzMsg, authzSigner := b.WrapMessageWithAuthz(msg) + var gasLimit uint64 = DefaultGasLimit for i := 0; i < DefaultRetryCount; i++ { zetaTxHash, err := b.Broadcast(gasLimit, authzMsg, authzSigner) From ea49309746e1896cca84fcf9ad85317a42651972 Mon Sep 17 00:00:00 2001 From: Tanmay Date: Wed, 20 Sep 2023 14:02:12 -0400 Subject: [PATCH 4/5] Move permission check to Event Processing rather from Process All logs (#1152) --- x/crosschain/keeper/evm_hooks.go | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/x/crosschain/keeper/evm_hooks.go b/x/crosschain/keeper/evm_hooks.go index 5ef345e7c3..a87e0a041c 100644 --- a/x/crosschain/keeper/evm_hooks.go +++ b/x/crosschain/keeper/evm_hooks.go @@ -81,9 +81,6 @@ func (k Keeper) PostTxProcessing( // from registered ZRC20 contract, new CCTX will be created to trigger and track outbound // transaction. func (k Keeper) ProcessLogs(ctx sdk.Context, logs []*ethtypes.Log, emittingContract ethcommon.Address, txOrigin string) error { - if !k.zetaObserverKeeper.IsInboundEnabled(ctx) { - return types.ErrNotEnoughPermissions - } system, found := k.fungibleKeeper.GetSystemContract(ctx) if !found { return fmt.Errorf("cannot find system contract") @@ -113,6 +110,9 @@ func (k Keeper) ProcessLogs(ctx sdk.Context, logs []*ethtypes.Log, emittingContr // ProcessZRC20WithdrawalEvent creates a new CCTX to process the withdrawal event // error indicates system error and non-recoverable; should abort func (k Keeper) ProcessZRC20WithdrawalEvent(ctx sdk.Context, event *zrc20.ZRC20Withdrawal, emittingContract ethcommon.Address, txOrigin string) error { + if !k.zetaObserverKeeper.IsInboundEnabled(ctx) { + return types.ErrNotEnoughPermissions + } ctx.Logger().Info("ZRC20 withdrawal to %s amount %d\n", hex.EncodeToString(event.To), event.Value) tss, found := k.GetTSS(ctx) if !found { @@ -164,6 +164,9 @@ func (k Keeper) ProcessZRC20WithdrawalEvent(ctx sdk.Context, event *zrc20.ZRC20W } func (k Keeper) ProcessZetaSentEvent(ctx sdk.Context, event *connectorzevm.ZetaConnectorZEVMZetaSent, emittingContract ethcommon.Address, txOrigin string) error { + if !k.zetaObserverKeeper.IsInboundEnabled(ctx) { + return types.ErrNotEnoughPermissions + } ctx.Logger().Info(fmt.Sprintf( "Zeta withdrawal to %s amount %d to chain with chainId %d", hex.EncodeToString(event.DestinationAddress), From a5d704b48d8274e0eca7ee1668eed5440f5e7f7d Mon Sep 17 00:00:00 2001 From: Tanmay Date: Wed, 20 Sep 2023 15:41:07 -0400 Subject: [PATCH 5/5] feat: add new query for pending nonces using chain id (#1131) --- docs/openapi/openapi.swagger.yaml | 25 + proto/crosschain/query.proto | 12 + x/crosschain/keeper/keeper_pending_nonces.go | 20 + x/crosschain/types/query.pb.go | 786 ++++++++++++++----- x/crosschain/types/query.pb.gw.go | 101 +++ 5 files changed, 734 insertions(+), 210 deletions(-) diff --git a/docs/openapi/openapi.swagger.yaml b/docs/openapi/openapi.swagger.yaml index 50af221fae..025b70c325 100644 --- a/docs/openapi/openapi.swagger.yaml +++ b/docs/openapi/openapi.swagger.yaml @@ -27213,6 +27213,26 @@ paths: $ref: '#/definitions/googlerpcStatus' tags: - Query + /zeta-chain/crosschain/pendingNonces/{chain_id}: + get: + operationId: Query_PendingNoncesByChain + responses: + "200": + description: A successful response. + schema: + $ref: '#/definitions/crosschainQueryPendingNoncesByChainResponse' + default: + description: An unexpected error response. + schema: + $ref: '#/definitions/googlerpcStatus' + parameters: + - name: chain_id + in: path + required: true + type: string + format: uint64 + tags: + - Query /zeta-chain/crosschain/protocolFee: get: operationId: Query_ProtocolFee @@ -50660,6 +50680,11 @@ definitions: properties: feeInZeta: type: string + crosschainQueryPendingNoncesByChainResponse: + type: object + properties: + pending_nonces: + $ref: '#/definitions/crosschainPendingNonces' crosschainQueryTssHistoryResponse: type: object properties: diff --git a/proto/crosschain/query.proto b/proto/crosschain/query.proto index 600645508e..ca7ccb7f51 100644 --- a/proto/crosschain/query.proto +++ b/proto/crosschain/query.proto @@ -94,6 +94,10 @@ service Query { option (google.api.http).get = "/zeta-chain/crosschain/pendingNonces"; } + rpc PendingNoncesByChain(QueryPendingNoncesByChainRequest) returns (QueryPendingNoncesByChainResponse) { + option (google.api.http).get = "/zeta-chain/crosschain/pendingNonces/{chain_id}"; + } + // Queries a lastBlockHeight by index. rpc LastBlockHeight(QueryGetLastBlockHeightRequest) returns (QueryGetLastBlockHeightResponse) { option (google.api.http).get = "/zeta-chain/crosschain/lastBlockHeight/{index}"; @@ -253,6 +257,14 @@ message QueryAllPendingNoncesResponse { repeated PendingNonces pending_nonces = 1; } +message QueryPendingNoncesByChainRequest { + uint64 chain_id = 1; +} + +message QueryPendingNoncesByChainResponse { + PendingNonces pending_nonces = 1 [(gogoproto.nullable) = false]; +} + message QueryGetLastBlockHeightRequest { string index = 1; } diff --git a/x/crosschain/keeper/keeper_pending_nonces.go b/x/crosschain/keeper/keeper_pending_nonces.go index da1648b104..8808b6ec4b 100644 --- a/x/crosschain/keeper/keeper_pending_nonces.go +++ b/x/crosschain/keeper/keeper_pending_nonces.go @@ -93,3 +93,23 @@ func (k Keeper) PendingNoncesAll(c context.Context, req *types.QueryAllPendingNo PendingNonces: list, }, nil } + +func (k Keeper) PendingNoncesByChain(c context.Context, req *types.QueryPendingNoncesByChainRequest) (*types.QueryPendingNoncesByChainResponse, error) { + if req == nil { + return nil, status.Error(codes.InvalidArgument, "invalid request") + } + + ctx := sdk.UnwrapSDKContext(c) + tss, found := k.GetTSS(ctx) + if !found { + return nil, status.Error(codes.NotFound, "tss not found") + } + list, found := k.GetPendingNonces(ctx, tss.TssPubkey, req.ChainId) + if !found { + return nil, status.Error(codes.NotFound, fmt.Sprintf("pending nonces not found for chain id : %d", req.ChainId)) + } + + return &types.QueryPendingNoncesByChainResponse{ + PendingNonces: list, + }, nil +} diff --git a/x/crosschain/types/query.pb.go b/x/crosschain/types/query.pb.go index ab9aef612d..4a808fb004 100644 --- a/x/crosschain/types/query.pb.go +++ b/x/crosschain/types/query.pb.go @@ -1378,6 +1378,94 @@ func (m *QueryAllPendingNoncesResponse) GetPendingNonces() []*PendingNonces { return nil } +type QueryPendingNoncesByChainRequest struct { + ChainId uint64 `protobuf:"varint,1,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"` +} + +func (m *QueryPendingNoncesByChainRequest) Reset() { *m = QueryPendingNoncesByChainRequest{} } +func (m *QueryPendingNoncesByChainRequest) String() string { return proto.CompactTextString(m) } +func (*QueryPendingNoncesByChainRequest) ProtoMessage() {} +func (*QueryPendingNoncesByChainRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_65a992045e92a606, []int{30} +} +func (m *QueryPendingNoncesByChainRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *QueryPendingNoncesByChainRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_QueryPendingNoncesByChainRequest.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *QueryPendingNoncesByChainRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_QueryPendingNoncesByChainRequest.Merge(m, src) +} +func (m *QueryPendingNoncesByChainRequest) XXX_Size() int { + return m.Size() +} +func (m *QueryPendingNoncesByChainRequest) XXX_DiscardUnknown() { + xxx_messageInfo_QueryPendingNoncesByChainRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_QueryPendingNoncesByChainRequest proto.InternalMessageInfo + +func (m *QueryPendingNoncesByChainRequest) GetChainId() uint64 { + if m != nil { + return m.ChainId + } + return 0 +} + +type QueryPendingNoncesByChainResponse struct { + PendingNonces PendingNonces `protobuf:"bytes,1,opt,name=pending_nonces,json=pendingNonces,proto3" json:"pending_nonces"` +} + +func (m *QueryPendingNoncesByChainResponse) Reset() { *m = QueryPendingNoncesByChainResponse{} } +func (m *QueryPendingNoncesByChainResponse) String() string { return proto.CompactTextString(m) } +func (*QueryPendingNoncesByChainResponse) ProtoMessage() {} +func (*QueryPendingNoncesByChainResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_65a992045e92a606, []int{31} +} +func (m *QueryPendingNoncesByChainResponse) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *QueryPendingNoncesByChainResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_QueryPendingNoncesByChainResponse.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *QueryPendingNoncesByChainResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_QueryPendingNoncesByChainResponse.Merge(m, src) +} +func (m *QueryPendingNoncesByChainResponse) XXX_Size() int { + return m.Size() +} +func (m *QueryPendingNoncesByChainResponse) XXX_DiscardUnknown() { + xxx_messageInfo_QueryPendingNoncesByChainResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_QueryPendingNoncesByChainResponse proto.InternalMessageInfo + +func (m *QueryPendingNoncesByChainResponse) GetPendingNonces() PendingNonces { + if m != nil { + return m.PendingNonces + } + return PendingNonces{} +} + type QueryGetLastBlockHeightRequest struct { Index string `protobuf:"bytes,1,opt,name=index,proto3" json:"index,omitempty"` } @@ -1386,7 +1474,7 @@ func (m *QueryGetLastBlockHeightRequest) Reset() { *m = QueryGetLastBloc func (m *QueryGetLastBlockHeightRequest) String() string { return proto.CompactTextString(m) } func (*QueryGetLastBlockHeightRequest) ProtoMessage() {} func (*QueryGetLastBlockHeightRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{30} + return fileDescriptor_65a992045e92a606, []int{32} } func (m *QueryGetLastBlockHeightRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1430,7 +1518,7 @@ func (m *QueryGetLastBlockHeightResponse) Reset() { *m = QueryGetLastBlo func (m *QueryGetLastBlockHeightResponse) String() string { return proto.CompactTextString(m) } func (*QueryGetLastBlockHeightResponse) ProtoMessage() {} func (*QueryGetLastBlockHeightResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{31} + return fileDescriptor_65a992045e92a606, []int{33} } func (m *QueryGetLastBlockHeightResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1474,7 +1562,7 @@ func (m *QueryAllLastBlockHeightRequest) Reset() { *m = QueryAllLastBloc func (m *QueryAllLastBlockHeightRequest) String() string { return proto.CompactTextString(m) } func (*QueryAllLastBlockHeightRequest) ProtoMessage() {} func (*QueryAllLastBlockHeightRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{32} + return fileDescriptor_65a992045e92a606, []int{34} } func (m *QueryAllLastBlockHeightRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1519,7 +1607,7 @@ func (m *QueryAllLastBlockHeightResponse) Reset() { *m = QueryAllLastBlo func (m *QueryAllLastBlockHeightResponse) String() string { return proto.CompactTextString(m) } func (*QueryAllLastBlockHeightResponse) ProtoMessage() {} func (*QueryAllLastBlockHeightResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{33} + return fileDescriptor_65a992045e92a606, []int{35} } func (m *QueryAllLastBlockHeightResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1570,7 +1658,7 @@ func (m *QueryGetCctxRequest) Reset() { *m = QueryGetCctxRequest{} } func (m *QueryGetCctxRequest) String() string { return proto.CompactTextString(m) } func (*QueryGetCctxRequest) ProtoMessage() {} func (*QueryGetCctxRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{34} + return fileDescriptor_65a992045e92a606, []int{36} } func (m *QueryGetCctxRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1615,7 +1703,7 @@ func (m *QueryGetCctxByNonceRequest) Reset() { *m = QueryGetCctxByNonceR func (m *QueryGetCctxByNonceRequest) String() string { return proto.CompactTextString(m) } func (*QueryGetCctxByNonceRequest) ProtoMessage() {} func (*QueryGetCctxByNonceRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{35} + return fileDescriptor_65a992045e92a606, []int{37} } func (m *QueryGetCctxByNonceRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1666,7 +1754,7 @@ func (m *QueryGetCctxResponse) Reset() { *m = QueryGetCctxResponse{} } func (m *QueryGetCctxResponse) String() string { return proto.CompactTextString(m) } func (*QueryGetCctxResponse) ProtoMessage() {} func (*QueryGetCctxResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{36} + return fileDescriptor_65a992045e92a606, []int{38} } func (m *QueryGetCctxResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1710,7 +1798,7 @@ func (m *QueryAllCctxRequest) Reset() { *m = QueryAllCctxRequest{} } func (m *QueryAllCctxRequest) String() string { return proto.CompactTextString(m) } func (*QueryAllCctxRequest) ProtoMessage() {} func (*QueryAllCctxRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{37} + return fileDescriptor_65a992045e92a606, []int{39} } func (m *QueryAllCctxRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1755,7 +1843,7 @@ func (m *QueryAllCctxResponse) Reset() { *m = QueryAllCctxResponse{} } func (m *QueryAllCctxResponse) String() string { return proto.CompactTextString(m) } func (*QueryAllCctxResponse) ProtoMessage() {} func (*QueryAllCctxResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{38} + return fileDescriptor_65a992045e92a606, []int{40} } func (m *QueryAllCctxResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1807,7 +1895,7 @@ func (m *QueryAllCctxPendingRequest) Reset() { *m = QueryAllCctxPendingR func (m *QueryAllCctxPendingRequest) String() string { return proto.CompactTextString(m) } func (*QueryAllCctxPendingRequest) ProtoMessage() {} func (*QueryAllCctxPendingRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{39} + return fileDescriptor_65a992045e92a606, []int{41} } func (m *QueryAllCctxPendingRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1859,7 +1947,7 @@ func (m *QueryAllCctxPendingResponse) Reset() { *m = QueryAllCctxPending func (m *QueryAllCctxPendingResponse) String() string { return proto.CompactTextString(m) } func (*QueryAllCctxPendingResponse) ProtoMessage() {} func (*QueryAllCctxPendingResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{40} + return fileDescriptor_65a992045e92a606, []int{42} } func (m *QueryAllCctxPendingResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1909,7 +1997,7 @@ func (m *QueryLastZetaHeightRequest) Reset() { *m = QueryLastZetaHeightR func (m *QueryLastZetaHeightRequest) String() string { return proto.CompactTextString(m) } func (*QueryLastZetaHeightRequest) ProtoMessage() {} func (*QueryLastZetaHeightRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{41} + return fileDescriptor_65a992045e92a606, []int{43} } func (m *QueryLastZetaHeightRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1946,7 +2034,7 @@ func (m *QueryLastZetaHeightResponse) Reset() { *m = QueryLastZetaHeight func (m *QueryLastZetaHeightResponse) String() string { return proto.CompactTextString(m) } func (*QueryLastZetaHeightResponse) ProtoMessage() {} func (*QueryLastZetaHeightResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{42} + return fileDescriptor_65a992045e92a606, []int{44} } func (m *QueryLastZetaHeightResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1991,7 +2079,7 @@ func (m *QueryConvertGasToZetaRequest) Reset() { *m = QueryConvertGasToZ func (m *QueryConvertGasToZetaRequest) String() string { return proto.CompactTextString(m) } func (*QueryConvertGasToZetaRequest) ProtoMessage() {} func (*QueryConvertGasToZetaRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{43} + return fileDescriptor_65a992045e92a606, []int{45} } func (m *QueryConvertGasToZetaRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2044,7 +2132,7 @@ func (m *QueryConvertGasToZetaResponse) Reset() { *m = QueryConvertGasTo func (m *QueryConvertGasToZetaResponse) String() string { return proto.CompactTextString(m) } func (*QueryConvertGasToZetaResponse) ProtoMessage() {} func (*QueryConvertGasToZetaResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{44} + return fileDescriptor_65a992045e92a606, []int{46} } func (m *QueryConvertGasToZetaResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2101,7 +2189,7 @@ func (m *QueryMessagePassingProtocolFeeRequest) Reset() { *m = QueryMess func (m *QueryMessagePassingProtocolFeeRequest) String() string { return proto.CompactTextString(m) } func (*QueryMessagePassingProtocolFeeRequest) ProtoMessage() {} func (*QueryMessagePassingProtocolFeeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{45} + return fileDescriptor_65a992045e92a606, []int{47} } func (m *QueryMessagePassingProtocolFeeRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2140,7 +2228,7 @@ func (m *QueryMessagePassingProtocolFeeResponse) Reset() { func (m *QueryMessagePassingProtocolFeeResponse) String() string { return proto.CompactTextString(m) } func (*QueryMessagePassingProtocolFeeResponse) ProtoMessage() {} func (*QueryMessagePassingProtocolFeeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{46} + return fileDescriptor_65a992045e92a606, []int{48} } func (m *QueryMessagePassingProtocolFeeResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2184,7 +2272,7 @@ func (m *QueryZEVMGetTransactionReceiptRequest) Reset() { *m = QueryZEVM func (m *QueryZEVMGetTransactionReceiptRequest) String() string { return proto.CompactTextString(m) } func (*QueryZEVMGetTransactionReceiptRequest) ProtoMessage() {} func (*QueryZEVMGetTransactionReceiptRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{47} + return fileDescriptor_65a992045e92a606, []int{49} } func (m *QueryZEVMGetTransactionReceiptRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2241,7 +2329,7 @@ func (m *QueryZEVMGetTransactionReceiptResponse) Reset() { func (m *QueryZEVMGetTransactionReceiptResponse) String() string { return proto.CompactTextString(m) } func (*QueryZEVMGetTransactionReceiptResponse) ProtoMessage() {} func (*QueryZEVMGetTransactionReceiptResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{48} + return fileDescriptor_65a992045e92a606, []int{50} } func (m *QueryZEVMGetTransactionReceiptResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2371,7 +2459,7 @@ func (m *Log) Reset() { *m = Log{} } func (m *Log) String() string { return proto.CompactTextString(m) } func (*Log) ProtoMessage() {} func (*Log) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{49} + return fileDescriptor_65a992045e92a606, []int{51} } func (m *Log) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2471,7 +2559,7 @@ func (m *QueryZEVMGetTransactionRequest) Reset() { *m = QueryZEVMGetTran func (m *QueryZEVMGetTransactionRequest) String() string { return proto.CompactTextString(m) } func (*QueryZEVMGetTransactionRequest) ProtoMessage() {} func (*QueryZEVMGetTransactionRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{50} + return fileDescriptor_65a992045e92a606, []int{52} } func (m *QueryZEVMGetTransactionRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2531,7 +2619,7 @@ func (m *QueryZEVMGetTransactionResponse) Reset() { *m = QueryZEVMGetTra func (m *QueryZEVMGetTransactionResponse) String() string { return proto.CompactTextString(m) } func (*QueryZEVMGetTransactionResponse) ProtoMessage() {} func (*QueryZEVMGetTransactionResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{51} + return fileDescriptor_65a992045e92a606, []int{53} } func (m *QueryZEVMGetTransactionResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2687,7 +2775,7 @@ func (m *QueryZEVMGetBlockByNumberRequest) Reset() { *m = QueryZEVMGetBl func (m *QueryZEVMGetBlockByNumberRequest) String() string { return proto.CompactTextString(m) } func (*QueryZEVMGetBlockByNumberRequest) ProtoMessage() {} func (*QueryZEVMGetBlockByNumberRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{52} + return fileDescriptor_65a992045e92a606, []int{54} } func (m *QueryZEVMGetBlockByNumberRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2751,7 +2839,7 @@ func (m *QueryZEVMGetBlockByNumberResponse) Reset() { *m = QueryZEVMGetB func (m *QueryZEVMGetBlockByNumberResponse) String() string { return proto.CompactTextString(m) } func (*QueryZEVMGetBlockByNumberResponse) ProtoMessage() {} func (*QueryZEVMGetBlockByNumberResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_65a992045e92a606, []int{53} + return fileDescriptor_65a992045e92a606, []int{55} } func (m *QueryZEVMGetBlockByNumberResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2958,6 +3046,8 @@ func init() { proto.RegisterType((*QueryAllChainNoncesResponse)(nil), "zetachain.zetacore.crosschain.QueryAllChainNoncesResponse") proto.RegisterType((*QueryAllPendingNoncesRequest)(nil), "zetachain.zetacore.crosschain.QueryAllPendingNoncesRequest") proto.RegisterType((*QueryAllPendingNoncesResponse)(nil), "zetachain.zetacore.crosschain.QueryAllPendingNoncesResponse") + proto.RegisterType((*QueryPendingNoncesByChainRequest)(nil), "zetachain.zetacore.crosschain.QueryPendingNoncesByChainRequest") + proto.RegisterType((*QueryPendingNoncesByChainResponse)(nil), "zetachain.zetacore.crosschain.QueryPendingNoncesByChainResponse") proto.RegisterType((*QueryGetLastBlockHeightRequest)(nil), "zetachain.zetacore.crosschain.QueryGetLastBlockHeightRequest") proto.RegisterType((*QueryGetLastBlockHeightResponse)(nil), "zetachain.zetacore.crosschain.QueryGetLastBlockHeightResponse") proto.RegisterType((*QueryAllLastBlockHeightRequest)(nil), "zetachain.zetacore.crosschain.QueryAllLastBlockHeightRequest") @@ -2987,192 +3077,196 @@ func init() { func init() { proto.RegisterFile("crosschain/query.proto", fileDescriptor_65a992045e92a606) } var fileDescriptor_65a992045e92a606 = []byte{ - // 2949 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xd4, 0x5a, 0x5b, 0x6f, 0x1b, 0xc7, - 0xf5, 0xf7, 0x8a, 0x14, 0x25, 0x8d, 0xae, 0x1e, 0x2b, 0x0e, 0xc3, 0xd8, 0xa2, 0xb3, 0x8e, 0x2f, - 0xf1, 0x85, 0x8c, 0x15, 0xdb, 0x49, 0x6c, 0x27, 0xf8, 0x4b, 0x76, 0xac, 0x18, 0x51, 0x12, 0xfd, - 0x57, 0x4a, 0x5b, 0xb8, 0x68, 0x89, 0xd5, 0x72, 0x4c, 0x2d, 0xb2, 0xe4, 0x32, 0x3b, 0x43, 0x41, - 0x8a, 0xe1, 0x3e, 0xe4, 0x13, 0x04, 0x28, 0xd0, 0xbe, 0xf4, 0xb5, 0x97, 0x87, 0x3e, 0x14, 0x68, - 0xd0, 0x14, 0x28, 0x90, 0x3e, 0xb4, 0x4d, 0xf3, 0x18, 0xa0, 0x40, 0xd1, 0x22, 0x00, 0x51, 0xc4, - 0x7d, 0xe2, 0x37, 0x28, 0xd0, 0x87, 0x62, 0xce, 0x9e, 0xe5, 0xce, 0x92, 0xbb, 0xe2, 0x9a, 0x62, - 0x8b, 0xf6, 0x85, 0x3b, 0x73, 0x66, 0xce, 0x99, 0xdf, 0xb9, 0xcc, 0xcc, 0xd9, 0x3d, 0x24, 0xc7, - 0x2d, 0xcf, 0xe5, 0xdc, 0xda, 0x31, 0xed, 0x46, 0xf9, 0x83, 0x16, 0xf3, 0xf6, 0x4b, 0x4d, 0xcf, - 0x15, 0x2e, 0x3d, 0xf9, 0x21, 0x13, 0x26, 0x90, 0x4b, 0xd0, 0x72, 0x3d, 0x56, 0x0a, 0xa7, 0x16, - 0x2e, 0x58, 0x2e, 0xaf, 0xbb, 0xbc, 0xbc, 0x6d, 0x72, 0xe6, 0xf3, 0x95, 0x77, 0xaf, 0x6c, 0x33, - 0x61, 0x5e, 0x29, 0x37, 0xcd, 0x9a, 0xdd, 0x30, 0x85, 0xed, 0x36, 0x7c, 0x51, 0x85, 0x93, 0xca, - 0x12, 0xf0, 0x5b, 0x69, 0xb8, 0x0d, 0x8b, 0x71, 0x1c, 0x2e, 0xaa, 0xc3, 0xb2, 0x59, 0xf1, 0x27, - 0x89, 0x3d, 0x9c, 0x50, 0x50, 0x26, 0xd4, 0x4c, 0x5e, 0x69, 0x7a, 0xb6, 0xc5, 0x70, 0xec, 0xb4, - 0x32, 0x06, 0x3c, 0x95, 0x1d, 0x93, 0xef, 0x54, 0x84, 0x5b, 0xb1, 0xac, 0xae, 0x00, 0x5d, 0x99, - 0xe4, 0x98, 0x5c, 0x54, 0xb6, 0x1d, 0xd7, 0x7a, 0xbf, 0xb2, 0xc3, 0xec, 0xda, 0x8e, 0xc0, 0x39, - 0x4b, 0xca, 0x1c, 0x80, 0xd7, 0x23, 0x43, 0x45, 0xe9, 0xb6, 0x84, 0x5c, 0x49, 0x78, 0xa6, 0xf5, - 0x3e, 0xf3, 0x70, 0xc2, 0xd3, 0xca, 0x84, 0xa6, 0xe9, 0x99, 0xf5, 0x40, 0xbf, 0x45, 0x65, 0x40, - 0xf0, 0x2e, 0xb5, 0xe6, 0xd6, 0x5c, 0x68, 0x96, 0x65, 0x0b, 0xa9, 0x27, 0x6a, 0xae, 0x5b, 0x73, - 0x58, 0xd9, 0x6c, 0xda, 0x65, 0xb3, 0xd1, 0x70, 0x05, 0xd8, 0x11, 0x79, 0xf4, 0x3c, 0x39, 0xfe, - 0xff, 0xd2, 0xd4, 0x5b, 0x9c, 0xbf, 0x69, 0x73, 0xe1, 0x7a, 0xfb, 0x06, 0xfb, 0xa0, 0xc5, 0xb8, - 0xd0, 0xbf, 0x4b, 0x9e, 0xee, 0x1b, 0xe1, 0x4d, 0xb7, 0xc1, 0x19, 0xbd, 0x4d, 0x26, 0x05, 0xe7, - 0x15, 0xc7, 0xe6, 0x22, 0xaf, 0x9d, 0xca, 0x9c, 0x9f, 0x5e, 0xd6, 0x4b, 0x07, 0xfa, 0xb6, 0xb4, - 0xb5, 0xb9, 0xb9, 0x9a, 0xfd, 0xa2, 0x5d, 0x3c, 0x62, 0x4c, 0x08, 0xce, 0xd7, 0x6d, 0x2e, 0xf4, - 0x45, 0x42, 0x41, 0xfe, 0x06, 0x28, 0x16, 0xac, 0x7a, 0x9f, 0x1c, 0x8b, 0x50, 0xbb, 0x2b, 0xe6, - 0x7c, 0x03, 0xe4, 0xb5, 0x53, 0xda, 0xf9, 0xe9, 0xe5, 0x33, 0x03, 0xd6, 0xf3, 0xd9, 0x71, 0x49, - 0x64, 0xd5, 0xdf, 0x26, 0xcf, 0x82, 0xec, 0x35, 0x26, 0xde, 0x6d, 0x89, 0xad, 0xbd, 0x2d, 0xdf, - 0xd8, 0xb8, 0x34, 0xcd, 0x93, 0x09, 0x60, 0xbe, 0x77, 0x07, 0x16, 0xc9, 0x18, 0x41, 0x97, 0x2e, - 0x92, 0x71, 0xf0, 0x5f, 0x7e, 0xec, 0x94, 0x76, 0x3e, 0x6b, 0xf8, 0x1d, 0xbd, 0x45, 0x4e, 0xc4, - 0x8b, 0x43, 0xcc, 0xef, 0x91, 0x19, 0x57, 0xa1, 0x23, 0xf2, 0x8b, 0x03, 0x90, 0xab, 0xa2, 0x10, - 0x7f, 0x44, 0x8c, 0xce, 0x50, 0x8b, 0x15, 0xc7, 0x89, 0xd3, 0xe2, 0x2e, 0x21, 0xe1, 0x6e, 0xc1, - 0x35, 0xcf, 0x96, 0xfc, 0xad, 0x55, 0x92, 0x5b, 0xab, 0xe4, 0x6f, 0x49, 0xdc, 0x5a, 0xa5, 0x0d, - 0xb3, 0xc6, 0x90, 0xd7, 0x50, 0x38, 0xf5, 0xcf, 0x34, 0x54, 0xaf, 0x6f, 0x9d, 0x44, 0xf5, 0x32, - 0x23, 0x50, 0x8f, 0xae, 0x45, 0xf0, 0x8f, 0x01, 0xfe, 0x73, 0x03, 0xf1, 0xfb, 0x98, 0x22, 0x0a, - 0x7c, 0xa4, 0x11, 0x3d, 0x4e, 0x81, 0xd5, 0xfd, 0xdb, 0x12, 0x49, 0x60, 0xaf, 0x45, 0x32, 0x0e, - 0xc8, 0xd0, 0xe7, 0x7e, 0xa7, 0xc7, 0x8a, 0x63, 0x43, 0x5b, 0xf1, 0x0f, 0x1a, 0x39, 0x7d, 0x20, - 0x88, 0xff, 0x11, 0x63, 0xde, 0x24, 0x27, 0x83, 0x58, 0xbf, 0xd7, 0xd8, 0xda, 0x7b, 0xd3, 0xe4, - 0x3b, 0x5b, 0xee, 0x6d, 0x4b, 0xec, 0x05, 0x66, 0x2c, 0x90, 0x49, 0x1b, 0x07, 0xc0, 0x92, 0x53, - 0x46, 0xb7, 0xaf, 0x3f, 0x22, 0x4b, 0x49, 0xcc, 0xa8, 0xfe, 0xb7, 0xc9, 0x9c, 0x1d, 0x19, 0xc1, - 0xc0, 0xbd, 0x3c, 0xc0, 0x00, 0x51, 0x71, 0x68, 0x82, 0x1e, 0x51, 0xfa, 0x2d, 0x5c, 0x3e, 0x3a, - 0xf9, 0x8e, 0x29, 0xcc, 0x34, 0xe0, 0x3f, 0x24, 0xc5, 0x44, 0x6e, 0x44, 0xff, 0x4d, 0x32, 0x7b, - 0x5b, 0x62, 0x02, 0x97, 0x6e, 0xed, 0xf1, 0x94, 0xde, 0x53, 0x79, 0x10, 0x7a, 0x54, 0x8e, 0x5e, - 0x43, 0xab, 0xaf, 0x38, 0x4e, 0xbc, 0xd5, 0x47, 0xb5, 0xd9, 0x3f, 0xd7, 0xd0, 0x46, 0x31, 0x2b, - 0x1d, 0xe0, 0xa2, 0xcc, 0x88, 0x5c, 0x34, 0xba, 0x38, 0x7d, 0x96, 0x3c, 0x13, 0x84, 0xda, 0x16, - 0xe7, 0x2b, 0xd5, 0xaa, 0xc7, 0x78, 0xf7, 0x6e, 0xf9, 0x3f, 0x52, 0x88, 0x1b, 0x44, 0x05, 0x17, - 0x48, 0x86, 0x89, 0xc0, 0xff, 0xb2, 0x29, 0x29, 0xdb, 0xc2, 0x02, 0x38, 0x53, 0x86, 0x6c, 0x76, - 0xef, 0x2c, 0x29, 0x61, 0x73, 0x33, 0x90, 0xfb, 0x16, 0xde, 0x59, 0x01, 0x15, 0x05, 0x5e, 0x25, - 0x99, 0xad, 0xcd, 0x4d, 0xf4, 0x4a, 0x8a, 0x0b, 0xd2, 0x90, 0xd3, 0xf5, 0x32, 0x5e, 0xbb, 0x6b, - 0x4c, 0xac, 0x99, 0x7c, 0x43, 0xe6, 0x25, 0xca, 0x51, 0x65, 0x37, 0xaa, 0x6c, 0x0f, 0x31, 0xfa, - 0x1d, 0xbd, 0x42, 0xf2, 0xfd, 0x0c, 0xe1, 0x45, 0x1d, 0xd0, 0x10, 0xc7, 0xb9, 0x01, 0x38, 0xba, - 0x22, 0xba, 0x8c, 0xba, 0x89, 0x88, 0x56, 0x1c, 0xa7, 0x17, 0xd1, 0xa8, 0xe2, 0xef, 0x67, 0x1a, - 0x2a, 0x11, 0x59, 0x23, 0x56, 0x89, 0xcc, 0x50, 0x4a, 0x8c, 0x2e, 0xc2, 0x96, 0xc3, 0x20, 0x82, - 0x7d, 0xfa, 0x0e, 0xe4, 0x9d, 0x07, 0xbb, 0xe8, 0xfd, 0x30, 0xf1, 0x88, 0xf0, 0xa0, 0x82, 0xeb, - 0x64, 0x5a, 0x21, 0xa3, 0x19, 0x2f, 0x0c, 0x3a, 0x3d, 0x14, 0x41, 0x2a, 0xbb, 0x5e, 0x45, 0x80, - 0x2b, 0x8e, 0x13, 0x03, 0x70, 0x54, 0x1e, 0xfb, 0x44, 0x0b, 0xd3, 0x90, 0x54, 0x3a, 0x65, 0x0e, - 0xa1, 0xd3, 0xe8, 0xbc, 0xb7, 0x14, 0x26, 0x35, 0x1b, 0xac, 0x51, 0xb5, 0x1b, 0xb5, 0x88, 0x79, - 0x74, 0x11, 0x9e, 0xb8, 0x3d, 0xe3, 0xa8, 0xd7, 0x26, 0x99, 0x6b, 0xfa, 0x03, 0xf8, 0xc6, 0x81, - 0xaa, 0x5d, 0x1a, 0x94, 0x90, 0x46, 0xa4, 0xcd, 0x36, 0xd5, 0xae, 0x7e, 0x3d, 0xbc, 0x20, 0xd7, - 0x4d, 0x2e, 0x56, 0xe5, 0xab, 0xc4, 0x9b, 0xf0, 0x26, 0x71, 0x70, 0x5c, 0x3d, 0xc4, 0xbb, 0x29, - 0x8e, 0x0f, 0xf1, 0x7e, 0x8b, 0xcc, 0xf7, 0x0c, 0xa1, 0xd3, 0x4b, 0x03, 0x00, 0xf7, 0x0a, 0xec, - 0x15, 0xa3, 0xef, 0x84, 0x57, 0x46, 0x02, 0xe8, 0x51, 0xc5, 0xda, 0xef, 0x35, 0xd4, 0x33, 0x6e, - 0xa9, 0x83, 0xf4, 0xcc, 0x8c, 0x40, 0xcf, 0xd1, 0xc5, 0xde, 0xc5, 0xf0, 0x9a, 0x50, 0xef, 0xf0, - 0x78, 0xd7, 0xae, 0x2b, 0xc7, 0x8c, 0xbc, 0x37, 0xf7, 0x21, 0x54, 0x86, 0x7d, 0x55, 0xa9, 0x91, - 0xc5, 0xe8, 0xd2, 0x68, 0xb5, 0x77, 0xc9, 0x8c, 0x9a, 0x71, 0xa4, 0x7c, 0x45, 0x51, 0x59, 0x8c, - 0x88, 0x00, 0xfd, 0x3b, 0xa8, 0xa3, 0x3c, 0x15, 0xfe, 0x0d, 0x79, 0xca, 0x2f, 0x34, 0x54, 0xa4, - 0x2b, 0x3f, 0x51, 0x91, 0xcc, 0xa1, 0x14, 0x19, 0x9d, 0xd7, 0xbf, 0xa7, 0x1c, 0xc7, 0x96, 0xd8, - 0xc3, 0x73, 0xa0, 0xcf, 0x91, 0x55, 0xb0, 0x4a, 0x36, 0x70, 0x64, 0x75, 0x64, 0x6f, 0x20, 0x9f, - 0xaa, 0x07, 0xb5, 0x0a, 0xe0, 0xbf, 0xde, 0x72, 0x27, 0xd0, 0x72, 0x72, 0x43, 0xde, 0x67, 0xc2, - 0x8c, 0x1c, 0x2e, 0xfa, 0x35, 0x54, 0xab, 0x77, 0x14, 0xd5, 0x3a, 0x4e, 0x72, 0xca, 0x71, 0x97, - 0x31, 0xb0, 0xa7, 0x6f, 0xe1, 0x05, 0x70, 0xdb, 0x6d, 0xec, 0x32, 0x4f, 0x66, 0x4c, 0x5b, 0xae, - 0x64, 0x4f, 0x70, 0x48, 0x26, 0x74, 0x48, 0x81, 0x4c, 0xd6, 0x4c, 0xbe, 0x6e, 0xd7, 0x6d, 0x81, - 0x29, 0x61, 0xb7, 0xaf, 0xff, 0x58, 0xc3, 0x7b, 0xa3, 0x5f, 0x2c, 0xe2, 0xb9, 0x44, 0x8e, 0xba, - 0x2d, 0xb1, 0xed, 0xb6, 0x1a, 0xd5, 0x35, 0x93, 0xdf, 0x6b, 0xc8, 0x41, 0xdc, 0xf1, 0xfd, 0x03, - 0x72, 0x36, 0x7c, 0x9e, 0xb1, 0x5c, 0xe7, 0x2e, 0x63, 0x38, 0xdb, 0x5f, 0xb4, 0x7f, 0x80, 0x9e, - 0x27, 0xf3, 0xf2, 0xa9, 0x9e, 0x7d, 0x19, 0x08, 0xa6, 0x5e, 0xb2, 0x7e, 0x8e, 0x9c, 0x01, 0x98, - 0x6f, 0x33, 0xce, 0xcd, 0x1a, 0xdb, 0x30, 0x39, 0xb7, 0x1b, 0xb5, 0x8d, 0x50, 0x62, 0x60, 0xdd, - 0xbb, 0xe4, 0xec, 0xa0, 0x89, 0xa8, 0xd8, 0x09, 0x32, 0xf5, 0xa0, 0x0b, 0xd1, 0x57, 0x28, 0x24, - 0xe8, 0x37, 0x71, 0xc1, 0xfb, 0x6f, 0x7c, 0xe3, 0x6d, 0x99, 0x1e, 0x7b, 0x66, 0x83, 0x9b, 0x96, - 0x74, 0xaf, 0xc1, 0x2c, 0x66, 0x37, 0xbb, 0x77, 0x05, 0x25, 0xd9, 0x9d, 0xf0, 0xf5, 0x0b, 0xda, - 0xfa, 0x3f, 0xb3, 0x88, 0xe2, 0x00, 0xee, 0xae, 0x79, 0x09, 0x7e, 0x80, 0xeb, 0x0a, 0x59, 0x9d, - 0xed, 0xb4, 0x8b, 0x53, 0x40, 0x95, 0x6f, 0x1a, 0x46, 0xd8, 0xa4, 0xcb, 0x64, 0xc6, 0x9f, 0xdd, - 0x68, 0xd5, 0xb7, 0x99, 0xe7, 0x5b, 0x76, 0x75, 0xbe, 0xd3, 0x2e, 0x4e, 0x03, 0xfd, 0x1d, 0x20, - 0x1b, 0x6a, 0x87, 0xbe, 0x4e, 0x16, 0x2c, 0xb7, 0x21, 0x3c, 0xd3, 0x12, 0x15, 0xd3, 0x7f, 0x75, - 0x00, 0x2b, 0x4f, 0xad, 0x1e, 0xeb, 0xb4, 0x8b, 0xf3, 0xc1, 0x58, 0xf0, 0x56, 0xd1, 0x4b, 0xa0, - 0x6f, 0x90, 0x63, 0x56, 0xab, 0xde, 0x72, 0x4c, 0x61, 0xef, 0xb2, 0x4a, 0xcd, 0xe4, 0x95, 0x16, - 0x67, 0xd5, 0x7c, 0x16, 0x44, 0x3c, 0xd5, 0x69, 0x17, 0x8f, 0x86, 0xc3, 0x6b, 0x26, 0x7f, 0x8f, - 0xb3, 0xaa, 0xd1, 0x4f, 0xa2, 0x27, 0x48, 0xf6, 0x81, 0xe7, 0xd6, 0xf3, 0xe3, 0xc0, 0x37, 0xd9, - 0x69, 0x17, 0xa1, 0x6f, 0xc0, 0x2f, 0x3d, 0x0b, 0x31, 0xea, 0x4b, 0xce, 0xc1, 0x8c, 0xe9, 0x4e, - 0xbb, 0x38, 0x51, 0x43, 0x79, 0x41, 0x43, 0x9a, 0xcb, 0x71, 0x6b, 0xbc, 0xb2, 0xed, 0xb8, 0x6e, - 0x3d, 0x3f, 0x11, 0x9a, 0x4b, 0x52, 0x57, 0x25, 0xd1, 0x08, 0x9b, 0x54, 0x27, 0x39, 0x2e, 0x4c, - 0xd1, 0xe2, 0xf9, 0x49, 0x98, 0x49, 0x3a, 0xed, 0x22, 0x52, 0x0c, 0x7c, 0xd2, 0xe3, 0x64, 0x4c, - 0xb8, 0xf9, 0x29, 0x18, 0xcf, 0x75, 0xda, 0xc5, 0x31, 0xe1, 0x1a, 0x63, 0xc2, 0x95, 0x66, 0x13, - 0xa1, 0xdb, 0x7c, 0xf7, 0x90, 0xd0, 0x6c, 0xca, 0x18, 0x38, 0xa9, 0x97, 0x40, 0x57, 0xc8, 0x51, - 0x95, 0xdf, 0xbf, 0x29, 0xa7, 0x41, 0xc0, 0x62, 0xa7, 0x5d, 0x54, 0x85, 0xdf, 0x93, 0x63, 0x46, - 0x1f, 0x85, 0x5e, 0x27, 0x59, 0xa9, 0x4b, 0x7e, 0x26, 0xd5, 0x97, 0xca, 0x75, 0xb7, 0x66, 0xc0, - 0x7c, 0xfd, 0xa3, 0x0c, 0xc9, 0xac, 0xbb, 0x35, 0x79, 0x24, 0x04, 0x0e, 0xf7, 0xa3, 0x33, 0xe8, - 0xca, 0x43, 0x46, 0xb8, 0x4d, 0xdb, 0xe2, 0xf9, 0xb1, 0x53, 0x99, 0xf3, 0x53, 0x06, 0xf6, 0x64, - 0x30, 0x57, 0x4d, 0x61, 0xfa, 0xf1, 0x61, 0x40, 0xbb, 0x2f, 0xe6, 0xa4, 0xe3, 0xb3, 0x83, 0x63, - 0xae, 0xcf, 0x78, 0xe3, 0x87, 0x35, 0x5e, 0x0e, 0x16, 0x4e, 0x6b, 0xbc, 0xe8, 0xc6, 0x9a, 0x18, - 0xb0, 0xb1, 0x5e, 0x20, 0x32, 0x6c, 0x70, 0xa1, 0x49, 0x58, 0x68, 0xa6, 0xd3, 0x2e, 0x4e, 0x3a, - 0x6e, 0xcd, 0x5f, 0xa0, 0xdb, 0xa2, 0x67, 0xc8, 0x84, 0xc7, 0xea, 0xee, 0x2e, 0xab, 0x42, 0xd4, - 0x4c, 0xfa, 0x91, 0x8a, 0x24, 0x23, 0x68, 0xe8, 0x57, 0x31, 0xcb, 0x8c, 0x3b, 0x02, 0x92, 0x4f, - 0x8e, 0x7f, 0x64, 0x31, 0x63, 0x8c, 0x63, 0xfb, 0x8f, 0x1d, 0x19, 0xc1, 0x5e, 0xcd, 0xc4, 0xee, - 0xd5, 0x67, 0x48, 0xa6, 0x66, 0x72, 0x3c, 0x00, 0x26, 0x3a, 0xed, 0xa2, 0xec, 0x1a, 0xf2, 0x47, - 0x9a, 0xb1, 0x5b, 0x94, 0x40, 0x87, 0x83, 0x19, 0x6b, 0xdd, 0xf7, 0xda, 0xa0, 0x25, 0xd7, 0x00, - 0xfc, 0xb9, 0x70, 0x0d, 0xd9, 0xf7, 0xed, 0x40, 0x8b, 0x32, 0xb7, 0x6c, 0xb6, 0x04, 0x3a, 0x6e, - 0xaa, 0xd3, 0x2e, 0xfa, 0x04, 0xc3, 0x7f, 0xc8, 0x09, 0x7e, 0xba, 0x38, 0x19, 0x4e, 0x00, 0x02, - 0x66, 0x8e, 0x89, 0xfb, 0x3a, 0x36, 0xb4, 0xc8, 0x13, 0xed, 0xcb, 0x22, 0x19, 0xdf, 0x35, 0x9d, - 0x16, 0xc3, 0xed, 0x0c, 0x6b, 0x03, 0xc1, 0xf0, 0x1f, 0x52, 0x37, 0xb1, 0xdf, 0x64, 0xf9, 0x99, - 0x50, 0x37, 0xd9, 0x37, 0xe0, 0x97, 0x96, 0xc9, 0xb4, 0x69, 0x59, 0x2c, 0xa8, 0x43, 0xcc, 0xca, - 0x1d, 0xb8, 0x3a, 0xd7, 0x69, 0x17, 0x89, 0x4f, 0x5e, 0xb7, 0x65, 0x26, 0x14, 0xb6, 0xe5, 0xe1, - 0xe8, 0x57, 0x81, 0xec, 0x6a, 0x7e, 0x2e, 0x3c, 0x1c, 0xf1, 0x7e, 0x0f, 0x2f, 0xfa, 0x63, 0x44, - 0xdb, 0xcd, 0xcf, 0xc3, 0x84, 0xf1, 0x4e, 0xbb, 0xa8, 0xed, 0x1a, 0xda, 0xae, 0x24, 0x7a, 0xf9, - 0x85, 0x90, 0xe8, 0x19, 0x9a, 0x27, 0x89, 0x3c, 0x7f, 0x34, 0x24, 0x72, 0x43, 0xe3, 0xfa, 0x0d, - 0x72, 0x4a, 0x0d, 0x3d, 0xb8, 0x7e, 0x57, 0xf7, 0x31, 0x3e, 0x30, 0x66, 0x8f, 0x93, 0xdc, 0x4e, - 0x98, 0x9d, 0x64, 0x0d, 0xec, 0xe9, 0x7f, 0x9d, 0x20, 0xcf, 0x1d, 0xc0, 0x8c, 0x91, 0xab, 0x93, - 0x1c, 0x46, 0xa1, 0x16, 0x9e, 0xc7, 0x3e, 0xc5, 0xc0, 0x67, 0x37, 0x2e, 0xc6, 0x62, 0xe3, 0xa2, - 0x4c, 0xa6, 0x9b, 0xa6, 0xc7, 0x1a, 0xc2, 0x0f, 0x7e, 0x3f, 0x40, 0xc1, 0x76, 0x3e, 0x19, 0xa2, - 0x5f, 0x69, 0x87, 0x71, 0x92, 0x4d, 0x88, 0x93, 0x32, 0x99, 0xe6, 0x3b, 0xe6, 0x4b, 0x95, 0x56, - 0xc3, 0x72, 0x18, 0xc7, 0xa0, 0x05, 0x89, 0x92, 0xfc, 0x1e, 0x50, 0x0d, 0xa5, 0xdd, 0x73, 0x05, - 0xe5, 0x06, 0x5c, 0x41, 0xd1, 0x70, 0xe3, 0x15, 0xcf, 0x75, 0x83, 0xa0, 0xee, 0x0d, 0x37, 0x6e, - 0xb8, 0xae, 0x30, 0xfa, 0x28, 0x72, 0x41, 0x79, 0x57, 0x31, 0x9f, 0x77, 0x32, 0x5c, 0x10, 0xa8, - 0xc0, 0x14, 0x36, 0xe9, 0x35, 0x32, 0xeb, 0xf9, 0x39, 0x06, 0x2e, 0xe6, 0x6f, 0x81, 0x85, 0x4e, - 0xbb, 0x38, 0x13, 0x0c, 0x00, 0x4f, 0xa4, 0x27, 0xed, 0x54, 0xb7, 0x1b, 0xcc, 0xc3, 0xad, 0x00, - 0x76, 0x02, 0x82, 0xe1, 0x3f, 0x68, 0x89, 0x90, 0xaa, 0xfd, 0xe0, 0x81, 0x6d, 0xb5, 0x1c, 0xb1, - 0x8f, 0x91, 0x0f, 0x66, 0x0a, 0xa9, 0x86, 0xd2, 0x86, 0x2b, 0xc0, 0x15, 0xa6, 0x53, 0x51, 0xb8, - 0x66, 0x94, 0x2b, 0x40, 0x8e, 0xdd, 0x09, 0x59, 0x7b, 0x09, 0x52, 0x6b, 0xb6, 0x27, 0x3c, 0xb3, - 0x02, 0x17, 0xd2, 0x6c, 0xa8, 0x35, 0x50, 0xe1, 0x33, 0x76, 0xd8, 0x94, 0x51, 0xc3, 0xed, 0x0f, - 0x19, 0x6e, 0x0f, 0x88, 0x1a, 0xd9, 0x37, 0xe0, 0x37, 0x38, 0x96, 0x1c, 0x48, 0x81, 0xe7, 0x23, - 0xc7, 0x12, 0xa4, 0xc1, 0x61, 0x42, 0x1c, 0x49, 0x44, 0x16, 0x0e, 0x48, 0x44, 0x2e, 0x92, 0x29, - 0x61, 0xd7, 0x19, 0x17, 0x66, 0xbd, 0x89, 0x3b, 0x09, 0xd0, 0x75, 0x89, 0x46, 0xd8, 0xa4, 0x57, - 0xc9, 0x8c, 0xea, 0xd5, 0x3c, 0x85, 0x2d, 0x0f, 0x2e, 0x89, 0x78, 0x3b, 0xd2, 0x93, 0xbb, 0x05, - 0x83, 0xf2, 0x18, 0xcc, 0x87, 0xdd, 0xe2, 0x53, 0x0c, 0x7c, 0xd2, 0x1b, 0x64, 0x41, 0xbe, 0x99, - 0x54, 0x1e, 0x30, 0x56, 0x69, 0x32, 0x4f, 0xa6, 0x67, 0xf9, 0x45, 0x40, 0x73, 0xb4, 0xd3, 0x2e, - 0xce, 0xca, 0xb1, 0xbb, 0x8c, 0x6d, 0x30, 0x6f, 0xcd, 0xe4, 0x46, 0xb4, 0x2b, 0x55, 0xad, 0xdb, - 0x7e, 0x8d, 0x38, 0xff, 0x54, 0xa8, 0x6a, 0xdd, 0x86, 0x0f, 0xdc, 0x46, 0xd0, 0x58, 0xfe, 0x4a, - 0x27, 0xe3, 0xb0, 0xb7, 0xe9, 0x0f, 0x34, 0x92, 0xf3, 0x0b, 0x94, 0xf4, 0xca, 0x80, 0x6c, 0xa4, - 0xbf, 0x42, 0x5a, 0x58, 0x7e, 0x12, 0x16, 0xff, 0xc4, 0xd0, 0xcf, 0x7c, 0xf4, 0xa7, 0xbf, 0x7f, - 0x7f, 0xac, 0x48, 0x4f, 0x96, 0x25, 0xc7, 0x65, 0xa5, 0x30, 0xae, 0x16, 0x97, 0xe9, 0xe7, 0x1a, - 0x99, 0x51, 0x6b, 0x4a, 0xf4, 0x46, 0x9a, 0xb5, 0xe2, 0xcb, 0xa9, 0x85, 0x9b, 0x43, 0xf1, 0x22, - 0xe0, 0xd7, 0x00, 0xf0, 0xcb, 0xf4, 0x5a, 0x02, 0x60, 0xb5, 0xca, 0x55, 0x7e, 0x88, 0x1f, 0x3f, - 0x1e, 0x95, 0x1f, 0xc2, 0x61, 0xf4, 0x88, 0x7e, 0xaa, 0x91, 0x79, 0x55, 0xee, 0x8a, 0xe3, 0xa4, - 0xd3, 0x25, 0xbe, 0xa8, 0x9a, 0x4e, 0x97, 0x84, 0x42, 0xa9, 0x7e, 0x11, 0x74, 0x39, 0x43, 0x4f, - 0xa7, 0xd0, 0x85, 0x7e, 0xa5, 0x91, 0xe3, 0x3d, 0xc8, 0xb1, 0x56, 0x48, 0x57, 0x86, 0x00, 0x11, - 0x2d, 0x76, 0x16, 0x56, 0x0f, 0x23, 0x02, 0xd5, 0xb9, 0x01, 0xea, 0x5c, 0xa5, 0xcb, 0x29, 0xd4, - 0x41, 0x5e, 0xf4, 0xd0, 0x23, 0xfa, 0x47, 0x8d, 0xcc, 0x45, 0x0b, 0x42, 0xf4, 0x56, 0xca, 0x30, - 0x89, 0x2d, 0x80, 0x15, 0x5e, 0x1b, 0x92, 0x1b, 0x75, 0x79, 0x05, 0x74, 0x59, 0xa6, 0x2f, 0x26, - 0xe8, 0x12, 0x2d, 0x53, 0x95, 0x1f, 0x06, 0xfd, 0x47, 0xf4, 0xcf, 0x1a, 0xa1, 0xfd, 0x25, 0x41, - 0x9a, 0x0a, 0x4f, 0x62, 0x21, 0xb2, 0xf0, 0xfa, 0xb0, 0xec, 0xa8, 0xcf, 0x0a, 0xe8, 0x73, 0x93, - 0xbe, 0x9a, 0xa8, 0x4f, 0xef, 0xdf, 0x59, 0xe0, 0x5e, 0x50, 0x15, 0xfb, 0xad, 0x46, 0x8e, 0x46, - 0x57, 0x90, 0x9b, 0xe7, 0x56, 0xca, 0xc0, 0x39, 0x84, 0x97, 0x12, 0x4b, 0x8f, 0xfa, 0x65, 0xd0, - 0xea, 0x1c, 0x3d, 0x93, 0xca, 0x4b, 0xf4, 0x13, 0x8d, 0xcc, 0x46, 0x4a, 0x7c, 0xf4, 0x95, 0x94, - 0x51, 0xd2, 0x57, 0x32, 0x2c, 0xbc, 0x3a, 0x04, 0x27, 0xa2, 0x2e, 0x01, 0xea, 0xf3, 0xf4, 0x6c, - 0x02, 0xea, 0x1a, 0x13, 0x15, 0xc1, 0x79, 0xf0, 0x31, 0x81, 0x7e, 0xac, 0x41, 0xbd, 0x30, 0xdd, - 0x95, 0x10, 0x29, 0x40, 0xa6, 0xbb, 0x12, 0xa2, 0xd5, 0x49, 0x5d, 0x07, 0x78, 0x27, 0x68, 0x21, - 0x01, 0x9e, 0x84, 0xf2, 0x73, 0x2d, 0x2c, 0xbd, 0xd1, 0xeb, 0x29, 0x17, 0xe9, 0xa9, 0x11, 0x16, - 0x5e, 0x7e, 0x62, 0x3e, 0x44, 0x58, 0x06, 0x84, 0x2f, 0xd0, 0x73, 0x49, 0x06, 0x44, 0x06, 0x19, - 0xbd, 0x55, 0xb6, 0xf7, 0x88, 0xfe, 0x54, 0x23, 0xd3, 0x81, 0x14, 0x19, 0xb4, 0xd7, 0x53, 0x86, - 0xdd, 0x50, 0x88, 0x63, 0x2a, 0x95, 0xfa, 0x39, 0x40, 0xfc, 0x1c, 0x2d, 0x0e, 0x40, 0x4c, 0x3f, - 0xd3, 0xc8, 0x42, 0xef, 0xa7, 0x42, 0x9a, 0xea, 0x92, 0x49, 0xf8, 0x6e, 0x59, 0xb8, 0x35, 0x1c, - 0x73, 0x4a, 0x53, 0x5b, 0xbd, 0x58, 0x3f, 0xd7, 0xc8, 0xb4, 0xf2, 0x35, 0x90, 0xde, 0x49, 0xb3, - 0xfc, 0xa0, 0xaf, 0x8e, 0x85, 0x37, 0x0e, 0x29, 0x05, 0xb5, 0xb9, 0x00, 0xda, 0x3c, 0x4f, 0xf5, - 0xa4, 0x6c, 0x47, 0x01, 0xfe, 0x6b, 0x2d, 0x52, 0xa8, 0xa4, 0x69, 0x37, 0x7c, 0x7f, 0x69, 0xb5, - 0x70, 0x63, 0x18, 0x56, 0x84, 0xbc, 0x0c, 0x90, 0x2f, 0xd1, 0x0b, 0x49, 0x0e, 0x08, 0x79, 0xba, - 0xe1, 0xfe, 0x4b, 0x8d, 0xcc, 0x29, 0xb2, 0x64, 0xc4, 0xbf, 0x9a, 0x32, 0x72, 0x87, 0x45, 0x1f, - 0x5f, 0xec, 0x1d, 0x68, 0x70, 0x05, 0x3d, 0xfd, 0x8d, 0x46, 0x16, 0x22, 0xc5, 0x50, 0x89, 0x3b, - 0x6d, 0x7e, 0x15, 0x57, 0xb3, 0x2d, 0xdc, 0x1a, 0x8e, 0x19, 0xb1, 0x5f, 0x02, 0xec, 0x67, 0xe9, - 0xf3, 0x49, 0xc1, 0xa2, 0x72, 0xd1, 0x2f, 0xb4, 0xbe, 0x3a, 0x23, 0x4d, 0x9b, 0x83, 0xc4, 0x57, - 0x49, 0xd3, 0xdd, 0xf9, 0xc9, 0x15, 0x5e, 0xfd, 0x3a, 0x28, 0xf0, 0x22, 0x2d, 0x25, 0x28, 0xe0, - 0x44, 0xf9, 0xba, 0xe1, 0xf3, 0x3b, 0x8d, 0xd0, 0x1e, 0x99, 0xd2, 0x15, 0x69, 0xef, 0xea, 0xc3, - 0x68, 0x93, 0x5c, 0xc7, 0x1d, 0x78, 0x6b, 0xf6, 0x68, 0x43, 0x7f, 0xa4, 0x91, 0x2c, 0xdc, 0xfa, - 0x69, 0xef, 0x40, 0x35, 0x2f, 0x79, 0xe9, 0x89, 0x78, 0x52, 0xa6, 0xf3, 0x16, 0x66, 0x8a, 0x60, - 0xe4, 0x4f, 0xe4, 0xf1, 0x12, 0xd6, 0x6f, 0xd3, 0x1f, 0x2f, 0x7d, 0x35, 0xdf, 0xe1, 0xc0, 0x5e, - 0x03, 0xb0, 0x65, 0x7a, 0xf9, 0x40, 0xb0, 0x7d, 0xef, 0x4f, 0x3f, 0xd4, 0xc8, 0x44, 0x90, 0xfa, - 0x2d, 0xa7, 0x3d, 0x18, 0x9e, 0xd4, 0xb0, 0x3d, 0x35, 0x5c, 0xfd, 0x34, 0x60, 0x3d, 0x49, 0x9f, - 0x3d, 0x00, 0xab, 0x7f, 0xe8, 0xf9, 0xc8, 0x70, 0x3f, 0xa7, 0x3f, 0xf4, 0xfa, 0xca, 0xaf, 0xe9, - 0x0f, 0xbd, 0xfe, 0xc2, 0xe9, 0xe0, 0x43, 0x2f, 0xe4, 0xa1, 0xbf, 0xd2, 0xc8, 0x5c, 0xb4, 0x50, - 0x99, 0x0e, 0x75, 0x6c, 0xe9, 0x33, 0x1d, 0xea, 0xf8, 0xba, 0xe8, 0xc0, 0x5c, 0xda, 0x89, 0xa2, - 0xfc, 0x89, 0x46, 0x48, 0xf8, 0x07, 0x70, 0x7a, 0x2d, 0xcd, 0xca, 0x7d, 0x7f, 0x25, 0x2f, 0x5c, - 0x7f, 0x52, 0x36, 0x04, 0xfb, 0x02, 0x80, 0x3d, 0x4d, 0x9f, 0x4b, 0x00, 0x2b, 0xba, 0x2c, 0xab, - 0x6f, 0x7d, 0xf1, 0xf5, 0x92, 0xf6, 0xe5, 0xd7, 0x4b, 0xda, 0xdf, 0xbe, 0x5e, 0xd2, 0x3e, 0x7e, - 0xbc, 0x74, 0xe4, 0xcb, 0xc7, 0x4b, 0x47, 0xfe, 0xf2, 0x78, 0xe9, 0xc8, 0xfd, 0x2b, 0x35, 0x5b, - 0xec, 0xb4, 0xb6, 0x4b, 0x96, 0x5b, 0x57, 0xc5, 0x04, 0x38, 0xca, 0x7b, 0x11, 0x89, 0xfb, 0x4d, - 0xc6, 0xb7, 0x73, 0x90, 0x21, 0xbc, 0xf4, 0xaf, 0x00, 0x00, 0x00, 0xff, 0xff, 0x64, 0xbe, 0xfc, - 0x57, 0xc9, 0x30, 0x00, 0x00, + // 3021 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xd4, 0x5a, 0xcd, 0x6f, 0x1b, 0xc7, + 0x15, 0xf7, 0x8a, 0xb4, 0x3e, 0x46, 0x9f, 0x1e, 0x2b, 0x0e, 0xc3, 0xd8, 0xa2, 0xb3, 0x8e, 0x3f, + 0xe2, 0x0f, 0x32, 0x56, 0x6c, 0x27, 0xb1, 0x9d, 0x34, 0x92, 0x1d, 0x2b, 0x46, 0x94, 0x44, 0x5d, + 0x29, 0xfd, 0x70, 0xd1, 0x12, 0xab, 0xe5, 0x98, 0x5a, 0x64, 0xc9, 0x65, 0x76, 0x86, 0x82, 0x14, + 0x43, 0x39, 0xe4, 0x2f, 0x08, 0x50, 0xa0, 0xbd, 0xf4, 0xda, 0x8f, 0x43, 0x0f, 0x01, 0x1a, 0x34, + 0x05, 0x0a, 0xa4, 0x87, 0xb6, 0x69, 0x8e, 0x41, 0x0b, 0x14, 0x2d, 0x0a, 0x10, 0x45, 0xd2, 0x13, + 0xff, 0x83, 0x02, 0x3d, 0x14, 0xf3, 0xf6, 0x2d, 0x77, 0x96, 0xdc, 0x15, 0x57, 0x14, 0x5b, 0xb4, + 0x17, 0x71, 0xe6, 0xcd, 0xbc, 0x37, 0xbf, 0xf7, 0x31, 0x33, 0x6f, 0xf6, 0x89, 0x9c, 0xb0, 0x3c, + 0x97, 0x73, 0x6b, 0xcb, 0xb4, 0xeb, 0xa5, 0x77, 0x9b, 0xcc, 0xdb, 0x2d, 0x36, 0x3c, 0x57, 0xb8, + 0xf4, 0xd4, 0x7b, 0x4c, 0x98, 0x40, 0x2e, 0x42, 0xcb, 0xf5, 0x58, 0x31, 0x9c, 0x9a, 0xbf, 0x68, + 0xb9, 0xbc, 0xe6, 0xf2, 0xd2, 0xa6, 0xc9, 0x99, 0xcf, 0x57, 0xda, 0xbe, 0xba, 0xc9, 0x84, 0x79, + 0xb5, 0xd4, 0x30, 0xab, 0x76, 0xdd, 0x14, 0xb6, 0x5b, 0xf7, 0x45, 0xe5, 0x4f, 0x29, 0x4b, 0xc0, + 0xdf, 0x72, 0xdd, 0xad, 0x5b, 0x8c, 0xe3, 0x70, 0x41, 0x1d, 0x96, 0xcd, 0xb2, 0x3f, 0x49, 0xec, + 0xe0, 0x84, 0xbc, 0x32, 0xa1, 0x6a, 0xf2, 0x72, 0xc3, 0xb3, 0x2d, 0x86, 0x63, 0x67, 0x94, 0x31, + 0xe0, 0x29, 0x6f, 0x99, 0x7c, 0xab, 0x2c, 0xdc, 0xb2, 0x65, 0x75, 0x04, 0xe8, 0xca, 0x24, 0xc7, + 0xe4, 0xa2, 0xbc, 0xe9, 0xb8, 0xd6, 0x3b, 0xe5, 0x2d, 0x66, 0x57, 0xb7, 0x04, 0xce, 0x59, 0x50, + 0xe6, 0x00, 0xbc, 0x2e, 0x19, 0x2a, 0x4a, 0xb7, 0x29, 0xe4, 0x4a, 0xc2, 0x33, 0xad, 0x77, 0x98, + 0x87, 0x13, 0x1e, 0x57, 0x26, 0x34, 0x4c, 0xcf, 0xac, 0x05, 0xfa, 0xcd, 0x2b, 0x03, 0x82, 0x77, + 0xa8, 0x55, 0xb7, 0xea, 0x42, 0xb3, 0x24, 0x5b, 0x48, 0x3d, 0x59, 0x75, 0xdd, 0xaa, 0xc3, 0x4a, + 0x66, 0xc3, 0x2e, 0x99, 0xf5, 0xba, 0x2b, 0xc0, 0x8e, 0xc8, 0xa3, 0xe7, 0xc8, 0x89, 0xaf, 0x4b, + 0x53, 0x6f, 0x70, 0xfe, 0x9a, 0xcd, 0x85, 0xeb, 0xed, 0x1a, 0xec, 0xdd, 0x26, 0xe3, 0x42, 0xff, + 0x1e, 0x79, 0xbc, 0x67, 0x84, 0x37, 0xdc, 0x3a, 0x67, 0xf4, 0x0e, 0x19, 0x17, 0x9c, 0x97, 0x1d, + 0x9b, 0x8b, 0x9c, 0x76, 0x3a, 0x73, 0x61, 0x72, 0x51, 0x2f, 0xee, 0xeb, 0xdb, 0xe2, 0xc6, 0xfa, + 0xfa, 0x72, 0xf6, 0xf3, 0x56, 0xe1, 0x88, 0x31, 0x26, 0x38, 0x5f, 0xb5, 0xb9, 0xd0, 0xe7, 0x09, + 0x05, 0xf9, 0x6b, 0xa0, 0x58, 0xb0, 0xea, 0x03, 0x72, 0x3c, 0x42, 0xed, 0xac, 0x38, 0xea, 0x1b, + 0x20, 0xa7, 0x9d, 0xd6, 0x2e, 0x4c, 0x2e, 0x9e, 0xed, 0xb3, 0x9e, 0xcf, 0x8e, 0x4b, 0x22, 0xab, + 0xfe, 0x06, 0x79, 0x12, 0x64, 0xaf, 0x30, 0xf1, 0x56, 0x53, 0x6c, 0xec, 0x6c, 0xf8, 0xc6, 0xc6, + 0xa5, 0x69, 0x8e, 0x8c, 0x01, 0xf3, 0xfd, 0xbb, 0xb0, 0x48, 0xc6, 0x08, 0xba, 0x74, 0x9e, 0x1c, + 0x05, 0xff, 0xe5, 0x46, 0x4e, 0x6b, 0x17, 0xb2, 0x86, 0xdf, 0xd1, 0x9b, 0xe4, 0x64, 0xbc, 0x38, + 0xc4, 0xfc, 0x36, 0x99, 0x72, 0x15, 0x3a, 0x22, 0xbf, 0xd4, 0x07, 0xb9, 0x2a, 0x0a, 0xf1, 0x47, + 0xc4, 0xe8, 0x0c, 0xb5, 0x58, 0x72, 0x9c, 0x38, 0x2d, 0xee, 0x11, 0x12, 0xee, 0x16, 0x5c, 0xf3, + 0x5c, 0xd1, 0xdf, 0x5a, 0x45, 0xb9, 0xb5, 0x8a, 0xfe, 0x96, 0xc4, 0xad, 0x55, 0x5c, 0x33, 0xab, + 0x0c, 0x79, 0x0d, 0x85, 0x53, 0xff, 0x54, 0x43, 0xf5, 0x7a, 0xd6, 0x49, 0x54, 0x2f, 0x33, 0x04, + 0xf5, 0xe8, 0x4a, 0x04, 0xff, 0x08, 0xe0, 0x3f, 0xdf, 0x17, 0xbf, 0x8f, 0x29, 0xa2, 0xc0, 0x07, + 0x1a, 0xd1, 0xe3, 0x14, 0x58, 0xde, 0xbd, 0x23, 0x91, 0x04, 0xf6, 0x9a, 0x27, 0x47, 0x01, 0x19, + 0xfa, 0xdc, 0xef, 0x74, 0x59, 0x71, 0x64, 0x60, 0x2b, 0xfe, 0x5e, 0x23, 0x67, 0xf6, 0x05, 0xf1, + 0x7f, 0x62, 0xcc, 0x5b, 0xe4, 0x54, 0x10, 0xeb, 0xf7, 0xeb, 0x1b, 0x3b, 0xaf, 0x99, 0x7c, 0x6b, + 0xc3, 0xbd, 0x63, 0x89, 0x9d, 0xc0, 0x8c, 0x79, 0x32, 0x6e, 0xe3, 0x00, 0x58, 0x72, 0xc2, 0xe8, + 0xf4, 0xf5, 0x3d, 0xb2, 0x90, 0xc4, 0x8c, 0xea, 0x7f, 0x87, 0xcc, 0xd8, 0x91, 0x11, 0x0c, 0xdc, + 0x2b, 0x7d, 0x0c, 0x10, 0x15, 0x87, 0x26, 0xe8, 0x12, 0xa5, 0xdf, 0xc6, 0xe5, 0xa3, 0x93, 0xef, + 0x9a, 0xc2, 0x4c, 0x03, 0xfe, 0x3d, 0x52, 0x48, 0xe4, 0x46, 0xf4, 0xdf, 0x24, 0xd3, 0x77, 0x24, + 0x26, 0x70, 0xe9, 0xc6, 0x0e, 0x4f, 0xe9, 0x3d, 0x95, 0x07, 0xa1, 0x47, 0xe5, 0xe8, 0x55, 0xb4, + 0xfa, 0x92, 0xe3, 0xc4, 0x5b, 0x7d, 0x58, 0x9b, 0xfd, 0x33, 0x0d, 0x6d, 0x14, 0xb3, 0xd2, 0x3e, + 0x2e, 0xca, 0x0c, 0xc9, 0x45, 0xc3, 0x8b, 0xd3, 0x27, 0xc9, 0x13, 0x41, 0xa8, 0x6d, 0x70, 0xbe, + 0x54, 0xa9, 0x78, 0x8c, 0x77, 0xee, 0x96, 0x57, 0x48, 0x3e, 0x6e, 0x10, 0x15, 0x9c, 0x23, 0x19, + 0x26, 0x02, 0xff, 0xcb, 0xa6, 0xa4, 0x6c, 0x0a, 0x0b, 0xe0, 0x4c, 0x18, 0xb2, 0xd9, 0xb9, 0xb3, + 0xa4, 0x84, 0xf5, 0xf5, 0x40, 0xee, 0xeb, 0x78, 0x67, 0x05, 0x54, 0x14, 0x78, 0x8d, 0x64, 0x36, + 0xd6, 0xd7, 0xd1, 0x2b, 0x29, 0x2e, 0x48, 0x43, 0x4e, 0xd7, 0x4b, 0x78, 0xed, 0xae, 0x30, 0xb1, + 0x62, 0xf2, 0x35, 0x99, 0x97, 0x28, 0x47, 0x95, 0x5d, 0xaf, 0xb0, 0x1d, 0xc4, 0xe8, 0x77, 0xf4, + 0x32, 0xc9, 0xf5, 0x32, 0x84, 0x17, 0x75, 0x40, 0x43, 0x1c, 0xe7, 0xfb, 0xe0, 0xe8, 0x88, 0xe8, + 0x30, 0xea, 0x26, 0x22, 0x5a, 0x72, 0x9c, 0x6e, 0x44, 0xc3, 0x8a, 0xbf, 0x9f, 0x69, 0xa8, 0x44, + 0x64, 0x8d, 0x58, 0x25, 0x32, 0x03, 0x29, 0x31, 0xbc, 0x08, 0x5b, 0x0c, 0x83, 0x08, 0xf6, 0xe9, + 0x9b, 0x90, 0x77, 0xee, 0xef, 0xa2, 0x77, 0xc2, 0xc4, 0x23, 0xc2, 0x83, 0x0a, 0xae, 0x92, 0x49, + 0x85, 0x8c, 0x66, 0xbc, 0xd8, 0xef, 0xf4, 0x50, 0x04, 0xa9, 0xec, 0x7a, 0x05, 0x01, 0x2e, 0x39, + 0x4e, 0x0c, 0xc0, 0x61, 0x79, 0xec, 0x63, 0x2d, 0x4c, 0x43, 0x52, 0xe9, 0x94, 0x39, 0x84, 0x4e, + 0xc3, 0xf3, 0xde, 0x42, 0x98, 0xd4, 0xac, 0xb1, 0x7a, 0xc5, 0xae, 0x57, 0x23, 0xe6, 0xd1, 0x45, + 0x78, 0xe2, 0x76, 0x8d, 0xa3, 0x5e, 0xeb, 0x64, 0xa6, 0xe1, 0x0f, 0xe0, 0x8b, 0x03, 0x55, 0xbb, + 0xdc, 0x2f, 0x21, 0x8d, 0x48, 0x9b, 0x6e, 0xa8, 0x5d, 0xfd, 0x25, 0x72, 0xda, 0x4f, 0x7a, 0x55, + 0x6a, 0x57, 0x9e, 0xf2, 0x04, 0x19, 0xf7, 0xdf, 0x30, 0x76, 0x05, 0xdc, 0x96, 0x0d, 0xd2, 0xd3, + 0x8a, 0xfe, 0x3e, 0x79, 0x6a, 0x1f, 0x76, 0x04, 0xfe, 0xed, 0x18, 0xe0, 0xda, 0x41, 0x81, 0x07, + 0xd7, 0x54, 0x14, 0xfe, 0x8d, 0xf0, 0x7e, 0x5f, 0x35, 0xb9, 0x58, 0x96, 0x2f, 0xa1, 0xd7, 0xe0, + 0x21, 0xb4, 0xff, 0xb6, 0x78, 0x84, 0x57, 0x6b, 0x1c, 0x1f, 0xa2, 0xfe, 0x16, 0x99, 0xed, 0x1a, + 0x42, 0xd8, 0xc5, 0x3e, 0xb0, 0xbb, 0x05, 0x76, 0x8b, 0xd1, 0xb7, 0xc2, 0x1b, 0x2f, 0x01, 0xf4, + 0xb0, 0xb6, 0xca, 0xef, 0x34, 0xd4, 0x33, 0x6e, 0xa9, 0xfd, 0xf4, 0xcc, 0x0c, 0x41, 0xcf, 0xe1, + 0x6d, 0x9d, 0x4b, 0xe1, 0x2d, 0xa7, 0xa6, 0x20, 0xf1, 0xae, 0x5d, 0x55, 0x4e, 0x49, 0x79, 0xed, + 0xef, 0x42, 0xa8, 0x0c, 0xfa, 0xd2, 0xaa, 0x92, 0xf9, 0xe8, 0xd2, 0x68, 0xb5, 0xb7, 0xc8, 0x94, + 0x9a, 0x30, 0xa5, 0x7c, 0x61, 0xa9, 0x2c, 0x46, 0x44, 0x80, 0xfe, 0x5d, 0xd4, 0x51, 0x1e, 0x6a, + 0xff, 0x81, 0x34, 0xeb, 0x23, 0x0d, 0x15, 0xe9, 0xc8, 0x4f, 0x54, 0x24, 0x73, 0x28, 0x45, 0x86, + 0xe7, 0xf5, 0xf7, 0x95, 0xdb, 0xc4, 0x12, 0x3b, 0x78, 0x1a, 0xf4, 0x38, 0xb2, 0xfb, 0x4c, 0x1a, + 0xda, 0x03, 0xea, 0x13, 0xf5, 0x9e, 0x51, 0x01, 0xfc, 0xcf, 0x5b, 0xee, 0x24, 0x5a, 0x4e, 0x6e, + 0xc8, 0x07, 0x4c, 0x98, 0x91, 0xc3, 0x45, 0xbf, 0x8e, 0x6a, 0x75, 0x8f, 0xa2, 0x5a, 0x27, 0xc8, + 0xa8, 0x72, 0xdc, 0x65, 0x0c, 0xec, 0xe9, 0x1b, 0x78, 0x7f, 0xdd, 0x71, 0xeb, 0xdb, 0xcc, 0x93, + 0x09, 0xdf, 0x86, 0x2b, 0xd9, 0x13, 0x1c, 0x92, 0x09, 0x1d, 0x92, 0x27, 0xe3, 0x55, 0x93, 0xaf, + 0xda, 0x35, 0x5b, 0x60, 0x46, 0xdb, 0xe9, 0xeb, 0x3f, 0xd6, 0xf0, 0xda, 0xeb, 0x15, 0x8b, 0x78, + 0x2e, 0x93, 0x63, 0x6e, 0x53, 0x6c, 0xba, 0xcd, 0x7a, 0x65, 0xc5, 0xe4, 0xf7, 0xeb, 0x72, 0x10, + 0x77, 0x7c, 0xef, 0x80, 0x9c, 0x0d, 0x5f, 0x97, 0x2c, 0xd7, 0xb9, 0xc7, 0x18, 0xce, 0xf6, 0x17, + 0xed, 0x1d, 0xa0, 0x17, 0xc8, 0xac, 0xfc, 0x55, 0xcf, 0xbe, 0x0c, 0x04, 0x53, 0x37, 0x59, 0x3f, + 0x4f, 0xce, 0x02, 0xcc, 0x37, 0x18, 0xe7, 0x66, 0x95, 0xad, 0x99, 0x9c, 0xdb, 0xf5, 0xea, 0x5a, + 0x28, 0x31, 0xb0, 0xee, 0x3d, 0x72, 0xae, 0xdf, 0x44, 0x54, 0xec, 0x24, 0x99, 0x78, 0xd8, 0x81, + 0xe8, 0x2b, 0x14, 0x12, 0xf4, 0x5b, 0xb8, 0xe0, 0x83, 0x57, 0xbf, 0xf1, 0x86, 0xcc, 0xee, 0x3d, + 0xb3, 0xce, 0x4d, 0x4b, 0xba, 0xd7, 0x60, 0x16, 0xb3, 0x1b, 0x9d, 0xbb, 0x82, 0x92, 0xec, 0x56, + 0xf8, 0x7a, 0x84, 0xb6, 0xfe, 0xaf, 0x2c, 0xa2, 0xd8, 0x87, 0xbb, 0x63, 0x5e, 0x82, 0xdf, 0x0f, + 0x3b, 0x42, 0x96, 0xa7, 0xdb, 0xad, 0xc2, 0x04, 0x50, 0xe5, 0x43, 0xc9, 0x08, 0x9b, 0x74, 0x91, + 0x4c, 0xf9, 0xb3, 0xeb, 0xcd, 0xda, 0x26, 0xf3, 0x7c, 0xcb, 0x2e, 0xcf, 0xb6, 0x5b, 0x85, 0x49, + 0xa0, 0xbf, 0x09, 0x64, 0x43, 0xed, 0xd0, 0x97, 0xc9, 0x9c, 0xe5, 0xd6, 0x85, 0x67, 0x5a, 0xa2, + 0x6c, 0xfa, 0x2f, 0x1f, 0xb0, 0xf2, 0xc4, 0xf2, 0xf1, 0x76, 0xab, 0x30, 0x1b, 0x8c, 0x05, 0x8f, + 0xa2, 0x6e, 0x02, 0x7d, 0x95, 0x1c, 0xb7, 0x9a, 0xb5, 0xa6, 0x63, 0x0a, 0x7b, 0x9b, 0x95, 0xab, + 0x26, 0x2f, 0x37, 0x39, 0xab, 0xe4, 0xb2, 0x20, 0xe2, 0xb1, 0x76, 0xab, 0x70, 0x2c, 0x1c, 0x5e, + 0x31, 0xf9, 0xdb, 0x9c, 0x55, 0x8c, 0x5e, 0x12, 0x3d, 0x49, 0xb2, 0x0f, 0x3d, 0xb7, 0x96, 0x3b, + 0x0a, 0x7c, 0xe3, 0xed, 0x56, 0x01, 0xfa, 0x06, 0xfc, 0xa5, 0xe7, 0x20, 0x46, 0x7d, 0xc9, 0xa3, + 0x30, 0x63, 0xb2, 0xdd, 0x2a, 0x8c, 0x55, 0x51, 0x5e, 0xd0, 0x90, 0xe6, 0x72, 0xdc, 0x2a, 0x2f, + 0x6f, 0x3a, 0xae, 0x5b, 0xcb, 0x8d, 0x85, 0xe6, 0x92, 0xd4, 0x65, 0x49, 0x34, 0xc2, 0x26, 0xd5, + 0xc9, 0x28, 0x17, 0xa6, 0x68, 0xf2, 0xdc, 0x38, 0xcc, 0x24, 0xed, 0x56, 0x01, 0x29, 0x06, 0xfe, + 0xd2, 0x13, 0x64, 0x44, 0xb8, 0xb9, 0x09, 0x18, 0x1f, 0x6d, 0xb7, 0x0a, 0x23, 0xc2, 0x35, 0x46, + 0x84, 0x2b, 0xcd, 0x26, 0x42, 0xb7, 0xf9, 0xee, 0x21, 0xa1, 0xd9, 0x94, 0x31, 0x70, 0x52, 0x37, + 0x81, 0x2e, 0x91, 0x63, 0x2a, 0xbf, 0x7f, 0x53, 0x4e, 0x82, 0x80, 0xf9, 0x76, 0xab, 0xa0, 0x0a, + 0xbf, 0x2f, 0xc7, 0x8c, 0x1e, 0x0a, 0xbd, 0x41, 0xb2, 0x52, 0x97, 0xdc, 0x54, 0xaa, 0x0f, 0xad, + 0xab, 0x6e, 0xd5, 0x80, 0xf9, 0xfa, 0x07, 0x19, 0x92, 0x59, 0x75, 0xab, 0xf2, 0x48, 0x08, 0x1c, + 0xee, 0x47, 0x67, 0xd0, 0x95, 0x87, 0x8c, 0x70, 0x1b, 0xb6, 0xc5, 0x73, 0x23, 0xa7, 0x33, 0x17, + 0x26, 0x0c, 0xec, 0xc9, 0x60, 0xae, 0x98, 0xc2, 0xf4, 0xe3, 0xc3, 0x80, 0x76, 0x4f, 0xcc, 0x49, + 0xc7, 0x67, 0xfb, 0xc7, 0x5c, 0x8f, 0xf1, 0x8e, 0x1e, 0xd6, 0x78, 0xa3, 0xb0, 0x70, 0x5a, 0xe3, + 0x45, 0x37, 0xd6, 0x58, 0x9f, 0x8d, 0xf5, 0x0c, 0x91, 0x61, 0x83, 0x0b, 0x8d, 0xc3, 0x42, 0x53, + 0xed, 0x56, 0x61, 0xdc, 0x71, 0xab, 0xfe, 0x02, 0x9d, 0x16, 0x3d, 0x4b, 0xc6, 0x3c, 0x56, 0x73, + 0xb7, 0x59, 0x05, 0xa2, 0x66, 0xdc, 0x8f, 0x54, 0x24, 0x19, 0x41, 0x43, 0xbf, 0x86, 0x59, 0x66, + 0xdc, 0x11, 0x90, 0x7c, 0x72, 0xfc, 0x33, 0x8b, 0x19, 0x63, 0x1c, 0xdb, 0x7f, 0xed, 0xc8, 0x08, + 0xf6, 0x6a, 0x26, 0x76, 0xaf, 0x3e, 0x41, 0x32, 0x55, 0x93, 0xe3, 0x01, 0x30, 0xd6, 0x6e, 0x15, + 0x64, 0xd7, 0x90, 0x7f, 0xa4, 0x19, 0x3b, 0x35, 0x15, 0x74, 0x38, 0x98, 0xb1, 0xda, 0x79, 0x96, + 0x07, 0x2d, 0xb9, 0x06, 0xe0, 0x1f, 0x0d, 0xd7, 0x90, 0x7d, 0xdf, 0x0e, 0xb4, 0x20, 0x73, 0xcb, + 0x46, 0x53, 0xa0, 0xe3, 0x26, 0xda, 0xad, 0x82, 0x4f, 0x30, 0xfc, 0x1f, 0x39, 0xc1, 0x4f, 0x17, + 0xc7, 0xc3, 0x09, 0x40, 0xc0, 0xcc, 0x31, 0x71, 0x5f, 0xc7, 0x86, 0x16, 0x39, 0xd0, 0xbe, 0x2c, + 0x90, 0xa3, 0xdb, 0xa6, 0xd3, 0x64, 0xb8, 0x9d, 0x61, 0x6d, 0x20, 0x18, 0xfe, 0x8f, 0xd4, 0x4d, + 0xec, 0x36, 0x58, 0x6e, 0x2a, 0xd4, 0x4d, 0xf6, 0x0d, 0xf8, 0x4b, 0x4b, 0x64, 0xd2, 0xb4, 0x2c, + 0x16, 0x94, 0x51, 0xa6, 0xe5, 0x0e, 0x5c, 0x9e, 0x69, 0xb7, 0x0a, 0xc4, 0x27, 0xaf, 0xda, 0x32, + 0x13, 0x0a, 0xdb, 0xf2, 0x70, 0xec, 0x3c, 0x00, 0x67, 0xc2, 0xc3, 0x11, 0xef, 0xf7, 0xf0, 0xa2, + 0x3f, 0x4e, 0xb4, 0xed, 0xdc, 0x2c, 0x4c, 0x38, 0xda, 0x6e, 0x15, 0xb4, 0x6d, 0x43, 0xdb, 0x96, + 0x44, 0x2f, 0x37, 0x17, 0x12, 0x3d, 0x43, 0xf3, 0x24, 0x91, 0xe7, 0x8e, 0x85, 0x44, 0x6e, 0x68, + 0x5c, 0xbf, 0x89, 0x6f, 0x51, 0x0c, 0x3d, 0xb8, 0x7e, 0x97, 0x77, 0x31, 0x3e, 0x30, 0x66, 0x4f, + 0x90, 0xd1, 0xad, 0x30, 0x3b, 0xc9, 0x1a, 0xd8, 0xd3, 0xff, 0x3a, 0x86, 0x2f, 0xd1, 0x78, 0x66, + 0x8c, 0x5c, 0x9d, 0x8c, 0x62, 0x14, 0x6a, 0xe1, 0x79, 0xec, 0x53, 0x0c, 0xfc, 0xed, 0xc4, 0xc5, + 0x48, 0x6c, 0x5c, 0x94, 0xc8, 0x64, 0xc3, 0xf4, 0x58, 0x5d, 0xf8, 0xc1, 0xef, 0x07, 0x28, 0xd8, + 0xce, 0x27, 0x43, 0xf4, 0x2b, 0xed, 0x30, 0x4e, 0xb2, 0x09, 0x71, 0x52, 0x22, 0x93, 0x7c, 0xcb, + 0x7c, 0xae, 0xdc, 0xac, 0x5b, 0x0e, 0xe3, 0x18, 0xb4, 0x20, 0x51, 0x92, 0xdf, 0x06, 0xaa, 0xa1, + 0xb4, 0xbb, 0xae, 0xa0, 0xd1, 0x3e, 0x57, 0x50, 0x34, 0xdc, 0x78, 0xd9, 0x73, 0xdd, 0x20, 0xa8, + 0xbb, 0xc3, 0x8d, 0x1b, 0xae, 0x2b, 0x8c, 0x1e, 0x8a, 0x5c, 0x50, 0xde, 0x55, 0xcc, 0xe7, 0x1d, + 0x0f, 0x17, 0x04, 0x2a, 0x30, 0x85, 0x4d, 0x7a, 0x9d, 0x4c, 0x7b, 0x7e, 0x8e, 0x81, 0x8b, 0xf9, + 0x5b, 0x60, 0xae, 0xdd, 0x2a, 0x4c, 0x05, 0x03, 0xc0, 0x13, 0xe9, 0x49, 0x3b, 0xd5, 0xec, 0x3a, + 0xf3, 0x70, 0x2b, 0x80, 0x9d, 0x80, 0x60, 0xf8, 0x3f, 0xb4, 0x48, 0x48, 0xc5, 0x7e, 0xf8, 0xd0, + 0xb6, 0x9a, 0x8e, 0xd8, 0xc5, 0xc8, 0x07, 0x33, 0x85, 0x54, 0x43, 0x69, 0xc3, 0x15, 0xe0, 0x0a, + 0xd3, 0x29, 0x2b, 0x5c, 0x53, 0xca, 0x15, 0x20, 0xc7, 0xee, 0x86, 0xac, 0xdd, 0x04, 0xa9, 0x35, + 0xdb, 0x11, 0x9e, 0x59, 0x86, 0x0b, 0x69, 0x3a, 0xd4, 0x1a, 0xa8, 0xf0, 0x15, 0x3e, 0x6c, 0xca, + 0xa8, 0xe1, 0xf6, 0x7b, 0x0c, 0xb7, 0x07, 0x44, 0x8d, 0xec, 0x1b, 0xf0, 0x37, 0x38, 0x96, 0x1c, + 0x48, 0x81, 0x67, 0x23, 0xc7, 0x12, 0xa4, 0xc1, 0x61, 0x42, 0x1c, 0x49, 0x44, 0xe6, 0xf6, 0x49, + 0x44, 0x2e, 0x91, 0x09, 0x61, 0xd7, 0x18, 0x17, 0x66, 0xad, 0x81, 0x3b, 0x09, 0xd0, 0x75, 0x88, + 0x46, 0xd8, 0xa4, 0xd7, 0xc8, 0x94, 0xea, 0xd5, 0x1c, 0x85, 0x2d, 0x0f, 0x2e, 0x89, 0x78, 0x3b, + 0xd2, 0x93, 0xbb, 0x05, 0x83, 0xf2, 0x38, 0xcc, 0x87, 0xdd, 0xe2, 0x53, 0x0c, 0xfc, 0xa5, 0x37, + 0xc9, 0x9c, 0x7c, 0x99, 0x94, 0x1f, 0x32, 0x56, 0x6e, 0x30, 0x4f, 0xa6, 0x67, 0xb9, 0x79, 0x40, + 0x73, 0xac, 0xdd, 0x2a, 0x4c, 0xcb, 0xb1, 0x7b, 0x8c, 0xad, 0x31, 0x6f, 0xc5, 0xe4, 0x46, 0xb4, + 0x2b, 0x55, 0xad, 0xd9, 0x7e, 0x89, 0x3b, 0xf7, 0x58, 0xa8, 0x6a, 0xcd, 0x86, 0xef, 0xf3, 0x46, + 0xd0, 0x58, 0xfc, 0xe8, 0x69, 0x72, 0x14, 0xf6, 0x36, 0xfd, 0x81, 0x46, 0x46, 0xfd, 0xfa, 0x2a, + 0xbd, 0xda, 0x27, 0x1b, 0xe9, 0x2d, 0xf0, 0xe6, 0x17, 0x0f, 0xc2, 0xe2, 0x9f, 0x18, 0xfa, 0xd9, + 0x0f, 0xfe, 0xf4, 0x8f, 0xef, 0x8f, 0x14, 0xe8, 0xa9, 0x92, 0xe4, 0xb8, 0xa2, 0xd4, 0xf5, 0xd5, + 0xda, 0x38, 0xfd, 0x4c, 0x23, 0x53, 0x6a, 0x49, 0x8c, 0xde, 0x4c, 0xb3, 0x56, 0x7c, 0x35, 0x38, + 0x7f, 0x6b, 0x20, 0x5e, 0x04, 0xfc, 0x12, 0x00, 0x7e, 0x9e, 0x5e, 0x4f, 0x00, 0xac, 0x16, 0xe9, + 0x4a, 0x8f, 0xf0, 0xe3, 0xc7, 0x5e, 0xe9, 0x11, 0x1c, 0x46, 0x7b, 0xf4, 0x13, 0x8d, 0xcc, 0xaa, + 0x72, 0x97, 0x1c, 0x27, 0x9d, 0x2e, 0xf1, 0x35, 0xe1, 0x74, 0xba, 0x24, 0xd4, 0x79, 0xf5, 0x4b, + 0xa0, 0xcb, 0x59, 0x7a, 0x26, 0x85, 0x2e, 0xf4, 0x6f, 0x1a, 0x39, 0xd1, 0x85, 0x1c, 0x3f, 0x44, + 0xd2, 0xa5, 0x01, 0x40, 0x44, 0xbf, 0x81, 0xe6, 0x97, 0x0f, 0x23, 0x02, 0xd5, 0xb9, 0x09, 0xea, + 0x5c, 0xa3, 0x8b, 0x29, 0xd4, 0x41, 0x5e, 0xf4, 0xd0, 0x1e, 0xfd, 0x83, 0x46, 0x66, 0xa2, 0xf5, + 0x2c, 0x7a, 0x3b, 0x65, 0x98, 0xc4, 0xd6, 0xef, 0xf2, 0x2f, 0x0d, 0xc8, 0x8d, 0xba, 0xbc, 0x00, + 0xba, 0x2c, 0xd2, 0x67, 0x13, 0x74, 0x89, 0x56, 0xd9, 0x4a, 0x8f, 0x82, 0xfe, 0x1e, 0xfd, 0xb3, + 0x46, 0x68, 0x6f, 0x45, 0x93, 0xa6, 0xc2, 0x93, 0x58, 0x47, 0xcd, 0xbf, 0x3c, 0x28, 0x3b, 0xea, + 0xb3, 0x04, 0xfa, 0xdc, 0xa2, 0x2f, 0x26, 0xea, 0xd3, 0xfd, 0xdf, 0x38, 0x70, 0x2f, 0xa8, 0x8a, + 0xfd, 0x46, 0x23, 0xc7, 0xa2, 0x2b, 0xc8, 0xcd, 0x73, 0x3b, 0x65, 0xe0, 0x1c, 0xc2, 0x4b, 0x89, + 0x95, 0x53, 0xfd, 0x0a, 0x68, 0x75, 0x9e, 0x9e, 0x4d, 0xe5, 0x25, 0xfa, 0xb1, 0x46, 0xa6, 0x23, + 0x15, 0x4a, 0xfa, 0x42, 0xca, 0x28, 0xe9, 0xa9, 0x78, 0xe6, 0x5f, 0x1c, 0x80, 0x13, 0x51, 0x17, + 0x01, 0xf5, 0x05, 0x7a, 0x2e, 0x01, 0x75, 0x95, 0x89, 0xb2, 0xe0, 0x3c, 0xf8, 0x98, 0x40, 0x3f, + 0xd4, 0xa0, 0xdc, 0x99, 0xee, 0x4a, 0x88, 0xd4, 0x4f, 0xd3, 0x5d, 0x09, 0xd1, 0xe2, 0xaa, 0xae, + 0x03, 0xbc, 0x93, 0x34, 0x9f, 0x00, 0x4f, 0x42, 0xf9, 0xb9, 0x16, 0x56, 0x0e, 0xe9, 0x8d, 0x94, + 0x8b, 0x74, 0x95, 0x38, 0xf3, 0xcf, 0x1f, 0x98, 0x0f, 0x11, 0x96, 0x00, 0xe1, 0x33, 0xf4, 0x7c, + 0x92, 0x01, 0x91, 0x41, 0x46, 0x6f, 0x85, 0xed, 0xec, 0xd1, 0x9f, 0x6a, 0x64, 0x32, 0x90, 0x22, + 0x83, 0xf6, 0x46, 0xca, 0xb0, 0x1b, 0x08, 0x71, 0x4c, 0xa1, 0x55, 0x3f, 0x0f, 0x88, 0x9f, 0xa2, + 0x85, 0x3e, 0x88, 0xe9, 0xa7, 0x1a, 0x99, 0xeb, 0xfe, 0x54, 0x48, 0x53, 0x5d, 0x32, 0x09, 0xdf, + 0x2d, 0xf3, 0xb7, 0x07, 0x63, 0x4e, 0x69, 0x6a, 0xab, 0x1b, 0xeb, 0x67, 0x1a, 0x99, 0x54, 0xbe, + 0x06, 0xd2, 0xbb, 0x69, 0x96, 0xef, 0xf7, 0xd5, 0x31, 0xff, 0xea, 0x21, 0xa5, 0xa0, 0x36, 0x17, + 0x41, 0x9b, 0xa7, 0xa9, 0x9e, 0x94, 0xed, 0x28, 0xc0, 0x7f, 0xa5, 0x45, 0xea, 0xac, 0x34, 0xed, + 0x86, 0xef, 0xad, 0x0c, 0xe7, 0x6f, 0x0e, 0xc2, 0x8a, 0x90, 0x17, 0x01, 0xf2, 0x65, 0x7a, 0x31, + 0xc9, 0x01, 0x21, 0x4f, 0x27, 0xdc, 0x7f, 0xa1, 0x91, 0x19, 0x45, 0x96, 0x8c, 0xf8, 0x17, 0x53, + 0x46, 0xee, 0xa0, 0xe8, 0xe3, 0x6b, 0xd5, 0x7d, 0x0d, 0xae, 0xa0, 0xa7, 0xbf, 0xd6, 0xc8, 0x5c, + 0xa4, 0x24, 0x2a, 0x71, 0xa7, 0xcd, 0xaf, 0xe2, 0x4a, 0xce, 0xf9, 0xdb, 0x83, 0x31, 0x23, 0xf6, + 0xcb, 0x80, 0xfd, 0x1c, 0x7d, 0x3a, 0x29, 0x58, 0x54, 0x2e, 0xfa, 0x47, 0x8d, 0xcc, 0xc7, 0x55, + 0x89, 0xe9, 0xd7, 0x52, 0x65, 0xe5, 0xc9, 0xe5, 0xe9, 0xfc, 0x2b, 0x83, 0x0b, 0x40, 0x4d, 0x9e, + 0x07, 0x4d, 0xae, 0xd2, 0x52, 0x1a, 0x4d, 0x30, 0x25, 0x2b, 0xdb, 0x95, 0x3d, 0xfa, 0xb9, 0xd6, + 0x53, 0x3c, 0xa5, 0x69, 0x13, 0xab, 0xf8, 0xd2, 0x6f, 0xba, 0x44, 0x26, 0xb9, 0x6c, 0xad, 0xdf, + 0x00, 0x5d, 0x9e, 0xa5, 0xc5, 0x04, 0x5d, 0x9c, 0x28, 0x5f, 0x67, 0x4f, 0xfc, 0x56, 0x23, 0xb4, + 0x4b, 0xa6, 0x8c, 0xaf, 0xb4, 0x09, 0xc8, 0x61, 0xb4, 0x49, 0x2e, 0x4e, 0xf7, 0x4d, 0x05, 0xba, + 0xb4, 0xa1, 0x3f, 0xd2, 0x48, 0x16, 0x52, 0x99, 0xb4, 0x17, 0xbb, 0x9a, 0x6c, 0x3d, 0x77, 0x20, + 0x9e, 0x94, 0x6f, 0x14, 0x0b, 0xd3, 0x5f, 0x30, 0xf2, 0xc7, 0xf2, 0xcc, 0x0c, 0x8b, 0xd2, 0xe9, + 0xcf, 0xcc, 0x9e, 0x42, 0xf6, 0x60, 0x60, 0xaf, 0x03, 0xd8, 0x12, 0xbd, 0xb2, 0x2f, 0xd8, 0x9e, + 0x47, 0xe1, 0x0f, 0x35, 0x32, 0x16, 0xe4, 0xb3, 0x8b, 0x69, 0x4f, 0xbb, 0x83, 0x1a, 0xb6, 0xab, + 0x30, 0xad, 0x9f, 0x01, 0xac, 0xa7, 0xe8, 0x93, 0xfb, 0x60, 0xf5, 0x4f, 0x72, 0x1f, 0x19, 0xee, + 0xf0, 0xf4, 0x27, 0x79, 0x4f, 0x4d, 0x39, 0xfd, 0x49, 0xde, 0x5b, 0x0d, 0xee, 0x7f, 0x92, 0x87, + 0x3c, 0xf4, 0x97, 0x1a, 0x99, 0x89, 0x56, 0x5f, 0xd3, 0xa1, 0x8e, 0xad, 0xe7, 0xa6, 0x43, 0x1d, + 0x5f, 0xec, 0xed, 0xfb, 0x40, 0x70, 0xa2, 0x28, 0x7f, 0xa2, 0x11, 0x12, 0xfe, 0x53, 0x3e, 0xbd, + 0x9e, 0x66, 0xe5, 0x9e, 0x7f, 0xef, 0xcf, 0xdf, 0x38, 0x28, 0x1b, 0x82, 0x7d, 0x06, 0xc0, 0x9e, + 0xa1, 0x4f, 0x25, 0x80, 0x15, 0x1d, 0x96, 0xe5, 0xd7, 0x3f, 0xff, 0x72, 0x41, 0xfb, 0xe2, 0xcb, + 0x05, 0xed, 0xef, 0x5f, 0x2e, 0x68, 0x1f, 0x7e, 0xb5, 0x70, 0xe4, 0x8b, 0xaf, 0x16, 0x8e, 0xfc, + 0xe5, 0xab, 0x85, 0x23, 0x0f, 0xae, 0x56, 0x6d, 0xb1, 0xd5, 0xdc, 0x2c, 0x5a, 0x6e, 0x4d, 0x15, + 0x13, 0xe0, 0x28, 0xed, 0x44, 0x24, 0xee, 0x36, 0x18, 0xdf, 0x1c, 0x85, 0xb4, 0xe7, 0xb9, 0x7f, + 0x07, 0x00, 0x00, 0xff, 0xff, 0xa6, 0xf5, 0xed, 0x4b, 0x5d, 0x32, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -3215,6 +3309,7 @@ type QueryClient interface { // Queries a list of chainNonces items. ChainNoncesAll(ctx context.Context, in *QueryAllChainNoncesRequest, opts ...grpc.CallOption) (*QueryAllChainNoncesResponse, error) PendingNoncesAll(ctx context.Context, in *QueryAllPendingNoncesRequest, opts ...grpc.CallOption) (*QueryAllPendingNoncesResponse, error) + PendingNoncesByChain(ctx context.Context, in *QueryPendingNoncesByChainRequest, opts ...grpc.CallOption) (*QueryPendingNoncesByChainResponse, error) // Queries a lastBlockHeight by index. LastBlockHeight(ctx context.Context, in *QueryGetLastBlockHeightRequest, opts ...grpc.CallOption) (*QueryGetLastBlockHeightResponse, error) // Queries a list of lastBlockHeight items. @@ -3384,6 +3479,15 @@ func (c *queryClient) PendingNoncesAll(ctx context.Context, in *QueryAllPendingN return out, nil } +func (c *queryClient) PendingNoncesByChain(ctx context.Context, in *QueryPendingNoncesByChainRequest, opts ...grpc.CallOption) (*QueryPendingNoncesByChainResponse, error) { + out := new(QueryPendingNoncesByChainResponse) + err := c.cc.Invoke(ctx, "/zetachain.zetacore.crosschain.Query/PendingNoncesByChain", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + func (c *queryClient) LastBlockHeight(ctx context.Context, in *QueryGetLastBlockHeightRequest, opts ...grpc.CallOption) (*QueryGetLastBlockHeightResponse, error) { out := new(QueryGetLastBlockHeightResponse) err := c.cc.Invoke(ctx, "/zetachain.zetacore.crosschain.Query/LastBlockHeight", in, out, opts...) @@ -3486,6 +3590,7 @@ type QueryServer interface { // Queries a list of chainNonces items. ChainNoncesAll(context.Context, *QueryAllChainNoncesRequest) (*QueryAllChainNoncesResponse, error) PendingNoncesAll(context.Context, *QueryAllPendingNoncesRequest) (*QueryAllPendingNoncesResponse, error) + PendingNoncesByChain(context.Context, *QueryPendingNoncesByChainRequest) (*QueryPendingNoncesByChainResponse, error) // Queries a lastBlockHeight by index. LastBlockHeight(context.Context, *QueryGetLastBlockHeightRequest) (*QueryGetLastBlockHeightResponse, error) // Queries a list of lastBlockHeight items. @@ -3555,6 +3660,9 @@ func (*UnimplementedQueryServer) ChainNoncesAll(ctx context.Context, req *QueryA func (*UnimplementedQueryServer) PendingNoncesAll(ctx context.Context, req *QueryAllPendingNoncesRequest) (*QueryAllPendingNoncesResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method PendingNoncesAll not implemented") } +func (*UnimplementedQueryServer) PendingNoncesByChain(ctx context.Context, req *QueryPendingNoncesByChainRequest) (*QueryPendingNoncesByChainResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method PendingNoncesByChain not implemented") +} func (*UnimplementedQueryServer) LastBlockHeight(ctx context.Context, req *QueryGetLastBlockHeightRequest) (*QueryGetLastBlockHeightResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method LastBlockHeight not implemented") } @@ -3872,6 +3980,24 @@ func _Query_PendingNoncesAll_Handler(srv interface{}, ctx context.Context, dec f return interceptor(ctx, in, info, handler) } +func _Query_PendingNoncesByChain_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(QueryPendingNoncesByChainRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(QueryServer).PendingNoncesByChain(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/zetachain.zetacore.crosschain.Query/PendingNoncesByChain", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(QueryServer).PendingNoncesByChain(ctx, req.(*QueryPendingNoncesByChainRequest)) + } + return interceptor(ctx, in, info, handler) +} + func _Query_LastBlockHeight_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(QueryGetLastBlockHeightRequest) if err := dec(in); err != nil { @@ -4084,6 +4210,10 @@ var _Query_serviceDesc = grpc.ServiceDesc{ MethodName: "PendingNoncesAll", Handler: _Query_PendingNoncesAll_Handler, }, + { + MethodName: "PendingNoncesByChain", + Handler: _Query_PendingNoncesByChain_Handler, + }, { MethodName: "LastBlockHeight", Handler: _Query_LastBlockHeight_Handler, @@ -5166,6 +5296,67 @@ func (m *QueryAllPendingNoncesResponse) MarshalToSizedBuffer(dAtA []byte) (int, return len(dAtA) - i, nil } +func (m *QueryPendingNoncesByChainRequest) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *QueryPendingNoncesByChainRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryPendingNoncesByChainRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.ChainId != 0 { + i = encodeVarintQuery(dAtA, i, uint64(m.ChainId)) + i-- + dAtA[i] = 0x8 + } + return len(dAtA) - i, nil +} + +func (m *QueryPendingNoncesByChainResponse) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *QueryPendingNoncesByChainResponse) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryPendingNoncesByChainResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.PendingNonces.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintQuery(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + func (m *QueryGetLastBlockHeightRequest) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) @@ -6808,6 +6999,29 @@ func (m *QueryAllPendingNoncesResponse) Size() (n int) { return n } +func (m *QueryPendingNoncesByChainRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.ChainId != 0 { + n += 1 + sovQuery(uint64(m.ChainId)) + } + return n +} + +func (m *QueryPendingNoncesByChainResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.PendingNonces.Size() + n += 1 + l + sovQuery(uint64(l)) + return n +} + func (m *QueryGetLastBlockHeightRequest) Size() (n int) { if m == nil { return 0 @@ -9963,6 +10177,158 @@ func (m *QueryAllPendingNoncesResponse) Unmarshal(dAtA []byte) error { } return nil } +func (m *QueryPendingNoncesByChainRequest) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: QueryPendingNoncesByChainRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: QueryPendingNoncesByChainRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType) + } + m.ChainId = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ChainId |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipQuery(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthQuery + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *QueryPendingNoncesByChainResponse) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: QueryPendingNoncesByChainResponse: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: QueryPendingNoncesByChainResponse: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PendingNonces", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthQuery + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthQuery + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.PendingNonces.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipQuery(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthQuery + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func (m *QueryGetLastBlockHeightRequest) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 diff --git a/x/crosschain/types/query.pb.gw.go b/x/crosschain/types/query.pb.gw.go index 2b64d0ef9a..f8ea4ecbae 100644 --- a/x/crosschain/types/query.pb.gw.go +++ b/x/crosschain/types/query.pb.gw.go @@ -667,6 +667,60 @@ func local_request_Query_PendingNoncesAll_0(ctx context.Context, marshaler runti } +func request_Query_PendingNoncesByChain_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq QueryPendingNoncesByChainRequest + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["chain_id"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "chain_id") + } + + protoReq.ChainId, err = runtime.Uint64(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "chain_id", err) + } + + msg, err := client.PendingNoncesByChain(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_Query_PendingNoncesByChain_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq QueryPendingNoncesByChainRequest + var metadata runtime.ServerMetadata + + var ( + val string + ok bool + err error + _ = err + ) + + val, ok = pathParams["chain_id"] + if !ok { + return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "chain_id") + } + + protoReq.ChainId, err = runtime.Uint64(val) + + if err != nil { + return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "chain_id", err) + } + + msg, err := server.PendingNoncesByChain(ctx, &protoReq) + return msg, metadata, err + +} + func request_Query_LastBlockHeight_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { var protoReq QueryGetLastBlockHeightRequest var metadata runtime.ServerMetadata @@ -1369,6 +1423,29 @@ func RegisterQueryHandlerServer(ctx context.Context, mux *runtime.ServeMux, serv }) + mux.Handle("GET", pattern_Query_PendingNoncesByChain_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + var stream runtime.ServerTransportStream + ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_Query_PendingNoncesByChain_0(rctx, inboundMarshaler, server, req, pathParams) + md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_Query_PendingNoncesByChain_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + mux.Handle("GET", pattern_Query_LastBlockHeight_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { ctx, cancel := context.WithCancel(req.Context()) defer cancel() @@ -1914,6 +1991,26 @@ func RegisterQueryHandlerClient(ctx context.Context, mux *runtime.ServeMux, clie }) + mux.Handle("GET", pattern_Query_PendingNoncesByChain_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_Query_PendingNoncesByChain_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_Query_PendingNoncesByChain_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + mux.Handle("GET", pattern_Query_LastBlockHeight_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { ctx, cancel := context.WithCancel(req.Context()) defer cancel() @@ -2110,6 +2207,8 @@ var ( pattern_Query_PendingNoncesAll_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"zeta-chain", "crosschain", "pendingNonces"}, "", runtime.AssumeColonVerbOpt(false))) + pattern_Query_PendingNoncesByChain_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3}, []string{"zeta-chain", "crosschain", "pendingNonces", "chain_id"}, "", runtime.AssumeColonVerbOpt(false))) + pattern_Query_LastBlockHeight_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 1, 0, 4, 1, 5, 3}, []string{"zeta-chain", "crosschain", "lastBlockHeight", "index"}, "", runtime.AssumeColonVerbOpt(false))) pattern_Query_LastBlockHeightAll_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"zeta-chain", "crosschain", "lastBlockHeight"}, "", runtime.AssumeColonVerbOpt(false))) @@ -2160,6 +2259,8 @@ var ( forward_Query_PendingNoncesAll_0 = runtime.ForwardResponseMessage + forward_Query_PendingNoncesByChain_0 = runtime.ForwardResponseMessage + forward_Query_LastBlockHeight_0 = runtime.ForwardResponseMessage forward_Query_LastBlockHeightAll_0 = runtime.ForwardResponseMessage