From b73fbcf93d8412e7358a15b8ac873bcf2df32e5a Mon Sep 17 00:00:00 2001 From: Tanmay Date: Tue, 28 May 2024 11:36:40 -0400 Subject: [PATCH 1/5] refactor: MsgUpdateZRC20 into MsgPauseZrc20 and MsgUnPauseZRC20 (#2262) * refactor MsgUpdateZRC20 into MsgPauseZrc20 and MsgUnPauseZRC20 * refactor MsgUpdateZRC20 into MsgPauseZrc20 and MsgUnPauseZRC20 * add changelog entry * add breaking changes * generate files * add todo for skipping missed coins * generate 2 * fix proto files * Update x/fungible/keeper/msg_server_pause_zrc20.go Co-authored-by: Lucas Bertrand * remove validate basic checks * generate files 3 * remove action from tx Unpause and Pause --------- Co-authored-by: Lucas Bertrand --- changelog.md | 1 + docs/cli/zetacored/zetacored_tx_fungible.md | 3 +- ...d => zetacored_tx_fungible_pause-zrc20.md} | 10 +- .../zetacored_tx_fungible_unpause-zrc20.md | 59 ++ docs/openapi/openapi.swagger.yaml | 12 +- docs/releases/v17_breaking_changes.md | 4 + docs/spec/fungible/messages.md | 35 +- e2e/e2etests/test_pause_zrc20.go | 10 +- .../zetachain/zetacore/fungible/events.proto | 11 +- proto/zetachain/zetacore/fungible/tx.proto | 31 +- .../zetacore/fungible/events_pb.d.ts | 52 +- .../zetachain/zetacore/fungible/tx_pb.d.ts | 138 +-- x/fungible/client/cli/tx.go | 3 +- .../cli/tx_update_zrc20_paused_status.go | 47 +- x/fungible/keeper/msg_server_pause_zrc20.go | 55 ++ ...test.go => msg_server_pause_zrc20_test.go} | 95 +- x/fungible/keeper/msg_server_unpause_zrc20.go | 55 ++ .../keeper/msg_server_unpause_zrc20_test.go | 142 +++ .../msg_server_update_zrc20_paused_status.go | 74 -- x/fungible/types/codec.go | 6 +- x/fungible/types/events.pb.go | 430 +++++++-- ...aused_status.go => message_pause_zrc20.go} | 29 +- ...us_test.go => message_pause_zrc20_test.go} | 54 +- x/fungible/types/message_unpause_zrc20.go | 59 ++ .../types/message_unpause_zrc20_test.go | 147 +++ x/fungible/types/tx.pb.go | 838 ++++++++++++------ 26 files changed, 1690 insertions(+), 710 deletions(-) rename docs/cli/zetacored/{zetacored_tx_fungible_update-zrc20-paused-status.md => zetacored_tx_fungible_pause-zrc20.md} (89%) create mode 100644 docs/cli/zetacored/zetacored_tx_fungible_unpause-zrc20.md create mode 100644 x/fungible/keeper/msg_server_pause_zrc20.go rename x/fungible/keeper/{msg_server_update_zrc20_paused_status_test.go => msg_server_pause_zrc20_test.go} (53%) create mode 100644 x/fungible/keeper/msg_server_unpause_zrc20.go create mode 100644 x/fungible/keeper/msg_server_unpause_zrc20_test.go delete mode 100644 x/fungible/keeper/msg_server_update_zrc20_paused_status.go rename x/fungible/types/{message_update_zrc20_paused_status.go => message_pause_zrc20.go} (54%) rename x/fungible/types/{message_update_zrc20_paused_status_test.go => message_pause_zrc20_test.go} (61%) create mode 100644 x/fungible/types/message_unpause_zrc20.go create mode 100644 x/fungible/types/message_unpause_zrc20_test.go diff --git a/changelog.md b/changelog.md index fcbfee4d18..1414740d47 100644 --- a/changelog.md +++ b/changelog.md @@ -30,6 +30,7 @@ * [2210](https://github.com/zeta-chain/node/pull/2210) - removed uncessary panics in the zetaclientd process * [2205](https://github.com/zeta-chain/node/pull/2205) - remove deprecated variables pre-v17 * [2226](https://github.com/zeta-chain/node/pull/2226) - improve Go formatting with imports standardization and max line length to 120 +* [2262](https://github.com/zeta-chain/node/pull/2262) - refactor MsgUpdateZRC20 into MsgPauseZrc20 and MsgUnPauseZRC20 ### Tests diff --git a/docs/cli/zetacored/zetacored_tx_fungible.md b/docs/cli/zetacored/zetacored_tx_fungible.md index 37fc724871..3a54cf4315 100644 --- a/docs/cli/zetacored/zetacored_tx_fungible.md +++ b/docs/cli/zetacored/zetacored_tx_fungible.md @@ -28,10 +28,11 @@ zetacored tx fungible [flags] * [zetacored tx](zetacored_tx.md) - Transactions subcommands * [zetacored tx fungible deploy-fungible-coin-zrc-4](zetacored_tx_fungible_deploy-fungible-coin-zrc-4.md) - Broadcast message DeployFungibleCoinZRC20 * [zetacored tx fungible deploy-system-contracts](zetacored_tx_fungible_deploy-system-contracts.md) - Broadcast message SystemContracts +* [zetacored tx fungible pause-zrc20](zetacored_tx_fungible_pause-zrc20.md) - Broadcast message PauseZRC20 * [zetacored tx fungible remove-foreign-coin](zetacored_tx_fungible_remove-foreign-coin.md) - Broadcast message RemoveForeignCoin +* [zetacored tx fungible unpause-zrc20](zetacored_tx_fungible_unpause-zrc20.md) - Broadcast message UnpauseZRC20 * [zetacored tx fungible update-contract-bytecode](zetacored_tx_fungible_update-contract-bytecode.md) - Broadcast message UpdateContractBytecode * [zetacored tx fungible update-system-contract](zetacored_tx_fungible_update-system-contract.md) - Broadcast message UpdateSystemContract * [zetacored tx fungible update-zrc20-liquidity-cap](zetacored_tx_fungible_update-zrc20-liquidity-cap.md) - Broadcast message UpdateZRC20LiquidityCap -* [zetacored tx fungible update-zrc20-paused-status](zetacored_tx_fungible_update-zrc20-paused-status.md) - Broadcast message UpdateZRC20PausedStatus * [zetacored tx fungible update-zrc20-withdraw-fee](zetacored_tx_fungible_update-zrc20-withdraw-fee.md) - Broadcast message UpdateZRC20WithdrawFee diff --git a/docs/cli/zetacored/zetacored_tx_fungible_update-zrc20-paused-status.md b/docs/cli/zetacored/zetacored_tx_fungible_pause-zrc20.md similarity index 89% rename from docs/cli/zetacored/zetacored_tx_fungible_update-zrc20-paused-status.md rename to docs/cli/zetacored/zetacored_tx_fungible_pause-zrc20.md index c25b2afeb1..6f2e587551 100644 --- a/docs/cli/zetacored/zetacored_tx_fungible_update-zrc20-paused-status.md +++ b/docs/cli/zetacored/zetacored_tx_fungible_pause-zrc20.md @@ -1,15 +1,15 @@ -# tx fungible update-zrc20-paused-status +# tx fungible pause-zrc20 -Broadcast message UpdateZRC20PausedStatus +Broadcast message PauseZRC20 ``` -zetacored tx fungible update-zrc20-paused-status [contractAddress1, contractAddress2, ...] [pausedStatus] [flags] +zetacored tx fungible pause-zrc20 [contractAddress1, contractAddress2, ...] [flags] ``` ### Examples ``` -zetacored tx fungible update-zrc20-paused-status "0xece40cbB54d65282c4623f141c4a8a0bE7D6AdEc, 0xece40cbB54d65282c4623f141c4a8a0bEjgksncf" 0 +zetacored tx fungible pause-zrc20 "0xece40cbB54d65282c4623f141c4a8a0bE7D6AdEc, 0xece40cbB54d65282c4623f141c4a8a0bEjgksncf" ``` ### Options @@ -28,7 +28,7 @@ zetacored tx fungible update-zrc20-paused-status "0xece40cbB54d65282c4623f141c4a --gas-adjustment float adjustment factor to be multiplied against the estimate returned by the tx simulation; if the gas limit is set manually this flag is ignored (default 1) --gas-prices string Gas prices in decimal format to determine the transaction fee (e.g. 0.1uatom) --generate-only Build an unsigned transaction and write it to STDOUT (when enabled, the local Keybase only accessed when providing a key name) - -h, --help help for update-zrc20-paused-status + -h, --help help for pause-zrc20 --keyring-backend string Select keyring's backend (os|file|kwallet|pass|test|memory) --keyring-dir string The client Keyring directory; if omitted, the default 'home' directory will be used --ledger Use a connected Ledger device diff --git a/docs/cli/zetacored/zetacored_tx_fungible_unpause-zrc20.md b/docs/cli/zetacored/zetacored_tx_fungible_unpause-zrc20.md new file mode 100644 index 0000000000..3063faee84 --- /dev/null +++ b/docs/cli/zetacored/zetacored_tx_fungible_unpause-zrc20.md @@ -0,0 +1,59 @@ +# tx fungible unpause-zrc20 + +Broadcast message UnpauseZRC20 + +``` +zetacored tx fungible unpause-zrc20 [contractAddress1, contractAddress2, ...] [flags] +``` + +### Examples + +``` +zetacored tx fungible unpause-zrc20 "0xece40cbB54d65282c4623f141c4a8a0bE7D6AdEc, 0xece40cbB54d65282c4623f141c4a8a0bEjgksncf" +``` + +### Options + +``` + -a, --account-number uint The account number of the signing account (offline mode only) + --aux Generate aux signer data instead of sending a tx + -b, --broadcast-mode string Transaction broadcasting mode (sync|async) + --chain-id string The network chain ID + --dry-run ignore the --gas flag and perform a simulation of a transaction, but don't broadcast it (when enabled, the local Keybase is not accessible) + --fee-granter string Fee granter grants fees for the transaction + --fee-payer string Fee payer pays fees for the transaction instead of deducting from the signer + --fees string Fees to pay along with transaction; eg: 10uatom + --from string Name or address of private key with which to sign + --gas string gas limit to set per-transaction; set to "auto" to calculate sufficient gas automatically. Note: "auto" option doesn't always report accurate results. Set a valid coin value to adjust the result. Can be used instead of "fees". (default 200000) + --gas-adjustment float adjustment factor to be multiplied against the estimate returned by the tx simulation; if the gas limit is set manually this flag is ignored (default 1) + --gas-prices string Gas prices in decimal format to determine the transaction fee (e.g. 0.1uatom) + --generate-only Build an unsigned transaction and write it to STDOUT (when enabled, the local Keybase only accessed when providing a key name) + -h, --help help for unpause-zrc20 + --keyring-backend string Select keyring's backend (os|file|kwallet|pass|test|memory) + --keyring-dir string The client Keyring directory; if omitted, the default 'home' directory will be used + --ledger Use a connected Ledger device + --node string [host]:[port] to tendermint rpc interface for this chain + --note string Note to add a description to the transaction (previously --memo) + --offline Offline mode (does not allow any online functionality) + -o, --output string Output format (text|json) + -s, --sequence uint The sequence number of the signing account (offline mode only) + --sign-mode string Choose sign mode (direct|amino-json|direct-aux), this is an advanced feature + --timeout-height uint Set a block timeout height to prevent the tx from being committed past a certain height + --tip string Tip is the amount that is going to be transferred to the fee payer on the target chain. This flag is only valid when used with --aux, and is ignored if the target chain didn't enable the TipDecorator + -y, --yes Skip tx broadcasting prompt confirmation +``` + +### Options inherited from parent commands + +``` + --home string directory for config and data + --log_format string The logging format (json|plain) + --log_level string The logging level (trace|debug|info|warn|error|fatal|panic) + --log_no_color Disable colored logs + --trace print out full stack trace on errors +``` + +### SEE ALSO + +* [zetacored tx fungible](zetacored_tx_fungible.md) - fungible transactions subcommands + diff --git a/docs/openapi/openapi.swagger.yaml b/docs/openapi/openapi.swagger.yaml index 92c7ac28c8..9067eccc6d 100644 --- a/docs/openapi/openapi.swagger.yaml +++ b/docs/openapi/openapi.swagger.yaml @@ -57422,16 +57422,18 @@ definitions: type: string systemContract: type: string + fungibleMsgPauseZRC20Response: + type: object fungibleMsgRemoveForeignCoinResponse: type: object + fungibleMsgUnpauseZRC20Response: + type: object fungibleMsgUpdateContractBytecodeResponse: type: object fungibleMsgUpdateSystemContractResponse: type: object fungibleMsgUpdateZRC20LiquidityCapResponse: type: object - fungibleMsgUpdateZRC20PausedStatusResponse: - type: object fungibleMsgUpdateZRC20WithdrawFeeResponse: type: object fungibleQueryAllForeignCoinsResponse: @@ -57486,12 +57488,6 @@ definitions: type: string connector_zevm: type: string - fungibleUpdatePausedStatusAction: - type: string - enum: - - PAUSE - - UNPAUSE - default: PAUSE googlerpcStatus: type: object properties: diff --git a/docs/releases/v17_breaking_changes.md b/docs/releases/v17_breaking_changes.md index b1598cbf9b..13dc5df873 100644 --- a/docs/releases/v17_breaking_changes.md +++ b/docs/releases/v17_breaking_changes.md @@ -47,3 +47,7 @@ * `/zeta-chain/crosschain/inTxHashToCctxData/{hash}` endpoint is now `/zeta-chain/crosschain/inboundHashToCctxData/{hash}` * `InTxHashToCctxAll` has been renamed to `InboundHashToCctxAll` * `/zeta-chain/crosschain/inTxHashToCctx` endpoint is now `/zeta-chain/crosschain/inboundHashToCctx` + +* `MsgUpdateZRC20` has been removed, and replaced with `MsgPauseZRC20` and `MsgUnpauseZRC20` messages. + * `MsgPauseZRC20` message pauses a ZRC20 token and can be triggered via `PolicyType_groupEmergency` + * `MsgUnpauseZRC20` message unpauses a ZRC20 token and can be triggered via `PolicyType_groupOperational` diff --git a/docs/spec/fungible/messages.md b/docs/spec/fungible/messages.md index 2e3aceb19e..93c7864aef 100644 --- a/docs/spec/fungible/messages.md +++ b/docs/spec/fungible/messages.md @@ -102,32 +102,41 @@ message MsgUpdateZRC20WithdrawFee { } ``` -## MsgUpdateZRC20PausedStatus +## MsgUpdateZRC20LiquidityCap -UpdateZRC20PausedStatus updates the paused status of a ZRC20 -The list of ZRC20s are either paused or unpaused +UpdateZRC20LiquidityCap updates the liquidity cap for a ZRC20 token. -Authorized: admin policy group 1 (pausing), group 2 (pausing & unpausing) +Authorized: admin policy group 2. ```proto -message MsgUpdateZRC20PausedStatus { +message MsgUpdateZRC20LiquidityCap { string creator = 1; - string zrc20_addresses = 2; - UpdatePausedStatusAction action = 3; + string zrc20_address = 2; + string liquidity_cap = 3; } ``` -## MsgUpdateZRC20LiquidityCap +## MsgPauseZRC20 -UpdateZRC20LiquidityCap updates the liquidity cap for a ZRC20 token. +PauseZRC20 pauses a list of ZRC20 tokens +Authorized: admin policy group groupEmergency. -Authorized: admin policy group 2. +```proto +message MsgPauseZRC20 { + string creator = 1; + string zrc20_addresses = 2; +} +``` + +## MsgUnpauseZRC20 + +UnpauseZRC20 unpauses the ZRC20 token +Authorized: admin policy group groupOperational. ```proto -message MsgUpdateZRC20LiquidityCap { +message MsgUnpauseZRC20 { string creator = 1; - string zrc20_address = 2; - string liquidity_cap = 3; + string zrc20_addresses = 2; } ``` diff --git a/e2e/e2etests/test_pause_zrc20.go b/e2e/e2etests/test_pause_zrc20.go index 07505d4b2a..dbe5182e80 100644 --- a/e2e/e2etests/test_pause_zrc20.go +++ b/e2e/e2etests/test_pause_zrc20.go @@ -39,12 +39,11 @@ func TestPauseZRC20(r *runner.E2ERunner, _ []string) { // Pause ETH ZRC20 r.Logger.Info("Pausing ETH") - msg := fungibletypes.NewMsgUpdateZRC20PausedStatus( + msgPause := fungibletypes.NewMsgPauseZRC20( r.ZetaTxServer.GetAccountAddress(0), []string{r.ETHZRC20Addr.Hex()}, - fungibletypes.UpdatePausedStatusAction_PAUSE, ) - res, err := r.ZetaTxServer.BroadcastTx(utils.FungibleAdminName, msg) + res, err := r.ZetaTxServer.BroadcastTx(utils.FungibleAdminName, msgPause) if err != nil { panic(err) } @@ -129,12 +128,11 @@ func TestPauseZRC20(r *runner.E2ERunner, _ []string) { // Unpause ETH ZRC20 r.Logger.Info("Unpausing ETH") - msg = fungibletypes.NewMsgUpdateZRC20PausedStatus( + msgUnpause := fungibletypes.NewMsgUnpauseZRC20( r.ZetaTxServer.GetAccountAddress(0), []string{r.ETHZRC20Addr.Hex()}, - fungibletypes.UpdatePausedStatusAction_UNPAUSE, ) - res, err = r.ZetaTxServer.BroadcastTx(utils.FungibleAdminName, msg) + res, err = r.ZetaTxServer.BroadcastTx(utils.FungibleAdminName, msgUnpause) if err != nil { panic(err) } diff --git a/proto/zetachain/zetacore/fungible/events.proto b/proto/zetachain/zetacore/fungible/events.proto index 406da2c94d..41b78c635e 100644 --- a/proto/zetachain/zetacore/fungible/events.proto +++ b/proto/zetachain/zetacore/fungible/events.proto @@ -38,11 +38,16 @@ message EventZRC20WithdrawFeeUpdated { string new_gas_limit = 9; } -message EventZRC20PausedStatusUpdated { +message EventZRC20Paused { string msg_type_url = 1; repeated string zrc20_addresses = 2; - UpdatePausedStatusAction action = 3; - string signer = 4; + string signer = 3; +} + +message EventZRC20Unpaused { + string msg_type_url = 1; + repeated string zrc20_addresses = 2; + string signer = 3; } message EventSystemContractsDeployed { diff --git a/proto/zetachain/zetacore/fungible/tx.proto b/proto/zetachain/zetacore/fungible/tx.proto index 3090591e2d..bdb9ee8939 100644 --- a/proto/zetachain/zetacore/fungible/tx.proto +++ b/proto/zetachain/zetacore/fungible/tx.proto @@ -20,10 +20,10 @@ service Msg { returns (MsgUpdateContractBytecodeResponse); rpc UpdateZRC20WithdrawFee(MsgUpdateZRC20WithdrawFee) returns (MsgUpdateZRC20WithdrawFeeResponse); - rpc UpdateZRC20PausedStatus(MsgUpdateZRC20PausedStatus) - returns (MsgUpdateZRC20PausedStatusResponse); rpc UpdateZRC20LiquidityCap(MsgUpdateZRC20LiquidityCap) returns (MsgUpdateZRC20LiquidityCapResponse); + rpc PauseZRC20(MsgPauseZRC20) returns (MsgPauseZRC20Response); + rpc UnpauseZRC20(MsgUnpauseZRC20) returns (MsgUnpauseZRC20Response); } message MsgDeploySystemContracts { string creator = 1; } @@ -86,19 +86,6 @@ message MsgUpdateContractBytecode { message MsgUpdateContractBytecodeResponse {} -enum UpdatePausedStatusAction { - PAUSE = 0; - UNPAUSE = 1; -} - -message MsgUpdateZRC20PausedStatus { - string creator = 1; - repeated string zrc20_addresses = 2; - UpdatePausedStatusAction action = 3; -} - -message MsgUpdateZRC20PausedStatusResponse {} - message MsgUpdateZRC20LiquidityCap { string creator = 1; string zrc20_address = 2; @@ -109,3 +96,17 @@ message MsgUpdateZRC20LiquidityCap { } message MsgUpdateZRC20LiquidityCapResponse {} + +message MsgPauseZRC20 { + string creator = 1; + repeated string zrc20_addresses = 2; +} + +message MsgPauseZRC20Response {} + +message MsgUnpauseZRC20 { + string creator = 1; + repeated string zrc20_addresses = 2; +} + +message MsgUnpauseZRC20Response {} \ No newline at end of file diff --git a/typescript/zetachain/zetacore/fungible/events_pb.d.ts b/typescript/zetachain/zetacore/fungible/events_pb.d.ts index 111f48bac8..2cfb7f648b 100644 --- a/typescript/zetachain/zetacore/fungible/events_pb.d.ts +++ b/typescript/zetachain/zetacore/fungible/events_pb.d.ts @@ -6,7 +6,6 @@ import type { BinaryReadOptions, FieldList, JsonReadOptions, JsonValue, PartialMessage, PlainMessage } from "@bufbuild/protobuf"; import { Message, proto3 } from "@bufbuild/protobuf"; import type { CoinType } from "../pkg/coin/coin_pb.js"; -import type { UpdatePausedStatusAction } from "./tx_pb.js"; /** * @generated from message zetachain.zetacore.fungible.EventSystemContractUpdated @@ -176,9 +175,9 @@ export declare class EventZRC20WithdrawFeeUpdated extends Message { +export declare class EventZRC20Paused extends Message { /** * @generated from field: string msg_type_url = 1; */ @@ -190,28 +189,57 @@ export declare class EventZRC20PausedStatusUpdated extends Message); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.fungible.EventZRC20Paused"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): EventZRC20Paused; + static fromJson(jsonValue: JsonValue, options?: Partial): EventZRC20Paused; + + static fromJsonString(jsonString: string, options?: Partial): EventZRC20Paused; + + static equals(a: EventZRC20Paused | PlainMessage | undefined, b: EventZRC20Paused | PlainMessage | undefined): boolean; +} + +/** + * @generated from message zetachain.zetacore.fungible.EventZRC20Unpaused + */ +export declare class EventZRC20Unpaused extends Message { /** - * @generated from field: string signer = 4; + * @generated from field: string msg_type_url = 1; + */ + msgTypeUrl: string; + + /** + * @generated from field: repeated string zrc20_addresses = 2; + */ + zrc20Addresses: string[]; + + /** + * @generated from field: string signer = 3; */ signer: string; - constructor(data?: PartialMessage); + constructor(data?: PartialMessage); static readonly runtime: typeof proto3; - static readonly typeName = "zetachain.zetacore.fungible.EventZRC20PausedStatusUpdated"; + static readonly typeName = "zetachain.zetacore.fungible.EventZRC20Unpaused"; static readonly fields: FieldList; - static fromBinary(bytes: Uint8Array, options?: Partial): EventZRC20PausedStatusUpdated; + static fromBinary(bytes: Uint8Array, options?: Partial): EventZRC20Unpaused; - static fromJson(jsonValue: JsonValue, options?: Partial): EventZRC20PausedStatusUpdated; + static fromJson(jsonValue: JsonValue, options?: Partial): EventZRC20Unpaused; - static fromJsonString(jsonString: string, options?: Partial): EventZRC20PausedStatusUpdated; + static fromJsonString(jsonString: string, options?: Partial): EventZRC20Unpaused; - static equals(a: EventZRC20PausedStatusUpdated | PlainMessage | undefined, b: EventZRC20PausedStatusUpdated | PlainMessage | undefined): boolean; + static equals(a: EventZRC20Unpaused | PlainMessage | undefined, b: EventZRC20Unpaused | PlainMessage | undefined): boolean; } /** diff --git a/typescript/zetachain/zetacore/fungible/tx_pb.d.ts b/typescript/zetachain/zetacore/fungible/tx_pb.d.ts index de3c7df658..a1038d4bfd 100644 --- a/typescript/zetachain/zetacore/fungible/tx_pb.d.ts +++ b/typescript/zetachain/zetacore/fungible/tx_pb.d.ts @@ -7,21 +7,6 @@ import type { BinaryReadOptions, FieldList, JsonReadOptions, JsonValue, PartialM import { Message, proto3 } from "@bufbuild/protobuf"; import type { CoinType } from "../pkg/coin/coin_pb.js"; -/** - * @generated from enum zetachain.zetacore.fungible.UpdatePausedStatusAction - */ -export declare enum UpdatePausedStatusAction { - /** - * @generated from enum value: PAUSE = 0; - */ - PAUSE = 0, - - /** - * @generated from enum value: UNPAUSE = 1; - */ - UNPAUSE = 1, -} - /** * @generated from message zetachain.zetacore.fungible.MsgDeploySystemContracts */ @@ -383,108 +368,151 @@ export declare class MsgUpdateContractBytecodeResponse extends Message { +export declare class MsgUpdateZRC20LiquidityCap extends Message { /** * @generated from field: string creator = 1; */ creator: string; /** - * @generated from field: repeated string zrc20_addresses = 2; + * @generated from field: string zrc20_address = 2; */ - zrc20Addresses: string[]; + zrc20Address: string; /** - * @generated from field: zetachain.zetacore.fungible.UpdatePausedStatusAction action = 3; + * @generated from field: string liquidity_cap = 3; */ - action: UpdatePausedStatusAction; + liquidityCap: string; - constructor(data?: PartialMessage); + constructor(data?: PartialMessage); static readonly runtime: typeof proto3; - static readonly typeName = "zetachain.zetacore.fungible.MsgUpdateZRC20PausedStatus"; + static readonly typeName = "zetachain.zetacore.fungible.MsgUpdateZRC20LiquidityCap"; static readonly fields: FieldList; - static fromBinary(bytes: Uint8Array, options?: Partial): MsgUpdateZRC20PausedStatus; + static fromBinary(bytes: Uint8Array, options?: Partial): MsgUpdateZRC20LiquidityCap; - static fromJson(jsonValue: JsonValue, options?: Partial): MsgUpdateZRC20PausedStatus; + static fromJson(jsonValue: JsonValue, options?: Partial): MsgUpdateZRC20LiquidityCap; - static fromJsonString(jsonString: string, options?: Partial): MsgUpdateZRC20PausedStatus; + static fromJsonString(jsonString: string, options?: Partial): MsgUpdateZRC20LiquidityCap; - static equals(a: MsgUpdateZRC20PausedStatus | PlainMessage | undefined, b: MsgUpdateZRC20PausedStatus | PlainMessage | undefined): boolean; + static equals(a: MsgUpdateZRC20LiquidityCap | PlainMessage | undefined, b: MsgUpdateZRC20LiquidityCap | PlainMessage | undefined): boolean; } /** - * @generated from message zetachain.zetacore.fungible.MsgUpdateZRC20PausedStatusResponse + * @generated from message zetachain.zetacore.fungible.MsgUpdateZRC20LiquidityCapResponse */ -export declare class MsgUpdateZRC20PausedStatusResponse extends Message { - constructor(data?: PartialMessage); +export declare class MsgUpdateZRC20LiquidityCapResponse extends Message { + constructor(data?: PartialMessage); static readonly runtime: typeof proto3; - static readonly typeName = "zetachain.zetacore.fungible.MsgUpdateZRC20PausedStatusResponse"; + static readonly typeName = "zetachain.zetacore.fungible.MsgUpdateZRC20LiquidityCapResponse"; static readonly fields: FieldList; - static fromBinary(bytes: Uint8Array, options?: Partial): MsgUpdateZRC20PausedStatusResponse; + static fromBinary(bytes: Uint8Array, options?: Partial): MsgUpdateZRC20LiquidityCapResponse; - static fromJson(jsonValue: JsonValue, options?: Partial): MsgUpdateZRC20PausedStatusResponse; + static fromJson(jsonValue: JsonValue, options?: Partial): MsgUpdateZRC20LiquidityCapResponse; - static fromJsonString(jsonString: string, options?: Partial): MsgUpdateZRC20PausedStatusResponse; + static fromJsonString(jsonString: string, options?: Partial): MsgUpdateZRC20LiquidityCapResponse; - static equals(a: MsgUpdateZRC20PausedStatusResponse | PlainMessage | undefined, b: MsgUpdateZRC20PausedStatusResponse | PlainMessage | undefined): boolean; + static equals(a: MsgUpdateZRC20LiquidityCapResponse | PlainMessage | undefined, b: MsgUpdateZRC20LiquidityCapResponse | PlainMessage | undefined): boolean; } /** - * @generated from message zetachain.zetacore.fungible.MsgUpdateZRC20LiquidityCap + * @generated from message zetachain.zetacore.fungible.MsgPauseZRC20 */ -export declare class MsgUpdateZRC20LiquidityCap extends Message { +export declare class MsgPauseZRC20 extends Message { /** * @generated from field: string creator = 1; */ creator: string; /** - * @generated from field: string zrc20_address = 2; + * @generated from field: repeated string zrc20_addresses = 2; */ - zrc20Address: string; + zrc20Addresses: string[]; + + constructor(data?: PartialMessage); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.fungible.MsgPauseZRC20"; + static readonly fields: FieldList; + static fromBinary(bytes: Uint8Array, options?: Partial): MsgPauseZRC20; + + static fromJson(jsonValue: JsonValue, options?: Partial): MsgPauseZRC20; + + static fromJsonString(jsonString: string, options?: Partial): MsgPauseZRC20; + + static equals(a: MsgPauseZRC20 | PlainMessage | undefined, b: MsgPauseZRC20 | PlainMessage | undefined): boolean; +} + +/** + * @generated from message zetachain.zetacore.fungible.MsgPauseZRC20Response + */ +export declare class MsgPauseZRC20Response extends Message { + constructor(data?: PartialMessage); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.fungible.MsgPauseZRC20Response"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): MsgPauseZRC20Response; + + static fromJson(jsonValue: JsonValue, options?: Partial): MsgPauseZRC20Response; + + static fromJsonString(jsonString: string, options?: Partial): MsgPauseZRC20Response; + + static equals(a: MsgPauseZRC20Response | PlainMessage | undefined, b: MsgPauseZRC20Response | PlainMessage | undefined): boolean; +} + +/** + * @generated from message zetachain.zetacore.fungible.MsgUnpauseZRC20 + */ +export declare class MsgUnpauseZRC20 extends Message { /** - * @generated from field: string liquidity_cap = 3; + * @generated from field: string creator = 1; */ - liquidityCap: string; + creator: string; - constructor(data?: PartialMessage); + /** + * @generated from field: repeated string zrc20_addresses = 2; + */ + zrc20Addresses: string[]; + + constructor(data?: PartialMessage); static readonly runtime: typeof proto3; - static readonly typeName = "zetachain.zetacore.fungible.MsgUpdateZRC20LiquidityCap"; + static readonly typeName = "zetachain.zetacore.fungible.MsgUnpauseZRC20"; static readonly fields: FieldList; - static fromBinary(bytes: Uint8Array, options?: Partial): MsgUpdateZRC20LiquidityCap; + static fromBinary(bytes: Uint8Array, options?: Partial): MsgUnpauseZRC20; - static fromJson(jsonValue: JsonValue, options?: Partial): MsgUpdateZRC20LiquidityCap; + static fromJson(jsonValue: JsonValue, options?: Partial): MsgUnpauseZRC20; - static fromJsonString(jsonString: string, options?: Partial): MsgUpdateZRC20LiquidityCap; + static fromJsonString(jsonString: string, options?: Partial): MsgUnpauseZRC20; - static equals(a: MsgUpdateZRC20LiquidityCap | PlainMessage | undefined, b: MsgUpdateZRC20LiquidityCap | PlainMessage | undefined): boolean; + static equals(a: MsgUnpauseZRC20 | PlainMessage | undefined, b: MsgUnpauseZRC20 | PlainMessage | undefined): boolean; } /** - * @generated from message zetachain.zetacore.fungible.MsgUpdateZRC20LiquidityCapResponse + * @generated from message zetachain.zetacore.fungible.MsgUnpauseZRC20Response */ -export declare class MsgUpdateZRC20LiquidityCapResponse extends Message { - constructor(data?: PartialMessage); +export declare class MsgUnpauseZRC20Response extends Message { + constructor(data?: PartialMessage); static readonly runtime: typeof proto3; - static readonly typeName = "zetachain.zetacore.fungible.MsgUpdateZRC20LiquidityCapResponse"; + static readonly typeName = "zetachain.zetacore.fungible.MsgUnpauseZRC20Response"; static readonly fields: FieldList; - static fromBinary(bytes: Uint8Array, options?: Partial): MsgUpdateZRC20LiquidityCapResponse; + static fromBinary(bytes: Uint8Array, options?: Partial): MsgUnpauseZRC20Response; - static fromJson(jsonValue: JsonValue, options?: Partial): MsgUpdateZRC20LiquidityCapResponse; + static fromJson(jsonValue: JsonValue, options?: Partial): MsgUnpauseZRC20Response; - static fromJsonString(jsonString: string, options?: Partial): MsgUpdateZRC20LiquidityCapResponse; + static fromJsonString(jsonString: string, options?: Partial): MsgUnpauseZRC20Response; - static equals(a: MsgUpdateZRC20LiquidityCapResponse | PlainMessage | undefined, b: MsgUpdateZRC20LiquidityCapResponse | PlainMessage | undefined): boolean; + static equals(a: MsgUnpauseZRC20Response | PlainMessage | undefined, b: MsgUnpauseZRC20Response | PlainMessage | undefined): boolean; } diff --git a/x/fungible/client/cli/tx.go b/x/fungible/client/cli/tx.go index 5830233c37..8d81382cc8 100644 --- a/x/fungible/client/cli/tx.go +++ b/x/fungible/client/cli/tx.go @@ -26,7 +26,8 @@ func GetTxCmd() *cobra.Command { CmdUpdateZRC20LiquidityCap(), CmdUpdateContractBytecode(), CmdUpdateSystemContract(), - CmdUpdateZRC20PausedStatus(), + CmdPauseZRC20(), + CmdUnpauseZRC20(), CmdUpdateZRC20WithdrawFee(), ) diff --git a/x/fungible/client/cli/tx_update_zrc20_paused_status.go b/x/fungible/client/cli/tx_update_zrc20_paused_status.go index 3c0b498d5a..553cf68545 100644 --- a/x/fungible/client/cli/tx_update_zrc20_paused_status.go +++ b/x/fungible/client/cli/tx_update_zrc20_paused_status.go @@ -1,25 +1,22 @@ package cli import ( - "strconv" "strings" - cosmoserrors "cosmossdk.io/errors" "github.com/cosmos/cosmos-sdk/client" "github.com/cosmos/cosmos-sdk/client/flags" "github.com/cosmos/cosmos-sdk/client/tx" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" "github.com/spf13/cobra" "github.com/zeta-chain/zetacore/x/fungible/types" ) -func CmdUpdateZRC20PausedStatus() *cobra.Command { +func CmdPauseZRC20() *cobra.Command { cmd := &cobra.Command{ - Use: "update-zrc20-paused-status [contractAddress1, contractAddress2, ...] [pausedStatus]", - Short: "Broadcast message UpdateZRC20PausedStatus", - Example: `zetacored tx fungible update-zrc20-paused-status "0xece40cbB54d65282c4623f141c4a8a0bE7D6AdEc, 0xece40cbB54d65282c4623f141c4a8a0bEjgksncf" 0 `, - Args: cobra.ExactArgs(2), + Use: "pause-zrc20 [contractAddress1, contractAddress2, ...]", + Short: "Broadcast message PauseZRC20", + Example: `zetacored tx fungible pause-zrc20 "0xece40cbB54d65282c4623f141c4a8a0bE7D6AdEc, 0xece40cbB54d65282c4623f141c4a8a0bEjgksncf" `, + Args: cobra.ExactArgs(1), RunE: func(cmd *cobra.Command, args []string) (err error) { clientCtx, err := client.GetClientTxContext(cmd) if err != nil { @@ -28,23 +25,37 @@ func CmdUpdateZRC20PausedStatus() *cobra.Command { contractAddressList := strings.Split(strings.TrimSpace(args[0]), ",") - action, err := strconv.ParseUint(args[1], 10, 32) + msg := types.NewMsgPauseZRC20( + clientCtx.GetFromAddress().String(), + contractAddressList, + ) + + return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) + }, + } + + flags.AddTxFlagsToCmd(cmd) + + return cmd +} + +func CmdUnpauseZRC20() *cobra.Command { + cmd := &cobra.Command{ + Use: "unpause-zrc20 [contractAddress1, contractAddress2, ...]", + Short: "Broadcast message UnpauseZRC20", + Example: `zetacored tx fungible unpause-zrc20 "0xece40cbB54d65282c4623f141c4a8a0bE7D6AdEc, 0xece40cbB54d65282c4623f141c4a8a0bEjgksncf" `, + Args: cobra.ExactArgs(1), + RunE: func(cmd *cobra.Command, args []string) (err error) { + clientCtx, err := client.GetClientTxContext(cmd) if err != nil { return err } - if (action != 0) && (action != 1) { - return cosmoserrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid action (%d)", action) - } - pausedStatus := types.UpdatePausedStatusAction_PAUSE - if action == 1 { - pausedStatus = types.UpdatePausedStatusAction_UNPAUSE - } + contractAddressList := strings.Split(strings.TrimSpace(args[0]), ",") - msg := types.NewMsgUpdateZRC20PausedStatus( + msg := types.NewMsgUnpauseZRC20( clientCtx.GetFromAddress().String(), contractAddressList, - pausedStatus, ) return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) diff --git a/x/fungible/keeper/msg_server_pause_zrc20.go b/x/fungible/keeper/msg_server_pause_zrc20.go new file mode 100644 index 0000000000..536da472a1 --- /dev/null +++ b/x/fungible/keeper/msg_server_pause_zrc20.go @@ -0,0 +1,55 @@ +package keeper + +import ( + "context" + + cosmoserrors "cosmossdk.io/errors" + sdk "github.com/cosmos/cosmos-sdk/types" + + authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" + "github.com/zeta-chain/zetacore/x/fungible/types" +) + +// PauseZRC20 pauses a list of ZRC20 tokens +// Authorized: admin policy group groupEmergency. +func (k msgServer) PauseZRC20( + goCtx context.Context, + msg *types.MsgPauseZRC20, +) (*types.MsgPauseZRC20Response, error) { + ctx := sdk.UnwrapSDKContext(goCtx) + + if !k.GetAuthorityKeeper().IsAuthorized(ctx, msg.Creator, authoritytypes.PolicyType_groupEmergency) { + return nil, cosmoserrors.Wrap( + authoritytypes.ErrUnauthorized, + "PauseZRC20 can only be executed by the correct policy account", + ) + } + + // iterate all foreign coins and set paused status + for _, zrc20 := range msg.Zrc20Addresses { + fc, found := k.GetForeignCoins(ctx, zrc20) + if !found { + return nil, cosmoserrors.Wrapf(types.ErrForeignCoinNotFound, "foreign coin not found %s", zrc20) + } + // Set status to paused + fc.Paused = true + k.SetForeignCoins(ctx, fc) + } + + err := ctx.EventManager().EmitTypedEvent( + &types.EventZRC20Paused{ + MsgTypeUrl: sdk.MsgTypeURL(&types.MsgPauseZRC20{}), + Zrc20Addresses: msg.Zrc20Addresses, + Signer: msg.Creator, + }, + ) + if err != nil { + k.Logger(ctx).Error("failed to emit event", + "event", "EventZRC20Paused", + "error", err.Error(), + ) + return nil, cosmoserrors.Wrapf(types.ErrEmitEvent, "failed to emit event (%s)", err.Error()) + } + + return &types.MsgPauseZRC20Response{}, nil +} diff --git a/x/fungible/keeper/msg_server_update_zrc20_paused_status_test.go b/x/fungible/keeper/msg_server_pause_zrc20_test.go similarity index 53% rename from x/fungible/keeper/msg_server_update_zrc20_paused_status_test.go rename to x/fungible/keeper/msg_server_pause_zrc20_test.go index 588361ce5a..9f9edc68fe 100644 --- a/x/fungible/keeper/msg_server_update_zrc20_paused_status_test.go +++ b/x/fungible/keeper/msg_server_pause_zrc20_test.go @@ -3,7 +3,6 @@ package keeper_test import ( "testing" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" "github.com/stretchr/testify/require" keepertest "github.com/zeta-chain/zetacore/testutil/keeper" @@ -13,8 +12,8 @@ import ( "github.com/zeta-chain/zetacore/x/fungible/types" ) -func TestKeeper_UpdateZRC20PausedStatus(t *testing.T) { - t.Run("can update the paused status of zrc20", func(t *testing.T) { +func TestKeeper_PauseZRC20(t *testing.T) { + t.Run("can pause zrc20", func(t *testing.T) { k, ctx, _, _ := keepertest.FungibleKeeperWithMocks(t, keepertest.FungibleMockOptions{ UseAuthorityMock: true, }) @@ -51,113 +50,47 @@ func TestKeeper_UpdateZRC20PausedStatus(t *testing.T) { keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, true) // can pause zrc20 - _, err := msgServer.UpdateZRC20PausedStatus(ctx, types.NewMsgUpdateZRC20PausedStatus( + _, err := msgServer.PauseZRC20(ctx, types.NewMsgPauseZRC20( admin, []string{ zrc20A, zrc20B, }, - types.UpdatePausedStatusAction_PAUSE, )) require.NoError(t, err) assertPaused(zrc20A) assertPaused(zrc20B) assertUnpaused(zrc20C) - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) - - // can unpause zrc20 - _, err = msgServer.UpdateZRC20PausedStatus(ctx, types.NewMsgUpdateZRC20PausedStatus( - admin, - []string{ - zrc20A, - }, - types.UpdatePausedStatusAction_UNPAUSE, - )) - require.NoError(t, err) - assertUnpaused(zrc20A) - assertPaused(zrc20B) - assertUnpaused(zrc20C) - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, true) // can pause already paused zrc20 - _, err = msgServer.UpdateZRC20PausedStatus(ctx, types.NewMsgUpdateZRC20PausedStatus( + _, err = msgServer.PauseZRC20(ctx, types.NewMsgPauseZRC20( admin, []string{ zrc20B, }, - types.UpdatePausedStatusAction_PAUSE, - )) - require.NoError(t, err) - assertUnpaused(zrc20A) - assertPaused(zrc20B) - assertUnpaused(zrc20C) - - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) - - // can unpause already unpaused zrc20 - _, err = msgServer.UpdateZRC20PausedStatus(ctx, types.NewMsgUpdateZRC20PausedStatus( - admin, - []string{ - zrc20C, - }, - types.UpdatePausedStatusAction_UNPAUSE, )) require.NoError(t, err) - assertUnpaused(zrc20A) + assertPaused(zrc20A) assertPaused(zrc20B) assertUnpaused(zrc20C) keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, true) // can pause all zrc20 - _, err = msgServer.UpdateZRC20PausedStatus(ctx, types.NewMsgUpdateZRC20PausedStatus( + _, err = msgServer.PauseZRC20(ctx, types.NewMsgPauseZRC20( admin, []string{ zrc20A, zrc20B, zrc20C, }, - types.UpdatePausedStatusAction_PAUSE, )) require.NoError(t, err) assertPaused(zrc20A) assertPaused(zrc20B) assertPaused(zrc20C) - - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) - - // can unpause all zrc20 - _, err = msgServer.UpdateZRC20PausedStatus(ctx, types.NewMsgUpdateZRC20PausedStatus( - admin, - []string{ - zrc20A, - zrc20B, - zrc20C, - }, - types.UpdatePausedStatusAction_UNPAUSE, - )) - require.NoError(t, err) - assertUnpaused(zrc20A) - assertUnpaused(zrc20B) - assertUnpaused(zrc20C) - }) - - t.Run("should fail if invalid message", func(t *testing.T) { - k, ctx, _, _ := keepertest.FungibleKeeperWithMocks(t, keepertest.FungibleMockOptions{ - UseAuthorityMock: true, - }) - - msgServer := keeper.NewMsgServerImpl(*k) - - admin := sample.AccAddress() - - invalidMsg := types.NewMsgUpdateZRC20PausedStatus(admin, []string{}, types.UpdatePausedStatusAction_PAUSE) - require.ErrorIs(t, invalidMsg.ValidateBasic(), sdkerrors.ErrInvalidRequest) - - _, err := msgServer.UpdateZRC20PausedStatus(ctx, invalidMsg) - require.ErrorIs(t, err, sdkerrors.ErrInvalidRequest) }) t.Run("should fail if not authorized", func(t *testing.T) { @@ -171,22 +104,11 @@ func TestKeeper_UpdateZRC20PausedStatus(t *testing.T) { authorityMock := keepertest.GetFungibleAuthorityMock(t, k) keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, false) - _, err := msgServer.UpdateZRC20PausedStatus(ctx, types.NewMsgUpdateZRC20PausedStatus( + _, err := msgServer.PauseZRC20(ctx, types.NewMsgPauseZRC20( admin, []string{sample.EthAddress().String()}, - types.UpdatePausedStatusAction_PAUSE, )) require.ErrorIs(t, err, authoritytypes.ErrUnauthorized) - - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, false) - - _, err = msgServer.UpdateZRC20PausedStatus(ctx, types.NewMsgUpdateZRC20PausedStatus( - admin, - []string{sample.EthAddress().String()}, - types.UpdatePausedStatusAction_UNPAUSE, - )) - - require.ErrorIs(t, err, authoritytypes.ErrUnauthorized) }) t.Run("should fail if zrc20 does not exist", func(t *testing.T) { @@ -204,14 +126,13 @@ func TestKeeper_UpdateZRC20PausedStatus(t *testing.T) { k.SetForeignCoins(ctx, sample.ForeignCoins(t, zrc20A)) k.SetForeignCoins(ctx, sample.ForeignCoins(t, zrc20B)) - _, err := msgServer.UpdateZRC20PausedStatus(ctx, types.NewMsgUpdateZRC20PausedStatus( + _, err := msgServer.PauseZRC20(ctx, types.NewMsgPauseZRC20( admin, []string{ zrc20A, sample.EthAddress().String(), zrc20B, }, - types.UpdatePausedStatusAction_PAUSE, )) require.ErrorIs(t, err, types.ErrForeignCoinNotFound) }) diff --git a/x/fungible/keeper/msg_server_unpause_zrc20.go b/x/fungible/keeper/msg_server_unpause_zrc20.go new file mode 100644 index 0000000000..f00afd6909 --- /dev/null +++ b/x/fungible/keeper/msg_server_unpause_zrc20.go @@ -0,0 +1,55 @@ +package keeper + +import ( + "context" + + cosmoserrors "cosmossdk.io/errors" + sdk "github.com/cosmos/cosmos-sdk/types" + + authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" + "github.com/zeta-chain/zetacore/x/fungible/types" +) + +// UnpauseZRC20 unpauses the ZRC20 token +// Authorized: admin policy group groupOperational. +func (k msgServer) UnpauseZRC20( + goCtx context.Context, + msg *types.MsgUnpauseZRC20, +) (*types.MsgUnpauseZRC20Response, error) { + ctx := sdk.UnwrapSDKContext(goCtx) + + if !k.GetAuthorityKeeper().IsAuthorized(ctx, msg.Creator, authoritytypes.PolicyType_groupOperational) { + return nil, cosmoserrors.Wrap( + authoritytypes.ErrUnauthorized, + "UnPauseZRC20 can only be executed by the correct policy account", + ) + } + + // iterate all foreign coins and set unpaused status + for _, zrc20 := range msg.Zrc20Addresses { + fc, found := k.GetForeignCoins(ctx, zrc20) + if !found { + return nil, cosmoserrors.Wrapf(types.ErrForeignCoinNotFound, "foreign coin not found %s", zrc20) + } + // Set status to unpaused + fc.Paused = false + k.SetForeignCoins(ctx, fc) + } + + err := ctx.EventManager().EmitTypedEvent( + &types.EventZRC20Unpaused{ + MsgTypeUrl: sdk.MsgTypeURL(&types.MsgUnpauseZRC20{}), + Zrc20Addresses: msg.Zrc20Addresses, + Signer: msg.Creator, + }, + ) + if err != nil { + k.Logger(ctx).Error("failed to emit event", + "event", "EventZRC20Unpaused", + "error", err.Error(), + ) + return nil, cosmoserrors.Wrapf(types.ErrEmitEvent, "failed to emit event (%s)", err.Error()) + } + + return &types.MsgUnpauseZRC20Response{}, nil +} diff --git a/x/fungible/keeper/msg_server_unpause_zrc20_test.go b/x/fungible/keeper/msg_server_unpause_zrc20_test.go new file mode 100644 index 0000000000..ea90f01e85 --- /dev/null +++ b/x/fungible/keeper/msg_server_unpause_zrc20_test.go @@ -0,0 +1,142 @@ +package keeper_test + +import ( + "testing" + + "github.com/stretchr/testify/require" + + keepertest "github.com/zeta-chain/zetacore/testutil/keeper" + "github.com/zeta-chain/zetacore/testutil/sample" + authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" + "github.com/zeta-chain/zetacore/x/fungible/keeper" + "github.com/zeta-chain/zetacore/x/fungible/types" +) + +func TestKeeper_UnpauseZRC20(t *testing.T) { + t.Run("can unpause status of zrc20", func(t *testing.T) { + k, ctx, _, _ := keepertest.FungibleKeeperWithMocks(t, keepertest.FungibleMockOptions{ + UseAuthorityMock: true, + }) + + msgServer := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + authorityMock := keepertest.GetFungibleAuthorityMock(t, k) + + assertUnpaused := func(zrc20 string) { + fc, found := k.GetForeignCoins(ctx, zrc20) + require.True(t, found) + require.False(t, fc.Paused) + } + assertPaused := func(zrc20 string) { + fc, found := k.GetForeignCoins(ctx, zrc20) + require.True(t, found) + require.True(t, fc.Paused) + } + + // setup zrc20 + zrc20A, zrc20B, zrc20C := sample.EthAddress(). + String(), + sample.EthAddress(). + String(), + sample.EthAddress(). + String() + k.SetForeignCoins(ctx, sample.ForeignCoins(t, zrc20A)) + fcB := sample.ForeignCoins(t, zrc20B) + fcB.Paused = true + k.SetForeignCoins(ctx, fcB) + k.SetForeignCoins(ctx, sample.ForeignCoins(t, zrc20C)) + assertUnpaused(zrc20A) + assertPaused(zrc20B) + assertUnpaused(zrc20C) + + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + // can unpause zrc20 + _, err := msgServer.UnpauseZRC20(ctx, types.NewMsgUnpauseZRC20( + admin, + []string{ + zrc20A, + }, + )) + require.NoError(t, err) + assertUnpaused(zrc20A) + assertPaused(zrc20B) + assertUnpaused(zrc20C) + + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + // can unpause already unpaused zrc20 + _, err = msgServer.UnpauseZRC20(ctx, types.NewMsgUnpauseZRC20( + admin, + []string{ + zrc20C, + }, + )) + require.NoError(t, err) + assertUnpaused(zrc20A) + assertPaused(zrc20B) + assertUnpaused(zrc20C) + + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + // can unpause all zrc20 + _, err = msgServer.UnpauseZRC20(ctx, types.NewMsgUnpauseZRC20( + admin, + []string{ + zrc20A, + zrc20B, + zrc20C, + }, + )) + require.NoError(t, err) + assertUnpaused(zrc20A) + assertUnpaused(zrc20B) + assertUnpaused(zrc20C) + }) + + t.Run("should fail if not authorized", func(t *testing.T) { + k, ctx, _, _ := keepertest.FungibleKeeperWithMocks(t, keepertest.FungibleMockOptions{ + UseAuthorityMock: true, + }) + + msgServer := keeper.NewMsgServerImpl(*k) + + admin := sample.AccAddress() + authorityMock := keepertest.GetFungibleAuthorityMock(t, k) + + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, false) + + _, err := msgServer.UnpauseZRC20(ctx, types.NewMsgUnpauseZRC20( + admin, + []string{sample.EthAddress().String()}, + )) + + require.ErrorIs(t, err, authoritytypes.ErrUnauthorized) + }) + + t.Run("should fail if zrc20 does not exist", func(t *testing.T) { + k, ctx, _, _ := keepertest.FungibleKeeperWithMocks(t, keepertest.FungibleMockOptions{ + UseAuthorityMock: true, + }) + + msgServer := keeper.NewMsgServerImpl(*k) + + admin := sample.AccAddress() + authorityMock := keepertest.GetFungibleAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + zrc20A, zrc20B := sample.EthAddress().String(), sample.EthAddress().String() + k.SetForeignCoins(ctx, sample.ForeignCoins(t, zrc20A)) + k.SetForeignCoins(ctx, sample.ForeignCoins(t, zrc20B)) + + _, err := msgServer.UnpauseZRC20(ctx, types.NewMsgUnpauseZRC20( + admin, + []string{ + zrc20A, + sample.EthAddress().String(), + zrc20B, + }, + )) + require.ErrorIs(t, err, types.ErrForeignCoinNotFound) + }) +} diff --git a/x/fungible/keeper/msg_server_update_zrc20_paused_status.go b/x/fungible/keeper/msg_server_update_zrc20_paused_status.go deleted file mode 100644 index a8a17fe585..0000000000 --- a/x/fungible/keeper/msg_server_update_zrc20_paused_status.go +++ /dev/null @@ -1,74 +0,0 @@ -package keeper - -import ( - "context" - - cosmoserrors "cosmossdk.io/errors" - sdk "github.com/cosmos/cosmos-sdk/types" - - authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" - "github.com/zeta-chain/zetacore/x/fungible/types" -) - -// UpdateZRC20PausedStatus updates the paused status of a ZRC20 -// The list of ZRC20s are either paused or unpaused -// -// Authorized: admin policy group 1 (pausing), group 2 (pausing & unpausing) -func (k msgServer) UpdateZRC20PausedStatus( - goCtx context.Context, - msg *types.MsgUpdateZRC20PausedStatus, -) (*types.MsgUpdateZRC20PausedStatusResponse, error) { - ctx := sdk.UnwrapSDKContext(goCtx) - - // check message validity - if err := msg.ValidateBasic(); err != nil { - return nil, err - } - - // check if the sender is the admin - // unpausing requires operational policy - requiredPolicyAccount := authoritytypes.PolicyType_groupEmergency - if msg.Action == types.UpdatePausedStatusAction_UNPAUSE { - requiredPolicyAccount = authoritytypes.PolicyType_groupOperational - } - if !k.GetAuthorityKeeper().IsAuthorized(ctx, msg.Creator, requiredPolicyAccount) { - return nil, cosmoserrors.Wrap( - authoritytypes.ErrUnauthorized, - "Update can only be executed by the correct policy account", - ) - } - - pausedStatus := true - if msg.Action == types.UpdatePausedStatusAction_UNPAUSE { - pausedStatus = false - } - - // iterate all foreign coins and set paused status - for _, zrc20 := range msg.Zrc20Addresses { - fc, found := k.GetForeignCoins(ctx, zrc20) - if !found { - return nil, cosmoserrors.Wrapf(types.ErrForeignCoinNotFound, "foreign coin not found %s", zrc20) - } - - fc.Paused = pausedStatus - k.SetForeignCoins(ctx, fc) - } - - err := ctx.EventManager().EmitTypedEvent( - &types.EventZRC20PausedStatusUpdated{ - MsgTypeUrl: sdk.MsgTypeURL(&types.MsgUpdateZRC20PausedStatus{}), - Action: msg.Action, - Zrc20Addresses: msg.Zrc20Addresses, - Signer: msg.Creator, - }, - ) - if err != nil { - k.Logger(ctx).Error("failed to emit event", - "event", "EventZRC20PausedStatusUpdated", - "error", err.Error(), - ) - return nil, cosmoserrors.Wrapf(types.ErrEmitEvent, "failed to emit event (%s)", err.Error()) - } - - return &types.MsgUpdateZRC20PausedStatusResponse{}, nil -} diff --git a/x/fungible/types/codec.go b/x/fungible/types/codec.go index ac7fc91429..fd31724336 100644 --- a/x/fungible/types/codec.go +++ b/x/fungible/types/codec.go @@ -14,8 +14,9 @@ func RegisterCodec(cdc *codec.LegacyAmino) { cdc.RegisterConcrete(&MsgUpdateSystemContract{}, "fungible/UpdateSystemContract", nil) cdc.RegisterConcrete(&MsgUpdateZRC20WithdrawFee{}, "fungible/UpdateZRC20WithdrawFee", nil) cdc.RegisterConcrete(&MsgUpdateContractBytecode{}, "fungible/UpdateContractBytecode", nil) - cdc.RegisterConcrete(&MsgUpdateZRC20PausedStatus{}, "fungible/UpdateZRC20PausedStatus", nil) cdc.RegisterConcrete(&MsgUpdateZRC20LiquidityCap{}, "fungible/UpdateZRC20LiquidityCap", nil) + cdc.RegisterConcrete(&MsgPauseZRC20{}, "fungible/PauseZRC20", nil) + cdc.RegisterConcrete(&MsgUnpauseZRC20{}, "fungible/UnpauseZRC20", nil) } func RegisterInterfaces(registry cdctypes.InterfaceRegistry) { @@ -26,8 +27,9 @@ func RegisterInterfaces(registry cdctypes.InterfaceRegistry) { &MsgUpdateSystemContract{}, &MsgUpdateZRC20WithdrawFee{}, &MsgUpdateContractBytecode{}, - &MsgUpdateZRC20PausedStatus{}, &MsgUpdateZRC20LiquidityCap{}, + &MsgPauseZRC20{}, + &MsgUnpauseZRC20{}, ) msgservice.RegisterMsgServiceDesc(registry, &_Msg_serviceDesc) diff --git a/x/fungible/types/events.pb.go b/x/fungible/types/events.pb.go index ba43982bc1..41795a24b7 100644 --- a/x/fungible/types/events.pb.go +++ b/x/fungible/types/events.pb.go @@ -308,25 +308,24 @@ func (m *EventZRC20WithdrawFeeUpdated) GetNewGasLimit() string { return "" } -type EventZRC20PausedStatusUpdated struct { - MsgTypeUrl string `protobuf:"bytes,1,opt,name=msg_type_url,json=msgTypeUrl,proto3" json:"msg_type_url,omitempty"` - Zrc20Addresses []string `protobuf:"bytes,2,rep,name=zrc20_addresses,json=zrc20Addresses,proto3" json:"zrc20_addresses,omitempty"` - Action UpdatePausedStatusAction `protobuf:"varint,3,opt,name=action,proto3,enum=zetachain.zetacore.fungible.UpdatePausedStatusAction" json:"action,omitempty"` - Signer string `protobuf:"bytes,4,opt,name=signer,proto3" json:"signer,omitempty"` +type EventZRC20Paused struct { + MsgTypeUrl string `protobuf:"bytes,1,opt,name=msg_type_url,json=msgTypeUrl,proto3" json:"msg_type_url,omitempty"` + Zrc20Addresses []string `protobuf:"bytes,2,rep,name=zrc20_addresses,json=zrc20Addresses,proto3" json:"zrc20_addresses,omitempty"` + Signer string `protobuf:"bytes,3,opt,name=signer,proto3" json:"signer,omitempty"` } -func (m *EventZRC20PausedStatusUpdated) Reset() { *m = EventZRC20PausedStatusUpdated{} } -func (m *EventZRC20PausedStatusUpdated) String() string { return proto.CompactTextString(m) } -func (*EventZRC20PausedStatusUpdated) ProtoMessage() {} -func (*EventZRC20PausedStatusUpdated) Descriptor() ([]byte, []int) { +func (m *EventZRC20Paused) Reset() { *m = EventZRC20Paused{} } +func (m *EventZRC20Paused) String() string { return proto.CompactTextString(m) } +func (*EventZRC20Paused) ProtoMessage() {} +func (*EventZRC20Paused) Descriptor() ([]byte, []int) { return fileDescriptor_1e6611815bc2713b, []int{3} } -func (m *EventZRC20PausedStatusUpdated) XXX_Unmarshal(b []byte) error { +func (m *EventZRC20Paused) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) } -func (m *EventZRC20PausedStatusUpdated) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { +func (m *EventZRC20Paused) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { if deterministic { - return xxx_messageInfo_EventZRC20PausedStatusUpdated.Marshal(b, m, deterministic) + return xxx_messageInfo_EventZRC20Paused.Marshal(b, m, deterministic) } else { b = b[:cap(b)] n, err := m.MarshalToSizedBuffer(b) @@ -336,40 +335,93 @@ func (m *EventZRC20PausedStatusUpdated) XXX_Marshal(b []byte, deterministic bool return b[:n], nil } } -func (m *EventZRC20PausedStatusUpdated) XXX_Merge(src proto.Message) { - xxx_messageInfo_EventZRC20PausedStatusUpdated.Merge(m, src) +func (m *EventZRC20Paused) XXX_Merge(src proto.Message) { + xxx_messageInfo_EventZRC20Paused.Merge(m, src) } -func (m *EventZRC20PausedStatusUpdated) XXX_Size() int { +func (m *EventZRC20Paused) XXX_Size() int { return m.Size() } -func (m *EventZRC20PausedStatusUpdated) XXX_DiscardUnknown() { - xxx_messageInfo_EventZRC20PausedStatusUpdated.DiscardUnknown(m) +func (m *EventZRC20Paused) XXX_DiscardUnknown() { + xxx_messageInfo_EventZRC20Paused.DiscardUnknown(m) } -var xxx_messageInfo_EventZRC20PausedStatusUpdated proto.InternalMessageInfo +var xxx_messageInfo_EventZRC20Paused proto.InternalMessageInfo -func (m *EventZRC20PausedStatusUpdated) GetMsgTypeUrl() string { +func (m *EventZRC20Paused) GetMsgTypeUrl() string { if m != nil { return m.MsgTypeUrl } return "" } -func (m *EventZRC20PausedStatusUpdated) GetZrc20Addresses() []string { +func (m *EventZRC20Paused) GetZrc20Addresses() []string { if m != nil { return m.Zrc20Addresses } return nil } -func (m *EventZRC20PausedStatusUpdated) GetAction() UpdatePausedStatusAction { +func (m *EventZRC20Paused) GetSigner() string { if m != nil { - return m.Action + return m.Signer + } + return "" +} + +type EventZRC20Unpaused struct { + MsgTypeUrl string `protobuf:"bytes,1,opt,name=msg_type_url,json=msgTypeUrl,proto3" json:"msg_type_url,omitempty"` + Zrc20Addresses []string `protobuf:"bytes,2,rep,name=zrc20_addresses,json=zrc20Addresses,proto3" json:"zrc20_addresses,omitempty"` + Signer string `protobuf:"bytes,3,opt,name=signer,proto3" json:"signer,omitempty"` +} + +func (m *EventZRC20Unpaused) Reset() { *m = EventZRC20Unpaused{} } +func (m *EventZRC20Unpaused) String() string { return proto.CompactTextString(m) } +func (*EventZRC20Unpaused) ProtoMessage() {} +func (*EventZRC20Unpaused) Descriptor() ([]byte, []int) { + return fileDescriptor_1e6611815bc2713b, []int{4} +} +func (m *EventZRC20Unpaused) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *EventZRC20Unpaused) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_EventZRC20Unpaused.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil } - return UpdatePausedStatusAction_PAUSE +} +func (m *EventZRC20Unpaused) XXX_Merge(src proto.Message) { + xxx_messageInfo_EventZRC20Unpaused.Merge(m, src) +} +func (m *EventZRC20Unpaused) XXX_Size() int { + return m.Size() +} +func (m *EventZRC20Unpaused) XXX_DiscardUnknown() { + xxx_messageInfo_EventZRC20Unpaused.DiscardUnknown(m) +} + +var xxx_messageInfo_EventZRC20Unpaused proto.InternalMessageInfo + +func (m *EventZRC20Unpaused) GetMsgTypeUrl() string { + if m != nil { + return m.MsgTypeUrl + } + return "" } -func (m *EventZRC20PausedStatusUpdated) GetSigner() string { +func (m *EventZRC20Unpaused) GetZrc20Addresses() []string { + if m != nil { + return m.Zrc20Addresses + } + return nil +} + +func (m *EventZRC20Unpaused) GetSigner() string { if m != nil { return m.Signer } @@ -390,7 +442,7 @@ func (m *EventSystemContractsDeployed) Reset() { *m = EventSystemContrac func (m *EventSystemContractsDeployed) String() string { return proto.CompactTextString(m) } func (*EventSystemContractsDeployed) ProtoMessage() {} func (*EventSystemContractsDeployed) Descriptor() ([]byte, []int) { - return fileDescriptor_1e6611815bc2713b, []int{4} + return fileDescriptor_1e6611815bc2713b, []int{5} } func (m *EventSystemContractsDeployed) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -480,7 +532,7 @@ func (m *EventBytecodeUpdated) Reset() { *m = EventBytecodeUpdated{} } func (m *EventBytecodeUpdated) String() string { return proto.CompactTextString(m) } func (*EventBytecodeUpdated) ProtoMessage() {} func (*EventBytecodeUpdated) Descriptor() ([]byte, []int) { - return fileDescriptor_1e6611815bc2713b, []int{5} + return fileDescriptor_1e6611815bc2713b, []int{6} } func (m *EventBytecodeUpdated) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -548,7 +600,8 @@ func init() { proto.RegisterType((*EventSystemContractUpdated)(nil), "zetachain.zetacore.fungible.EventSystemContractUpdated") proto.RegisterType((*EventZRC20Deployed)(nil), "zetachain.zetacore.fungible.EventZRC20Deployed") proto.RegisterType((*EventZRC20WithdrawFeeUpdated)(nil), "zetachain.zetacore.fungible.EventZRC20WithdrawFeeUpdated") - proto.RegisterType((*EventZRC20PausedStatusUpdated)(nil), "zetachain.zetacore.fungible.EventZRC20PausedStatusUpdated") + proto.RegisterType((*EventZRC20Paused)(nil), "zetachain.zetacore.fungible.EventZRC20Paused") + proto.RegisterType((*EventZRC20Unpaused)(nil), "zetachain.zetacore.fungible.EventZRC20Unpaused") proto.RegisterType((*EventSystemContractsDeployed)(nil), "zetachain.zetacore.fungible.EventSystemContractsDeployed") proto.RegisterType((*EventBytecodeUpdated)(nil), "zetachain.zetacore.fungible.EventBytecodeUpdated") } @@ -558,56 +611,55 @@ func init() { } var fileDescriptor_1e6611815bc2713b = []byte{ - // 775 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x55, 0xdd, 0x4e, 0xe3, 0x46, - 0x14, 0xc6, 0x04, 0x02, 0x19, 0x7e, 0x02, 0xa3, 0xa8, 0x72, 0x43, 0x1b, 0xa1, 0xb4, 0xb4, 0x29, - 0x6a, 0x1d, 0x94, 0xaa, 0x0f, 0x00, 0xb4, 0xb4, 0x48, 0xad, 0x54, 0x85, 0xd2, 0x4a, 0xdc, 0x58, - 0x13, 0xfb, 0xe0, 0x58, 0xd8, 0x33, 0x96, 0x67, 0x12, 0x63, 0x9e, 0xa2, 0x97, 0xfb, 0x10, 0xfb, - 0x04, 0xfb, 0x04, 0x7b, 0xc9, 0x6a, 0x6f, 0xf6, 0x72, 0x05, 0x2f, 0xb1, 0x97, 0xab, 0x19, 0x8f, - 0x1d, 0x9b, 0x05, 0x04, 0x7b, 0x13, 0xcd, 0x99, 0x7c, 0xe7, 0x9c, 0xef, 0x7c, 0xfe, 0x66, 0x06, - 0xf5, 0xae, 0x40, 0x10, 0x67, 0x4c, 0x7c, 0xda, 0x57, 0x2b, 0x16, 0x43, 0xff, 0x7c, 0x42, 0x3d, - 0x7f, 0x14, 0x40, 0x1f, 0xa6, 0x40, 0x05, 0xb7, 0xa2, 0x98, 0x09, 0x86, 0xb7, 0x0a, 0xa4, 0x95, - 0x23, 0xad, 0x1c, 0xd9, 0xfe, 0xf6, 0xb1, 0x32, 0xe2, 0x32, 0x2b, 0xd1, 0x6e, 0x79, 0xcc, 0x63, - 0x6a, 0xd9, 0x97, 0x2b, 0xbd, 0xfb, 0xdd, 0x3d, 0xb9, 0xd1, 0x85, 0xd7, 0x77, 0x98, 0x4f, 0xd5, - 0x4f, 0x86, 0xeb, 0xbe, 0x32, 0x50, 0xfb, 0x37, 0xc9, 0xe8, 0x24, 0xe5, 0x02, 0xc2, 0x43, 0x46, - 0x45, 0x4c, 0x1c, 0x71, 0x1a, 0xb9, 0x44, 0x80, 0x8b, 0xb7, 0xd1, 0x6a, 0xc8, 0x3d, 0x5b, 0xa4, - 0x11, 0xd8, 0x93, 0x38, 0x30, 0x8d, 0x6d, 0xa3, 0xd7, 0x18, 0xa2, 0x90, 0x7b, 0xff, 0xa4, 0x11, - 0x9c, 0xc6, 0x01, 0xde, 0x43, 0x2d, 0x0a, 0x89, 0xed, 0xe8, 0x44, 0x9b, 0xb8, 0x6e, 0x0c, 0x9c, - 0x9b, 0xf3, 0x0a, 0x89, 0x29, 0x24, 0x79, 0xcd, 0xfd, 0xec, 0x1f, 0x99, 0xc1, 0x02, 0xf7, 0xd3, - 0x8c, 0x5a, 0x96, 0xc1, 0x02, 0xf7, 0x6e, 0xc6, 0x17, 0xa8, 0xce, 0x7d, 0x8f, 0x42, 0x6c, 0x2e, - 0x28, 0x8c, 0x8e, 0xba, 0x2f, 0xe7, 0x11, 0x56, 0xe4, 0xcf, 0x86, 0x87, 0x83, 0xbd, 0x5f, 0x21, - 0x0a, 0x58, 0xfa, 0x24, 0xd2, 0x5f, 0xa2, 0x65, 0xa5, 0x8d, 0xed, 0xbb, 0x8a, 0x68, 0x6d, 0xb8, - 0xa4, 0xe2, 0x63, 0x17, 0xb7, 0xd1, 0x72, 0xce, 0x4c, 0x33, 0x2a, 0x62, 0x8c, 0xd1, 0x02, 0x25, - 0x21, 0x68, 0x16, 0x6a, 0xad, 0xb8, 0xa5, 0xe1, 0x88, 0x05, 0xe6, 0xa2, 0xe6, 0xa6, 0x22, 0x59, - 0xc7, 0x05, 0xc7, 0x0f, 0x49, 0xc0, 0xcd, 0xba, 0x6a, 0x51, 0xc4, 0xf8, 0x00, 0x35, 0xe4, 0x27, - 0x50, 0x0c, 0xcd, 0xa5, 0x6d, 0xa3, 0xb7, 0x3e, 0xd8, 0xb1, 0xee, 0x71, 0x42, 0x74, 0xe1, 0x59, - 0xea, 0x5b, 0x1d, 0x32, 0x9f, 0x4a, 0xee, 0x92, 0x4b, 0xb6, 0xc2, 0x2d, 0xb4, 0x08, 0xb1, 0x33, - 0xd8, 0x33, 0x97, 0x55, 0xdb, 0x2c, 0xc0, 0x5b, 0xa8, 0xe1, 0x11, 0x6e, 0x07, 0x7e, 0xe8, 0x0b, - 0xb3, 0x91, 0xb5, 0xf5, 0x08, 0xff, 0x53, 0xc6, 0xdd, 0x0f, 0xf3, 0xe8, 0xab, 0x99, 0x5c, 0xff, - 0xf9, 0x62, 0xec, 0xc6, 0x24, 0x39, 0x02, 0x78, 0xfa, 0xd7, 0x7e, 0x44, 0xb8, 0xca, 0x50, 0xb5, - 0xcf, 0x1b, 0xea, 0x1b, 0xb4, 0x76, 0x25, 0xe7, 0x28, 0x3c, 0x91, 0x29, 0xbd, 0xaa, 0x36, 0x73, - 0x37, 0xf4, 0xd0, 0x86, 0xf4, 0x4f, 0xa2, 0xf9, 0xdb, 0xe7, 0x00, 0x5a, 0xfb, 0x75, 0x16, 0xb8, - 0xa5, 0xb1, 0x24, 0x52, 0x7a, 0xb3, 0x82, 0xac, 0x67, 0x48, 0x0a, 0x49, 0x19, 0x39, 0x73, 0xd8, - 0x52, 0xd9, 0x61, 0xb8, 0x8b, 0xd6, 0x64, 0xaf, 0x99, 0xa6, 0x99, 0xda, 0x2b, 0x2c, 0x70, 0x7f, - 0xd7, 0xb2, 0x4a, 0x8c, 0xec, 0x52, 0xd5, 0xbd, 0x31, 0x5c, 0xa1, 0x90, 0xe4, 0x98, 0xee, 0x1b, - 0x03, 0x7d, 0x3d, 0x93, 0xfe, 0x6f, 0x32, 0xe1, 0xe0, 0x9e, 0x08, 0x22, 0x26, 0xfc, 0xe9, 0xda, - 0x7f, 0x8f, 0x9a, 0x15, 0x71, 0x40, 0x1e, 0xb2, 0x9a, 0x1c, 0xa6, 0x2c, 0x0f, 0x70, 0xfc, 0x17, - 0xaa, 0x13, 0x47, 0xf8, 0x8c, 0xea, 0xcf, 0xf0, 0x8b, 0xf5, 0xc8, 0x2d, 0x63, 0x65, 0x04, 0xca, - 0x94, 0xf6, 0x55, 0xf2, 0x50, 0x17, 0x79, 0xf0, 0xf4, 0xbd, 0xc8, 0xed, 0x54, 0xbd, 0x3a, 0xf8, - 0x33, 0xce, 0xe1, 0x8f, 0x08, 0x4f, 0xa8, 0xcf, 0x13, 0x12, 0xd9, 0xd3, 0x81, 0x7d, 0x4e, 0x1c, - 0xc1, 0xe2, 0x54, 0x5f, 0x1d, 0x1b, 0xfa, 0x9f, 0x7f, 0x07, 0x47, 0xd9, 0xbe, 0xb4, 0x7c, 0x22, - 0xf9, 0xeb, 0x73, 0x99, 0x05, 0x78, 0x17, 0x6d, 0x96, 0x6a, 0xc4, 0x6c, 0x22, 0x0a, 0xa6, 0xcd, - 0xa2, 0xc4, 0x50, 0x6d, 0xe3, 0x1d, 0xb4, 0xee, 0x30, 0x4a, 0x41, 0xd6, 0xb3, 0xaf, 0x60, 0x1a, - 0x6a, 0xe3, 0xac, 0x15, 0xbb, 0x67, 0x30, 0x0d, 0xa5, 0xd2, 0x5c, 0xcd, 0x54, 0x5c, 0x52, 0xb9, - 0x6d, 0x78, 0x65, 0xd4, 0x87, 0x6c, 0xd3, 0x7d, 0x6b, 0xa0, 0x96, 0x92, 0xe6, 0x20, 0x15, 0xe0, - 0x30, 0xf7, 0x19, 0x27, 0xec, 0x07, 0xb4, 0xf1, 0xc0, 0x5d, 0xda, 0x74, 0xee, 0x5c, 0x8b, 0xbb, - 0x68, 0x53, 0x1a, 0x6f, 0xa4, 0x7b, 0xd8, 0x63, 0xc2, 0xc7, 0x5a, 0x9b, 0x26, 0x85, 0x24, 0xef, - 0xfd, 0x07, 0xe1, 0x63, 0x89, 0x95, 0x46, 0xae, 0x62, 0xb5, 0x4a, 0x2c, 0x70, 0x2b, 0xd8, 0xd9, - 0x54, 0x8b, 0xe5, 0xa9, 0x0e, 0x8e, 0x5f, 0xdf, 0x74, 0x8c, 0xeb, 0x9b, 0x8e, 0xf1, 0xfe, 0xa6, - 0x63, 0xfc, 0x7f, 0xdb, 0x99, 0xbb, 0xbe, 0xed, 0xcc, 0xbd, 0xbb, 0xed, 0xcc, 0x9d, 0xf5, 0x3d, - 0x5f, 0x8c, 0x27, 0x23, 0xcb, 0x61, 0xa1, 0x7a, 0x6e, 0x7e, 0xba, 0xf3, 0xf2, 0x5c, 0x96, 0xde, - 0xad, 0x34, 0x02, 0x3e, 0xaa, 0xab, 0xd7, 0xe7, 0xe7, 0x8f, 0x01, 0x00, 0x00, 0xff, 0xff, 0xf7, - 0x23, 0x3a, 0xee, 0x2a, 0x07, 0x00, 0x00, + // 754 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x55, 0xdd, 0x4e, 0xdb, 0x48, + 0x14, 0xc6, 0x04, 0x02, 0x19, 0x7e, 0x12, 0x46, 0xd1, 0xca, 0x1b, 0x56, 0x11, 0xca, 0x2e, 0xbb, + 0x59, 0xb4, 0x9b, 0xa0, 0xf4, 0x09, 0x0a, 0x2d, 0x2d, 0x52, 0x2f, 0xaa, 0xb4, 0xb4, 0x12, 0x37, + 0xd6, 0xc4, 0x3e, 0x38, 0x16, 0xf6, 0x8c, 0xe5, 0x99, 0xc4, 0x98, 0xa7, 0xe8, 0x65, 0x1f, 0xa2, + 0x4f, 0xd0, 0x27, 0xe8, 0x25, 0x52, 0x6f, 0x7a, 0x59, 0xc1, 0x4b, 0xf4, 0xb2, 0x9a, 0xf1, 0xd8, + 0xb1, 0x29, 0x20, 0xe8, 0x45, 0x6f, 0xa2, 0x39, 0x93, 0x6f, 0xce, 0xf9, 0xce, 0xe7, 0xef, 0xcc, + 0xa0, 0xee, 0x39, 0x08, 0x62, 0x8f, 0x89, 0x47, 0xfb, 0x6a, 0xc5, 0x22, 0xe8, 0x9f, 0x4c, 0xa8, + 0xeb, 0x8d, 0x7c, 0xe8, 0xc3, 0x14, 0xa8, 0xe0, 0xbd, 0x30, 0x62, 0x82, 0xe1, 0xcd, 0x1c, 0xd9, + 0xcb, 0x90, 0xbd, 0x0c, 0xd9, 0xfa, 0xeb, 0xae, 0x34, 0xe2, 0x2c, 0x4d, 0xd1, 0x6a, 0xba, 0xcc, + 0x65, 0x6a, 0xd9, 0x97, 0x2b, 0xbd, 0xfb, 0xf7, 0x0d, 0x67, 0xc3, 0x53, 0xb7, 0x6f, 0x33, 0x8f, + 0xaa, 0x9f, 0x14, 0xd7, 0xf9, 0x68, 0xa0, 0xd6, 0x53, 0xc9, 0xe8, 0x55, 0xc2, 0x05, 0x04, 0xfb, + 0x8c, 0x8a, 0x88, 0xd8, 0xe2, 0x28, 0x74, 0x88, 0x00, 0x07, 0x6f, 0xa1, 0xd5, 0x80, 0xbb, 0x96, + 0x48, 0x42, 0xb0, 0x26, 0x91, 0x6f, 0x1a, 0x5b, 0x46, 0xb7, 0x36, 0x44, 0x01, 0x77, 0x5f, 0x27, + 0x21, 0x1c, 0x45, 0x3e, 0xde, 0x45, 0x4d, 0x0a, 0xb1, 0x65, 0xeb, 0x83, 0x16, 0x71, 0x9c, 0x08, + 0x38, 0x37, 0xe7, 0x15, 0x12, 0x53, 0x88, 0xb3, 0x9c, 0x8f, 0xd3, 0x7f, 0xe4, 0x09, 0xe6, 0x3b, + 0x3f, 0x9e, 0xa8, 0xa4, 0x27, 0x98, 0xef, 0x5c, 0x3f, 0xf1, 0x1b, 0xaa, 0x72, 0xcf, 0xa5, 0x10, + 0x99, 0x0b, 0x0a, 0xa3, 0xa3, 0xce, 0x87, 0x79, 0x84, 0x15, 0xf9, 0xe3, 0xe1, 0xfe, 0x60, 0xf7, + 0x09, 0x84, 0x3e, 0x4b, 0xee, 0x45, 0xfa, 0x77, 0xb4, 0xac, 0xb4, 0xb1, 0x3c, 0x47, 0x11, 0xad, + 0x0c, 0x97, 0x54, 0x7c, 0xe8, 0xe0, 0x16, 0x5a, 0xce, 0x98, 0x69, 0x46, 0x79, 0x8c, 0x31, 0x5a, + 0xa0, 0x24, 0x00, 0xcd, 0x42, 0xad, 0x15, 0xb7, 0x24, 0x18, 0x31, 0xdf, 0x5c, 0xd4, 0xdc, 0x54, + 0x24, 0xf3, 0x38, 0x60, 0x7b, 0x01, 0xf1, 0xb9, 0x59, 0x55, 0x25, 0xf2, 0x18, 0xef, 0xa1, 0x9a, + 0xfc, 0x04, 0x8a, 0xa1, 0xb9, 0xb4, 0x65, 0x74, 0xd7, 0x07, 0xdb, 0xbd, 0x1b, 0x9c, 0x10, 0x9e, + 0xba, 0x3d, 0xf5, 0xad, 0xf6, 0x99, 0x47, 0x25, 0x77, 0xc9, 0x25, 0x5d, 0xe1, 0x26, 0x5a, 0x84, + 0xc8, 0x1e, 0xec, 0x9a, 0xcb, 0xaa, 0x6c, 0x1a, 0xe0, 0x4d, 0x54, 0x73, 0x09, 0xb7, 0x7c, 0x2f, + 0xf0, 0x84, 0x59, 0x4b, 0xcb, 0xba, 0x84, 0xbf, 0x90, 0x71, 0xe7, 0xdb, 0x3c, 0xfa, 0x63, 0x26, + 0xd7, 0x5b, 0x4f, 0x8c, 0x9d, 0x88, 0xc4, 0x07, 0x00, 0xf7, 0xff, 0xda, 0x77, 0x08, 0x57, 0x6a, + 0xaa, 0xf2, 0x73, 0x4d, 0xfd, 0x89, 0xd6, 0xce, 0x65, 0x1f, 0xb9, 0x27, 0x52, 0xa5, 0x57, 0xd5, + 0x66, 0xe6, 0x86, 0x2e, 0x6a, 0x48, 0xff, 0xc4, 0x9a, 0xbf, 0x75, 0x02, 0xa0, 0xb5, 0x5f, 0x67, + 0xbe, 0x53, 0x68, 0x4b, 0x22, 0xa5, 0x37, 0x4b, 0xc8, 0x6a, 0x8a, 0xa4, 0x10, 0x17, 0x91, 0x33, + 0x87, 0x2d, 0x15, 0x1d, 0x86, 0x3b, 0x68, 0x4d, 0xd6, 0x9a, 0x69, 0x9a, 0xaa, 0xbd, 0xc2, 0x7c, + 0xe7, 0x99, 0x96, 0x55, 0x62, 0x64, 0x95, 0xb2, 0xee, 0xb5, 0xe1, 0x0a, 0x85, 0x38, 0xc3, 0x74, + 0x26, 0xa8, 0x31, 0x53, 0xfe, 0x25, 0x99, 0xf0, 0x7b, 0xa9, 0xfd, 0x0f, 0xaa, 0x97, 0xe4, 0x00, + 0x39, 0x56, 0x15, 0x49, 0xbf, 0x28, 0x08, 0x14, 0x07, 0xa4, 0x52, 0x1a, 0x90, 0xb8, 0x38, 0x1f, + 0x47, 0x34, 0xfc, 0x65, 0x85, 0xdf, 0x67, 0x56, 0x2b, 0x5f, 0x2b, 0xfc, 0x01, 0x33, 0xfa, 0x1f, + 0xc2, 0x13, 0xea, 0xf1, 0x98, 0x84, 0xd6, 0x74, 0x60, 0x9d, 0x10, 0x5b, 0xb0, 0x28, 0xd1, 0xd7, + 0x4a, 0x43, 0xff, 0xf3, 0x66, 0x70, 0x90, 0xee, 0xcb, 0x71, 0x88, 0xa5, 0xc5, 0x34, 0x8f, 0x34, + 0xc0, 0x3b, 0x68, 0xa3, 0x90, 0x23, 0x62, 0x13, 0x91, 0xdf, 0x21, 0xf5, 0x3c, 0xc5, 0x50, 0x6d, + 0xe3, 0x6d, 0xb4, 0x6e, 0x33, 0x4a, 0x41, 0xe6, 0xb3, 0xce, 0x61, 0x1a, 0x68, 0x53, 0xad, 0xe5, + 0xbb, 0xc7, 0x30, 0x0d, 0xa4, 0x34, 0x5c, 0xf5, 0x94, 0x5f, 0x60, 0x99, 0xa5, 0x78, 0xa9, 0xd5, + 0xdb, 0x2c, 0xd5, 0xf9, 0x6c, 0xa0, 0xa6, 0x92, 0x66, 0x2f, 0x11, 0x60, 0x33, 0xe7, 0x01, 0xd3, + 0xf7, 0x2f, 0x6a, 0xdc, 0x72, 0xcf, 0xd6, 0xed, 0x6b, 0x57, 0xe6, 0x0e, 0xda, 0x90, 0xa6, 0x1c, + 0xe9, 0x1a, 0xd6, 0x98, 0xf0, 0xb1, 0xd6, 0xa6, 0x4e, 0x21, 0xce, 0x6a, 0x3f, 0x27, 0x7c, 0x2c, + 0xb1, 0xd2, 0xe4, 0x65, 0xac, 0x56, 0x89, 0xf9, 0x4e, 0x09, 0x3b, 0xeb, 0x6a, 0xb1, 0xd8, 0xd5, + 0xde, 0xe1, 0xa7, 0xcb, 0xb6, 0x71, 0x71, 0xd9, 0x36, 0xbe, 0x5e, 0xb6, 0x8d, 0x77, 0x57, 0xed, + 0xb9, 0x8b, 0xab, 0xf6, 0xdc, 0x97, 0xab, 0xf6, 0xdc, 0x71, 0xdf, 0xf5, 0xc4, 0x78, 0x32, 0xea, + 0xd9, 0x2c, 0x50, 0x4f, 0xd1, 0xff, 0xd7, 0x5e, 0xa5, 0xb3, 0xc2, 0x9b, 0x96, 0x84, 0xc0, 0x47, + 0x55, 0xf5, 0x32, 0x3d, 0xfa, 0x1e, 0x00, 0x00, 0xff, 0xff, 0x55, 0x3b, 0x93, 0x8b, 0x46, 0x07, + 0x00, 0x00, } func (m *EventSystemContractUpdated) Marshal() (dAtA []byte, err error) { @@ -821,7 +873,7 @@ func (m *EventZRC20WithdrawFeeUpdated) MarshalToSizedBuffer(dAtA []byte) (int, e return len(dAtA) - i, nil } -func (m *EventZRC20PausedStatusUpdated) Marshal() (dAtA []byte, err error) { +func (m *EventZRC20Paused) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) n, err := m.MarshalToSizedBuffer(dAtA[:size]) @@ -831,12 +883,12 @@ func (m *EventZRC20PausedStatusUpdated) Marshal() (dAtA []byte, err error) { return dAtA[:n], nil } -func (m *EventZRC20PausedStatusUpdated) MarshalTo(dAtA []byte) (int, error) { +func (m *EventZRC20Paused) MarshalTo(dAtA []byte) (int, error) { size := m.Size() return m.MarshalToSizedBuffer(dAtA[:size]) } -func (m *EventZRC20PausedStatusUpdated) MarshalToSizedBuffer(dAtA []byte) (int, error) { +func (m *EventZRC20Paused) MarshalToSizedBuffer(dAtA []byte) (int, error) { i := len(dAtA) _ = i var l int @@ -846,12 +898,53 @@ func (m *EventZRC20PausedStatusUpdated) MarshalToSizedBuffer(dAtA []byte) (int, copy(dAtA[i:], m.Signer) i = encodeVarintEvents(dAtA, i, uint64(len(m.Signer))) i-- - dAtA[i] = 0x22 + dAtA[i] = 0x1a } - if m.Action != 0 { - i = encodeVarintEvents(dAtA, i, uint64(m.Action)) + if len(m.Zrc20Addresses) > 0 { + for iNdEx := len(m.Zrc20Addresses) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Zrc20Addresses[iNdEx]) + copy(dAtA[i:], m.Zrc20Addresses[iNdEx]) + i = encodeVarintEvents(dAtA, i, uint64(len(m.Zrc20Addresses[iNdEx]))) + i-- + dAtA[i] = 0x12 + } + } + if len(m.MsgTypeUrl) > 0 { + i -= len(m.MsgTypeUrl) + copy(dAtA[i:], m.MsgTypeUrl) + i = encodeVarintEvents(dAtA, i, uint64(len(m.MsgTypeUrl))) i-- - dAtA[i] = 0x18 + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *EventZRC20Unpaused) 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 *EventZRC20Unpaused) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *EventZRC20Unpaused) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Signer) > 0 { + i -= len(m.Signer) + copy(dAtA[i:], m.Signer) + i = encodeVarintEvents(dAtA, i, uint64(len(m.Signer))) + i-- + dAtA[i] = 0x1a } if len(m.Zrc20Addresses) > 0 { for iNdEx := len(m.Zrc20Addresses) - 1; iNdEx >= 0; iNdEx-- { @@ -1122,7 +1215,7 @@ func (m *EventZRC20WithdrawFeeUpdated) Size() (n int) { return n } -func (m *EventZRC20PausedStatusUpdated) Size() (n int) { +func (m *EventZRC20Paused) Size() (n int) { if m == nil { return 0 } @@ -1138,8 +1231,28 @@ func (m *EventZRC20PausedStatusUpdated) Size() (n int) { n += 1 + l + sovEvents(uint64(l)) } } - if m.Action != 0 { - n += 1 + sovEvents(uint64(m.Action)) + l = len(m.Signer) + if l > 0 { + n += 1 + l + sovEvents(uint64(l)) + } + return n +} + +func (m *EventZRC20Unpaused) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.MsgTypeUrl) + if l > 0 { + n += 1 + l + sovEvents(uint64(l)) + } + if len(m.Zrc20Addresses) > 0 { + for _, s := range m.Zrc20Addresses { + l = len(s) + n += 1 + l + sovEvents(uint64(l)) + } } l = len(m.Signer) if l > 0 { @@ -1996,7 +2109,7 @@ func (m *EventZRC20WithdrawFeeUpdated) Unmarshal(dAtA []byte) error { } return nil } -func (m *EventZRC20PausedStatusUpdated) Unmarshal(dAtA []byte) error { +func (m *EventZRC20Paused) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -2019,10 +2132,10 @@ func (m *EventZRC20PausedStatusUpdated) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: EventZRC20PausedStatusUpdated: wiretype end group for non-group") + return fmt.Errorf("proto: EventZRC20Paused: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: EventZRC20PausedStatusUpdated: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: EventZRC20Paused: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -2090,10 +2203,10 @@ func (m *EventZRC20PausedStatusUpdated) Unmarshal(dAtA []byte) error { m.Zrc20Addresses = append(m.Zrc20Addresses, string(dAtA[iNdEx:postIndex])) iNdEx = postIndex case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Action", wireType) + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Signer", wireType) } - m.Action = 0 + var stringLen uint64 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowEvents @@ -2103,12 +2216,139 @@ func (m *EventZRC20PausedStatusUpdated) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.Action |= UpdatePausedStatusAction(b&0x7F) << shift + stringLen |= uint64(b&0x7F) << shift if b < 0x80 { break } } - case 4: + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthEvents + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Signer = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipEvents(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthEvents + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *EventZRC20Unpaused) 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 ErrIntOverflowEvents + } + 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: EventZRC20Unpaused: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: EventZRC20Unpaused: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field MsgTypeUrl", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvents + } + 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 ErrInvalidLengthEvents + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.MsgTypeUrl = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Zrc20Addresses", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvents + } + 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 ErrInvalidLengthEvents + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Zrc20Addresses = append(m.Zrc20Addresses, string(dAtA[iNdEx:postIndex])) + iNdEx = postIndex + case 3: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Signer", wireType) } diff --git a/x/fungible/types/message_update_zrc20_paused_status.go b/x/fungible/types/message_pause_zrc20.go similarity index 54% rename from x/fungible/types/message_update_zrc20_paused_status.go rename to x/fungible/types/message_pause_zrc20.go index cbffdf0324..48adefdd06 100644 --- a/x/fungible/types/message_update_zrc20_paused_status.go +++ b/x/fungible/types/message_pause_zrc20.go @@ -7,31 +7,26 @@ import ( ethcommon "github.com/ethereum/go-ethereum/common" ) -const TypeMsgUpdateZRC20PausedStatus = "update_zrc20_withdraw_fee" +const TypeMsgPauseZrc20 = "pause_zrc20" -var _ sdk.Msg = &MsgUpdateZRC20PausedStatus{} +var _ sdk.Msg = &MsgPauseZRC20{} -func NewMsgUpdateZRC20PausedStatus( - creator string, - zrc20 []string, - action UpdatePausedStatusAction, -) *MsgUpdateZRC20PausedStatus { - return &MsgUpdateZRC20PausedStatus{ +func NewMsgPauseZRC20(creator string, zrc20 []string) *MsgPauseZRC20 { + return &MsgPauseZRC20{ Creator: creator, Zrc20Addresses: zrc20, - Action: action, } } -func (msg *MsgUpdateZRC20PausedStatus) Route() string { +func (msg *MsgPauseZRC20) Route() string { return RouterKey } -func (msg *MsgUpdateZRC20PausedStatus) Type() string { - return TypeMsgUpdateZRC20PausedStatus +func (msg *MsgPauseZRC20) Type() string { + return TypeMsgPauseZrc20 } -func (msg *MsgUpdateZRC20PausedStatus) GetSigners() []sdk.AccAddress { +func (msg *MsgPauseZRC20) GetSigners() []sdk.AccAddress { creator, err := sdk.AccAddressFromBech32(msg.Creator) if err != nil { panic(err) @@ -39,21 +34,17 @@ func (msg *MsgUpdateZRC20PausedStatus) GetSigners() []sdk.AccAddress { return []sdk.AccAddress{creator} } -func (msg *MsgUpdateZRC20PausedStatus) GetSignBytes() []byte { +func (msg *MsgPauseZRC20) GetSignBytes() []byte { bz := ModuleCdc.MustMarshalJSON(msg) return sdk.MustSortJSON(bz) } -func (msg *MsgUpdateZRC20PausedStatus) ValidateBasic() error { +func (msg *MsgPauseZRC20) ValidateBasic() error { _, err := sdk.AccAddressFromBech32(msg.Creator) if err != nil { return cosmoserrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) } - if msg.Action != UpdatePausedStatusAction_PAUSE && msg.Action != UpdatePausedStatusAction_UNPAUSE { - return cosmoserrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid action (%d)", msg.Action) - } - if len(msg.Zrc20Addresses) == 0 { return cosmoserrors.Wrap(sdkerrors.ErrInvalidRequest, "no zrc20 to update") } diff --git a/x/fungible/types/message_update_zrc20_paused_status_test.go b/x/fungible/types/message_pause_zrc20_test.go similarity index 61% rename from x/fungible/types/message_update_zrc20_paused_status_test.go rename to x/fungible/types/message_pause_zrc20_test.go index 691585711f..a6b6e1fda8 100644 --- a/x/fungible/types/message_update_zrc20_paused_status_test.go +++ b/x/fungible/types/message_pause_zrc20_test.go @@ -10,83 +10,65 @@ import ( "github.com/zeta-chain/zetacore/x/fungible/types" ) -func TestMMsgUpdateZRC20PausedStatus_ValidateBasic(t *testing.T) { +func TestMsgPauseZRC20_ValidateBasic(t *testing.T) { tt := []struct { name string - msg *types.MsgUpdateZRC20PausedStatus + msg *types.MsgPauseZRC20 wantErr bool }{ { name: "valid pause message", - msg: types.NewMsgUpdateZRC20PausedStatus( + msg: types.NewMsgPauseZRC20( sample.AccAddress(), []string{ sample.EthAddress().String(), sample.EthAddress().String(), sample.EthAddress().String(), }, - types.UpdatePausedStatusAction_PAUSE, ), wantErr: false, }, { name: "valid unpause message", - msg: types.NewMsgUpdateZRC20PausedStatus( + msg: types.NewMsgPauseZRC20( sample.AccAddress(), []string{ sample.EthAddress().String(), sample.EthAddress().String(), sample.EthAddress().String(), }, - types.UpdatePausedStatusAction_UNPAUSE, ), wantErr: false, }, { name: "invalid creator address", - msg: types.NewMsgUpdateZRC20PausedStatus( + msg: types.NewMsgPauseZRC20( "invalid", []string{ sample.EthAddress().String(), sample.EthAddress().String(), sample.EthAddress().String(), }, - types.UpdatePausedStatusAction_PAUSE, ), wantErr: true, }, { name: "invalid empty zrc20 address", - msg: types.NewMsgUpdateZRC20PausedStatus( + msg: types.NewMsgPauseZRC20( sample.AccAddress(), []string{}, - types.UpdatePausedStatusAction_PAUSE, ), wantErr: true, }, { name: "invalid zrc20 address", - msg: types.NewMsgUpdateZRC20PausedStatus( + msg: types.NewMsgPauseZRC20( sample.AccAddress(), []string{ sample.EthAddress().String(), "invalid", sample.EthAddress().String(), }, - types.UpdatePausedStatusAction_PAUSE, - ), - wantErr: true, - }, - { - name: "invalid action", - msg: types.NewMsgUpdateZRC20PausedStatus( - sample.AccAddress(), - []string{ - sample.EthAddress().String(), - sample.EthAddress().String(), - sample.EthAddress().String(), - }, - 3, ), wantErr: true, }, @@ -104,23 +86,23 @@ func TestMMsgUpdateZRC20PausedStatus_ValidateBasic(t *testing.T) { } } -func TestMMsgUpdateZRC20PausedStatus_GetSigners(t *testing.T) { +func TestMsgPauseZRC20_GetSigners(t *testing.T) { signer := sample.AccAddress() tests := []struct { name string - msg types.MsgUpdateZRC20PausedStatus + msg types.MsgPauseZRC20 panics bool }{ { name: "valid signer", - msg: types.MsgUpdateZRC20PausedStatus{ + msg: types.MsgPauseZRC20{ Creator: signer, }, panics: false, }, { name: "invalid signer", - msg: types.MsgUpdateZRC20PausedStatus{ + msg: types.MsgPauseZRC20{ Creator: "invalid", }, panics: true, @@ -141,22 +123,22 @@ func TestMMsgUpdateZRC20PausedStatus_GetSigners(t *testing.T) { } } -func TestMMsgUpdateZRC20PausedStatus_Type(t *testing.T) { - msg := types.MsgUpdateZRC20PausedStatus{ +func TestMsgPauseZRC20_Type(t *testing.T) { + msg := types.MsgPauseZRC20{ Creator: sample.AccAddress(), } - require.Equal(t, types.TypeMsgUpdateZRC20PausedStatus, msg.Type()) + require.Equal(t, types.TypeMsgPauseZrc20, msg.Type()) } -func TestMMsgUpdateZRC20PausedStatus_Route(t *testing.T) { - msg := types.MsgUpdateZRC20PausedStatus{ +func TestMsgPauseZRC20_Route(t *testing.T) { + msg := types.MsgPauseZRC20{ Creator: sample.AccAddress(), } require.Equal(t, types.RouterKey, msg.Route()) } -func TestMMsgUpdateZRC20PausedStatus_GetSignBytes(t *testing.T) { - msg := types.MsgUpdateZRC20PausedStatus{ +func TestMsgPauseZRC20_GetSignBytes(t *testing.T) { + msg := types.MsgPauseZRC20{ Creator: sample.AccAddress(), } require.NotPanics(t, func() { diff --git a/x/fungible/types/message_unpause_zrc20.go b/x/fungible/types/message_unpause_zrc20.go new file mode 100644 index 0000000000..560b0c04b3 --- /dev/null +++ b/x/fungible/types/message_unpause_zrc20.go @@ -0,0 +1,59 @@ +package types + +import ( + cosmoserrors "cosmossdk.io/errors" + sdk "github.com/cosmos/cosmos-sdk/types" + sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" + ethcommon "github.com/ethereum/go-ethereum/common" +) + +const TypeMsgUnpauseZRC20 = "unpause_zrc20" + +var _ sdk.Msg = &MsgUnpauseZRC20{} + +func NewMsgUnpauseZRC20(creator string, zrc20 []string) *MsgUnpauseZRC20 { + return &MsgUnpauseZRC20{ + Creator: creator, + Zrc20Addresses: zrc20, + } +} + +func (msg *MsgUnpauseZRC20) Route() string { + return RouterKey +} + +func (msg *MsgUnpauseZRC20) Type() string { + return TypeMsgUnpauseZRC20 +} + +func (msg *MsgUnpauseZRC20) GetSigners() []sdk.AccAddress { + creator, err := sdk.AccAddressFromBech32(msg.Creator) + if err != nil { + panic(err) + } + return []sdk.AccAddress{creator} +} + +func (msg *MsgUnpauseZRC20) GetSignBytes() []byte { + bz := ModuleCdc.MustMarshalJSON(msg) + return sdk.MustSortJSON(bz) +} + +func (msg *MsgUnpauseZRC20) ValidateBasic() error { + _, err := sdk.AccAddressFromBech32(msg.Creator) + if err != nil { + return cosmoserrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) + } + + if len(msg.Zrc20Addresses) == 0 { + return cosmoserrors.Wrap(sdkerrors.ErrInvalidRequest, "no zrc20 to update") + } + + // check if all zrc20 addresses are valid + for _, zrc20 := range msg.Zrc20Addresses { + if !ethcommon.IsHexAddress(zrc20) { + return cosmoserrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid zrc20 contract address (%s)", zrc20) + } + } + return nil +} diff --git a/x/fungible/types/message_unpause_zrc20_test.go b/x/fungible/types/message_unpause_zrc20_test.go new file mode 100644 index 0000000000..3a959ab459 --- /dev/null +++ b/x/fungible/types/message_unpause_zrc20_test.go @@ -0,0 +1,147 @@ +package types_test + +import ( + "testing" + + sdk "github.com/cosmos/cosmos-sdk/types" + "github.com/stretchr/testify/require" + + "github.com/zeta-chain/zetacore/testutil/sample" + "github.com/zeta-chain/zetacore/x/fungible/types" +) + +func TestMsgUnpauseZRC20_ValidateBasic(t *testing.T) { + tt := []struct { + name string + msg *types.MsgUnpauseZRC20 + wantErr bool + }{ + { + name: "valid unpause message", + msg: types.NewMsgUnpauseZRC20( + sample.AccAddress(), + []string{ + sample.EthAddress().String(), + sample.EthAddress().String(), + sample.EthAddress().String(), + }, + ), + wantErr: false, + }, + { + name: "valid unpause message", + msg: types.NewMsgUnpauseZRC20( + sample.AccAddress(), + []string{ + sample.EthAddress().String(), + sample.EthAddress().String(), + sample.EthAddress().String(), + }, + ), + wantErr: false, + }, + { + name: "invalid creator address", + msg: types.NewMsgUnpauseZRC20( + "invalid", + []string{ + sample.EthAddress().String(), + sample.EthAddress().String(), + sample.EthAddress().String(), + }, + ), + wantErr: true, + }, + { + name: "invalid empty zrc20 address", + msg: types.NewMsgUnpauseZRC20( + sample.AccAddress(), + []string{}, + ), + wantErr: true, + }, + { + name: "invalid zrc20 address", + msg: types.NewMsgUnpauseZRC20( + sample.AccAddress(), + []string{ + sample.EthAddress().String(), + "invalid", + sample.EthAddress().String(), + }, + ), + wantErr: true, + }, + } + for _, tc := range tt { + tc := tc + t.Run(tc.name, func(t *testing.T) { + err := tc.msg.ValidateBasic() + if tc.wantErr { + require.Error(t, err) + } else { + require.NoError(t, err) + } + }) + } +} + +func TestMsgUnpauseZRC20_GetSigners(t *testing.T) { + signer := sample.AccAddress() + tests := []struct { + name string + msg types.MsgUnpauseZRC20 + panics bool + }{ + { + name: "valid signer", + msg: types.MsgUnpauseZRC20{ + Creator: signer, + }, + panics: false, + }, + { + name: "invalid signer", + msg: types.MsgUnpauseZRC20{ + Creator: "invalid", + }, + panics: true, + }, + } + + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + if !tt.panics { + signers := tt.msg.GetSigners() + require.Equal(t, []sdk.AccAddress{sdk.MustAccAddressFromBech32(signer)}, signers) + } else { + require.Panics(t, func() { + tt.msg.GetSigners() + }) + } + }) + } +} + +func TestMsgUnpauseZRC20_Type(t *testing.T) { + msg := types.MsgUnpauseZRC20{ + Creator: sample.AccAddress(), + } + require.Equal(t, types.TypeMsgUnpauseZRC20, msg.Type()) +} + +func TestMsgUnpauseZRC20_Route(t *testing.T) { + msg := types.MsgUnpauseZRC20{ + Creator: sample.AccAddress(), + } + require.Equal(t, types.RouterKey, msg.Route()) +} + +func TestMsgUnpauseZRC20_GetSignBytes(t *testing.T) { + msg := types.MsgUnpauseZRC20{ + Creator: sample.AccAddress(), + } + require.NotPanics(t, func() { + msg.GetSignBytes() + }) +} diff --git a/x/fungible/types/tx.pb.go b/x/fungible/types/tx.pb.go index be4e46fbd0..f72a00bc24 100644 --- a/x/fungible/types/tx.pb.go +++ b/x/fungible/types/tx.pb.go @@ -30,31 +30,6 @@ var _ = math.Inf // proto package needs to be updated. const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package -type UpdatePausedStatusAction int32 - -const ( - UpdatePausedStatusAction_PAUSE UpdatePausedStatusAction = 0 - UpdatePausedStatusAction_UNPAUSE UpdatePausedStatusAction = 1 -) - -var UpdatePausedStatusAction_name = map[int32]string{ - 0: "PAUSE", - 1: "UNPAUSE", -} - -var UpdatePausedStatusAction_value = map[string]int32{ - "PAUSE": 0, - "UNPAUSE": 1, -} - -func (x UpdatePausedStatusAction) String() string { - return proto.EnumName(UpdatePausedStatusAction_name, int32(x)) -} - -func (UpdatePausedStatusAction) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_7bea9688d1d01113, []int{0} -} - type MsgDeploySystemContracts struct { Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` } @@ -681,24 +656,24 @@ func (m *MsgUpdateContractBytecodeResponse) XXX_DiscardUnknown() { var xxx_messageInfo_MsgUpdateContractBytecodeResponse proto.InternalMessageInfo -type MsgUpdateZRC20PausedStatus struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` - Zrc20Addresses []string `protobuf:"bytes,2,rep,name=zrc20_addresses,json=zrc20Addresses,proto3" json:"zrc20_addresses,omitempty"` - Action UpdatePausedStatusAction `protobuf:"varint,3,opt,name=action,proto3,enum=zetachain.zetacore.fungible.UpdatePausedStatusAction" json:"action,omitempty"` +type MsgUpdateZRC20LiquidityCap struct { + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + Zrc20Address string `protobuf:"bytes,2,opt,name=zrc20_address,json=zrc20Address,proto3" json:"zrc20_address,omitempty"` + LiquidityCap github_com_cosmos_cosmos_sdk_types.Uint `protobuf:"bytes,3,opt,name=liquidity_cap,json=liquidityCap,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Uint" json:"liquidity_cap"` } -func (m *MsgUpdateZRC20PausedStatus) Reset() { *m = MsgUpdateZRC20PausedStatus{} } -func (m *MsgUpdateZRC20PausedStatus) String() string { return proto.CompactTextString(m) } -func (*MsgUpdateZRC20PausedStatus) ProtoMessage() {} -func (*MsgUpdateZRC20PausedStatus) Descriptor() ([]byte, []int) { +func (m *MsgUpdateZRC20LiquidityCap) Reset() { *m = MsgUpdateZRC20LiquidityCap{} } +func (m *MsgUpdateZRC20LiquidityCap) String() string { return proto.CompactTextString(m) } +func (*MsgUpdateZRC20LiquidityCap) ProtoMessage() {} +func (*MsgUpdateZRC20LiquidityCap) Descriptor() ([]byte, []int) { return fileDescriptor_7bea9688d1d01113, []int{12} } -func (m *MsgUpdateZRC20PausedStatus) XXX_Unmarshal(b []byte) error { +func (m *MsgUpdateZRC20LiquidityCap) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) } -func (m *MsgUpdateZRC20PausedStatus) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { +func (m *MsgUpdateZRC20LiquidityCap) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { if deterministic { - return xxx_messageInfo_MsgUpdateZRC20PausedStatus.Marshal(b, m, deterministic) + return xxx_messageInfo_MsgUpdateZRC20LiquidityCap.Marshal(b, m, deterministic) } else { b = b[:cap(b)] n, err := m.MarshalToSizedBuffer(b) @@ -708,54 +683,135 @@ func (m *MsgUpdateZRC20PausedStatus) XXX_Marshal(b []byte, deterministic bool) ( return b[:n], nil } } -func (m *MsgUpdateZRC20PausedStatus) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUpdateZRC20PausedStatus.Merge(m, src) +func (m *MsgUpdateZRC20LiquidityCap) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgUpdateZRC20LiquidityCap.Merge(m, src) } -func (m *MsgUpdateZRC20PausedStatus) XXX_Size() int { +func (m *MsgUpdateZRC20LiquidityCap) XXX_Size() int { return m.Size() } -func (m *MsgUpdateZRC20PausedStatus) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUpdateZRC20PausedStatus.DiscardUnknown(m) +func (m *MsgUpdateZRC20LiquidityCap) XXX_DiscardUnknown() { + xxx_messageInfo_MsgUpdateZRC20LiquidityCap.DiscardUnknown(m) } -var xxx_messageInfo_MsgUpdateZRC20PausedStatus proto.InternalMessageInfo +var xxx_messageInfo_MsgUpdateZRC20LiquidityCap proto.InternalMessageInfo -func (m *MsgUpdateZRC20PausedStatus) GetCreator() string { +func (m *MsgUpdateZRC20LiquidityCap) GetCreator() string { if m != nil { return m.Creator } return "" } -func (m *MsgUpdateZRC20PausedStatus) GetZrc20Addresses() []string { +func (m *MsgUpdateZRC20LiquidityCap) GetZrc20Address() string { if m != nil { - return m.Zrc20Addresses + return m.Zrc20Address } - return nil + return "" +} + +type MsgUpdateZRC20LiquidityCapResponse struct { +} + +func (m *MsgUpdateZRC20LiquidityCapResponse) Reset() { *m = MsgUpdateZRC20LiquidityCapResponse{} } +func (m *MsgUpdateZRC20LiquidityCapResponse) String() string { return proto.CompactTextString(m) } +func (*MsgUpdateZRC20LiquidityCapResponse) ProtoMessage() {} +func (*MsgUpdateZRC20LiquidityCapResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_7bea9688d1d01113, []int{13} +} +func (m *MsgUpdateZRC20LiquidityCapResponse) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MsgUpdateZRC20LiquidityCapResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_MsgUpdateZRC20LiquidityCapResponse.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 *MsgUpdateZRC20LiquidityCapResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgUpdateZRC20LiquidityCapResponse.Merge(m, src) +} +func (m *MsgUpdateZRC20LiquidityCapResponse) XXX_Size() int { + return m.Size() +} +func (m *MsgUpdateZRC20LiquidityCapResponse) XXX_DiscardUnknown() { + xxx_messageInfo_MsgUpdateZRC20LiquidityCapResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_MsgUpdateZRC20LiquidityCapResponse proto.InternalMessageInfo + +type MsgPauseZRC20 struct { + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + Zrc20Addresses []string `protobuf:"bytes,2,rep,name=zrc20_addresses,json=zrc20Addresses,proto3" json:"zrc20_addresses,omitempty"` +} + +func (m *MsgPauseZRC20) Reset() { *m = MsgPauseZRC20{} } +func (m *MsgPauseZRC20) String() string { return proto.CompactTextString(m) } +func (*MsgPauseZRC20) ProtoMessage() {} +func (*MsgPauseZRC20) Descriptor() ([]byte, []int) { + return fileDescriptor_7bea9688d1d01113, []int{14} +} +func (m *MsgPauseZRC20) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MsgPauseZRC20) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_MsgPauseZRC20.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 *MsgPauseZRC20) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgPauseZRC20.Merge(m, src) +} +func (m *MsgPauseZRC20) XXX_Size() int { + return m.Size() +} +func (m *MsgPauseZRC20) XXX_DiscardUnknown() { + xxx_messageInfo_MsgPauseZRC20.DiscardUnknown(m) +} + +var xxx_messageInfo_MsgPauseZRC20 proto.InternalMessageInfo + +func (m *MsgPauseZRC20) GetCreator() string { + if m != nil { + return m.Creator + } + return "" } -func (m *MsgUpdateZRC20PausedStatus) GetAction() UpdatePausedStatusAction { +func (m *MsgPauseZRC20) GetZrc20Addresses() []string { if m != nil { - return m.Action + return m.Zrc20Addresses } - return UpdatePausedStatusAction_PAUSE + return nil } -type MsgUpdateZRC20PausedStatusResponse struct { +type MsgPauseZRC20Response struct { } -func (m *MsgUpdateZRC20PausedStatusResponse) Reset() { *m = MsgUpdateZRC20PausedStatusResponse{} } -func (m *MsgUpdateZRC20PausedStatusResponse) String() string { return proto.CompactTextString(m) } -func (*MsgUpdateZRC20PausedStatusResponse) ProtoMessage() {} -func (*MsgUpdateZRC20PausedStatusResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_7bea9688d1d01113, []int{13} +func (m *MsgPauseZRC20Response) Reset() { *m = MsgPauseZRC20Response{} } +func (m *MsgPauseZRC20Response) String() string { return proto.CompactTextString(m) } +func (*MsgPauseZRC20Response) ProtoMessage() {} +func (*MsgPauseZRC20Response) Descriptor() ([]byte, []int) { + return fileDescriptor_7bea9688d1d01113, []int{15} } -func (m *MsgUpdateZRC20PausedStatusResponse) XXX_Unmarshal(b []byte) error { +func (m *MsgPauseZRC20Response) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) } -func (m *MsgUpdateZRC20PausedStatusResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { +func (m *MsgPauseZRC20Response) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { if deterministic { - return xxx_messageInfo_MsgUpdateZRC20PausedStatusResponse.Marshal(b, m, deterministic) + return xxx_messageInfo_MsgPauseZRC20Response.Marshal(b, m, deterministic) } else { b = b[:cap(b)] n, err := m.MarshalToSizedBuffer(b) @@ -765,36 +821,35 @@ func (m *MsgUpdateZRC20PausedStatusResponse) XXX_Marshal(b []byte, deterministic return b[:n], nil } } -func (m *MsgUpdateZRC20PausedStatusResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUpdateZRC20PausedStatusResponse.Merge(m, src) +func (m *MsgPauseZRC20Response) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgPauseZRC20Response.Merge(m, src) } -func (m *MsgUpdateZRC20PausedStatusResponse) XXX_Size() int { +func (m *MsgPauseZRC20Response) XXX_Size() int { return m.Size() } -func (m *MsgUpdateZRC20PausedStatusResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUpdateZRC20PausedStatusResponse.DiscardUnknown(m) +func (m *MsgPauseZRC20Response) XXX_DiscardUnknown() { + xxx_messageInfo_MsgPauseZRC20Response.DiscardUnknown(m) } -var xxx_messageInfo_MsgUpdateZRC20PausedStatusResponse proto.InternalMessageInfo +var xxx_messageInfo_MsgPauseZRC20Response proto.InternalMessageInfo -type MsgUpdateZRC20LiquidityCap struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` - Zrc20Address string `protobuf:"bytes,2,opt,name=zrc20_address,json=zrc20Address,proto3" json:"zrc20_address,omitempty"` - LiquidityCap github_com_cosmos_cosmos_sdk_types.Uint `protobuf:"bytes,3,opt,name=liquidity_cap,json=liquidityCap,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Uint" json:"liquidity_cap"` +type MsgUnpauseZRC20 struct { + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + Zrc20Addresses []string `protobuf:"bytes,2,rep,name=zrc20_addresses,json=zrc20Addresses,proto3" json:"zrc20_addresses,omitempty"` } -func (m *MsgUpdateZRC20LiquidityCap) Reset() { *m = MsgUpdateZRC20LiquidityCap{} } -func (m *MsgUpdateZRC20LiquidityCap) String() string { return proto.CompactTextString(m) } -func (*MsgUpdateZRC20LiquidityCap) ProtoMessage() {} -func (*MsgUpdateZRC20LiquidityCap) Descriptor() ([]byte, []int) { - return fileDescriptor_7bea9688d1d01113, []int{14} +func (m *MsgUnpauseZRC20) Reset() { *m = MsgUnpauseZRC20{} } +func (m *MsgUnpauseZRC20) String() string { return proto.CompactTextString(m) } +func (*MsgUnpauseZRC20) ProtoMessage() {} +func (*MsgUnpauseZRC20) Descriptor() ([]byte, []int) { + return fileDescriptor_7bea9688d1d01113, []int{16} } -func (m *MsgUpdateZRC20LiquidityCap) XXX_Unmarshal(b []byte) error { +func (m *MsgUnpauseZRC20) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) } -func (m *MsgUpdateZRC20LiquidityCap) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { +func (m *MsgUnpauseZRC20) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { if deterministic { - return xxx_messageInfo_MsgUpdateZRC20LiquidityCap.Marshal(b, m, deterministic) + return xxx_messageInfo_MsgUnpauseZRC20.Marshal(b, m, deterministic) } else { b = b[:cap(b)] n, err := m.MarshalToSizedBuffer(b) @@ -804,47 +859,47 @@ func (m *MsgUpdateZRC20LiquidityCap) XXX_Marshal(b []byte, deterministic bool) ( return b[:n], nil } } -func (m *MsgUpdateZRC20LiquidityCap) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUpdateZRC20LiquidityCap.Merge(m, src) +func (m *MsgUnpauseZRC20) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgUnpauseZRC20.Merge(m, src) } -func (m *MsgUpdateZRC20LiquidityCap) XXX_Size() int { +func (m *MsgUnpauseZRC20) XXX_Size() int { return m.Size() } -func (m *MsgUpdateZRC20LiquidityCap) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUpdateZRC20LiquidityCap.DiscardUnknown(m) +func (m *MsgUnpauseZRC20) XXX_DiscardUnknown() { + xxx_messageInfo_MsgUnpauseZRC20.DiscardUnknown(m) } -var xxx_messageInfo_MsgUpdateZRC20LiquidityCap proto.InternalMessageInfo +var xxx_messageInfo_MsgUnpauseZRC20 proto.InternalMessageInfo -func (m *MsgUpdateZRC20LiquidityCap) GetCreator() string { +func (m *MsgUnpauseZRC20) GetCreator() string { if m != nil { return m.Creator } return "" } -func (m *MsgUpdateZRC20LiquidityCap) GetZrc20Address() string { +func (m *MsgUnpauseZRC20) GetZrc20Addresses() []string { if m != nil { - return m.Zrc20Address + return m.Zrc20Addresses } - return "" + return nil } -type MsgUpdateZRC20LiquidityCapResponse struct { +type MsgUnpauseZRC20Response struct { } -func (m *MsgUpdateZRC20LiquidityCapResponse) Reset() { *m = MsgUpdateZRC20LiquidityCapResponse{} } -func (m *MsgUpdateZRC20LiquidityCapResponse) String() string { return proto.CompactTextString(m) } -func (*MsgUpdateZRC20LiquidityCapResponse) ProtoMessage() {} -func (*MsgUpdateZRC20LiquidityCapResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_7bea9688d1d01113, []int{15} +func (m *MsgUnpauseZRC20Response) Reset() { *m = MsgUnpauseZRC20Response{} } +func (m *MsgUnpauseZRC20Response) String() string { return proto.CompactTextString(m) } +func (*MsgUnpauseZRC20Response) ProtoMessage() {} +func (*MsgUnpauseZRC20Response) Descriptor() ([]byte, []int) { + return fileDescriptor_7bea9688d1d01113, []int{17} } -func (m *MsgUpdateZRC20LiquidityCapResponse) XXX_Unmarshal(b []byte) error { +func (m *MsgUnpauseZRC20Response) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) } -func (m *MsgUpdateZRC20LiquidityCapResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { +func (m *MsgUnpauseZRC20Response) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { if deterministic { - return xxx_messageInfo_MsgUpdateZRC20LiquidityCapResponse.Marshal(b, m, deterministic) + return xxx_messageInfo_MsgUnpauseZRC20Response.Marshal(b, m, deterministic) } else { b = b[:cap(b)] n, err := m.MarshalToSizedBuffer(b) @@ -854,20 +909,19 @@ func (m *MsgUpdateZRC20LiquidityCapResponse) XXX_Marshal(b []byte, deterministic return b[:n], nil } } -func (m *MsgUpdateZRC20LiquidityCapResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUpdateZRC20LiquidityCapResponse.Merge(m, src) +func (m *MsgUnpauseZRC20Response) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgUnpauseZRC20Response.Merge(m, src) } -func (m *MsgUpdateZRC20LiquidityCapResponse) XXX_Size() int { +func (m *MsgUnpauseZRC20Response) XXX_Size() int { return m.Size() } -func (m *MsgUpdateZRC20LiquidityCapResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUpdateZRC20LiquidityCapResponse.DiscardUnknown(m) +func (m *MsgUnpauseZRC20Response) XXX_DiscardUnknown() { + xxx_messageInfo_MsgUnpauseZRC20Response.DiscardUnknown(m) } -var xxx_messageInfo_MsgUpdateZRC20LiquidityCapResponse proto.InternalMessageInfo +var xxx_messageInfo_MsgUnpauseZRC20Response proto.InternalMessageInfo func init() { - proto.RegisterEnum("zetachain.zetacore.fungible.UpdatePausedStatusAction", UpdatePausedStatusAction_name, UpdatePausedStatusAction_value) proto.RegisterType((*MsgDeploySystemContracts)(nil), "zetachain.zetacore.fungible.MsgDeploySystemContracts") proto.RegisterType((*MsgDeploySystemContractsResponse)(nil), "zetachain.zetacore.fungible.MsgDeploySystemContractsResponse") proto.RegisterType((*MsgUpdateZRC20WithdrawFee)(nil), "zetachain.zetacore.fungible.MsgUpdateZRC20WithdrawFee") @@ -880,10 +934,12 @@ func init() { proto.RegisterType((*MsgRemoveForeignCoinResponse)(nil), "zetachain.zetacore.fungible.MsgRemoveForeignCoinResponse") proto.RegisterType((*MsgUpdateContractBytecode)(nil), "zetachain.zetacore.fungible.MsgUpdateContractBytecode") proto.RegisterType((*MsgUpdateContractBytecodeResponse)(nil), "zetachain.zetacore.fungible.MsgUpdateContractBytecodeResponse") - proto.RegisterType((*MsgUpdateZRC20PausedStatus)(nil), "zetachain.zetacore.fungible.MsgUpdateZRC20PausedStatus") - proto.RegisterType((*MsgUpdateZRC20PausedStatusResponse)(nil), "zetachain.zetacore.fungible.MsgUpdateZRC20PausedStatusResponse") proto.RegisterType((*MsgUpdateZRC20LiquidityCap)(nil), "zetachain.zetacore.fungible.MsgUpdateZRC20LiquidityCap") proto.RegisterType((*MsgUpdateZRC20LiquidityCapResponse)(nil), "zetachain.zetacore.fungible.MsgUpdateZRC20LiquidityCapResponse") + proto.RegisterType((*MsgPauseZRC20)(nil), "zetachain.zetacore.fungible.MsgPauseZRC20") + proto.RegisterType((*MsgPauseZRC20Response)(nil), "zetachain.zetacore.fungible.MsgPauseZRC20Response") + proto.RegisterType((*MsgUnpauseZRC20)(nil), "zetachain.zetacore.fungible.MsgUnpauseZRC20") + proto.RegisterType((*MsgUnpauseZRC20Response)(nil), "zetachain.zetacore.fungible.MsgUnpauseZRC20Response") } func init() { @@ -891,71 +947,70 @@ func init() { } var fileDescriptor_7bea9688d1d01113 = []byte{ - // 1013 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xa4, 0x57, 0xdd, 0x6e, 0x1b, 0x45, - 0x14, 0xce, 0x26, 0xcd, 0x8f, 0x4f, 0x6b, 0xc7, 0x8c, 0x4c, 0xbb, 0x38, 0xc8, 0x69, 0xb7, 0xa1, - 0x0d, 0x95, 0x6a, 0x17, 0x53, 0xa8, 0x90, 0x68, 0x51, 0xe2, 0x26, 0x50, 0xa9, 0x46, 0xd5, 0xa6, - 0x29, 0x22, 0x37, 0xab, 0xc9, 0xee, 0x64, 0xbd, 0x8a, 0x3d, 0xb3, 0xec, 0x8c, 0x71, 0xdd, 0x3b, - 0x24, 0xae, 0x2a, 0x81, 0x2a, 0xf1, 0x00, 0xbc, 0x01, 0x12, 0x6f, 0xd1, 0xcb, 0x5e, 0x22, 0x84, - 0x2a, 0x94, 0xbc, 0x08, 0x9a, 0xd9, 0x9f, 0xae, 0x7f, 0xd6, 0x89, 0xcd, 0x4d, 0xb2, 0x33, 0x39, - 0xdf, 0x97, 0xef, 0x9c, 0x39, 0xe7, 0x9b, 0x5d, 0xd8, 0x78, 0x41, 0x04, 0xb6, 0x5b, 0xd8, 0xa3, - 0x35, 0xf5, 0xc4, 0x02, 0x52, 0x3b, 0xea, 0x52, 0xd7, 0x3b, 0x6c, 0x93, 0x9a, 0x78, 0x5e, 0xf5, - 0x03, 0x26, 0x18, 0x5a, 0x4b, 0xa2, 0xaa, 0x71, 0x54, 0x35, 0x8e, 0x2a, 0x97, 0x5c, 0xe6, 0x32, - 0x15, 0x57, 0x93, 0x4f, 0x21, 0xa4, 0x7c, 0x63, 0x0c, 0xb1, 0x7f, 0xec, 0xd6, 0x6c, 0xe6, 0x51, - 0xf5, 0x23, 0x8c, 0x33, 0xee, 0x82, 0xde, 0xe4, 0xee, 0x43, 0xe2, 0xb7, 0x59, 0x7f, 0xaf, 0xcf, - 0x05, 0xe9, 0x34, 0x18, 0x15, 0x01, 0xb6, 0x05, 0x47, 0x3a, 0x2c, 0xdb, 0x01, 0xc1, 0x82, 0x05, - 0xba, 0x76, 0x55, 0xdb, 0xcc, 0x99, 0xf1, 0xd2, 0xf8, 0x47, 0x83, 0xab, 0x59, 0x30, 0x93, 0x70, - 0x9f, 0x51, 0x4e, 0xd0, 0x2d, 0x28, 0x76, 0xa9, 0xc7, 0x7b, 0xd8, 0x7f, 0x56, 0xdf, 0xc5, 0xb6, - 0x60, 0x41, 0x3f, 0xe2, 0x19, 0xd9, 0x47, 0x25, 0x58, 0xec, 0x49, 0x9d, 0xfa, 0xbc, 0x0a, 0x08, - 0x17, 0x68, 0x13, 0x56, 0x93, 0x48, 0x93, 0x75, 0x05, 0x09, 0xf4, 0x05, 0xf5, 0xf7, 0xe1, 0x6d, - 0xb4, 0x01, 0x79, 0x9b, 0x51, 0x4a, 0x24, 0xdb, 0xc1, 0xce, 0xb3, 0xa6, 0x7e, 0x41, 0xc5, 0x0d, - 0x6e, 0xa2, 0x1b, 0x50, 0xe0, 0x03, 0x62, 0xf5, 0x45, 0x15, 0x36, 0xb4, 0x6b, 0xbc, 0x9c, 0x87, - 0x0f, 0x9a, 0xdc, 0xdd, 0xf7, 0x1d, 0x2c, 0xc8, 0x81, 0xd9, 0xa8, 0xdf, 0xf9, 0xce, 0x13, 0x2d, - 0x27, 0xc0, 0xbd, 0x5d, 0x42, 0xb2, 0xcb, 0x82, 0xae, 0x43, 0xfe, 0x45, 0x60, 0xd7, 0xef, 0x58, - 0xd8, 0x71, 0x02, 0xc2, 0x79, 0x94, 0xcd, 0x25, 0xb5, 0xb9, 0x15, 0xee, 0xa1, 0xef, 0xa1, 0x48, - 0x49, 0xcf, 0xea, 0x45, 0x8c, 0xd6, 0x11, 0x21, 0xfa, 0x92, 0x8c, 0xdb, 0xae, 0xbd, 0x7e, 0xbb, - 0x3e, 0xf7, 0xf7, 0xdb, 0xf5, 0x9b, 0xae, 0x27, 0x5a, 0xdd, 0xc3, 0xaa, 0xcd, 0x3a, 0x35, 0x9b, - 0xf1, 0x0e, 0xe3, 0xd1, 0xaf, 0xdb, 0xdc, 0x39, 0xae, 0x89, 0xbe, 0x4f, 0x78, 0x75, 0xdf, 0xa3, - 0xc2, 0x2c, 0x50, 0xd2, 0x4b, 0x2b, 0xdb, 0x83, 0xbc, 0xa4, 0x76, 0x31, 0xb7, 0xda, 0x5e, 0xc7, - 0x13, 0xfa, 0xf2, 0x6c, 0xbc, 0x17, 0x29, 0xe9, 0x7d, 0x8d, 0xf9, 0x63, 0xc9, 0x61, 0x5c, 0x87, - 0x6b, 0x99, 0xb5, 0x88, 0xcf, 0xda, 0x08, 0xe0, 0x4a, 0x12, 0x34, 0xd8, 0x0f, 0x13, 0xca, 0x75, - 0x1f, 0xd6, 0xa4, 0xdc, 0xb0, 0xf8, 0x96, 0x1d, 0x01, 0x86, 0x8a, 0xa7, 0x53, 0xd2, 0x1b, 0x64, - 0x8c, 0x0a, 0x69, 0x5c, 0x83, 0xf5, 0x8c, 0xff, 0x99, 0xc8, 0xfa, 0x7d, 0x1e, 0xca, 0x49, 0x9f, - 0xee, 0x46, 0x13, 0xd3, 0x60, 0x1e, 0x55, 0x89, 0x4c, 0x90, 0x56, 0x82, 0xc5, 0x1d, 0x19, 0x12, - 0xf7, 0xa3, 0x5a, 0xa0, 0x4d, 0x28, 0x1e, 0xb1, 0x80, 0x78, 0x2e, 0xb5, 0xd4, 0x68, 0x59, 0x9e, - 0xa3, 0x1a, 0x72, 0xc1, 0x2c, 0x44, 0xfb, 0x0d, 0xb9, 0xfd, 0xc8, 0x41, 0x65, 0x58, 0x71, 0x88, - 0xed, 0x75, 0x70, 0x9b, 0xab, 0x56, 0xcc, 0x9b, 0xc9, 0x1a, 0x21, 0xb8, 0x40, 0x71, 0x87, 0x44, - 0xbd, 0xa7, 0x9e, 0xd1, 0x65, 0x58, 0xe2, 0xfd, 0xce, 0x21, 0x6b, 0x87, 0xad, 0x60, 0x46, 0x2b, - 0xb4, 0x0d, 0x39, 0x39, 0xac, 0x96, 0x3c, 0x1c, 0x75, 0x9a, 0x85, 0xfa, 0x47, 0xd5, 0x31, 0x6e, - 0xe0, 0x1f, 0xbb, 0x55, 0x35, 0xd5, 0x32, 0xb9, 0xa7, 0x7d, 0x9f, 0x98, 0x2b, 0x76, 0xf4, 0x84, - 0xd6, 0x20, 0xf7, 0xae, 0x23, 0x56, 0x94, 0xdc, 0x15, 0x37, 0x3e, 0xdd, 0x07, 0x60, 0x64, 0x17, - 0x28, 0x19, 0x65, 0x1d, 0x96, 0xe3, 0x53, 0x89, 0x0a, 0x15, 0x2d, 0x8d, 0x87, 0x50, 0x6a, 0x72, - 0xd7, 0x24, 0x1d, 0xf6, 0x23, 0xd9, 0x8d, 0x6a, 0xc0, 0x3c, 0x3a, 0xa1, 0xb4, 0x71, 0xfa, 0xf3, - 0xef, 0xd2, 0x37, 0x2a, 0xf0, 0xe1, 0x38, 0x96, 0xe4, 0x1c, 0x7f, 0xd6, 0x52, 0x03, 0x19, 0x9f, - 0xf2, 0x76, 0x5f, 0x10, 0x9b, 0x39, 0x93, 0x06, 0xf2, 0x63, 0x28, 0x66, 0xb4, 0xd5, 0xaa, 0x3d, - 0xd8, 0x4d, 0xc8, 0x08, 0x67, 0x47, 0x12, 0x5a, 0x2d, 0xcc, 0x5b, 0x91, 0xd3, 0xc8, 0x51, 0x68, - 0x30, 0x87, 0x7c, 0x83, 0x79, 0x6b, 0x60, 0x14, 0x86, 0x55, 0x24, 0x5a, 0xff, 0xd0, 0x54, 0xcf, - 0xa5, 0x06, 0xe6, 0x09, 0xee, 0x72, 0xe2, 0xec, 0x09, 0x2c, 0xba, 0x13, 0x4c, 0x15, 0xdd, 0x84, - 0xd5, 0x01, 0xf7, 0x20, 0x52, 0xeb, 0x82, 0xb4, 0xa7, 0xb4, 0x7f, 0x10, 0x8e, 0x9a, 0xb0, 0x84, - 0x6d, 0xe1, 0x31, 0xaa, 0x34, 0x16, 0xea, 0x9f, 0x55, 0x27, 0xdc, 0x0f, 0xd5, 0x50, 0x48, 0x5a, - 0xc3, 0x96, 0x02, 0x9b, 0x11, 0x89, 0xb1, 0xa1, 0x5a, 0x20, 0x43, 0x6f, 0x92, 0xd6, 0x9f, 0x23, - 0x69, 0x3d, 0xf6, 0x7e, 0xe8, 0x7a, 0x8e, 0x27, 0xfa, 0x0d, 0xec, 0xff, 0x5f, 0x53, 0x7c, 0x0a, - 0xf9, 0x76, 0x4c, 0x67, 0xd9, 0xd8, 0x0f, 0xab, 0x3f, 0xbd, 0x73, 0x5d, 0x6a, 0xa7, 0x44, 0x8d, - 0x66, 0x96, 0x96, 0x1c, 0x67, 0x76, 0xab, 0x0e, 0x7a, 0x56, 0x8d, 0x50, 0x0e, 0x16, 0x9f, 0x6c, - 0xed, 0xef, 0xed, 0x14, 0xe7, 0xd0, 0x45, 0x58, 0xde, 0xff, 0x36, 0x5c, 0x68, 0xf5, 0x5f, 0x73, - 0xb0, 0xd0, 0xe4, 0x2e, 0xfa, 0x45, 0x83, 0xf7, 0xc7, 0x5f, 0x9e, 0x93, 0x0f, 0x25, 0xeb, 0xf2, - 0x2c, 0xdf, 0x9f, 0x09, 0x96, 0x0c, 0xea, 0x6f, 0x1a, 0x5c, 0xc9, 0x72, 0xbb, 0x7b, 0xe7, 0xa3, - 0x1e, 0x01, 0x96, 0xbf, 0x9a, 0x11, 0x98, 0xa8, 0xfa, 0x49, 0x83, 0xf7, 0x46, 0x2d, 0xe2, 0x93, - 0xb3, 0x68, 0x47, 0x20, 0xe5, 0x2f, 0xa6, 0x86, 0x24, 0x1a, 0x5e, 0x6a, 0x50, 0x1a, 0x7b, 0x3f, - 0xdd, 0x3d, 0x8b, 0x73, 0x1c, 0xaa, 0xfc, 0xe5, 0x2c, 0xa8, 0x44, 0xcc, 0x2b, 0x0d, 0x2e, 0x67, - 0x98, 0xd9, 0xe7, 0xe7, 0x23, 0x1e, 0xc6, 0x95, 0x1f, 0xcc, 0x86, 0x1b, 0x23, 0x69, 0xe4, 0x85, - 0xe7, 0x9c, 0x92, 0x86, 0x71, 0xe7, 0x95, 0x94, 0xf5, 0x52, 0xa1, 0x9a, 0x39, 0xcb, 0x46, 0xef, - 0x4d, 0xc1, 0x9d, 0x06, 0x9e, 0xdd, 0xcc, 0x67, 0x18, 0xe1, 0xb0, 0xaa, 0x01, 0x17, 0x9c, 0x46, - 0x55, 0x1a, 0x38, 0x95, 0xaa, 0x71, 0x26, 0xb6, 0xfd, 0xe8, 0xf5, 0x49, 0x45, 0x7b, 0x73, 0x52, - 0xd1, 0xfe, 0x3d, 0xa9, 0x68, 0xaf, 0x4e, 0x2b, 0x73, 0x6f, 0x4e, 0x2b, 0x73, 0x7f, 0x9d, 0x56, - 0xe6, 0x0e, 0x6a, 0x29, 0xef, 0x94, 0xd4, 0xb7, 0x87, 0xbe, 0x0a, 0x9e, 0xa7, 0x3e, 0x38, 0xa4, - 0x91, 0x1e, 0x2e, 0xa9, 0x2f, 0x83, 0x4f, 0xff, 0x0b, 0x00, 0x00, 0xff, 0xff, 0x8b, 0x1c, 0x83, - 0x64, 0x9c, 0x0c, 0x00, 0x00, + // 998 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x57, 0xdd, 0x6e, 0xdb, 0x46, + 0x13, 0x35, 0xed, 0xf8, 0x6f, 0x3e, 0xcb, 0xf6, 0xb7, 0x50, 0x62, 0x86, 0x2e, 0xe4, 0x84, 0x71, + 0x13, 0x37, 0x68, 0xc4, 0x54, 0x75, 0x1b, 0x14, 0x68, 0x52, 0xd4, 0x4a, 0xdc, 0x06, 0x88, 0x80, + 0x82, 0x71, 0x52, 0xd4, 0x37, 0xc4, 0x9a, 0x5c, 0x53, 0x84, 0xa5, 0x5d, 0x96, 0x4b, 0x55, 0x51, + 0xee, 0x0a, 0xf4, 0x2a, 0x40, 0x81, 0x00, 0x7d, 0x80, 0x3e, 0x43, 0xdf, 0x22, 0x97, 0xb9, 0x2c, + 0x82, 0x22, 0x28, 0xec, 0x17, 0x29, 0x76, 0xf9, 0x63, 0x52, 0x12, 0x25, 0x59, 0xed, 0x8d, 0xcd, + 0x1d, 0x9d, 0x39, 0x7b, 0x66, 0x76, 0x66, 0x96, 0x84, 0xed, 0x97, 0x24, 0xc4, 0x76, 0x13, 0x7b, + 0xd4, 0x90, 0x4f, 0x2c, 0x20, 0xc6, 0x71, 0x87, 0xba, 0xde, 0x51, 0x8b, 0x18, 0xe1, 0x8b, 0xaa, + 0x1f, 0xb0, 0x90, 0xa1, 0xcd, 0x14, 0x55, 0x4d, 0x50, 0xd5, 0x04, 0xa5, 0x95, 0x5d, 0xe6, 0x32, + 0x89, 0x33, 0xc4, 0x53, 0xe4, 0xa2, 0xdd, 0x1c, 0x42, 0xec, 0x9f, 0xb8, 0x86, 0xcd, 0x3c, 0x2a, + 0xff, 0x44, 0x38, 0x7d, 0x17, 0xd4, 0x06, 0x77, 0x1f, 0x12, 0xbf, 0xc5, 0x7a, 0x4f, 0x7b, 0x3c, + 0x24, 0xed, 0x3a, 0xa3, 0x61, 0x80, 0xed, 0x90, 0x23, 0x15, 0x16, 0xed, 0x80, 0xe0, 0x90, 0x05, + 0xaa, 0x72, 0x4d, 0xd9, 0x59, 0x36, 0x93, 0xa5, 0xfe, 0x97, 0x02, 0xd7, 0x8a, 0xdc, 0x4c, 0xc2, + 0x7d, 0x46, 0x39, 0x41, 0xb7, 0x61, 0xbd, 0x43, 0x3d, 0xde, 0xc5, 0xfe, 0xf3, 0xda, 0x3e, 0xb6, + 0x43, 0x16, 0xf4, 0x62, 0x9e, 0x01, 0x3b, 0x2a, 0xc3, 0x7c, 0x57, 0xe8, 0x54, 0x67, 0x25, 0x20, + 0x5a, 0xa0, 0x1d, 0x58, 0x4b, 0x91, 0x26, 0xeb, 0x84, 0x24, 0x50, 0xe7, 0xe4, 0xef, 0xfd, 0x66, + 0xb4, 0x0d, 0x25, 0x9b, 0x51, 0x4a, 0x04, 0xdb, 0xe1, 0xa3, 0xe7, 0x0d, 0xf5, 0x92, 0xc4, 0xe5, + 0x8d, 0xe8, 0x26, 0xac, 0xf2, 0x9c, 0x58, 0x75, 0x5e, 0xc2, 0xfa, 0xac, 0xfa, 0xab, 0x59, 0xb8, + 0xda, 0xe0, 0xee, 0x33, 0xdf, 0xc1, 0x21, 0x39, 0x34, 0xeb, 0xb5, 0xbb, 0xdf, 0x7b, 0x61, 0xd3, + 0x09, 0x70, 0x77, 0x9f, 0x90, 0xe2, 0xb4, 0xa0, 0x1b, 0x50, 0x7a, 0x19, 0xd8, 0xb5, 0xbb, 0x16, + 0x76, 0x9c, 0x80, 0x70, 0x1e, 0x47, 0xb3, 0x22, 0x8d, 0x5f, 0x47, 0x36, 0xf4, 0x03, 0xac, 0x53, + 0xd2, 0xb5, 0xba, 0x31, 0xa3, 0x75, 0x4c, 0x88, 0xba, 0x20, 0x70, 0x7b, 0xc6, 0x9b, 0xf7, 0x5b, + 0x33, 0xef, 0xde, 0x6f, 0xdd, 0x72, 0xbd, 0xb0, 0xd9, 0x39, 0xaa, 0xda, 0xac, 0x6d, 0xd8, 0x8c, + 0xb7, 0x19, 0x8f, 0xff, 0xdd, 0xe1, 0xce, 0x89, 0x11, 0xf6, 0x7c, 0xc2, 0xab, 0xcf, 0x3c, 0x1a, + 0x9a, 0xab, 0x94, 0x74, 0xb3, 0xca, 0x9e, 0x42, 0x49, 0x50, 0xbb, 0x98, 0x5b, 0x2d, 0xaf, 0xed, + 0x85, 0xea, 0xe2, 0x74, 0xbc, 0xff, 0xa3, 0xa4, 0xfb, 0x0d, 0xe6, 0x4f, 0x04, 0x87, 0x7e, 0x03, + 0xae, 0x17, 0xe6, 0x22, 0x39, 0x6b, 0x3d, 0x80, 0x8d, 0x14, 0x94, 0xaf, 0x87, 0x11, 0xe9, 0xba, + 0x0f, 0x9b, 0x42, 0x6e, 0x94, 0x7c, 0xcb, 0x8e, 0x1d, 0xfa, 0x92, 0xa7, 0x52, 0xd2, 0xcd, 0x33, + 0xc6, 0x89, 0xd4, 0xaf, 0xc3, 0x56, 0xc1, 0x9e, 0xa9, 0xac, 0xdf, 0x67, 0x41, 0x4b, 0xeb, 0x74, + 0x3f, 0xee, 0x98, 0x3a, 0xf3, 0xa8, 0x0c, 0x64, 0x84, 0xb4, 0x32, 0xcc, 0x3f, 0x12, 0x90, 0xa4, + 0x1e, 0xe5, 0x02, 0xed, 0xc0, 0xfa, 0x31, 0x0b, 0x88, 0xe7, 0x52, 0x4b, 0xb6, 0x96, 0xe5, 0x39, + 0xb2, 0x20, 0xe7, 0xcc, 0xd5, 0xd8, 0x5e, 0x17, 0xe6, 0xc7, 0x0e, 0xd2, 0x60, 0xc9, 0x21, 0xb6, + 0xd7, 0xc6, 0x2d, 0x2e, 0x4b, 0xb1, 0x64, 0xa6, 0x6b, 0x84, 0xe0, 0x12, 0xc5, 0x6d, 0x12, 0xd7, + 0x9e, 0x7c, 0x46, 0x57, 0x60, 0x81, 0xf7, 0xda, 0x47, 0xac, 0x15, 0x95, 0x82, 0x19, 0xaf, 0xd0, + 0x1e, 0x2c, 0x8b, 0x66, 0xb5, 0xc4, 0xe1, 0xc8, 0xd3, 0x5c, 0xad, 0x7d, 0x58, 0x1d, 0x32, 0x0d, + 0xfc, 0x13, 0xb7, 0x2a, 0xbb, 0x5a, 0x04, 0x77, 0xd0, 0xf3, 0x89, 0xb9, 0x64, 0xc7, 0x4f, 0x68, + 0x13, 0x96, 0xcf, 0x2b, 0x62, 0x49, 0xca, 0x5d, 0x72, 0x93, 0xd3, 0x7d, 0x00, 0x7a, 0x71, 0x82, + 0xd2, 0x56, 0x56, 0x61, 0x31, 0x39, 0x95, 0x38, 0x51, 0xf1, 0x52, 0x7f, 0x08, 0xe5, 0x06, 0x77, + 0x4d, 0xd2, 0x66, 0x3f, 0x91, 0xfd, 0x38, 0x07, 0xcc, 0xa3, 0x23, 0x52, 0x9b, 0x84, 0x3f, 0x7b, + 0x1e, 0xbe, 0x5e, 0x81, 0x0f, 0x86, 0xb1, 0xa4, 0xe7, 0xf8, 0x8b, 0x92, 0x69, 0xc8, 0xe4, 0x94, + 0xf7, 0x7a, 0x21, 0xb1, 0x99, 0x33, 0xaa, 0x21, 0x3f, 0x82, 0xf5, 0x82, 0xb2, 0x5a, 0xb3, 0xf3, + 0xd5, 0x84, 0xf4, 0xa8, 0x77, 0x04, 0xa1, 0xd5, 0xc4, 0xbc, 0x19, 0x4f, 0x1a, 0xd1, 0x0a, 0x75, + 0xe6, 0x90, 0x6f, 0x31, 0x6f, 0xe6, 0x5a, 0xa1, 0x5f, 0x45, 0xaa, 0xf5, 0x0f, 0x45, 0xd6, 0x5c, + 0xa6, 0x61, 0x9e, 0x78, 0x3f, 0x76, 0x3c, 0xc7, 0x0b, 0x7b, 0x75, 0xec, 0xff, 0xdb, 0xe9, 0x71, + 0x00, 0xa5, 0x56, 0x42, 0x67, 0xd9, 0xd8, 0x8f, 0x64, 0x5e, 0xbc, 0xc5, 0x57, 0x5a, 0x19, 0x51, + 0xfa, 0xb6, 0xac, 0x82, 0x02, 0xc9, 0x69, 0x64, 0x26, 0x94, 0x1a, 0xdc, 0xfd, 0x0e, 0x77, 0x38, + 0x19, 0xd7, 0x3f, 0xb7, 0x60, 0x2d, 0x17, 0x0b, 0x11, 0xd1, 0xcc, 0x89, 0x51, 0x9b, 0x8d, 0x86, + 0x70, 0x7d, 0x03, 0x2e, 0xe7, 0x38, 0xd3, 0xcd, 0x0e, 0x60, 0x4d, 0x48, 0xa2, 0xfe, 0x7f, 0xba, + 0xdd, 0xd5, 0x68, 0x4e, 0x65, 0x58, 0x93, 0x0d, 0x6b, 0xef, 0x96, 0x61, 0xae, 0xc1, 0x5d, 0xf4, + 0xab, 0x02, 0x97, 0x87, 0xdf, 0x87, 0x9f, 0x55, 0x47, 0xdc, 0xc3, 0xd5, 0xa2, 0xfb, 0x50, 0xbb, + 0x3f, 0x95, 0x5b, 0xda, 0x7b, 0xbf, 0x29, 0xb0, 0x51, 0x34, 0xc0, 0xee, 0x4d, 0x46, 0x3d, 0xe0, + 0xa8, 0x7d, 0x35, 0xa5, 0x63, 0xaa, 0xea, 0x67, 0x05, 0xfe, 0x3f, 0xd8, 0xf5, 0x9f, 0x8c, 0xa3, + 0x1d, 0x70, 0xd1, 0xbe, 0xb8, 0xb0, 0x4b, 0xaa, 0xe1, 0x95, 0x02, 0xe5, 0xa1, 0x57, 0xce, 0xee, + 0x38, 0xce, 0x61, 0x5e, 0xda, 0x97, 0xd3, 0x78, 0xa5, 0x62, 0x5e, 0x2b, 0x70, 0xa5, 0x60, 0x3e, + 0x7d, 0x3e, 0x19, 0x71, 0xbf, 0x9f, 0xf6, 0x60, 0x3a, 0xbf, 0x21, 0x92, 0x06, 0xde, 0x61, 0x26, + 0x94, 0xd4, 0xef, 0x37, 0xa9, 0xa4, 0xa2, 0xf7, 0x04, 0x59, 0xcc, 0x45, 0x93, 0xf1, 0xde, 0x05, + 0xb8, 0xb3, 0x8e, 0xe3, 0x8b, 0x79, 0xcc, 0x60, 0x43, 0x2d, 0x80, 0xcc, 0x54, 0xbb, 0x3d, 0x8e, + 0xee, 0x1c, 0xab, 0xd5, 0x26, 0xc7, 0xa6, 0xbb, 0x05, 0xb0, 0x92, 0x1b, 0x6b, 0x1f, 0x8f, 0x95, + 0x9f, 0x41, 0x6b, 0xbb, 0x17, 0x41, 0x27, 0x7b, 0xee, 0x3d, 0x7e, 0x73, 0x5a, 0x51, 0xde, 0x9e, + 0x56, 0x94, 0xbf, 0x4f, 0x2b, 0xca, 0xeb, 0xb3, 0xca, 0xcc, 0xdb, 0xb3, 0xca, 0xcc, 0x9f, 0x67, + 0x95, 0x99, 0x43, 0x23, 0x73, 0x63, 0x08, 0xbe, 0x3b, 0x7d, 0x1f, 0x0d, 0x2f, 0x32, 0xdf, 0x23, + 0xe2, 0xfa, 0x38, 0x5a, 0x90, 0x1f, 0x0e, 0x9f, 0xfe, 0x13, 0x00, 0x00, 0xff, 0xff, 0x6a, 0x35, + 0xf0, 0xc9, 0xbb, 0x0c, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -976,8 +1031,9 @@ type MsgClient interface { UpdateSystemContract(ctx context.Context, in *MsgUpdateSystemContract, opts ...grpc.CallOption) (*MsgUpdateSystemContractResponse, error) UpdateContractBytecode(ctx context.Context, in *MsgUpdateContractBytecode, opts ...grpc.CallOption) (*MsgUpdateContractBytecodeResponse, error) UpdateZRC20WithdrawFee(ctx context.Context, in *MsgUpdateZRC20WithdrawFee, opts ...grpc.CallOption) (*MsgUpdateZRC20WithdrawFeeResponse, error) - UpdateZRC20PausedStatus(ctx context.Context, in *MsgUpdateZRC20PausedStatus, opts ...grpc.CallOption) (*MsgUpdateZRC20PausedStatusResponse, error) UpdateZRC20LiquidityCap(ctx context.Context, in *MsgUpdateZRC20LiquidityCap, opts ...grpc.CallOption) (*MsgUpdateZRC20LiquidityCapResponse, error) + PauseZRC20(ctx context.Context, in *MsgPauseZRC20, opts ...grpc.CallOption) (*MsgPauseZRC20Response, error) + UnpauseZRC20(ctx context.Context, in *MsgUnpauseZRC20, opts ...grpc.CallOption) (*MsgUnpauseZRC20Response, error) } type msgClient struct { @@ -1042,18 +1098,27 @@ func (c *msgClient) UpdateZRC20WithdrawFee(ctx context.Context, in *MsgUpdateZRC return out, nil } -func (c *msgClient) UpdateZRC20PausedStatus(ctx context.Context, in *MsgUpdateZRC20PausedStatus, opts ...grpc.CallOption) (*MsgUpdateZRC20PausedStatusResponse, error) { - out := new(MsgUpdateZRC20PausedStatusResponse) - err := c.cc.Invoke(ctx, "/zetachain.zetacore.fungible.Msg/UpdateZRC20PausedStatus", in, out, opts...) +func (c *msgClient) UpdateZRC20LiquidityCap(ctx context.Context, in *MsgUpdateZRC20LiquidityCap, opts ...grpc.CallOption) (*MsgUpdateZRC20LiquidityCapResponse, error) { + out := new(MsgUpdateZRC20LiquidityCapResponse) + err := c.cc.Invoke(ctx, "/zetachain.zetacore.fungible.Msg/UpdateZRC20LiquidityCap", in, out, opts...) if err != nil { return nil, err } return out, nil } -func (c *msgClient) UpdateZRC20LiquidityCap(ctx context.Context, in *MsgUpdateZRC20LiquidityCap, opts ...grpc.CallOption) (*MsgUpdateZRC20LiquidityCapResponse, error) { - out := new(MsgUpdateZRC20LiquidityCapResponse) - err := c.cc.Invoke(ctx, "/zetachain.zetacore.fungible.Msg/UpdateZRC20LiquidityCap", in, out, opts...) +func (c *msgClient) PauseZRC20(ctx context.Context, in *MsgPauseZRC20, opts ...grpc.CallOption) (*MsgPauseZRC20Response, error) { + out := new(MsgPauseZRC20Response) + err := c.cc.Invoke(ctx, "/zetachain.zetacore.fungible.Msg/PauseZRC20", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *msgClient) UnpauseZRC20(ctx context.Context, in *MsgUnpauseZRC20, opts ...grpc.CallOption) (*MsgUnpauseZRC20Response, error) { + out := new(MsgUnpauseZRC20Response) + err := c.cc.Invoke(ctx, "/zetachain.zetacore.fungible.Msg/UnpauseZRC20", in, out, opts...) if err != nil { return nil, err } @@ -1068,8 +1133,9 @@ type MsgServer interface { UpdateSystemContract(context.Context, *MsgUpdateSystemContract) (*MsgUpdateSystemContractResponse, error) UpdateContractBytecode(context.Context, *MsgUpdateContractBytecode) (*MsgUpdateContractBytecodeResponse, error) UpdateZRC20WithdrawFee(context.Context, *MsgUpdateZRC20WithdrawFee) (*MsgUpdateZRC20WithdrawFeeResponse, error) - UpdateZRC20PausedStatus(context.Context, *MsgUpdateZRC20PausedStatus) (*MsgUpdateZRC20PausedStatusResponse, error) UpdateZRC20LiquidityCap(context.Context, *MsgUpdateZRC20LiquidityCap) (*MsgUpdateZRC20LiquidityCapResponse, error) + PauseZRC20(context.Context, *MsgPauseZRC20) (*MsgPauseZRC20Response, error) + UnpauseZRC20(context.Context, *MsgUnpauseZRC20) (*MsgUnpauseZRC20Response, error) } // UnimplementedMsgServer can be embedded to have forward compatible implementations. @@ -1094,12 +1160,15 @@ func (*UnimplementedMsgServer) UpdateContractBytecode(ctx context.Context, req * func (*UnimplementedMsgServer) UpdateZRC20WithdrawFee(ctx context.Context, req *MsgUpdateZRC20WithdrawFee) (*MsgUpdateZRC20WithdrawFeeResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method UpdateZRC20WithdrawFee not implemented") } -func (*UnimplementedMsgServer) UpdateZRC20PausedStatus(ctx context.Context, req *MsgUpdateZRC20PausedStatus) (*MsgUpdateZRC20PausedStatusResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method UpdateZRC20PausedStatus not implemented") -} func (*UnimplementedMsgServer) UpdateZRC20LiquidityCap(ctx context.Context, req *MsgUpdateZRC20LiquidityCap) (*MsgUpdateZRC20LiquidityCapResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method UpdateZRC20LiquidityCap not implemented") } +func (*UnimplementedMsgServer) PauseZRC20(ctx context.Context, req *MsgPauseZRC20) (*MsgPauseZRC20Response, error) { + return nil, status.Errorf(codes.Unimplemented, "method PauseZRC20 not implemented") +} +func (*UnimplementedMsgServer) UnpauseZRC20(ctx context.Context, req *MsgUnpauseZRC20) (*MsgUnpauseZRC20Response, error) { + return nil, status.Errorf(codes.Unimplemented, "method UnpauseZRC20 not implemented") +} func RegisterMsgServer(s grpc1.Server, srv MsgServer) { s.RegisterService(&_Msg_serviceDesc, srv) @@ -1213,38 +1282,56 @@ func _Msg_UpdateZRC20WithdrawFee_Handler(srv interface{}, ctx context.Context, d return interceptor(ctx, in, info, handler) } -func _Msg_UpdateZRC20PausedStatus_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgUpdateZRC20PausedStatus) +func _Msg_UpdateZRC20LiquidityCap_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(MsgUpdateZRC20LiquidityCap) if err := dec(in); err != nil { return nil, err } if interceptor == nil { - return srv.(MsgServer).UpdateZRC20PausedStatus(ctx, in) + return srv.(MsgServer).UpdateZRC20LiquidityCap(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, - FullMethod: "/zetachain.zetacore.fungible.Msg/UpdateZRC20PausedStatus", + FullMethod: "/zetachain.zetacore.fungible.Msg/UpdateZRC20LiquidityCap", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).UpdateZRC20PausedStatus(ctx, req.(*MsgUpdateZRC20PausedStatus)) + return srv.(MsgServer).UpdateZRC20LiquidityCap(ctx, req.(*MsgUpdateZRC20LiquidityCap)) } return interceptor(ctx, in, info, handler) } -func _Msg_UpdateZRC20LiquidityCap_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgUpdateZRC20LiquidityCap) +func _Msg_PauseZRC20_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(MsgPauseZRC20) if err := dec(in); err != nil { return nil, err } if interceptor == nil { - return srv.(MsgServer).UpdateZRC20LiquidityCap(ctx, in) + return srv.(MsgServer).PauseZRC20(ctx, in) } info := &grpc.UnaryServerInfo{ Server: srv, - FullMethod: "/zetachain.zetacore.fungible.Msg/UpdateZRC20LiquidityCap", + FullMethod: "/zetachain.zetacore.fungible.Msg/PauseZRC20", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).UpdateZRC20LiquidityCap(ctx, req.(*MsgUpdateZRC20LiquidityCap)) + return srv.(MsgServer).PauseZRC20(ctx, req.(*MsgPauseZRC20)) + } + return interceptor(ctx, in, info, handler) +} + +func _Msg_UnpauseZRC20_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(MsgUnpauseZRC20) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(MsgServer).UnpauseZRC20(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/zetachain.zetacore.fungible.Msg/UnpauseZRC20", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(MsgServer).UnpauseZRC20(ctx, req.(*MsgUnpauseZRC20)) } return interceptor(ctx, in, info, handler) } @@ -1277,14 +1364,18 @@ var _Msg_serviceDesc = grpc.ServiceDesc{ MethodName: "UpdateZRC20WithdrawFee", Handler: _Msg_UpdateZRC20WithdrawFee_Handler, }, - { - MethodName: "UpdateZRC20PausedStatus", - Handler: _Msg_UpdateZRC20PausedStatus_Handler, - }, { MethodName: "UpdateZRC20LiquidityCap", Handler: _Msg_UpdateZRC20LiquidityCap_Handler, }, + { + MethodName: "PauseZRC20", + Handler: _Msg_PauseZRC20_Handler, + }, + { + MethodName: "UnpauseZRC20", + Handler: _Msg_UnpauseZRC20_Handler, + }, }, Streams: []grpc.StreamDesc{}, Metadata: "zetachain/zetacore/fungible/tx.proto", @@ -1746,7 +1837,7 @@ func (m *MsgUpdateContractBytecodeResponse) MarshalToSizedBuffer(dAtA []byte) (i return len(dAtA) - i, nil } -func (m *MsgUpdateZRC20PausedStatus) Marshal() (dAtA []byte, err error) { +func (m *MsgUpdateZRC20LiquidityCap) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) n, err := m.MarshalToSizedBuffer(dAtA[:size]) @@ -1756,21 +1847,86 @@ func (m *MsgUpdateZRC20PausedStatus) Marshal() (dAtA []byte, err error) { return dAtA[:n], nil } -func (m *MsgUpdateZRC20PausedStatus) MarshalTo(dAtA []byte) (int, error) { +func (m *MsgUpdateZRC20LiquidityCap) MarshalTo(dAtA []byte) (int, error) { size := m.Size() return m.MarshalToSizedBuffer(dAtA[:size]) } -func (m *MsgUpdateZRC20PausedStatus) MarshalToSizedBuffer(dAtA []byte) (int, error) { +func (m *MsgUpdateZRC20LiquidityCap) MarshalToSizedBuffer(dAtA []byte) (int, error) { i := len(dAtA) _ = i var l int _ = l - if m.Action != 0 { - i = encodeVarintTx(dAtA, i, uint64(m.Action)) + { + size := m.LiquidityCap.Size() + i -= size + if _, err := m.LiquidityCap.MarshalTo(dAtA[i:]); err != nil { + return 0, err + } + i = encodeVarintTx(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + if len(m.Zrc20Address) > 0 { + i -= len(m.Zrc20Address) + copy(dAtA[i:], m.Zrc20Address) + i = encodeVarintTx(dAtA, i, uint64(len(m.Zrc20Address))) i-- - dAtA[i] = 0x18 + dAtA[i] = 0x12 + } + if len(m.Creator) > 0 { + i -= len(m.Creator) + copy(dAtA[i:], m.Creator) + i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *MsgUpdateZRC20LiquidityCapResponse) 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 *MsgUpdateZRC20LiquidityCapResponse) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MsgUpdateZRC20LiquidityCapResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + return len(dAtA) - i, nil +} + +func (m *MsgPauseZRC20) 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 *MsgPauseZRC20) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MsgPauseZRC20) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l if len(m.Zrc20Addresses) > 0 { for iNdEx := len(m.Zrc20Addresses) - 1; iNdEx >= 0; iNdEx-- { i -= len(m.Zrc20Addresses[iNdEx]) @@ -1790,7 +1946,7 @@ func (m *MsgUpdateZRC20PausedStatus) MarshalToSizedBuffer(dAtA []byte) (int, err return len(dAtA) - i, nil } -func (m *MsgUpdateZRC20PausedStatusResponse) Marshal() (dAtA []byte, err error) { +func (m *MsgPauseZRC20Response) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) n, err := m.MarshalToSizedBuffer(dAtA[:size]) @@ -1800,12 +1956,12 @@ func (m *MsgUpdateZRC20PausedStatusResponse) Marshal() (dAtA []byte, err error) return dAtA[:n], nil } -func (m *MsgUpdateZRC20PausedStatusResponse) MarshalTo(dAtA []byte) (int, error) { +func (m *MsgPauseZRC20Response) MarshalTo(dAtA []byte) (int, error) { size := m.Size() return m.MarshalToSizedBuffer(dAtA[:size]) } -func (m *MsgUpdateZRC20PausedStatusResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { +func (m *MsgPauseZRC20Response) MarshalToSizedBuffer(dAtA []byte) (int, error) { i := len(dAtA) _ = i var l int @@ -1813,7 +1969,7 @@ func (m *MsgUpdateZRC20PausedStatusResponse) MarshalToSizedBuffer(dAtA []byte) ( return len(dAtA) - i, nil } -func (m *MsgUpdateZRC20LiquidityCap) Marshal() (dAtA []byte, err error) { +func (m *MsgUnpauseZRC20) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) n, err := m.MarshalToSizedBuffer(dAtA[:size]) @@ -1823,32 +1979,24 @@ func (m *MsgUpdateZRC20LiquidityCap) Marshal() (dAtA []byte, err error) { return dAtA[:n], nil } -func (m *MsgUpdateZRC20LiquidityCap) MarshalTo(dAtA []byte) (int, error) { +func (m *MsgUnpauseZRC20) MarshalTo(dAtA []byte) (int, error) { size := m.Size() return m.MarshalToSizedBuffer(dAtA[:size]) } -func (m *MsgUpdateZRC20LiquidityCap) MarshalToSizedBuffer(dAtA []byte) (int, error) { +func (m *MsgUnpauseZRC20) MarshalToSizedBuffer(dAtA []byte) (int, error) { i := len(dAtA) _ = i var l int _ = l - { - size := m.LiquidityCap.Size() - i -= size - if _, err := m.LiquidityCap.MarshalTo(dAtA[i:]); err != nil { - return 0, err + if len(m.Zrc20Addresses) > 0 { + for iNdEx := len(m.Zrc20Addresses) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Zrc20Addresses[iNdEx]) + copy(dAtA[i:], m.Zrc20Addresses[iNdEx]) + i = encodeVarintTx(dAtA, i, uint64(len(m.Zrc20Addresses[iNdEx]))) + i-- + dAtA[i] = 0x12 } - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - if len(m.Zrc20Address) > 0 { - i -= len(m.Zrc20Address) - copy(dAtA[i:], m.Zrc20Address) - i = encodeVarintTx(dAtA, i, uint64(len(m.Zrc20Address))) - i-- - dAtA[i] = 0x12 } if len(m.Creator) > 0 { i -= len(m.Creator) @@ -1860,7 +2008,7 @@ func (m *MsgUpdateZRC20LiquidityCap) MarshalToSizedBuffer(dAtA []byte) (int, err return len(dAtA) - i, nil } -func (m *MsgUpdateZRC20LiquidityCapResponse) Marshal() (dAtA []byte, err error) { +func (m *MsgUnpauseZRC20Response) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) n, err := m.MarshalToSizedBuffer(dAtA[:size]) @@ -1870,12 +2018,12 @@ func (m *MsgUpdateZRC20LiquidityCapResponse) Marshal() (dAtA []byte, err error) return dAtA[:n], nil } -func (m *MsgUpdateZRC20LiquidityCapResponse) MarshalTo(dAtA []byte) (int, error) { +func (m *MsgUnpauseZRC20Response) MarshalTo(dAtA []byte) (int, error) { size := m.Size() return m.MarshalToSizedBuffer(dAtA[:size]) } -func (m *MsgUpdateZRC20LiquidityCapResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { +func (m *MsgUnpauseZRC20Response) MarshalToSizedBuffer(dAtA []byte) (int, error) { i := len(dAtA) _ = i var l int @@ -2098,7 +2246,35 @@ func (m *MsgUpdateContractBytecodeResponse) Size() (n int) { return n } -func (m *MsgUpdateZRC20PausedStatus) Size() (n int) { +func (m *MsgUpdateZRC20LiquidityCap) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Creator) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = len(m.Zrc20Address) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = m.LiquidityCap.Size() + n += 1 + l + sovTx(uint64(l)) + return n +} + +func (m *MsgUpdateZRC20LiquidityCapResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n +} + +func (m *MsgPauseZRC20) Size() (n int) { if m == nil { return 0 } @@ -2114,13 +2290,10 @@ func (m *MsgUpdateZRC20PausedStatus) Size() (n int) { n += 1 + l + sovTx(uint64(l)) } } - if m.Action != 0 { - n += 1 + sovTx(uint64(m.Action)) - } return n } -func (m *MsgUpdateZRC20PausedStatusResponse) Size() (n int) { +func (m *MsgPauseZRC20Response) Size() (n int) { if m == nil { return 0 } @@ -2129,7 +2302,7 @@ func (m *MsgUpdateZRC20PausedStatusResponse) Size() (n int) { return n } -func (m *MsgUpdateZRC20LiquidityCap) Size() (n int) { +func (m *MsgUnpauseZRC20) Size() (n int) { if m == nil { return 0 } @@ -2139,16 +2312,16 @@ func (m *MsgUpdateZRC20LiquidityCap) Size() (n int) { if l > 0 { n += 1 + l + sovTx(uint64(l)) } - l = len(m.Zrc20Address) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) + if len(m.Zrc20Addresses) > 0 { + for _, s := range m.Zrc20Addresses { + l = len(s) + n += 1 + l + sovTx(uint64(l)) + } } - l = m.LiquidityCap.Size() - n += 1 + l + sovTx(uint64(l)) return n } -func (m *MsgUpdateZRC20LiquidityCapResponse) Size() (n int) { +func (m *MsgUnpauseZRC20Response) Size() (n int) { if m == nil { return 0 } @@ -3547,7 +3720,7 @@ func (m *MsgUpdateContractBytecodeResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateZRC20PausedStatus) Unmarshal(dAtA []byte) error { +func (m *MsgUpdateZRC20LiquidityCap) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3570,10 +3743,10 @@ func (m *MsgUpdateZRC20PausedStatus) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateZRC20PausedStatus: wiretype end group for non-group") + return fmt.Errorf("proto: MsgUpdateZRC20LiquidityCap: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateZRC20PausedStatus: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgUpdateZRC20LiquidityCap: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -3610,7 +3783,7 @@ func (m *MsgUpdateZRC20PausedStatus) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Zrc20Addresses", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field Zrc20Address", wireType) } var stringLen uint64 for shift := uint(0); ; shift += 7 { @@ -3638,13 +3811,13 @@ func (m *MsgUpdateZRC20PausedStatus) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - m.Zrc20Addresses = append(m.Zrc20Addresses, string(dAtA[iNdEx:postIndex])) + m.Zrc20Address = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Action", wireType) + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field LiquidityCap", wireType) } - m.Action = 0 + var stringLen uint64 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -3654,11 +3827,26 @@ func (m *MsgUpdateZRC20PausedStatus) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.Action |= UpdatePausedStatusAction(b&0x7F) << shift + stringLen |= uint64(b&0x7F) << shift if b < 0x80 { break } } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.LiquidityCap.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -3680,7 +3868,7 @@ func (m *MsgUpdateZRC20PausedStatus) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateZRC20PausedStatusResponse) Unmarshal(dAtA []byte) error { +func (m *MsgUpdateZRC20LiquidityCapResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3703,10 +3891,10 @@ func (m *MsgUpdateZRC20PausedStatusResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateZRC20PausedStatusResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgUpdateZRC20LiquidityCapResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateZRC20PausedStatusResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgUpdateZRC20LiquidityCapResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { default: @@ -3730,7 +3918,7 @@ func (m *MsgUpdateZRC20PausedStatusResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateZRC20LiquidityCap) Unmarshal(dAtA []byte) error { +func (m *MsgPauseZRC20) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3753,10 +3941,10 @@ func (m *MsgUpdateZRC20LiquidityCap) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateZRC20LiquidityCap: wiretype end group for non-group") + return fmt.Errorf("proto: MsgPauseZRC20: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateZRC20LiquidityCap: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgPauseZRC20: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -3793,7 +3981,7 @@ func (m *MsgUpdateZRC20LiquidityCap) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Zrc20Address", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field Zrc20Addresses", wireType) } var stringLen uint64 for shift := uint(0); ; shift += 7 { @@ -3821,11 +4009,111 @@ func (m *MsgUpdateZRC20LiquidityCap) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - m.Zrc20Address = string(dAtA[iNdEx:postIndex]) + m.Zrc20Addresses = append(m.Zrc20Addresses, string(dAtA[iNdEx:postIndex])) iNdEx = postIndex - case 3: + default: + iNdEx = preIndex + skippy, err := skipTx(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthTx + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *MsgPauseZRC20Response) 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 ErrIntOverflowTx + } + 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: MsgPauseZRC20Response: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MsgPauseZRC20Response: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + default: + iNdEx = preIndex + skippy, err := skipTx(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthTx + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *MsgUnpauseZRC20) 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 ErrIntOverflowTx + } + 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: MsgUnpauseZRC20: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MsgUnpauseZRC20: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field LiquidityCap", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field Creator", wireType) } var stringLen uint64 for shift := uint(0); ; shift += 7 { @@ -3853,9 +4141,39 @@ func (m *MsgUpdateZRC20LiquidityCap) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.LiquidityCap.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + m.Creator = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Zrc20Addresses", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + 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 ErrInvalidLengthTx + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Zrc20Addresses = append(m.Zrc20Addresses, string(dAtA[iNdEx:postIndex])) iNdEx = postIndex default: iNdEx = preIndex @@ -3878,7 +4196,7 @@ func (m *MsgUpdateZRC20LiquidityCap) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateZRC20LiquidityCapResponse) Unmarshal(dAtA []byte) error { +func (m *MsgUnpauseZRC20Response) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3901,10 +4219,10 @@ func (m *MsgUpdateZRC20LiquidityCapResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateZRC20LiquidityCapResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgUnpauseZRC20Response: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateZRC20LiquidityCapResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgUnpauseZRC20Response: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { default: From 89ca461c7b15a339dd31be4dffb7f9e42ba8709e Mon Sep 17 00:00:00 2001 From: Alex Gartner Date: Wed, 29 May 2024 02:19:34 -0700 Subject: [PATCH 2/5] fix: remove quotes from e2e args (#2284) --- contrib/localnet/orchestrator/start-zetae2e.sh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/contrib/localnet/orchestrator/start-zetae2e.sh b/contrib/localnet/orchestrator/start-zetae2e.sh index ead84ee4d1..a297be595b 100644 --- a/contrib/localnet/orchestrator/start-zetae2e.sh +++ b/contrib/localnet/orchestrator/start-zetae2e.sh @@ -136,9 +136,9 @@ if [ "$OPTION" == "upgrade" ]; then # When the upgrade height is greater than 100 for upgrade test, the Bitcoin tests have been run once, therefore the Bitcoin wallet is already set up # Use light flag to skip advanced tests if [ "$UPGRADE_HEIGHT" -lt 100 ]; then - zetae2e "$ZETAE2E_CMD" --skip-setup --config deployed.yml --light --skip-header-proof + zetae2e $ZETAE2E_CMD --skip-setup --config deployed.yml --light --skip-header-proof else - zetae2e "$ZETAE2E_CMD" --skip-setup --config deployed.yml --skip-bitcoin-setup --light --skip-header-proof + zetae2e $ZETAE2E_CMD --skip-setup --config deployed.yml --skip-bitcoin-setup --light --skip-header-proof fi ZETAE2E_EXIT_CODE=$? @@ -156,7 +156,7 @@ else echo "running e2e setup..." if [[ ! -f deployed.yml ]]; then - zetae2e "$ZETAE2E_CMD" --setup-only --config-out deployed.yml + zetae2e $ZETAE2E_CMD --setup-only --config-out deployed.yml if [ $? -ne 0 ]; then echo "e2e setup failed" exit 1 @@ -167,7 +167,7 @@ else echo "running e2e tests..." - zetae2e "$ZETAE2E_CMD" --skip-setup --config deployed.yml + zetae2e $ZETAE2E_CMD --skip-setup --config deployed.yml ZETAE2E_EXIT_CODE=$? # if e2e passed, exit with 0, otherwise exit with 1 From 42fe69cd9186aee8995d6a9f5e341fd9b2f32186 Mon Sep 17 00:00:00 2001 From: Lucas Bertrand Date: Wed, 29 May 2024 16:22:15 +0200 Subject: [PATCH 3/5] feat: add `ChainInfo` singleton state variable in `authority` (#2275) * add chain validate method * add chain info type * add chain info type proto * add chain info in genesis * generate * changelog * Update x/authority/types/chain_info.go Co-authored-by: Tanmay * revert is ZetaChain logic * fix name --------- Co-authored-by: Tanmay --- changelog.md | 1 + pkg/chains/chain.go | 33 ++ pkg/chains/chain_test.go | 127 +++++++ .../zetacore/authority/chain_info.proto | 14 + .../zetacore/authority/genesis.proto | 6 +- testutil/sample/authority.go | 19 +- testutil/sample/sample.go | 15 +- .../zetacore/authority/chain_info_pb.d.ts | 37 ++ .../zetacore/authority/genesis_pb.d.ts | 6 + .../zetachain/zetacore/authority/index.d.ts | 1 + x/authority/genesis.go | 6 + x/authority/genesis_test.go | 8 +- x/authority/keeper/chain_info.go | 26 ++ x/authority/keeper/chain_info_test.go | 33 ++ x/authority/types/chain_info.go | 30 ++ x/authority/types/chain_info.pb.go | 335 ++++++++++++++++++ x/authority/types/chain_info_test.go | 79 +++++ x/authority/types/genesis.go | 9 +- x/authority/types/genesis.pb.go | 78 +++- x/authority/types/genesis_test.go | 25 +- x/authority/types/keys.go | 3 + 21 files changed, 872 insertions(+), 19 deletions(-) create mode 100644 proto/zetachain/zetacore/authority/chain_info.proto create mode 100644 typescript/zetachain/zetacore/authority/chain_info_pb.d.ts create mode 100644 x/authority/keeper/chain_info.go create mode 100644 x/authority/keeper/chain_info_test.go create mode 100644 x/authority/types/chain_info.go create mode 100644 x/authority/types/chain_info.pb.go create mode 100644 x/authority/types/chain_info_test.go diff --git a/changelog.md b/changelog.md index 1414740d47..27b8257de4 100644 --- a/changelog.md +++ b/changelog.md @@ -16,6 +16,7 @@ * [2113](https://github.com/zeta-chain/node/pull/2113) - add zetaclientd-supervisor process * [2154](https://github.com/zeta-chain/node/pull/2154) - add `ibccrosschain` module * [2258](https://github.com/zeta-chain/node/pull/2258) - add Optimism and Base in static chain information +* [2275](https://github.com/zeta-chain/node/pull/2275) - add ChainInfo singleton state variable in authority ### Refactor diff --git a/pkg/chains/chain.go b/pkg/chains/chain.go index 0b1c9edcc8..681e13a5ae 100644 --- a/pkg/chains/chain.go +++ b/pkg/chains/chain.go @@ -14,14 +14,47 @@ type SigninAlgo string // Chains represent a slice of Chain type Chains []Chain +// Validate checks whether the chain is valid +// The function check the chain ID is positive and all enum fields have a defined value +func (chain Chain) Validate() error { + if chain.ChainId <= 0 { + return fmt.Errorf("chain ID must be positive") + } + + if _, ok := ChainName_name[int32(chain.ChainName)]; !ok { + return fmt.Errorf("invalid chain name %d", int32(chain.ChainName)) + } + + if _, ok := Network_name[int32(chain.Network)]; !ok { + return fmt.Errorf("invalid network %d", int32(chain.Network)) + } + + if _, ok := NetworkType_name[int32(chain.NetworkType)]; !ok { + return fmt.Errorf("invalid network type %d", int32(chain.NetworkType)) + } + + if _, ok := Vm_name[int32(chain.Vm)]; !ok { + return fmt.Errorf("invalid vm %d", int32(chain.Vm)) + } + + if _, ok := Consensus_name[int32(chain.Consensus)]; !ok { + return fmt.Errorf("invalid consensus %d", int32(chain.Consensus)) + } + + return nil +} + // IsEqual compare two chain to see whether they represent the same chain func (chain Chain) IsEqual(c Chain) bool { return chain.ChainId == c.ChainId } +// IsZetaChain returns true if the chain is a ZetaChain chain func (chain Chain) IsZetaChain() bool { return chain.Network == Network_zeta } + +// IsExternalChain returns true if the chain is an ExternalChain chain, not ZetaChain func (chain Chain) IsExternalChain() bool { return chain.IsExternal } diff --git a/pkg/chains/chain_test.go b/pkg/chains/chain_test.go index 7bbb9de679..d14fd39a37 100644 --- a/pkg/chains/chain_test.go +++ b/pkg/chains/chain_test.go @@ -11,6 +11,133 @@ import ( "github.com/stretchr/testify/require" ) +func TestChain_Validate(t *testing.T) { + tests := []struct { + name string + chain Chain + errStr string + }{ + { + name: "should pass if chain is valid", + chain: Chain{ + ChainId: 42, + ChainName: ChainName_empty, + Network: Network_optimism, + NetworkType: NetworkType_testnet, + Vm: Vm_evm, + Consensus: Consensus_op_stack, + IsExternal: true, + }, + }, + { + name: "should error if chain ID is zero", + chain: Chain{ + ChainId: 0, + ChainName: ChainName_empty, + Network: Network_optimism, + NetworkType: NetworkType_testnet, + Vm: Vm_evm, + Consensus: Consensus_op_stack, + IsExternal: true, + }, + errStr: "chain ID must be positive", + }, + { + name: "should error if chain ID is negative", + chain: Chain{ + ChainId: 0, + ChainName: ChainName_empty, + Network: Network_optimism, + NetworkType: NetworkType_testnet, + Vm: Vm_evm, + Consensus: Consensus_op_stack, + IsExternal: true, + }, + errStr: "chain ID must be positive", + }, + { + name: "should error if chain name invalid", + chain: Chain{ + ChainId: 42, + ChainName: ChainName_base_sepolia + 1, + Network: Network_optimism, + NetworkType: NetworkType_testnet, + Vm: Vm_evm, + Consensus: Consensus_op_stack, + IsExternal: true, + }, + errStr: "invalid chain name", + }, + { + name: "should error if network invalid", + chain: Chain{ + ChainId: 42, + ChainName: ChainName_empty, + Network: Network_base + 1, + NetworkType: NetworkType_testnet, + Vm: Vm_evm, + Consensus: Consensus_op_stack, + IsExternal: true, + }, + errStr: "invalid network", + }, + { + name: "should error if network type invalid", + chain: Chain{ + ChainId: 42, + ChainName: ChainName_empty, + Network: Network_base, + NetworkType: NetworkType_devnet + 1, + Vm: Vm_evm, + Consensus: Consensus_op_stack, + IsExternal: true, + }, + errStr: "invalid network type", + }, + { + name: "should error if vm invalid", + chain: Chain{ + ChainId: 42, + ChainName: ChainName_empty, + Network: Network_base, + NetworkType: NetworkType_devnet, + Vm: Vm_evm + 1, + Consensus: Consensus_op_stack, + IsExternal: true, + }, + errStr: "invalid vm", + }, + { + name: "should error if consensus invalid", + chain: Chain{ + ChainId: 42, + ChainName: ChainName_empty, + Network: Network_base, + NetworkType: NetworkType_devnet, + Vm: Vm_evm, + Consensus: Consensus_op_stack + 1, + IsExternal: true, + }, + errStr: "invalid consensus", + }, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + if tt.errStr != "" { + require.ErrorContains(t, tt.chain.Validate(), tt.errStr) + } else { + require.NoError(t, tt.chain.Validate()) + } + }) + } + + t.Run("all default chains are valid", func(t *testing.T) { + for _, chain := range DefaultChainsList() { + require.NoError(t, chain.Validate()) + } + }) +} + func TestChain_EncodeAddress(t *testing.T) { tests := []struct { name string diff --git a/proto/zetachain/zetacore/authority/chain_info.proto b/proto/zetachain/zetacore/authority/chain_info.proto new file mode 100644 index 0000000000..f417184b06 --- /dev/null +++ b/proto/zetachain/zetacore/authority/chain_info.proto @@ -0,0 +1,14 @@ +syntax = "proto3"; +package zetachain.zetacore.authority; + +import "zetachain/zetacore/pkg/chains/chains.proto"; +import "gogoproto/gogo.proto"; + +option go_package = "github.com/zeta-chain/zetacore/x/authority/types"; + +// ChainInfo contains static information about the chains +// This structure is used to dynamically update these info on a live network +// before hardcoding the values in a upgrade +message ChainInfo { + repeated pkg.chains.Chain chains = 1 [ (gogoproto.nullable) = false ]; +} \ No newline at end of file diff --git a/proto/zetachain/zetacore/authority/genesis.proto b/proto/zetachain/zetacore/authority/genesis.proto index 93eee1e9fc..a23416161f 100644 --- a/proto/zetachain/zetacore/authority/genesis.proto +++ b/proto/zetachain/zetacore/authority/genesis.proto @@ -2,9 +2,13 @@ syntax = "proto3"; package zetachain.zetacore.authority; import "zetachain/zetacore/authority/policies.proto"; +import "zetachain/zetacore/authority/chain_info.proto"; import "gogoproto/gogo.proto"; option go_package = "github.com/zeta-chain/zetacore/x/authority/types"; // GenesisState defines the authority module's genesis state. -message GenesisState { Policies policies = 1 [ (gogoproto.nullable) = false ]; } +message GenesisState { + Policies policies = 1 [ (gogoproto.nullable) = false ]; + ChainInfo chain_info = 2 [ (gogoproto.nullable) = false ]; +} diff --git a/testutil/sample/authority.go b/testutil/sample/authority.go index 9f2535d2b3..f24542c7fc 100644 --- a/testutil/sample/authority.go +++ b/testutil/sample/authority.go @@ -1,6 +1,9 @@ package sample -import authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" +import ( + "github.com/zeta-chain/zetacore/pkg/chains" + authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" +) func Policies() authoritytypes.Policies { return authoritytypes.Policies{ @@ -20,3 +23,17 @@ func Policies() authoritytypes.Policies { }, } } + +func ChainInfo(startChainID int64) authoritytypes.ChainInfo { + chain1 := Chain(startChainID) + chain2 := Chain(startChainID + 1) + chain3 := Chain(startChainID + 2) + + return authoritytypes.ChainInfo{ + Chains: []chains.Chain{ + *chain1, + *chain2, + *chain3, + }, + } +} diff --git a/testutil/sample/sample.go b/testutil/sample/sample.go index 411c6dd7c9..431d93337d 100644 --- a/testutil/sample/sample.go +++ b/testutil/sample/sample.go @@ -121,9 +121,20 @@ func GenDoc(t *testing.T) *types.GenesisDoc { func Chain(chainID int64) *chains.Chain { r := newRandFromSeed(chainID) + chainNameLen := len(chains.ChainName_name) + networkLen := len(chains.Network_name) + networkTypeLen := len(chains.NetworkType_name) + vmLen := len(chains.Vm_name) + consensusLen := len(chains.Consensus_name) + return &chains.Chain{ - ChainName: chains.ChainName(r.Intn(4)), - ChainId: chainID, + ChainId: chainID, + ChainName: chains.ChainName(r.Intn(chainNameLen)), + Network: chains.Network(r.Intn(networkLen)), + NetworkType: chains.NetworkType(r.Intn(networkTypeLen)), + Vm: chains.Vm(r.Intn(vmLen)), + Consensus: chains.Consensus(r.Intn(consensusLen)), + IsExternal: true, } } diff --git a/typescript/zetachain/zetacore/authority/chain_info_pb.d.ts b/typescript/zetachain/zetacore/authority/chain_info_pb.d.ts new file mode 100644 index 0000000000..49437eb7e2 --- /dev/null +++ b/typescript/zetachain/zetacore/authority/chain_info_pb.d.ts @@ -0,0 +1,37 @@ +// @generated by protoc-gen-es v1.3.0 with parameter "target=dts" +// @generated from file zetachain/zetacore/authority/chain_info.proto (package zetachain.zetacore.authority, syntax proto3) +/* eslint-disable */ +// @ts-nocheck + +import type { BinaryReadOptions, FieldList, JsonReadOptions, JsonValue, PartialMessage, PlainMessage } from "@bufbuild/protobuf"; +import { Message, proto3 } from "@bufbuild/protobuf"; +import type { Chain } from "../pkg/chains/chains_pb.js"; + +/** + * ChainInfo contains static information about the chains + * This structure is used to dynamically update these info on a live network + * before hardcoding the values in a upgrade + * + * @generated from message zetachain.zetacore.authority.ChainInfo + */ +export declare class ChainInfo extends Message { + /** + * @generated from field: repeated zetachain.zetacore.pkg.chains.Chain chains = 1; + */ + chains: Chain[]; + + constructor(data?: PartialMessage); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.authority.ChainInfo"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): ChainInfo; + + static fromJson(jsonValue: JsonValue, options?: Partial): ChainInfo; + + static fromJsonString(jsonString: string, options?: Partial): ChainInfo; + + static equals(a: ChainInfo | PlainMessage | undefined, b: ChainInfo | PlainMessage | undefined): boolean; +} + diff --git a/typescript/zetachain/zetacore/authority/genesis_pb.d.ts b/typescript/zetachain/zetacore/authority/genesis_pb.d.ts index a20371004b..381048e226 100644 --- a/typescript/zetachain/zetacore/authority/genesis_pb.d.ts +++ b/typescript/zetachain/zetacore/authority/genesis_pb.d.ts @@ -6,6 +6,7 @@ import type { BinaryReadOptions, FieldList, JsonReadOptions, JsonValue, PartialMessage, PlainMessage } from "@bufbuild/protobuf"; import { Message, proto3 } from "@bufbuild/protobuf"; import type { Policies } from "./policies_pb.js"; +import type { ChainInfo } from "./chain_info_pb.js"; /** * GenesisState defines the authority module's genesis state. @@ -18,6 +19,11 @@ export declare class GenesisState extends Message { */ policies?: Policies; + /** + * @generated from field: zetachain.zetacore.authority.ChainInfo chain_info = 2; + */ + chainInfo?: ChainInfo; + constructor(data?: PartialMessage); static readonly runtime: typeof proto3; diff --git a/typescript/zetachain/zetacore/authority/index.d.ts b/typescript/zetachain/zetacore/authority/index.d.ts index d363dc44f4..e27cc8abc4 100644 --- a/typescript/zetachain/zetacore/authority/index.d.ts +++ b/typescript/zetachain/zetacore/authority/index.d.ts @@ -1,3 +1,4 @@ +export * from "./chain_info_pb"; export * from "./genesis_pb"; export * from "./policies_pb"; export * from "./query_pb"; diff --git a/x/authority/genesis.go b/x/authority/genesis.go index 1391b5954d..56528a5935 100644 --- a/x/authority/genesis.go +++ b/x/authority/genesis.go @@ -10,6 +10,7 @@ import ( // InitGenesis initializes the authority module's state from a provided genesis state func InitGenesis(ctx sdk.Context, k keeper.Keeper, genState types.GenesisState) { k.SetPolicies(ctx, genState.Policies) + k.SetChainInfo(ctx, genState.ChainInfo) } // ExportGenesis returns the authority module's exported genesis. @@ -21,5 +22,10 @@ func ExportGenesis(ctx sdk.Context, k keeper.Keeper) *types.GenesisState { genesis.Policies = policies } + chainInfo, found := k.GetChainInfo(ctx) + if found { + genesis.ChainInfo = chainInfo + } + return &genesis } diff --git a/x/authority/genesis_test.go b/x/authority/genesis_test.go index ac9c8d2e43..f14f4f37c6 100644 --- a/x/authority/genesis_test.go +++ b/x/authority/genesis_test.go @@ -14,7 +14,8 @@ import ( func TestGenesis(t *testing.T) { genesisState := types.GenesisState{ - Policies: sample.Policies(), + Policies: sample.Policies(), + ChainInfo: sample.ChainInfo(42), } // Init @@ -26,6 +27,11 @@ func TestGenesis(t *testing.T) { require.True(t, found) require.Equal(t, genesisState.Policies, policies) + // Check chain info is set + chainInfo, found := k.GetChainInfo(ctx) + require.True(t, found) + require.Equal(t, genesisState.ChainInfo, chainInfo) + // Export got := authority.ExportGenesis(ctx, *k) require.NotNil(t, got) diff --git a/x/authority/keeper/chain_info.go b/x/authority/keeper/chain_info.go new file mode 100644 index 0000000000..5c9056fe0c --- /dev/null +++ b/x/authority/keeper/chain_info.go @@ -0,0 +1,26 @@ +package keeper + +import ( + "github.com/cosmos/cosmos-sdk/store/prefix" + sdk "github.com/cosmos/cosmos-sdk/types" + + "github.com/zeta-chain/zetacore/x/authority/types" +) + +// SetChainInfo sets the chain info to the store +func (k Keeper) SetChainInfo(ctx sdk.Context, chainInfo types.ChainInfo) { + store := prefix.NewStore(ctx.KVStore(k.storeKey), types.KeyPrefix(types.ChainInfoKey)) + b := k.cdc.MustMarshal(&chainInfo) + store.Set([]byte{0}, b) +} + +// GetChainInfo returns the policies from the store +func (k Keeper) GetChainInfo(ctx sdk.Context) (val types.ChainInfo, found bool) { + store := prefix.NewStore(ctx.KVStore(k.storeKey), types.KeyPrefix(types.ChainInfoKey)) + b := store.Get([]byte{0}) + if b == nil { + return val, false + } + k.cdc.MustUnmarshal(b, &val) + return val, true +} diff --git a/x/authority/keeper/chain_info_test.go b/x/authority/keeper/chain_info_test.go new file mode 100644 index 0000000000..87424cb4dd --- /dev/null +++ b/x/authority/keeper/chain_info_test.go @@ -0,0 +1,33 @@ +package keeper_test + +import ( + "testing" + + "github.com/stretchr/testify/require" + + keepertest "github.com/zeta-chain/zetacore/testutil/keeper" + "github.com/zeta-chain/zetacore/testutil/sample" +) + +func TestKeeper_SetChainInfo(t *testing.T) { + k, ctx := keepertest.AuthorityKeeper(t) + chainInfo := sample.ChainInfo(42) + + _, found := k.GetChainInfo(ctx) + require.False(t, found) + + k.SetChainInfo(ctx, chainInfo) + + // Check policy is set + got, found := k.GetChainInfo(ctx) + require.True(t, found) + require.Equal(t, chainInfo, got) + + // Can set policies again + newChainInfo := sample.ChainInfo(84) + require.NotEqual(t, chainInfo, newChainInfo) + k.SetChainInfo(ctx, newChainInfo) + got, found = k.GetChainInfo(ctx) + require.True(t, found) + require.Equal(t, newChainInfo, got) +} diff --git a/x/authority/types/chain_info.go b/x/authority/types/chain_info.go new file mode 100644 index 0000000000..cff10235c4 --- /dev/null +++ b/x/authority/types/chain_info.go @@ -0,0 +1,30 @@ +package types + +import ( + "fmt" + + "github.com/zeta-chain/zetacore/pkg/chains" +) + +// DefaultChainInfo returns the structure with an empty list of chains +func DefaultChainInfo() ChainInfo { + return ChainInfo{ + Chains: []chains.Chain{}, + } +} + +// Validate performs basic validation of chain info +// It checks all chains are valid and they're all of external type +// The structure is used to store external chain information +func (ci ChainInfo) Validate() error { + for _, chain := range ci.Chains { + if err := chain.Validate(); err != nil { + return err + } + if !chain.IsExternal { + return fmt.Errorf("chain %d is not external", chain.ChainId) + } + } + + return nil +} diff --git a/x/authority/types/chain_info.pb.go b/x/authority/types/chain_info.pb.go new file mode 100644 index 0000000000..9dd945040e --- /dev/null +++ b/x/authority/types/chain_info.pb.go @@ -0,0 +1,335 @@ +// Code generated by protoc-gen-gogo. DO NOT EDIT. +// source: zetachain/zetacore/authority/chain_info.proto + +package types + +import ( + fmt "fmt" + _ "github.com/cosmos/gogoproto/gogoproto" + proto "github.com/cosmos/gogoproto/proto" + chains "github.com/zeta-chain/zetacore/pkg/chains" + io "io" + math "math" + math_bits "math/bits" +) + +// 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 + +// ChainInfo contains static information about the chains +// This structure is used to dynamically update these info on a live network +// before hardcoding the values in a upgrade +type ChainInfo struct { + Chains []chains.Chain `protobuf:"bytes,1,rep,name=chains,proto3" json:"chains"` +} + +func (m *ChainInfo) Reset() { *m = ChainInfo{} } +func (m *ChainInfo) String() string { return proto.CompactTextString(m) } +func (*ChainInfo) ProtoMessage() {} +func (*ChainInfo) Descriptor() ([]byte, []int) { + return fileDescriptor_88c7b2261e38c0a9, []int{0} +} +func (m *ChainInfo) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *ChainInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_ChainInfo.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 *ChainInfo) XXX_Merge(src proto.Message) { + xxx_messageInfo_ChainInfo.Merge(m, src) +} +func (m *ChainInfo) XXX_Size() int { + return m.Size() +} +func (m *ChainInfo) XXX_DiscardUnknown() { + xxx_messageInfo_ChainInfo.DiscardUnknown(m) +} + +var xxx_messageInfo_ChainInfo proto.InternalMessageInfo + +func (m *ChainInfo) GetChains() []chains.Chain { + if m != nil { + return m.Chains + } + return nil +} + +func init() { + proto.RegisterType((*ChainInfo)(nil), "zetachain.zetacore.authority.ChainInfo") +} + +func init() { + proto.RegisterFile("zetachain/zetacore/authority/chain_info.proto", fileDescriptor_88c7b2261e38c0a9) +} + +var fileDescriptor_88c7b2261e38c0a9 = []byte{ + // 206 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0xd2, 0xad, 0x4a, 0x2d, 0x49, + 0x4c, 0xce, 0x48, 0xcc, 0xcc, 0xd3, 0x07, 0xb3, 0xf2, 0x8b, 0x52, 0xf5, 0x13, 0x4b, 0x4b, 0x32, + 0xf2, 0x8b, 0x32, 0x4b, 0x2a, 0xf5, 0xc1, 0x12, 0xf1, 0x99, 0x79, 0x69, 0xf9, 0x7a, 0x05, 0x45, + 0xf9, 0x25, 0xf9, 0x42, 0x32, 0x70, 0xe5, 0x7a, 0x30, 0xe5, 0x7a, 0x70, 0xe5, 0x52, 0x5a, 0x58, + 0x0c, 0x2b, 0xc8, 0x4e, 0x87, 0x18, 0x53, 0x0c, 0xa5, 0x20, 0x26, 0x49, 0x89, 0xa4, 0xe7, 0xa7, + 0xe7, 0x83, 0x99, 0xfa, 0x20, 0x16, 0x44, 0x54, 0xc9, 0x9f, 0x8b, 0xd3, 0x19, 0xa4, 0xca, 0x33, + 0x2f, 0x2d, 0x5f, 0xc8, 0x89, 0x8b, 0x0d, 0xa2, 0x45, 0x82, 0x51, 0x81, 0x59, 0x83, 0xdb, 0x48, + 0x45, 0x0f, 0x8b, 0xed, 0x05, 0xd9, 0xe9, 0x7a, 0x50, 0x83, 0xc1, 0x3a, 0x9d, 0x58, 0x4e, 0xdc, + 0x93, 0x67, 0x08, 0x82, 0xea, 0x74, 0xf2, 0x3a, 0xf1, 0x48, 0x8e, 0xf1, 0xc2, 0x23, 0x39, 0xc6, + 0x07, 0x8f, 0xe4, 0x18, 0x27, 0x3c, 0x96, 0x63, 0xb8, 0xf0, 0x58, 0x8e, 0xe1, 0xc6, 0x63, 0x39, + 0x86, 0x28, 0x83, 0xf4, 0xcc, 0x92, 0x8c, 0xd2, 0x24, 0xbd, 0xe4, 0xfc, 0x5c, 0xb0, 0x6b, 0x75, + 0xd1, 0x1c, 0x5e, 0x81, 0x14, 0x0e, 0x25, 0x95, 0x05, 0xa9, 0xc5, 0x49, 0x6c, 0x60, 0x37, 0x1a, + 0x03, 0x02, 0x00, 0x00, 0xff, 0xff, 0x9c, 0x16, 0x2c, 0xe3, 0x34, 0x01, 0x00, 0x00, +} + +func (m *ChainInfo) 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 *ChainInfo) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *ChainInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Chains) > 0 { + for iNdEx := len(m.Chains) - 1; iNdEx >= 0; iNdEx-- { + { + size, err := m.Chains[iNdEx].MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintChainInfo(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + +func encodeVarintChainInfo(dAtA []byte, offset int, v uint64) int { + offset -= sovChainInfo(v) + base := offset + for v >= 1<<7 { + dAtA[offset] = uint8(v&0x7f | 0x80) + v >>= 7 + offset++ + } + dAtA[offset] = uint8(v) + return base +} +func (m *ChainInfo) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Chains) > 0 { + for _, e := range m.Chains { + l = e.Size() + n += 1 + l + sovChainInfo(uint64(l)) + } + } + return n +} + +func sovChainInfo(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozChainInfo(x uint64) (n int) { + return sovChainInfo(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (m *ChainInfo) 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 ErrIntOverflowChainInfo + } + 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: ChainInfo: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: ChainInfo: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Chains", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowChainInfo + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthChainInfo + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthChainInfo + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Chains = append(m.Chains, chains.Chain{}) + if err := m.Chains[len(m.Chains)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipChainInfo(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthChainInfo + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func skipChainInfo(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, ErrIntOverflowChainInfo + } + 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, ErrIntOverflowChainInfo + } + 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, ErrIntOverflowChainInfo + } + 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, ErrInvalidLengthChainInfo + } + iNdEx += length + case 3: + depth++ + case 4: + if depth == 0 { + return 0, ErrUnexpectedEndOfGroupChainInfo + } + depth-- + case 5: + iNdEx += 4 + default: + return 0, fmt.Errorf("proto: illegal wireType %d", wireType) + } + if iNdEx < 0 { + return 0, ErrInvalidLengthChainInfo + } + if depth == 0 { + return iNdEx, nil + } + } + return 0, io.ErrUnexpectedEOF +} + +var ( + ErrInvalidLengthChainInfo = fmt.Errorf("proto: negative length found during unmarshaling") + ErrIntOverflowChainInfo = fmt.Errorf("proto: integer overflow") + ErrUnexpectedEndOfGroupChainInfo = fmt.Errorf("proto: unexpected end of group") +) diff --git a/x/authority/types/chain_info_test.go b/x/authority/types/chain_info_test.go new file mode 100644 index 0000000000..dd43b4064f --- /dev/null +++ b/x/authority/types/chain_info_test.go @@ -0,0 +1,79 @@ +package types_test + +import ( + "testing" + + "github.com/stretchr/testify/require" + + "github.com/zeta-chain/zetacore/pkg/chains" + "github.com/zeta-chain/zetacore/testutil/sample" + "github.com/zeta-chain/zetacore/x/authority/types" +) + +func TestDefaultChainInfo(t *testing.T) { + t.Run("default is empty", func(t *testing.T) { + chainInfo := types.DefaultChainInfo() + require.Empty(t, chainInfo.Chains) + }) +} + +func TestChainInfo_Validate(t *testing.T) { + tests := []struct { + name string + chainInfo types.ChainInfo + errContains string + }{ + { + name: "empty is valid", + chainInfo: types.ChainInfo{}, + }, + { + name: "valid chain info", + chainInfo: sample.ChainInfo(42), + }, + { + name: "invalid if chain is invalid", + chainInfo: types.ChainInfo{ + Chains: []chains.Chain{ + { + ChainId: 0, + ChainName: chains.ChainName_empty, + Network: chains.Network_optimism, + NetworkType: chains.NetworkType_testnet, + Vm: chains.Vm_evm, + Consensus: chains.Consensus_op_stack, + IsExternal: true, + }, + }, + }, + errContains: "chain ID must be positive", + }, + { + name: "invalid if chain is not external", + chainInfo: types.ChainInfo{ + Chains: []chains.Chain{ + { + ChainId: 42, + ChainName: chains.ChainName_empty, + Network: chains.Network_optimism, + NetworkType: chains.NetworkType_testnet, + Vm: chains.Vm_evm, + Consensus: chains.Consensus_op_stack, + IsExternal: false, + }, + }, + }, + errContains: "not external", + }, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + err := tt.chainInfo.Validate() + if tt.errContains != "" { + require.ErrorContains(t, err, tt.errContains) + } else { + require.NoError(t, err) + } + }) + } +} diff --git a/x/authority/types/genesis.go b/x/authority/types/genesis.go index bed0e04a41..13a01030bf 100644 --- a/x/authority/types/genesis.go +++ b/x/authority/types/genesis.go @@ -3,11 +3,16 @@ package types // DefaultGenesis returns the default authority genesis state func DefaultGenesis() *GenesisState { return &GenesisState{ - Policies: DefaultPolicies(), + Policies: DefaultPolicies(), + ChainInfo: DefaultChainInfo(), } } // Validate performs basic genesis state validation returning an error upon any failure func (gs GenesisState) Validate() error { - return gs.Policies.Validate() + if err := gs.Policies.Validate(); err != nil { + return err + } + + return gs.ChainInfo.Validate() } diff --git a/x/authority/types/genesis.pb.go b/x/authority/types/genesis.pb.go index 77857e5b67..aca80bfed4 100644 --- a/x/authority/types/genesis.pb.go +++ b/x/authority/types/genesis.pb.go @@ -25,7 +25,8 @@ const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package // GenesisState defines the authority module's genesis state. type GenesisState struct { - Policies Policies `protobuf:"bytes,1,opt,name=policies,proto3" json:"policies"` + Policies Policies `protobuf:"bytes,1,opt,name=policies,proto3" json:"policies"` + ChainInfo ChainInfo `protobuf:"bytes,2,opt,name=chain_info,json=chainInfo,proto3" json:"chain_info"` } func (m *GenesisState) Reset() { *m = GenesisState{} } @@ -68,6 +69,13 @@ func (m *GenesisState) GetPolicies() Policies { return Policies{} } +func (m *GenesisState) GetChainInfo() ChainInfo { + if m != nil { + return m.ChainInfo + } + return ChainInfo{} +} + func init() { proto.RegisterType((*GenesisState)(nil), "zetachain.zetacore.authority.GenesisState") } @@ -77,20 +85,23 @@ func init() { } var fileDescriptor_633475075491b169 = []byte{ - // 202 bytes of a gzipped FileDescriptorProto + // 242 bytes of a gzipped FileDescriptorProto 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0xd2, 0xaa, 0x4a, 0x2d, 0x49, 0x4c, 0xce, 0x48, 0xcc, 0xcc, 0xd3, 0x07, 0xb3, 0xf2, 0x8b, 0x52, 0xf5, 0x13, 0x4b, 0x4b, 0x32, 0xf2, 0x8b, 0x32, 0x4b, 0x2a, 0xf5, 0xd3, 0x53, 0xf3, 0x52, 0x8b, 0x33, 0x8b, 0xf5, 0x0a, 0x8a, 0xf2, 0x4b, 0xf2, 0x85, 0x64, 0xe0, 0x6a, 0xf5, 0x60, 0x6a, 0xf5, 0xe0, 0x6a, 0xa5, 0xb4, 0xf1, - 0x9a, 0x54, 0x90, 0x9f, 0x93, 0x99, 0x9c, 0x99, 0x0a, 0x35, 0x4a, 0x4a, 0x24, 0x3d, 0x3f, 0x3d, - 0x1f, 0xcc, 0xd4, 0x07, 0xb1, 0x20, 0xa2, 0x4a, 0x11, 0x5c, 0x3c, 0xee, 0x10, 0x1b, 0x83, 0x4b, - 0x12, 0x4b, 0x52, 0x85, 0x3c, 0xb8, 0x38, 0x60, 0xfa, 0x24, 0x18, 0x15, 0x18, 0x35, 0xb8, 0x8d, - 0xd4, 0xf4, 0xf0, 0xb9, 0x41, 0x2f, 0x00, 0xaa, 0xda, 0x89, 0xe5, 0xc4, 0x3d, 0x79, 0x86, 0x20, - 0xb8, 0x6e, 0x27, 0xaf, 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, 0x32, 0x48, - 0xcf, 0x2c, 0xc9, 0x28, 0x4d, 0xd2, 0x4b, 0xce, 0xcf, 0x05, 0xbb, 0x5b, 0x17, 0xcd, 0x0b, 0x15, - 0x48, 0x9e, 0x28, 0xa9, 0x2c, 0x48, 0x2d, 0x4e, 0x62, 0x03, 0x3b, 0xd6, 0x18, 0x10, 0x00, 0x00, - 0xff, 0xff, 0xd8, 0x71, 0x7a, 0xaa, 0x3b, 0x01, 0x00, 0x00, + 0x9a, 0x54, 0x90, 0x9f, 0x93, 0x99, 0x9c, 0x99, 0x0a, 0x35, 0x4a, 0x4a, 0x17, 0xaf, 0x62, 0xb0, + 0x44, 0x7c, 0x66, 0x5e, 0x5a, 0x3e, 0x54, 0xb9, 0x48, 0x7a, 0x7e, 0x7a, 0x3e, 0x98, 0xa9, 0x0f, + 0x62, 0x41, 0x44, 0x95, 0x96, 0x31, 0x72, 0xf1, 0xb8, 0x43, 0x5c, 0x18, 0x5c, 0x92, 0x58, 0x92, + 0x2a, 0xe4, 0xc1, 0xc5, 0x01, 0xb3, 0x47, 0x82, 0x51, 0x81, 0x51, 0x83, 0xdb, 0x48, 0x4d, 0x0f, + 0x9f, 0x9b, 0xf5, 0x02, 0xa0, 0xaa, 0x9d, 0x58, 0x4e, 0xdc, 0x93, 0x67, 0x08, 0x82, 0xeb, 0x16, + 0xf2, 0xe1, 0xe2, 0x42, 0x38, 0x42, 0x82, 0x09, 0x6c, 0x96, 0x3a, 0x7e, 0xb3, 0x9c, 0x41, 0x12, + 0x9e, 0x79, 0x69, 0xf9, 0x50, 0xc3, 0x38, 0x93, 0xe1, 0x02, 0x5e, 0x27, 0x1e, 0xc9, 0x31, 0x5e, + 0x78, 0x24, 0xc7, 0xf8, 0xe0, 0x91, 0x1c, 0xe3, 0x84, 0xc7, 0x72, 0x0c, 0x17, 0x1e, 0xcb, 0x31, + 0xdc, 0x78, 0x2c, 0xc7, 0x10, 0x65, 0x90, 0x9e, 0x59, 0x92, 0x51, 0x9a, 0xa4, 0x97, 0x9c, 0x9f, + 0x0b, 0x0e, 0x08, 0x5d, 0xb4, 0x30, 0xa9, 0x40, 0x0a, 0x95, 0x92, 0xca, 0x82, 0xd4, 0xe2, 0x24, + 0x36, 0xb0, 0xdf, 0x8d, 0x01, 0x01, 0x00, 0x00, 0xff, 0xff, 0xaf, 0x5f, 0x4d, 0x13, 0xb9, 0x01, + 0x00, 0x00, } func (m *GenesisState) Marshal() (dAtA []byte, err error) { @@ -113,6 +124,16 @@ func (m *GenesisState) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l + { + size, err := m.ChainInfo.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintGenesis(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 { size, err := m.Policies.MarshalToSizedBuffer(dAtA[:i]) if err != nil { @@ -145,6 +166,8 @@ func (m *GenesisState) Size() (n int) { _ = l l = m.Policies.Size() n += 1 + l + sovGenesis(uint64(l)) + l = m.ChainInfo.Size() + n += 1 + l + sovGenesis(uint64(l)) return n } @@ -216,6 +239,39 @@ func (m *GenesisState) Unmarshal(dAtA []byte) error { return err } iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ChainInfo", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowGenesis + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthGenesis + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthGenesis + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.ChainInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipGenesis(dAtA[iNdEx:]) diff --git a/x/authority/types/genesis_test.go b/x/authority/types/genesis_test.go index 46f4ad9bcb..90aee92509 100644 --- a/x/authority/types/genesis_test.go +++ b/x/authority/types/genesis_test.go @@ -5,6 +5,7 @@ import ( "github.com/stretchr/testify/require" + "github.com/zeta-chain/zetacore/pkg/chains" "github.com/zeta-chain/zetacore/testutil/sample" "github.com/zeta-chain/zetacore/x/authority/types" ) @@ -25,7 +26,8 @@ func TestGenesisState_Validate(t *testing.T) { { name: "valid genesis", gs: &types.GenesisState{ - Policies: sample.Policies(), + Policies: sample.Policies(), + ChainInfo: sample.ChainInfo(42), }, errContains: "", }, @@ -40,9 +42,30 @@ func TestGenesisState_Validate(t *testing.T) { }, }, }, + ChainInfo: sample.ChainInfo(42), }, errContains: "invalid address", }, + { + name: "invalid if policies is invalid", + gs: &types.GenesisState{ + Policies: sample.Policies(), + ChainInfo: types.ChainInfo{ + Chains: []chains.Chain{ + { + ChainId: 0, + ChainName: chains.ChainName_empty, + Network: chains.Network_optimism, + NetworkType: chains.NetworkType_testnet, + Vm: chains.Vm_evm, + Consensus: chains.Consensus_op_stack, + IsExternal: true, + }, + }, + }, + }, + errContains: "chain ID must be positive", + }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { diff --git a/x/authority/types/keys.go b/x/authority/types/keys.go index 5b86ca9711..7593feed3a 100644 --- a/x/authority/types/keys.go +++ b/x/authority/types/keys.go @@ -25,4 +25,7 @@ func KeyPrefix(p string) []byte { const ( // PoliciesKey is the key for the policies store PoliciesKey = "Policies-value-" + + // ChainInfoKey is the key for the chain info store + ChainInfoKey = "ChainInfo-value-" ) From 180fcef0d9dab34bf4dac64378a7efbe63f7509b Mon Sep 17 00:00:00 2001 From: Lucas Bertrand Date: Wed, 29 May 2024 18:23:17 +0200 Subject: [PATCH 4/5] feat(`pkg/chains`): add a `CCTXGateway` field to chain static data (#2279) * proto gen * add field to chains * make generate * changelog * fix test * update comment * make format --- changelog.md | 1 + docs/openapi/openapi.swagger.yaml | 15 ++ pkg/chains/chains.go | 20 +++ pkg/chains/chains.pb.go | 155 +++++++++++++----- .../zetacore/pkg/chains/chains.proto | 16 ++ .../zetacore/pkg/chains/chains_pb.d.ts | 30 ++++ zetaclient/zetacore/tx_test.go | 3 +- 7 files changed, 196 insertions(+), 44 deletions(-) diff --git a/changelog.md b/changelog.md index 27b8257de4..a2fdd6c26c 100644 --- a/changelog.md +++ b/changelog.md @@ -16,6 +16,7 @@ * [2113](https://github.com/zeta-chain/node/pull/2113) - add zetaclientd-supervisor process * [2154](https://github.com/zeta-chain/node/pull/2154) - add `ibccrosschain` module * [2258](https://github.com/zeta-chain/node/pull/2258) - add Optimism and Base in static chain information +* [2279](https://github.com/zeta-chain/node/pull/2279) - add a CCTXGateway field to chain static data * [2275](https://github.com/zeta-chain/node/pull/2275) - add ChainInfo singleton state variable in authority ### Refactor diff --git a/docs/openapi/openapi.swagger.yaml b/docs/openapi/openapi.swagger.yaml index 9067eccc6d..9c0dbc1e10 100644 --- a/docs/openapi/openapi.swagger.yaml +++ b/docs/openapi/openapi.swagger.yaml @@ -56744,6 +56744,18 @@ definitions: description: |- QueryGetPoliciesResponse is the response type for the Query/Policies RPC method. + chainsCCTXGateway: + type: string + enum: + - zevm + - observers + default: zevm + description: |- + - zevm: zevm is the internal CCTX gateway to process outbound on the ZEVM and read + inbound events from the ZEVM only used for ZetaChain chains + - observers: observers is the CCTX gateway for chains relying on the observer set to + observe inbounds and TSS for outbounds + title: CCTXGateway describes for the chain the gateway used to handle CCTX outbounds chainsChain: type: object properties: @@ -56769,6 +56781,9 @@ definitions: is_external: type: boolean title: IsExternal describe if the chain is ZetaChain or external + cctx_gateway: + $ref: '#/definitions/chainsCCTXGateway' + title: CCTXGateway is the gateway used to handle CCTX outbounds title: |- Chain represents static data about a blockchain network it is identified by a unique chain ID diff --git a/pkg/chains/chains.go b/pkg/chains/chains.go index 21718f874d..61fffece76 100644 --- a/pkg/chains/chains.go +++ b/pkg/chains/chains.go @@ -16,6 +16,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_tendermint, IsExternal: false, + CctxGateway: CCTXGateway_zevm, } // Ethereum is Ethereum mainnet @@ -27,6 +28,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_ethereum, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // BscMainnet is Binance Smart Chain mainnet @@ -38,6 +40,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_ethereum, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // BitcoinMainnet is Bitcoin mainnet @@ -49,6 +52,7 @@ var ( Vm: Vm_no_vm, Consensus: Consensus_bitcoin, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // Polygon is Polygon mainnet @@ -60,6 +64,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_ethereum, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // OptimismMainnet is Optimism mainnet @@ -71,6 +76,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_op_stack, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // BaseMainnet is Base mainnet @@ -82,6 +88,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_op_stack, IsExternal: true, + CctxGateway: CCTXGateway_observers, } /** @@ -97,6 +104,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_tendermint, IsExternal: false, + CctxGateway: CCTXGateway_zevm, } // Sepolia is Ethereum sepolia testnet @@ -108,6 +116,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_ethereum, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // BscTestnet is Binance Smart Chain testnet @@ -119,6 +128,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_ethereum, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // BitcoinTestnet is Bitcoin testnet3 @@ -130,6 +140,7 @@ var ( Vm: Vm_no_vm, Consensus: Consensus_bitcoin, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // Amoy is Polygon amoy testnet @@ -141,6 +152,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_ethereum, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // OptimismSepolia is Optimism sepolia testnet @@ -152,6 +164,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_op_stack, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // BaseSepolia is Base sepolia testnet @@ -163,6 +176,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_op_stack, IsExternal: true, + CctxGateway: CCTXGateway_observers, } /** @@ -179,6 +193,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_tendermint, IsExternal: false, + CctxGateway: CCTXGateway_zevm, } /** @@ -194,6 +209,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_tendermint, IsExternal: false, + CctxGateway: CCTXGateway_zevm, } // BitcoinRegtest is Bitcoin regtest (localnet) @@ -205,6 +221,7 @@ var ( Vm: Vm_no_vm, Consensus: Consensus_bitcoin, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // GoerliLocalnet is Ethereum local goerli (localnet) @@ -216,6 +233,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_ethereum, IsExternal: true, + CctxGateway: CCTXGateway_observers, } /** @@ -231,6 +249,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_ethereum, IsExternal: true, + CctxGateway: CCTXGateway_observers, } // Mumbai is Polygon mumbai testnet (deprecated for amoy) @@ -242,6 +261,7 @@ var ( Vm: Vm_evm, Consensus: Consensus_ethereum, IsExternal: true, + CctxGateway: CCTXGateway_observers, } ) diff --git a/pkg/chains/chains.pb.go b/pkg/chains/chains.pb.go index 1153208c6d..848a7e1bc0 100644 --- a/pkg/chains/chains.pb.go +++ b/pkg/chains/chains.pb.go @@ -269,6 +269,36 @@ func (Consensus) EnumDescriptor() ([]byte, []int) { return fileDescriptor_236b85e7bff6130d, []int{5} } +// CCTXGateway describes for the chain the gateway used to handle CCTX outbounds +type CCTXGateway int32 + +const ( + // zevm is the internal CCTX gateway to process outbound on the ZEVM and read + // inbound events from the ZEVM only used for ZetaChain chains + CCTXGateway_zevm CCTXGateway = 0 + // observers is the CCTX gateway for chains relying on the observer set to + // observe inbounds and TSS for outbounds + CCTXGateway_observers CCTXGateway = 1 +) + +var CCTXGateway_name = map[int32]string{ + 0: "zevm", + 1: "observers", +} + +var CCTXGateway_value = map[string]int32{ + "zevm": 0, + "observers": 1, +} + +func (x CCTXGateway) String() string { + return proto.EnumName(CCTXGateway_name, int32(x)) +} + +func (CCTXGateway) EnumDescriptor() ([]byte, []int) { + return fileDescriptor_236b85e7bff6130d, []int{6} +} + // Chain represents static data about a blockchain network // it is identified by a unique chain ID type Chain struct { @@ -286,6 +316,8 @@ type Chain struct { Consensus Consensus `protobuf:"varint,6,opt,name=consensus,proto3,enum=zetachain.zetacore.pkg.chains.Consensus" json:"consensus,omitempty"` // IsExternal describe if the chain is ZetaChain or external IsExternal bool `protobuf:"varint,7,opt,name=is_external,json=isExternal,proto3" json:"is_external,omitempty"` + // CCTXGateway is the gateway used to handle CCTX outbounds + CctxGateway CCTXGateway `protobuf:"varint,8,opt,name=cctx_gateway,json=cctxGateway,proto3,enum=zetachain.zetacore.pkg.chains.CCTXGateway" json:"cctx_gateway,omitempty"` } func (m *Chain) Reset() { *m = Chain{} } @@ -370,6 +402,13 @@ func (m *Chain) GetIsExternal() bool { return false } +func (m *Chain) GetCctxGateway() CCTXGateway { + if m != nil { + return m.CctxGateway + } + return CCTXGateway_zevm +} + func init() { proto.RegisterEnum("zetachain.zetacore.pkg.chains.ReceiveStatus", ReceiveStatus_name, ReceiveStatus_value) proto.RegisterEnum("zetachain.zetacore.pkg.chains.ChainName", ChainName_name, ChainName_value) @@ -377,6 +416,7 @@ func init() { proto.RegisterEnum("zetachain.zetacore.pkg.chains.NetworkType", NetworkType_name, NetworkType_value) proto.RegisterEnum("zetachain.zetacore.pkg.chains.Vm", Vm_name, Vm_value) proto.RegisterEnum("zetachain.zetacore.pkg.chains.Consensus", Consensus_name, Consensus_value) + proto.RegisterEnum("zetachain.zetacore.pkg.chains.CCTXGateway", CCTXGateway_name, CCTXGateway_value) proto.RegisterType((*Chain)(nil), "zetachain.zetacore.pkg.chains.Chain") } @@ -385,49 +425,51 @@ func init() { } var fileDescriptor_236b85e7bff6130d = []byte{ - // 658 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x94, 0xcf, 0x6e, 0x13, 0x3b, - 0x14, 0xc6, 0x33, 0x93, 0xff, 0x27, 0x69, 0xea, 0xeb, 0x76, 0x91, 0x5b, 0xe9, 0xce, 0xed, 0xbd, - 0x0b, 0x14, 0x22, 0x91, 0x08, 0x58, 0xb2, 0x41, 0x54, 0x14, 0x81, 0x44, 0x17, 0x03, 0xaa, 0x04, - 0x9b, 0x68, 0xe2, 0x1c, 0x26, 0x56, 0x62, 0x7b, 0x34, 0x76, 0x02, 0xe1, 0x29, 0x58, 0xf2, 0x00, - 0x2c, 0x78, 0x14, 0x96, 0x5d, 0xb2, 0x44, 0xed, 0x03, 0xf0, 0x0a, 0xc8, 0xce, 0x78, 0x02, 0x0b, - 0x68, 0x57, 0x73, 0xfc, 0x9b, 0xef, 0x7c, 0xe7, 0xd8, 0x3e, 0x32, 0x0c, 0xdf, 0xa3, 0x49, 0xd8, - 0x3c, 0xe1, 0x72, 0xec, 0x22, 0x95, 0xe3, 0x38, 0x5b, 0xa4, 0x63, 0x87, 0x74, 0xf1, 0x19, 0x65, - 0xb9, 0x32, 0x8a, 0xfe, 0x53, 0x6a, 0x47, 0x5e, 0x3b, 0xca, 0x16, 0xe9, 0x68, 0x2b, 0x3a, 0x3a, - 0x4c, 0x55, 0xaa, 0x9c, 0x72, 0x6c, 0xa3, 0x6d, 0xd2, 0xff, 0x1f, 0xab, 0x50, 0x3f, 0xb1, 0x02, - 0xfa, 0x37, 0xb4, 0x9c, 0x72, 0xc2, 0x67, 0xfd, 0xf0, 0x38, 0x18, 0x54, 0xe3, 0xa6, 0x5b, 0x3f, - 0x9d, 0xd1, 0x27, 0x00, 0xdb, 0x5f, 0x32, 0x11, 0xd8, 0x0f, 0x8e, 0x83, 0x41, 0xef, 0xde, 0x60, - 0xf4, 0xc7, 0x72, 0x23, 0x67, 0x7a, 0x96, 0x08, 0x8c, 0xdb, 0xcc, 0x87, 0xf4, 0x21, 0x34, 0x25, - 0x9a, 0xb7, 0x2a, 0x5f, 0xf4, 0xab, 0xce, 0xe5, 0xd6, 0x35, 0x2e, 0x67, 0x5b, 0x75, 0xec, 0xd3, - 0xe8, 0x73, 0xe8, 0x16, 0xe1, 0xc4, 0x6c, 0x32, 0xec, 0xd7, 0x9c, 0xcd, 0xf0, 0x66, 0x36, 0x2f, - 0x37, 0x19, 0xc6, 0x1d, 0xb9, 0x5b, 0xd0, 0xbb, 0x10, 0xae, 0x45, 0xbf, 0xee, 0x4c, 0xfe, 0xbb, - 0xc6, 0xe4, 0x5c, 0xc4, 0xe1, 0x5a, 0xd0, 0x53, 0x68, 0x33, 0x25, 0x35, 0x4a, 0xbd, 0xd2, 0xfd, - 0xc6, 0xcd, 0xce, 0xc2, 0xeb, 0xe3, 0x5d, 0x2a, 0xfd, 0x17, 0x3a, 0x5c, 0x4f, 0xf0, 0x9d, 0xc1, - 0x5c, 0x26, 0xcb, 0x7e, 0xf3, 0x38, 0x18, 0xb4, 0x62, 0xe0, 0xfa, 0x71, 0x41, 0x86, 0x0f, 0x60, - 0x2f, 0x46, 0x86, 0x7c, 0x8d, 0x2f, 0x4c, 0x62, 0x56, 0x9a, 0x76, 0xa0, 0xc9, 0x72, 0x4c, 0x0c, - 0xce, 0x48, 0xc5, 0x2e, 0xf4, 0x8a, 0x31, 0xd4, 0x9a, 0x04, 0x14, 0xa0, 0xf1, 0x26, 0xe1, 0x4b, - 0x9c, 0x91, 0xf0, 0xa8, 0xf6, 0xf9, 0x53, 0x14, 0x0c, 0xbf, 0x87, 0xd0, 0x2e, 0xaf, 0x80, 0xb6, - 0xa1, 0x8e, 0x22, 0x33, 0x1b, 0x52, 0xa1, 0xfb, 0xd0, 0x41, 0x33, 0x9f, 0x88, 0x84, 0x4b, 0x89, - 0x86, 0x04, 0x94, 0x40, 0xd7, 0xf6, 0x5c, 0x92, 0xd0, 0x4a, 0xa6, 0x86, 0x95, 0xa0, 0x4a, 0x0f, - 0x60, 0x3f, 0x53, 0xcb, 0x4d, 0xaa, 0x64, 0x09, 0x6b, 0x4e, 0xa5, 0x77, 0xaa, 0x3a, 0xa5, 0xd0, - 0x4b, 0x15, 0xe6, 0x4b, 0x3e, 0x31, 0xa8, 0x8d, 0x65, 0x0d, 0xcb, 0xc4, 0x4a, 0x4c, 0x93, 0x1d, - 0x6b, 0xfa, 0x44, 0x0f, 0xa0, 0xec, 0xc0, 0x93, 0x8e, 0xef, 0xc0, 0x83, 0xae, 0xed, 0x40, 0x63, - 0xa6, 0x96, 0x7c, 0xa7, 0xda, 0xb3, 0xb0, 0x28, 0xb8, 0x54, 0x2c, 0x59, 0x5a, 0xd8, 0xf3, 0xa9, - 0x39, 0xa6, 0x56, 0x48, 0xf6, 0xad, 0x7b, 0x22, 0xd4, 0xa6, 0xcc, 0x23, 0xf4, 0x10, 0x88, 0xca, - 0x0c, 0x17, 0x5c, 0x8b, 0xb2, 0xfd, 0xbf, 0x7e, 0xa1, 0x45, 0x2d, 0x42, 0x6d, 0xf6, 0x34, 0xd1, - 0x58, 0xea, 0x0e, 0x4a, 0xe2, 0x35, 0x87, 0xc5, 0x89, 0xbf, 0x82, 0x66, 0x31, 0x66, 0xb4, 0x09, - 0x55, 0x34, 0x73, 0x52, 0xa1, 0x2d, 0xa8, 0xd9, 0x9d, 0x91, 0xc0, 0xa2, 0xa9, 0x61, 0x24, 0xb4, - 0xf7, 0x56, 0x9c, 0x25, 0xa9, 0x3a, 0xaa, 0x19, 0xa9, 0xd1, 0x2e, 0xb4, 0x7c, 0x71, 0x52, 0xb7, - 0x69, 0xb6, 0x04, 0x69, 0x14, 0xd6, 0xa7, 0xd0, 0xf9, 0x69, 0x82, 0xad, 0x85, 0x6f, 0xc7, 0xcd, - 0x81, 0xdf, 0x59, 0xe0, 0xcc, 0x73, 0xbe, 0xde, 0x5e, 0x23, 0x40, 0x63, 0x86, 0x2e, 0xae, 0x16, - 0x3e, 0x11, 0x84, 0xe7, 0xc2, 0x0e, 0x83, 0x54, 0x93, 0xb5, 0x20, 0x15, 0xd7, 0xe8, 0x5a, 0x90, - 0xa0, 0xf8, 0xff, 0x0c, 0xda, 0xe5, 0xa8, 0xda, 0x96, 0xd0, 0xcc, 0x31, 0xc7, 0x95, 0x55, 0xf6, - 0x00, 0x0c, 0xca, 0x19, 0xe6, 0x82, 0xcb, 0xa2, 0xd2, 0x94, 0x1b, 0xa6, 0xb8, 0x24, 0xe1, 0xb6, - 0xfb, 0x89, 0x36, 0x09, 0x5b, 0xf8, 0x5a, 0x8f, 0x4e, 0xbe, 0x5c, 0x46, 0xc1, 0xc5, 0x65, 0x14, - 0x7c, 0xbb, 0x8c, 0x82, 0x0f, 0x57, 0x51, 0xe5, 0xe2, 0x2a, 0xaa, 0x7c, 0xbd, 0x8a, 0x2a, 0xaf, - 0x6f, 0xa7, 0xdc, 0xcc, 0x57, 0xd3, 0x11, 0x53, 0xc2, 0x3d, 0x6a, 0x77, 0x7e, 0xfb, 0xbe, 0x4d, - 0x1b, 0xee, 0x91, 0xba, 0xff, 0x23, 0x00, 0x00, 0xff, 0xff, 0x15, 0x2a, 0x93, 0x8e, 0x07, 0x05, - 0x00, 0x00, + // 704 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x54, 0x3d, 0x8f, 0x2b, 0x35, + 0x14, 0xcd, 0x4c, 0xbe, 0xef, 0x64, 0xb3, 0xc6, 0x6f, 0x8b, 0xe1, 0x49, 0x0c, 0x0b, 0x05, 0x0a, + 0x11, 0x24, 0x02, 0x4a, 0x1a, 0x44, 0xc4, 0x7b, 0x02, 0x89, 0x57, 0x0c, 0xab, 0x15, 0xd0, 0x8c, + 0x3c, 0xce, 0x65, 0x62, 0x25, 0x1e, 0x8f, 0xc6, 0x4e, 0x76, 0xc3, 0xaf, 0xe0, 0x47, 0x50, 0xf0, + 0x53, 0x28, 0xb7, 0xa4, 0x44, 0xbb, 0x05, 0x25, 0x7f, 0x01, 0xd9, 0xf3, 0x91, 0xa5, 0x80, 0xdd, + 0x2a, 0xd7, 0x67, 0xce, 0x39, 0xf7, 0xd8, 0xbe, 0x31, 0xcc, 0x7f, 0x46, 0xc3, 0xf8, 0x86, 0x89, + 0x7c, 0xe9, 0x2a, 0x55, 0xe2, 0xb2, 0xd8, 0x66, 0x4b, 0x07, 0xe9, 0xfa, 0x67, 0x51, 0x94, 0xca, + 0x28, 0xfa, 0x4e, 0xcb, 0x5d, 0x34, 0xdc, 0x45, 0xb1, 0xcd, 0x16, 0x15, 0xe9, 0xe5, 0x45, 0xa6, + 0x32, 0xe5, 0x98, 0x4b, 0x5b, 0x55, 0xa2, 0xf7, 0xff, 0xea, 0x42, 0x7f, 0x65, 0x09, 0xf4, 0x6d, + 0x18, 0x39, 0x66, 0x22, 0xd6, 0xa1, 0x7f, 0xe9, 0xcd, 0xba, 0xf1, 0xd0, 0xad, 0xbf, 0x5e, 0xd3, + 0xd7, 0x00, 0xd5, 0xa7, 0x9c, 0x49, 0x0c, 0xbd, 0x4b, 0x6f, 0x36, 0xfd, 0x74, 0xb6, 0xf8, 0xdf, + 0x76, 0x0b, 0x67, 0xfa, 0x86, 0x49, 0x8c, 0xc7, 0xbc, 0x29, 0xe9, 0x17, 0x30, 0xcc, 0xd1, 0xdc, + 0xa8, 0x72, 0x1b, 0x76, 0x9d, 0xcb, 0x07, 0x4f, 0xb8, 0xbc, 0xa9, 0xd8, 0x71, 0x23, 0xa3, 0xdf, + 0xc2, 0xa4, 0x2e, 0x13, 0x73, 0x2c, 0x30, 0xec, 0x39, 0x9b, 0xf9, 0xf3, 0x6c, 0xae, 0x8e, 0x05, + 0xc6, 0x41, 0x7e, 0x5a, 0xd0, 0x4f, 0xc0, 0x3f, 0xc8, 0xb0, 0xef, 0x4c, 0xde, 0x7b, 0xc2, 0xe4, + 0x5a, 0xc6, 0xfe, 0x41, 0xd2, 0x57, 0x30, 0xe6, 0x2a, 0xd7, 0x98, 0xeb, 0xbd, 0x0e, 0x07, 0xcf, + 0x3b, 0x8b, 0x86, 0x1f, 0x9f, 0xa4, 0xf4, 0x5d, 0x08, 0x84, 0x4e, 0xf0, 0xd6, 0x60, 0x99, 0xb3, + 0x5d, 0x38, 0xbc, 0xf4, 0x66, 0xa3, 0x18, 0x84, 0xfe, 0xaa, 0x46, 0xec, 0x56, 0x39, 0x37, 0xb7, + 0x49, 0xc6, 0x0c, 0xde, 0xb0, 0x63, 0x38, 0x7a, 0xd6, 0x56, 0x57, 0xab, 0xab, 0xef, 0x5f, 0x57, + 0x8a, 0x38, 0xb0, 0xfa, 0x7a, 0x31, 0xff, 0x1c, 0xce, 0x62, 0xe4, 0x28, 0x0e, 0xf8, 0x9d, 0x61, + 0x66, 0xaf, 0x69, 0x00, 0x43, 0x5e, 0x22, 0x33, 0xb8, 0x26, 0x1d, 0xbb, 0xd0, 0x7b, 0xce, 0x51, + 0x6b, 0xe2, 0x51, 0x80, 0xc1, 0x4f, 0x4c, 0xec, 0x70, 0x4d, 0xfc, 0x97, 0xbd, 0xdf, 0x7e, 0x8d, + 0xbc, 0xf9, 0xdf, 0x3e, 0x8c, 0xdb, 0x1b, 0xa5, 0x63, 0xe8, 0xa3, 0x2c, 0xcc, 0x91, 0x74, 0xe8, + 0x39, 0x04, 0x68, 0x36, 0x89, 0x64, 0x22, 0xcf, 0xd1, 0x10, 0x8f, 0x12, 0x98, 0xd8, 0x58, 0x2d, + 0xe2, 0x5b, 0x4a, 0x6a, 0x78, 0x0b, 0x74, 0xe9, 0x0b, 0x38, 0x2f, 0xd4, 0xee, 0x98, 0xa9, 0xbc, + 0x05, 0x7b, 0x8e, 0xa5, 0x4f, 0xac, 0x3e, 0xa5, 0x30, 0xcd, 0x14, 0x96, 0x3b, 0x91, 0x18, 0xd4, + 0xc6, 0x62, 0x03, 0x8b, 0xc9, 0xbd, 0x4c, 0xd9, 0x09, 0x1b, 0x36, 0xc2, 0x06, 0x80, 0x36, 0x41, + 0x83, 0x04, 0x4d, 0x82, 0x06, 0x98, 0xd8, 0x04, 0x1a, 0x0b, 0xb5, 0x13, 0x27, 0xd6, 0x99, 0x05, + 0xeb, 0x86, 0x3b, 0xc5, 0xd9, 0xce, 0x82, 0xd3, 0x46, 0x5a, 0x62, 0x66, 0x89, 0xe4, 0xdc, 0xba, + 0x33, 0xa9, 0x8e, 0xad, 0x8e, 0xd0, 0x0b, 0x20, 0xaa, 0x30, 0x42, 0x0a, 0x2d, 0xdb, 0xf8, 0x6f, + 0xfd, 0x0b, 0xad, 0x7b, 0x11, 0x6a, 0xd5, 0x29, 0xd3, 0xd8, 0xf2, 0x5e, 0xb4, 0x48, 0xc3, 0xb9, + 0xa8, 0x4f, 0xfc, 0x07, 0x18, 0xd6, 0x53, 0x4b, 0x87, 0xd0, 0x45, 0xb3, 0x21, 0x1d, 0x3a, 0x82, + 0x9e, 0xdd, 0x19, 0xf1, 0x2c, 0x94, 0x1a, 0x4e, 0x7c, 0x7b, 0x6f, 0xf5, 0x59, 0x92, 0xae, 0x43, + 0x35, 0x27, 0x3d, 0x3a, 0x81, 0x51, 0xd3, 0x9c, 0xf4, 0xad, 0xcc, 0xb6, 0x20, 0x83, 0xda, 0xfa, + 0x15, 0x04, 0x8f, 0xfe, 0x10, 0xd6, 0xa2, 0x89, 0xe3, 0xe6, 0xa0, 0xd9, 0x99, 0xe7, 0xcc, 0x4b, + 0x71, 0xa8, 0xae, 0x11, 0x60, 0xb0, 0x46, 0x57, 0x77, 0x6b, 0x9f, 0x08, 0xfc, 0x6b, 0x69, 0x87, + 0x21, 0x57, 0xc9, 0x41, 0x92, 0x8e, 0x0b, 0x7a, 0x90, 0xc4, 0xab, 0xbf, 0x7f, 0x03, 0xe3, 0x76, + 0xf2, 0x6d, 0x24, 0x34, 0x1b, 0x2c, 0x71, 0x6f, 0x99, 0x53, 0x00, 0x83, 0xf9, 0x1a, 0x4b, 0x29, + 0xf2, 0xba, 0x53, 0x2a, 0x0c, 0x57, 0x22, 0x27, 0x7e, 0x95, 0x3e, 0xd1, 0x86, 0xf1, 0x6d, 0xdb, + 0xeb, 0x23, 0x08, 0x1e, 0x4d, 0x76, 0x75, 0x12, 0xae, 0xe7, 0x19, 0x8c, 0x55, 0xaa, 0xb1, 0x3c, + 0x60, 0xa9, 0x9b, 0xce, 0x5f, 0xae, 0x7e, 0xbf, 0x8f, 0xbc, 0xbb, 0xfb, 0xc8, 0xfb, 0xf3, 0x3e, + 0xf2, 0x7e, 0x79, 0x88, 0x3a, 0x77, 0x0f, 0x51, 0xe7, 0x8f, 0x87, 0xa8, 0xf3, 0xe3, 0x87, 0x99, + 0x30, 0x9b, 0x7d, 0xba, 0xe0, 0x4a, 0xba, 0x17, 0xf5, 0xe3, 0xff, 0x7c, 0x5c, 0xd3, 0x81, 0x7b, + 0x21, 0x3f, 0xfb, 0x27, 0x00, 0x00, 0xff, 0xff, 0x05, 0xa7, 0x7f, 0x40, 0x84, 0x05, 0x00, 0x00, } func (m *Chain) Marshal() (dAtA []byte, err error) { @@ -450,6 +492,11 @@ func (m *Chain) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l + if m.CctxGateway != 0 { + i = encodeVarintChains(dAtA, i, uint64(m.CctxGateway)) + i-- + dAtA[i] = 0x40 + } if m.IsExternal { i-- if m.IsExternal { @@ -531,6 +578,9 @@ func (m *Chain) Size() (n int) { if m.IsExternal { n += 2 } + if m.CctxGateway != 0 { + n += 1 + sovChains(uint64(m.CctxGateway)) + } return n } @@ -703,6 +753,25 @@ func (m *Chain) Unmarshal(dAtA []byte) error { } } m.IsExternal = bool(v != 0) + case 8: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field CctxGateway", wireType) + } + m.CctxGateway = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowChains + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.CctxGateway |= CCTXGateway(b&0x7F) << shift + if b < 0x80 { + break + } + } default: iNdEx = preIndex skippy, err := skipChains(dAtA[iNdEx:]) diff --git a/proto/zetachain/zetacore/pkg/chains/chains.proto b/proto/zetachain/zetacore/pkg/chains/chains.proto index 1f2279af35..8075822471 100644 --- a/proto/zetachain/zetacore/pkg/chains/chains.proto +++ b/proto/zetachain/zetacore/pkg/chains/chains.proto @@ -88,6 +88,19 @@ enum Consensus { op_stack = 3; } +// CCTXGateway describes for the chain the gateway used to handle CCTX outbounds +enum CCTXGateway { + option (gogoproto.goproto_enum_stringer) = true; + + // zevm is the internal CCTX gateway to process outbound on the ZEVM and read + // inbound events from the ZEVM only used for ZetaChain chains + zevm = 0; + + // observers is the CCTX gateway for chains relying on the observer set to + // observe inbounds and TSS for outbounds + observers = 1; +} + // Chain represents static data about a blockchain network // it is identified by a unique chain ID message Chain { @@ -111,4 +124,7 @@ message Chain { // IsExternal describe if the chain is ZetaChain or external bool is_external = 7; + + // CCTXGateway is the gateway used to handle CCTX outbounds + CCTXGateway cctx_gateway = 8; } diff --git a/typescript/zetachain/zetacore/pkg/chains/chains_pb.d.ts b/typescript/zetachain/zetacore/pkg/chains/chains_pb.d.ts index 6abe26cd04..782e669d43 100644 --- a/typescript/zetachain/zetacore/pkg/chains/chains_pb.d.ts +++ b/typescript/zetachain/zetacore/pkg/chains/chains_pb.d.ts @@ -253,6 +253,29 @@ export declare enum Consensus { op_stack = 3, } +/** + * CCTXGateway describes for the chain the gateway used to handle CCTX outbounds + * + * @generated from enum zetachain.zetacore.pkg.chains.CCTXGateway + */ +export declare enum CCTXGateway { + /** + * zevm is the internal CCTX gateway to process outbound on the ZEVM and read + * inbound events from the ZEVM only used for ZetaChain chains + * + * @generated from enum value: zevm = 0; + */ + zevm = 0, + + /** + * observers is the CCTX gateway for chains relying on the observer set to + * observe inbounds and TSS for outbounds + * + * @generated from enum value: observers = 1; + */ + observers = 1, +} + /** * Chain represents static data about a blockchain network * it is identified by a unique chain ID @@ -309,6 +332,13 @@ export declare class Chain extends Message { */ isExternal: boolean; + /** + * CCTXGateway is the gateway used to handle CCTX outbounds + * + * @generated from field: zetachain.zetacore.pkg.chains.CCTXGateway cctx_gateway = 8; + */ + cctxGateway: CCTXGateway; + constructor(data?: PartialMessage); static readonly runtime: typeof proto3; diff --git a/zetaclient/zetacore/tx_test.go b/zetaclient/zetacore/tx_test.go index f12fcc8b6a..919f9cc058 100644 --- a/zetaclient/zetacore/tx_test.go +++ b/zetaclient/zetacore/tx_test.go @@ -247,7 +247,6 @@ func TestZetacore_UpdateZetacoreContext(t *testing.T) { WithPayload(observertypes.QuerySupportedChains{}). Return(observertypes.QuerySupportedChainsResponse{ Chains: []*chains.Chain{ - { chains.BitcoinMainnet.ChainId, chains.BitcoinMainnet.ChainName, @@ -256,6 +255,7 @@ func TestZetacore_UpdateZetacoreContext(t *testing.T) { chains.BscMainnet.Vm, chains.BscMainnet.Consensus, chains.BscMainnet.IsExternal, + chains.BscMainnet.CctxGateway, }, { chains.Ethereum.ChainId, @@ -265,6 +265,7 @@ func TestZetacore_UpdateZetacoreContext(t *testing.T) { chains.Ethereum.Vm, chains.Ethereum.Consensus, chains.Ethereum.IsExternal, + chains.Ethereum.CctxGateway, }, }, }) From 85861bea3c614c3acb6c85b3077b40f55545db3b Mon Sep 17 00:00:00 2001 From: Tanmay Date: Wed, 29 May 2024 13:20:01 -0400 Subject: [PATCH 5/5] refactor: MsgUpdateCrosschainFlags into MsgEnableCCTXFlags, MsgDisableCCTXFlags and MsgUpdateGasPriceIncreaseFlags (#2269) --- changelog.md | 2 + docs/cli/zetacored/zetacored_tx_observer.md | 4 +- ... => zetacored_tx_observer_disable-cctx.md} | 8 +- .../zetacored_tx_observer_enable-cctx.md | 53 + ...bserver_update-gas-price-increase-flags.md | 53 + docs/openapi/openapi.swagger.yaml | 6 +- docs/releases/v17_breaking_changes.md | 7 + docs/spec/observer/messages.md | 54 +- .../zetachain/zetacore/observer/events.proto | 15 +- proto/zetachain/zetacore/observer/tx.proto | 39 +- testutil/sample/observer.go | 9 + .../zetacore/observer/events_pb.d.ts | 77 +- .../zetachain/zetacore/observer/tx_pb.d.ts | 214 +- x/observer/client/cli/tx.go | 4 +- .../client/cli/tx_disable_cctx_flags.go | 44 + ...ssion_flags.go => tx_enable_cctx_flags.go} | 22 +- .../cli/tx_update_gas_price_increase_flags.go | 67 + .../keeper/msg_server_disable_cctx_flags.go | 55 + .../msg_server_disable_cctx_flags_test.go | 152 + .../keeper/msg_server_enable_cctx_flags.go | 55 + .../msg_server_enable_cctx_flags_test.go | 152 + .../msg_server_update_crosschain_flags.go | 55 - ...msg_server_update_crosschain_flags_test.go | 165 -- ..._server_update_gas_price_increase_flags.go | 54 + ...er_update_gas_price_increase_flags_test.go | 116 + x/observer/types/codec.go | 8 +- x/observer/types/events.pb.go | 576 +++- .../types/message_disable_cctx_flags.go | 55 + .../types/message_disable_cctx_flags_test.go | 104 + x/observer/types/message_enable_cctx_flags.go | 55 + .../types/message_enable_cctx_flags_test.go | 104 + .../types/message_update_crosschain_flags.go | 86 - .../message_update_crosschain_flags_test.go | 246 -- ...message_update_gas_price_increase_flags.go | 64 + ...ge_update_gas_price_increase_flags_test.go | 164 ++ x/observer/types/tx.pb.go | 2540 +++++++++++------ 36 files changed, 3804 insertions(+), 1680 deletions(-) rename docs/cli/zetacored/{zetacored_tx_observer_update-crosschain-flags.md => zetacored_tx_observer_disable-cctx.md} (93%) create mode 100644 docs/cli/zetacored/zetacored_tx_observer_enable-cctx.md create mode 100644 docs/cli/zetacored/zetacored_tx_observer_update-gas-price-increase-flags.md create mode 100644 x/observer/client/cli/tx_disable_cctx_flags.go rename x/observer/client/cli/{tx_permission_flags.go => tx_enable_cctx_flags.go} (60%) create mode 100644 x/observer/client/cli/tx_update_gas_price_increase_flags.go create mode 100644 x/observer/keeper/msg_server_disable_cctx_flags.go create mode 100644 x/observer/keeper/msg_server_disable_cctx_flags_test.go create mode 100644 x/observer/keeper/msg_server_enable_cctx_flags.go create mode 100644 x/observer/keeper/msg_server_enable_cctx_flags_test.go delete mode 100644 x/observer/keeper/msg_server_update_crosschain_flags.go delete mode 100644 x/observer/keeper/msg_server_update_crosschain_flags_test.go create mode 100644 x/observer/keeper/msg_server_update_gas_price_increase_flags.go create mode 100644 x/observer/keeper/msg_server_update_gas_price_increase_flags_test.go create mode 100644 x/observer/types/message_disable_cctx_flags.go create mode 100644 x/observer/types/message_disable_cctx_flags_test.go create mode 100644 x/observer/types/message_enable_cctx_flags.go create mode 100644 x/observer/types/message_enable_cctx_flags_test.go delete mode 100644 x/observer/types/message_update_crosschain_flags.go delete mode 100644 x/observer/types/message_update_crosschain_flags_test.go create mode 100644 x/observer/types/message_update_gas_price_increase_flags.go create mode 100644 x/observer/types/message_update_gas_price_increase_flags_test.go diff --git a/changelog.md b/changelog.md index a2fdd6c26c..584d3c2409 100644 --- a/changelog.md +++ b/changelog.md @@ -33,6 +33,8 @@ * [2205](https://github.com/zeta-chain/node/pull/2205) - remove deprecated variables pre-v17 * [2226](https://github.com/zeta-chain/node/pull/2226) - improve Go formatting with imports standardization and max line length to 120 * [2262](https://github.com/zeta-chain/node/pull/2262) - refactor MsgUpdateZRC20 into MsgPauseZrc20 and MsgUnPauseZRC20 +* [2269](https://github.com/zeta-chain/node/pull/2269) - refactor MsgUpdateCrosschainFlags into MsgEnableCCTX, MsgDisableCCTX and MsgUpdateGasPriceIncreaseFlags + ### Tests diff --git a/docs/cli/zetacored/zetacored_tx_observer.md b/docs/cli/zetacored/zetacored_tx_observer.md index 1e5d002136..25711bd3f6 100644 --- a/docs/cli/zetacored/zetacored_tx_observer.md +++ b/docs/cli/zetacored/zetacored_tx_observer.md @@ -28,11 +28,13 @@ zetacored tx observer [flags] * [zetacored tx](zetacored_tx.md) - Transactions subcommands * [zetacored tx observer add-blame-vote](zetacored_tx_observer_add-blame-vote.md) - Broadcast message add-blame-vote * [zetacored tx observer add-observer](zetacored_tx_observer_add-observer.md) - Broadcast message add-observer +* [zetacored tx observer disable-cctx](zetacored_tx_observer_disable-cctx.md) - Disable inbound and outbound for CCTX +* [zetacored tx observer enable-cctx](zetacored_tx_observer_enable-cctx.md) - Enable inbound and outbound for CCTX * [zetacored tx observer encode](zetacored_tx_observer_encode.md) - Encode a json string into hex * [zetacored tx observer remove-chain-params](zetacored_tx_observer_remove-chain-params.md) - Broadcast message to remove chain params * [zetacored tx observer reset-chain-nonces](zetacored_tx_observer_reset-chain-nonces.md) - Broadcast message to reset chain nonces * [zetacored tx observer update-chain-params](zetacored_tx_observer_update-chain-params.md) - Broadcast message updateChainParams -* [zetacored tx observer update-crosschain-flags](zetacored_tx_observer_update-crosschain-flags.md) - Update crosschain flags +* [zetacored tx observer update-gas-price-increase-flags](zetacored_tx_observer_update-gas-price-increase-flags.md) - Update the gas price increase flags * [zetacored tx observer update-keygen](zetacored_tx_observer_update-keygen.md) - command to update the keygen block via a group proposal * [zetacored tx observer update-observer](zetacored_tx_observer_update-observer.md) - Broadcast message add-observer * [zetacored tx observer vote-tss](zetacored_tx_observer_vote-tss.md) - Vote for a new TSS creation diff --git a/docs/cli/zetacored/zetacored_tx_observer_update-crosschain-flags.md b/docs/cli/zetacored/zetacored_tx_observer_disable-cctx.md similarity index 93% rename from docs/cli/zetacored/zetacored_tx_observer_update-crosschain-flags.md rename to docs/cli/zetacored/zetacored_tx_observer_disable-cctx.md index b3be9ad4b7..a423cee3b7 100644 --- a/docs/cli/zetacored/zetacored_tx_observer_update-crosschain-flags.md +++ b/docs/cli/zetacored/zetacored_tx_observer_disable-cctx.md @@ -1,9 +1,9 @@ -# tx observer update-crosschain-flags +# tx observer disable-cctx -Update crosschain flags +Disable inbound and outbound for CCTX ``` -zetacored tx observer update-crosschain-flags [is-inbound-enabled] [is-outbound-enabled] [flags] +zetacored tx observer disable-cctx [disable-inbound] [disable-outbound] [flags] ``` ### Options @@ -22,7 +22,7 @@ zetacored tx observer update-crosschain-flags [is-inbound-enabled] [is-outbound- --gas-adjustment float adjustment factor to be multiplied against the estimate returned by the tx simulation; if the gas limit is set manually this flag is ignored (default 1) --gas-prices string Gas prices in decimal format to determine the transaction fee (e.g. 0.1uatom) --generate-only Build an unsigned transaction and write it to STDOUT (when enabled, the local Keybase only accessed when providing a key name) - -h, --help help for update-crosschain-flags + -h, --help help for disable-cctx --keyring-backend string Select keyring's backend (os|file|kwallet|pass|test|memory) --keyring-dir string The client Keyring directory; if omitted, the default 'home' directory will be used --ledger Use a connected Ledger device diff --git a/docs/cli/zetacored/zetacored_tx_observer_enable-cctx.md b/docs/cli/zetacored/zetacored_tx_observer_enable-cctx.md new file mode 100644 index 0000000000..59a37e5b95 --- /dev/null +++ b/docs/cli/zetacored/zetacored_tx_observer_enable-cctx.md @@ -0,0 +1,53 @@ +# tx observer enable-cctx + +Enable inbound and outbound for CCTX + +``` +zetacored tx observer enable-cctx [enable-inbound] [enable-outbound] [flags] +``` + +### Options + +``` + -a, --account-number uint The account number of the signing account (offline mode only) + --aux Generate aux signer data instead of sending a tx + -b, --broadcast-mode string Transaction broadcasting mode (sync|async) + --chain-id string The network chain ID + --dry-run ignore the --gas flag and perform a simulation of a transaction, but don't broadcast it (when enabled, the local Keybase is not accessible) + --fee-granter string Fee granter grants fees for the transaction + --fee-payer string Fee payer pays fees for the transaction instead of deducting from the signer + --fees string Fees to pay along with transaction; eg: 10uatom + --from string Name or address of private key with which to sign + --gas string gas limit to set per-transaction; set to "auto" to calculate sufficient gas automatically. Note: "auto" option doesn't always report accurate results. Set a valid coin value to adjust the result. Can be used instead of "fees". (default 200000) + --gas-adjustment float adjustment factor to be multiplied against the estimate returned by the tx simulation; if the gas limit is set manually this flag is ignored (default 1) + --gas-prices string Gas prices in decimal format to determine the transaction fee (e.g. 0.1uatom) + --generate-only Build an unsigned transaction and write it to STDOUT (when enabled, the local Keybase only accessed when providing a key name) + -h, --help help for enable-cctx + --keyring-backend string Select keyring's backend (os|file|kwallet|pass|test|memory) + --keyring-dir string The client Keyring directory; if omitted, the default 'home' directory will be used + --ledger Use a connected Ledger device + --node string [host]:[port] to tendermint rpc interface for this chain + --note string Note to add a description to the transaction (previously --memo) + --offline Offline mode (does not allow any online functionality) + -o, --output string Output format (text|json) + -s, --sequence uint The sequence number of the signing account (offline mode only) + --sign-mode string Choose sign mode (direct|amino-json|direct-aux), this is an advanced feature + --timeout-height uint Set a block timeout height to prevent the tx from being committed past a certain height + --tip string Tip is the amount that is going to be transferred to the fee payer on the target chain. This flag is only valid when used with --aux, and is ignored if the target chain didn't enable the TipDecorator + -y, --yes Skip tx broadcasting prompt confirmation +``` + +### Options inherited from parent commands + +``` + --home string directory for config and data + --log_format string The logging format (json|plain) + --log_level string The logging level (trace|debug|info|warn|error|fatal|panic) + --log_no_color Disable colored logs + --trace print out full stack trace on errors +``` + +### SEE ALSO + +* [zetacored tx observer](zetacored_tx_observer.md) - observer transactions subcommands + diff --git a/docs/cli/zetacored/zetacored_tx_observer_update-gas-price-increase-flags.md b/docs/cli/zetacored/zetacored_tx_observer_update-gas-price-increase-flags.md new file mode 100644 index 0000000000..8268638c44 --- /dev/null +++ b/docs/cli/zetacored/zetacored_tx_observer_update-gas-price-increase-flags.md @@ -0,0 +1,53 @@ +# tx observer update-gas-price-increase-flags + +Update the gas price increase flags + +``` +zetacored tx observer update-gas-price-increase-flags [epochLength] [retryInterval] [gasPriceIncreasePercent] [gasPriceIncreaseMax] [maxPendingCctxs] [flags] +``` + +### Options + +``` + -a, --account-number uint The account number of the signing account (offline mode only) + --aux Generate aux signer data instead of sending a tx + -b, --broadcast-mode string Transaction broadcasting mode (sync|async) + --chain-id string The network chain ID + --dry-run ignore the --gas flag and perform a simulation of a transaction, but don't broadcast it (when enabled, the local Keybase is not accessible) + --fee-granter string Fee granter grants fees for the transaction + --fee-payer string Fee payer pays fees for the transaction instead of deducting from the signer + --fees string Fees to pay along with transaction; eg: 10uatom + --from string Name or address of private key with which to sign + --gas string gas limit to set per-transaction; set to "auto" to calculate sufficient gas automatically. Note: "auto" option doesn't always report accurate results. Set a valid coin value to adjust the result. Can be used instead of "fees". (default 200000) + --gas-adjustment float adjustment factor to be multiplied against the estimate returned by the tx simulation; if the gas limit is set manually this flag is ignored (default 1) + --gas-prices string Gas prices in decimal format to determine the transaction fee (e.g. 0.1uatom) + --generate-only Build an unsigned transaction and write it to STDOUT (when enabled, the local Keybase only accessed when providing a key name) + -h, --help help for update-gas-price-increase-flags + --keyring-backend string Select keyring's backend (os|file|kwallet|pass|test|memory) + --keyring-dir string The client Keyring directory; if omitted, the default 'home' directory will be used + --ledger Use a connected Ledger device + --node string [host]:[port] to tendermint rpc interface for this chain + --note string Note to add a description to the transaction (previously --memo) + --offline Offline mode (does not allow any online functionality) + -o, --output string Output format (text|json) + -s, --sequence uint The sequence number of the signing account (offline mode only) + --sign-mode string Choose sign mode (direct|amino-json|direct-aux), this is an advanced feature + --timeout-height uint Set a block timeout height to prevent the tx from being committed past a certain height + --tip string Tip is the amount that is going to be transferred to the fee payer on the target chain. This flag is only valid when used with --aux, and is ignored if the target chain didn't enable the TipDecorator + -y, --yes Skip tx broadcasting prompt confirmation +``` + +### Options inherited from parent commands + +``` + --home string directory for config and data + --log_format string The logging format (json|plain) + --log_level string The logging level (trace|debug|info|warn|error|fatal|panic) + --log_no_color Disable colored logs + --trace print out full stack trace on errors +``` + +### SEE ALSO + +* [zetacored tx observer](zetacored_tx_observer.md) - observer transactions subcommands + diff --git a/docs/openapi/openapi.swagger.yaml b/docs/openapi/openapi.swagger.yaml index 9c0dbc1e10..112be45c71 100644 --- a/docs/openapi/openapi.swagger.yaml +++ b/docs/openapi/openapi.swagger.yaml @@ -57750,13 +57750,17 @@ definitions: type: object observerMsgAddObserverResponse: type: object + observerMsgDisableCCTXResponse: + type: object + observerMsgEnableCCTXResponse: + type: object observerMsgRemoveChainParamsResponse: type: object observerMsgResetChainNoncesResponse: type: object observerMsgUpdateChainParamsResponse: type: object - observerMsgUpdateCrosschainFlagsResponse: + observerMsgUpdateGasPriceIncreaseFlagsResponse: type: object observerMsgUpdateKeygenResponse: type: object diff --git a/docs/releases/v17_breaking_changes.md b/docs/releases/v17_breaking_changes.md index 13dc5df873..61d5c23921 100644 --- a/docs/releases/v17_breaking_changes.md +++ b/docs/releases/v17_breaking_changes.md @@ -7,6 +7,13 @@ * `MsgEnableHeaderVerification` message enables block header verification for a list of chains and can be triggered via `PolicyType_groupOperational` * `MsgDisableHeaderVerification` message disables block header verification for a list of chains and can be triggered via `PolicyType_emergency` +### Crosschain Flags update + +* `MsgUpdateCrosschainFlags` has been removed,and replaced with `MsgEnableCCTX`, `MsgDisableCCTX` and `MsgUpdateGasPriceIncreaseFlags` messages. + * `MsgEnableCCTX` message enables either the IsInboundEnabled flag,or the IsOutboundEnabled flag or both `PolicyType_groupOperational` + * `MsgDisableCCTX` message disables either the IsInboundEnabled flag,or the IsOutboundEnabled flag or both `PolicyType_emergency` + * `MsgUpdateGasPriceIncreaseFlags` message updates the gas price increase flags and can be triggered via `PolicyType_groupOperational` + ### `BallotMaturityBlocks` moved to `emissions` module * Observer param `ballot_maturity_blocks` is part of `emissions` module now. Observer `params` are deprecated and removed from `observer` module. diff --git a/docs/spec/observer/messages.md b/docs/spec/observer/messages.md index 2f7b25d91e..48e0b76de0 100644 --- a/docs/spec/observer/messages.md +++ b/docs/spec/observer/messages.md @@ -63,22 +63,6 @@ message MsgAddBlameVote { } ``` -## MsgUpdateCrosschainFlags - -UpdateCrosschainFlags updates the crosschain related flags. - -Aurthorized: admin policy group 1 (except enabling/disabled -inbounds/outbounds and gas price increase), admin policy group 2 (all). - -```proto -message MsgUpdateCrosschainFlags { - string creator = 1; - bool isInboundEnabled = 3; - bool isOutboundEnabled = 4; - GasPriceIncreaseFlags gasPriceIncreaseFlags = 5; -} -``` - ## MsgUpdateKeygen UpdateKeygen updates the block height of the keygen and sets the status to @@ -142,3 +126,41 @@ message MsgVoteTSS { } ``` +## MsgEnableCCTX + +EnableCCTX enables the IsInboundEnabled and IsOutboundEnabled flags.These flags control the creation of inbounds and outbounds. +The flags are enabled by the policy account with the groupOperational policy type. + +```proto +message MsgEnableCCTX { + string creator = 1; + bool enableInbound = 2; + bool enableOutbound = 3; +} +``` + +## MsgDisableCCTX + +DisableCCTX disables the IsInboundEnabled and IsOutboundEnabled flags. These flags control the creation of inbounds and outbounds. +The flags are disabled by the policy account with the groupEmergency policy type. + +```proto +message MsgDisableCCTX { + string creator = 1; + bool disableInbound = 2; + bool disableOutbound = 3; +} +``` + +## MsgUpdateGasPriceIncreaseFlags + +UpdateGasPriceIncreaseFlags updates the GasPriceIncreaseFlags. These flags control the increase of gas prices. +The flags are updated by the policy account with the groupOperational policy type. + +```proto +message MsgUpdateGasPriceIncreaseFlags { + string creator = 1; + GasPriceIncreaseFlags gasPriceIncreaseFlags = 2; +} +``` + diff --git a/proto/zetachain/zetacore/observer/events.proto b/proto/zetachain/zetacore/observer/events.proto index 4d752a4ce5..a939daafa1 100644 --- a/proto/zetachain/zetacore/observer/events.proto +++ b/proto/zetachain/zetacore/observer/events.proto @@ -29,10 +29,19 @@ message EventNewObserverAdded { uint64 observer_last_block_count = 5; } -message EventCrosschainFlagsUpdated { +message EventCCTXDisabled { string msg_type_url = 1; bool isInboundEnabled = 2; bool isOutboundEnabled = 3; - GasPriceIncreaseFlags gasPriceIncreaseFlags = 4; - string signer = 5; } + +message EventCCTXEnabled { + string msg_type_url = 1; + bool isInboundEnabled = 2; + bool isOutboundEnabled = 3; +} + +message EventGasPriceIncreaseFlagsUpdated { + string msg_type_url = 1; + GasPriceIncreaseFlags gasPriceIncreaseFlags = 2; +} \ No newline at end of file diff --git a/proto/zetachain/zetacore/observer/tx.proto b/proto/zetachain/zetacore/observer/tx.proto index 7316317fd4..a3a70c6c65 100644 --- a/proto/zetachain/zetacore/observer/tx.proto +++ b/proto/zetachain/zetacore/observer/tx.proto @@ -22,13 +22,15 @@ service Msg { rpc RemoveChainParams(MsgRemoveChainParams) returns (MsgRemoveChainParamsResponse); rpc AddBlameVote(MsgAddBlameVote) returns (MsgAddBlameVoteResponse); - rpc UpdateCrosschainFlags(MsgUpdateCrosschainFlags) - returns (MsgUpdateCrosschainFlagsResponse); rpc UpdateKeygen(MsgUpdateKeygen) returns (MsgUpdateKeygenResponse); rpc VoteBlockHeader(MsgVoteBlockHeader) returns (MsgVoteBlockHeaderResponse); rpc ResetChainNonces(MsgResetChainNonces) returns (MsgResetChainNoncesResponse); rpc VoteTSS(MsgVoteTSS) returns (MsgVoteTSSResponse); + rpc EnableCCTX(MsgEnableCCTX) returns (MsgEnableCCTXResponse); + rpc DisableCCTX(MsgDisableCCTX) returns (MsgDisableCCTXResponse); + rpc UpdateGasPriceIncreaseFlags(MsgUpdateGasPriceIncreaseFlags) + returns (MsgUpdateGasPriceIncreaseFlagsResponse); } message MsgUpdateObserver { @@ -83,15 +85,6 @@ message MsgAddBlameVote { message MsgAddBlameVoteResponse {} -message MsgUpdateCrosschainFlags { - string creator = 1; - bool isInboundEnabled = 3; - bool isOutboundEnabled = 4; - GasPriceIncreaseFlags gasPriceIncreaseFlags = 5; -} - -message MsgUpdateCrosschainFlagsResponse {} - message MsgUpdateKeygen { string creator = 1; int64 block = 2; @@ -120,3 +113,27 @@ message MsgVoteTSSResponse { bool vote_finalized = 2; bool keygen_success = 3; } + +message MsgEnableCCTX { + string creator = 1; + bool enableInbound = 2; + bool enableOutbound = 3; +} + +message MsgEnableCCTXResponse {} + +message MsgDisableCCTX { + string creator = 1; + bool disableInbound = 2; + bool disableOutbound = 3; +} + +message MsgDisableCCTXResponse {} + +message MsgUpdateGasPriceIncreaseFlags { + string creator = 1; + GasPriceIncreaseFlags gasPriceIncreaseFlags = 2 + [ (gogoproto.nullable) = false ]; +} + +message MsgUpdateGasPriceIncreaseFlagsResponse {} \ No newline at end of file diff --git a/testutil/sample/observer.go b/testutil/sample/observer.go index 4e3096fc8b..a67636642e 100644 --- a/testutil/sample/observer.go +++ b/testutil/sample/observer.go @@ -255,3 +255,12 @@ func NonceToCCTX(t *testing.T, seed string) types.NonceToCctx { Tss: Tss().TssPubkey, } } + +func GasPriceIncreaseFlags() types.GasPriceIncreaseFlags { + return types.GasPriceIncreaseFlags{ + EpochLength: 1, + RetryInterval: 1, + GasPriceIncreasePercent: 1, + MaxPendingCctxs: 100, + } +} diff --git a/typescript/zetachain/zetacore/observer/events_pb.d.ts b/typescript/zetachain/zetacore/observer/events_pb.d.ts index 122ff3672e..5139b88e2e 100644 --- a/typescript/zetachain/zetacore/observer/events_pb.d.ts +++ b/typescript/zetachain/zetacore/observer/events_pb.d.ts @@ -130,9 +130,9 @@ export declare class EventNewObserverAdded extends Message { +export declare class EventCCTXDisabled extends Message { /** * @generated from field: string msg_type_url = 1; */ @@ -148,28 +148,81 @@ export declare class EventCrosschainFlagsUpdated extends Message); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.observer.EventCCTXDisabled"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): EventCCTXDisabled; + + static fromJson(jsonValue: JsonValue, options?: Partial): EventCCTXDisabled; + + static fromJsonString(jsonString: string, options?: Partial): EventCCTXDisabled; + + static equals(a: EventCCTXDisabled | PlainMessage | undefined, b: EventCCTXDisabled | PlainMessage | undefined): boolean; +} + +/** + * @generated from message zetachain.zetacore.observer.EventCCTXEnabled + */ +export declare class EventCCTXEnabled extends Message { /** - * @generated from field: zetachain.zetacore.observer.GasPriceIncreaseFlags gasPriceIncreaseFlags = 4; + * @generated from field: string msg_type_url = 1; */ - gasPriceIncreaseFlags?: GasPriceIncreaseFlags; + msgTypeUrl: string; + + /** + * @generated from field: bool isInboundEnabled = 2; + */ + isInboundEnabled: boolean; /** - * @generated from field: string signer = 5; + * @generated from field: bool isOutboundEnabled = 3; */ - signer: string; + isOutboundEnabled: boolean; + + constructor(data?: PartialMessage); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.observer.EventCCTXEnabled"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): EventCCTXEnabled; + + static fromJson(jsonValue: JsonValue, options?: Partial): EventCCTXEnabled; + + static fromJsonString(jsonString: string, options?: Partial): EventCCTXEnabled; + + static equals(a: EventCCTXEnabled | PlainMessage | undefined, b: EventCCTXEnabled | PlainMessage | undefined): boolean; +} + +/** + * @generated from message zetachain.zetacore.observer.EventGasPriceIncreaseFlagsUpdated + */ +export declare class EventGasPriceIncreaseFlagsUpdated extends Message { + /** + * @generated from field: string msg_type_url = 1; + */ + msgTypeUrl: string; + + /** + * @generated from field: zetachain.zetacore.observer.GasPriceIncreaseFlags gasPriceIncreaseFlags = 2; + */ + gasPriceIncreaseFlags?: GasPriceIncreaseFlags; - constructor(data?: PartialMessage); + constructor(data?: PartialMessage); static readonly runtime: typeof proto3; - static readonly typeName = "zetachain.zetacore.observer.EventCrosschainFlagsUpdated"; + static readonly typeName = "zetachain.zetacore.observer.EventGasPriceIncreaseFlagsUpdated"; static readonly fields: FieldList; - static fromBinary(bytes: Uint8Array, options?: Partial): EventCrosschainFlagsUpdated; + static fromBinary(bytes: Uint8Array, options?: Partial): EventGasPriceIncreaseFlagsUpdated; - static fromJson(jsonValue: JsonValue, options?: Partial): EventCrosschainFlagsUpdated; + static fromJson(jsonValue: JsonValue, options?: Partial): EventGasPriceIncreaseFlagsUpdated; - static fromJsonString(jsonString: string, options?: Partial): EventCrosschainFlagsUpdated; + static fromJsonString(jsonString: string, options?: Partial): EventGasPriceIncreaseFlagsUpdated; - static equals(a: EventCrosschainFlagsUpdated | PlainMessage | undefined, b: EventCrosschainFlagsUpdated | PlainMessage | undefined): boolean; + static equals(a: EventGasPriceIncreaseFlagsUpdated | PlainMessage | undefined, b: EventGasPriceIncreaseFlagsUpdated | PlainMessage | undefined): boolean; } diff --git a/typescript/zetachain/zetacore/observer/tx_pb.d.ts b/typescript/zetachain/zetacore/observer/tx_pb.d.ts index 1482e2fd44..4b270f371d 100644 --- a/typescript/zetachain/zetacore/observer/tx_pb.d.ts +++ b/typescript/zetachain/zetacore/observer/tx_pb.d.ts @@ -9,8 +9,8 @@ import type { ObserverUpdateReason } from "./observer_pb.js"; import type { HeaderData } from "../pkg/proofs/proofs_pb.js"; import type { ChainParams } from "./params_pb.js"; import type { Blame } from "./blame_pb.js"; -import type { GasPriceIncreaseFlags } from "./crosschain_flags_pb.js"; import type { ReceiveStatus } from "../pkg/chains/chains_pb.js"; +import type { GasPriceIncreaseFlags } from "./crosschain_flags_pb.js"; /** * @generated from message zetachain.zetacore.observer.MsgUpdateObserver @@ -350,64 +350,6 @@ export declare class MsgAddBlameVoteResponse extends Message | undefined, b: MsgAddBlameVoteResponse | PlainMessage | undefined): boolean; } -/** - * @generated from message zetachain.zetacore.observer.MsgUpdateCrosschainFlags - */ -export declare class MsgUpdateCrosschainFlags extends Message { - /** - * @generated from field: string creator = 1; - */ - creator: string; - - /** - * @generated from field: bool isInboundEnabled = 3; - */ - isInboundEnabled: boolean; - - /** - * @generated from field: bool isOutboundEnabled = 4; - */ - isOutboundEnabled: boolean; - - /** - * @generated from field: zetachain.zetacore.observer.GasPriceIncreaseFlags gasPriceIncreaseFlags = 5; - */ - gasPriceIncreaseFlags?: GasPriceIncreaseFlags; - - constructor(data?: PartialMessage); - - static readonly runtime: typeof proto3; - static readonly typeName = "zetachain.zetacore.observer.MsgUpdateCrosschainFlags"; - static readonly fields: FieldList; - - static fromBinary(bytes: Uint8Array, options?: Partial): MsgUpdateCrosschainFlags; - - static fromJson(jsonValue: JsonValue, options?: Partial): MsgUpdateCrosschainFlags; - - static fromJsonString(jsonString: string, options?: Partial): MsgUpdateCrosschainFlags; - - static equals(a: MsgUpdateCrosschainFlags | PlainMessage | undefined, b: MsgUpdateCrosschainFlags | PlainMessage | undefined): boolean; -} - -/** - * @generated from message zetachain.zetacore.observer.MsgUpdateCrosschainFlagsResponse - */ -export declare class MsgUpdateCrosschainFlagsResponse extends Message { - constructor(data?: PartialMessage); - - static readonly runtime: typeof proto3; - static readonly typeName = "zetachain.zetacore.observer.MsgUpdateCrosschainFlagsResponse"; - static readonly fields: FieldList; - - static fromBinary(bytes: Uint8Array, options?: Partial): MsgUpdateCrosschainFlagsResponse; - - static fromJson(jsonValue: JsonValue, options?: Partial): MsgUpdateCrosschainFlagsResponse; - - static fromJsonString(jsonString: string, options?: Partial): MsgUpdateCrosschainFlagsResponse; - - static equals(a: MsgUpdateCrosschainFlagsResponse | PlainMessage | undefined, b: MsgUpdateCrosschainFlagsResponse | PlainMessage | undefined): boolean; -} - /** * @generated from message zetachain.zetacore.observer.MsgUpdateKeygen */ @@ -587,3 +529,157 @@ export declare class MsgVoteTSSResponse extends Message { static equals(a: MsgVoteTSSResponse | PlainMessage | undefined, b: MsgVoteTSSResponse | PlainMessage | undefined): boolean; } +/** + * @generated from message zetachain.zetacore.observer.MsgEnableCCTX + */ +export declare class MsgEnableCCTX extends Message { + /** + * @generated from field: string creator = 1; + */ + creator: string; + + /** + * @generated from field: bool enableInbound = 2; + */ + enableInbound: boolean; + + /** + * @generated from field: bool enableOutbound = 3; + */ + enableOutbound: boolean; + + constructor(data?: PartialMessage); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.observer.MsgEnableCCTX"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): MsgEnableCCTX; + + static fromJson(jsonValue: JsonValue, options?: Partial): MsgEnableCCTX; + + static fromJsonString(jsonString: string, options?: Partial): MsgEnableCCTX; + + static equals(a: MsgEnableCCTX | PlainMessage | undefined, b: MsgEnableCCTX | PlainMessage | undefined): boolean; +} + +/** + * @generated from message zetachain.zetacore.observer.MsgEnableCCTXResponse + */ +export declare class MsgEnableCCTXResponse extends Message { + constructor(data?: PartialMessage); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.observer.MsgEnableCCTXResponse"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): MsgEnableCCTXResponse; + + static fromJson(jsonValue: JsonValue, options?: Partial): MsgEnableCCTXResponse; + + static fromJsonString(jsonString: string, options?: Partial): MsgEnableCCTXResponse; + + static equals(a: MsgEnableCCTXResponse | PlainMessage | undefined, b: MsgEnableCCTXResponse | PlainMessage | undefined): boolean; +} + +/** + * @generated from message zetachain.zetacore.observer.MsgDisableCCTX + */ +export declare class MsgDisableCCTX extends Message { + /** + * @generated from field: string creator = 1; + */ + creator: string; + + /** + * @generated from field: bool disableInbound = 2; + */ + disableInbound: boolean; + + /** + * @generated from field: bool disableOutbound = 3; + */ + disableOutbound: boolean; + + constructor(data?: PartialMessage); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.observer.MsgDisableCCTX"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): MsgDisableCCTX; + + static fromJson(jsonValue: JsonValue, options?: Partial): MsgDisableCCTX; + + static fromJsonString(jsonString: string, options?: Partial): MsgDisableCCTX; + + static equals(a: MsgDisableCCTX | PlainMessage | undefined, b: MsgDisableCCTX | PlainMessage | undefined): boolean; +} + +/** + * @generated from message zetachain.zetacore.observer.MsgDisableCCTXResponse + */ +export declare class MsgDisableCCTXResponse extends Message { + constructor(data?: PartialMessage); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.observer.MsgDisableCCTXResponse"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): MsgDisableCCTXResponse; + + static fromJson(jsonValue: JsonValue, options?: Partial): MsgDisableCCTXResponse; + + static fromJsonString(jsonString: string, options?: Partial): MsgDisableCCTXResponse; + + static equals(a: MsgDisableCCTXResponse | PlainMessage | undefined, b: MsgDisableCCTXResponse | PlainMessage | undefined): boolean; +} + +/** + * @generated from message zetachain.zetacore.observer.MsgUpdateGasPriceIncreaseFlags + */ +export declare class MsgUpdateGasPriceIncreaseFlags extends Message { + /** + * @generated from field: string creator = 1; + */ + creator: string; + + /** + * @generated from field: zetachain.zetacore.observer.GasPriceIncreaseFlags gasPriceIncreaseFlags = 2; + */ + gasPriceIncreaseFlags?: GasPriceIncreaseFlags; + + constructor(data?: PartialMessage); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.observer.MsgUpdateGasPriceIncreaseFlags"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): MsgUpdateGasPriceIncreaseFlags; + + static fromJson(jsonValue: JsonValue, options?: Partial): MsgUpdateGasPriceIncreaseFlags; + + static fromJsonString(jsonString: string, options?: Partial): MsgUpdateGasPriceIncreaseFlags; + + static equals(a: MsgUpdateGasPriceIncreaseFlags | PlainMessage | undefined, b: MsgUpdateGasPriceIncreaseFlags | PlainMessage | undefined): boolean; +} + +/** + * @generated from message zetachain.zetacore.observer.MsgUpdateGasPriceIncreaseFlagsResponse + */ +export declare class MsgUpdateGasPriceIncreaseFlagsResponse extends Message { + constructor(data?: PartialMessage); + + static readonly runtime: typeof proto3; + static readonly typeName = "zetachain.zetacore.observer.MsgUpdateGasPriceIncreaseFlagsResponse"; + static readonly fields: FieldList; + + static fromBinary(bytes: Uint8Array, options?: Partial): MsgUpdateGasPriceIncreaseFlagsResponse; + + static fromJson(jsonValue: JsonValue, options?: Partial): MsgUpdateGasPriceIncreaseFlagsResponse; + + static fromJsonString(jsonString: string, options?: Partial): MsgUpdateGasPriceIncreaseFlagsResponse; + + static equals(a: MsgUpdateGasPriceIncreaseFlagsResponse | PlainMessage | undefined, b: MsgUpdateGasPriceIncreaseFlagsResponse | PlainMessage | undefined): boolean; +} + diff --git a/x/observer/client/cli/tx.go b/x/observer/client/cli/tx.go index b66dd7a058..78569fb753 100644 --- a/x/observer/client/cli/tx.go +++ b/x/observer/client/cli/tx.go @@ -23,13 +23,15 @@ func GetTxCmd() *cobra.Command { CmdAddObserver(), CmdUpdateChainParams(), CmdRemoveChainParams(), - CmdUpdateCrosschainFlags(), CmdUpdateKeygen(), CmdAddBlameVote(), CmdUpdateObserver(), CmdEncode(), CmdResetChainNonces(), CmdVoteTSS(), + CmdEnableCCTX(), + CmdDisableCCTX(), + CmdUpdateGasPriceIncreaseFlags(), ) return cmd diff --git a/x/observer/client/cli/tx_disable_cctx_flags.go b/x/observer/client/cli/tx_disable_cctx_flags.go new file mode 100644 index 0000000000..53cdf923bf --- /dev/null +++ b/x/observer/client/cli/tx_disable_cctx_flags.go @@ -0,0 +1,44 @@ +package cli + +import ( + "strconv" + + "github.com/cosmos/cosmos-sdk/client" + "github.com/cosmos/cosmos-sdk/client/flags" + "github.com/cosmos/cosmos-sdk/client/tx" + "github.com/spf13/cobra" + + "github.com/zeta-chain/zetacore/x/observer/types" +) + +func CmdDisableCCTX() *cobra.Command { + cmd := &cobra.Command{ + Use: "disable-cctx [disable-inbound] [disable-outbound]", + Short: "Disable inbound and outbound for CCTX", + Args: cobra.ExactArgs(2), + RunE: func(cmd *cobra.Command, args []string) (err error) { + + clientCtx, err := client.GetClientTxContext(cmd) + if err != nil { + return err + } + disableInbound, err := strconv.ParseBool(args[0]) + if err != nil { + return err + } + disableOutbound, err := strconv.ParseBool(args[1]) + if err != nil { + return err + } + msg := types.NewMsgDisableCCTX(clientCtx.GetFromAddress().String(), disableInbound, disableOutbound) + err = msg.ValidateBasic() + if err != nil { + return err + } + + return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) + }, + } + flags.AddTxFlagsToCmd(cmd) + return cmd +} diff --git a/x/observer/client/cli/tx_permission_flags.go b/x/observer/client/cli/tx_enable_cctx_flags.go similarity index 60% rename from x/observer/client/cli/tx_permission_flags.go rename to x/observer/client/cli/tx_enable_cctx_flags.go index 1aa219ac98..c21016e258 100644 --- a/x/observer/client/cli/tx_permission_flags.go +++ b/x/observer/client/cli/tx_enable_cctx_flags.go @@ -11,10 +11,10 @@ import ( "github.com/zeta-chain/zetacore/x/observer/types" ) -func CmdUpdateCrosschainFlags() *cobra.Command { +func CmdEnableCCTX() *cobra.Command { cmd := &cobra.Command{ - Use: "update-crosschain-flags [is-inbound-enabled] [is-outbound-enabled]", - Short: "Update crosschain flags", + Use: "enable-cctx [enable-inbound] [enable-outbound]", + Short: "Enable inbound and outbound for CCTX", Args: cobra.ExactArgs(2), RunE: func(cmd *cobra.Command, args []string) (err error) { @@ -22,25 +22,23 @@ func CmdUpdateCrosschainFlags() *cobra.Command { if err != nil { return err } - argIsInboundEnabled, err := strconv.ParseBool(args[0]) + enableInbound, err := strconv.ParseBool(args[0]) if err != nil { return err } - arsIsOutboundEnabled, err := strconv.ParseBool(args[1]) + enableOutbound, err := strconv.ParseBool(args[1]) + if err != nil { + return err + } + msg := types.NewMsgEnableCCTX(clientCtx.GetFromAddress().String(), enableInbound, enableOutbound) + err = msg.ValidateBasic() if err != nil { return err } - msg := types.NewMsgUpdateCrosschainFlags( - clientCtx.GetFromAddress().String(), - argIsInboundEnabled, - arsIsOutboundEnabled, - ) return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) }, } - flags.AddTxFlagsToCmd(cmd) - return cmd } diff --git a/x/observer/client/cli/tx_update_gas_price_increase_flags.go b/x/observer/client/cli/tx_update_gas_price_increase_flags.go new file mode 100644 index 0000000000..e2cc0a5685 --- /dev/null +++ b/x/observer/client/cli/tx_update_gas_price_increase_flags.go @@ -0,0 +1,67 @@ +package cli + +import ( + "strconv" + "time" + + "github.com/cosmos/cosmos-sdk/client" + "github.com/cosmos/cosmos-sdk/client/flags" + "github.com/cosmos/cosmos-sdk/client/tx" + "github.com/spf13/cobra" + + "github.com/zeta-chain/zetacore/x/observer/types" +) + +func CmdUpdateGasPriceIncreaseFlags() *cobra.Command { + cmd := &cobra.Command{ + Use: "update-gas-price-increase-flags [epochLength] [retryInterval] [gasPriceIncreasePercent] [gasPriceIncreaseMax] [maxPendingCctxs]", + Short: "Update the gas price increase flags", + Args: cobra.ExactArgs(5), + RunE: func(cmd *cobra.Command, args []string) (err error) { + + clientCtx, err := client.GetClientTxContext(cmd) + if err != nil { + return err + } + epochLength, err := strconv.ParseInt(args[0], 10, 64) + if err != nil { + return err + } + retryInterval, err := strconv.ParseInt(args[1], 10, 64) + if err != nil { + return err + } + + gasPriceIncreasePercent, err := strconv.ParseUint(args[2], 10, 32) + if err != nil { + return err + } + gasPriceIncreaseMax, err := strconv.ParseUint(args[3], 10, 32) + if err != nil { + return err + } + maxPendingCctxs, err := strconv.ParseUint(args[4], 10, 32) + if err != nil { + return err + } + gasPriceIncreaseFlags := types.GasPriceIncreaseFlags{ + EpochLength: epochLength, + RetryInterval: time.Duration(retryInterval), + // #nosec G701 bitsize set to 32 + GasPriceIncreasePercent: uint32(gasPriceIncreasePercent), + // #nosec G701 bitsize set to 32 + GasPriceIncreaseMax: uint32(gasPriceIncreaseMax), + // #nosec G701 bitsize set to 32 + MaxPendingCctxs: uint32(maxPendingCctxs)} + msg := types.NewMsgUpdateGasPriceIncreaseFlags(clientCtx.GetFromAddress().String(), gasPriceIncreaseFlags) + err = msg.ValidateBasic() + if err != nil { + return err + } + + return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) + }, + } + flags.AddTxFlagsToCmd(cmd) + return cmd +} diff --git a/x/observer/keeper/msg_server_disable_cctx_flags.go b/x/observer/keeper/msg_server_disable_cctx_flags.go new file mode 100644 index 0000000000..0645db2cc9 --- /dev/null +++ b/x/observer/keeper/msg_server_disable_cctx_flags.go @@ -0,0 +1,55 @@ +package keeper + +import ( + "context" + + sdk "github.com/cosmos/cosmos-sdk/types" + + authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" + "github.com/zeta-chain/zetacore/x/observer/types" +) + +// DisableCCTX disables the IsInboundEnabled and IsOutboundEnabled flags. These flags control the creation of inbounds and outbounds. +// The flags are disabled by the policy account with the groupEmergency policy type. +func (k msgServer) DisableCCTX( + goCtx context.Context, + msg *types.MsgDisableCCTX, +) (*types.MsgDisableCCTXResponse, error) { + ctx := sdk.UnwrapSDKContext(goCtx) + + // check permission + if !k.GetAuthorityKeeper().IsAuthorized(ctx, msg.Creator, authoritytypes.PolicyType_groupEmergency) { + return &types.MsgDisableCCTXResponse{}, authoritytypes.ErrUnauthorized.Wrap( + "DisableCCTX can only be executed by the correct policy account", + ) + } + + // check if the value exists, + // if not, set the default value for the Inbound and Outbound flags only + flags, isFound := k.GetCrosschainFlags(ctx) + if !isFound { + flags = *types.DefaultCrosschainFlags() + flags.GasPriceIncreaseFlags = nil + } + + if msg.DisableInbound { + flags.IsInboundEnabled = false + } + if msg.DisableOutbound { + flags.IsOutboundEnabled = false + } + + k.SetCrosschainFlags(ctx, flags) + + err := ctx.EventManager().EmitTypedEvents(&types.EventCCTXDisabled{ + MsgTypeUrl: sdk.MsgTypeURL(&types.MsgDisableCCTX{}), + IsInboundEnabled: flags.IsInboundEnabled, + IsOutboundEnabled: flags.IsOutboundEnabled, + }) + + if err != nil { + ctx.Logger().Error("Error emitting event EventCCTXDisabled :", err) + } + + return &types.MsgDisableCCTXResponse{}, nil +} diff --git a/x/observer/keeper/msg_server_disable_cctx_flags_test.go b/x/observer/keeper/msg_server_disable_cctx_flags_test.go new file mode 100644 index 0000000000..2dcab71f51 --- /dev/null +++ b/x/observer/keeper/msg_server_disable_cctx_flags_test.go @@ -0,0 +1,152 @@ +package keeper_test + +import ( + "testing" + + sdk "github.com/cosmos/cosmos-sdk/types" + "github.com/stretchr/testify/require" + + keepertest "github.com/zeta-chain/zetacore/testutil/keeper" + "github.com/zeta-chain/zetacore/testutil/sample" + authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" + "github.com/zeta-chain/zetacore/x/observer/keeper" + "github.com/zeta-chain/zetacore/x/observer/types" +) + +func TestMsgServer_MsgDisableCCTX(t *testing.T) { + t.Run("can disable cctx flags if flags dont exist", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgDisableCCTX{ + Creator: admin, + DisableOutbound: true, + DisableInbound: true, + } + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, true) + + _, err := srv.DisableCCTX(sdk.WrapSDKContext(ctx), msg) + require.NoError(t, err) + + flags, found := k.GetCrosschainFlags(ctx) + require.True(t, found) + require.False(t, flags.IsInboundEnabled) + require.False(t, flags.IsOutboundEnabled) + require.Nil(t, flags.GasPriceIncreaseFlags) + }) + + t.Run("can disable cctx flags if flags set to true", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + gasPriceIncreaseFlags := sample.GasPriceIncreaseFlags() + k.SetCrosschainFlags(ctx, types.CrosschainFlags{ + IsInboundEnabled: true, + IsOutboundEnabled: true, + GasPriceIncreaseFlags: &gasPriceIncreaseFlags, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgDisableCCTX{ + Creator: admin, + DisableOutbound: true, + DisableInbound: true, + } + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, true) + + _, err := srv.DisableCCTX(sdk.WrapSDKContext(ctx), msg) + require.NoError(t, err) + + flags, found := k.GetCrosschainFlags(ctx) + require.True(t, found) + require.False(t, flags.IsInboundEnabled) + require.False(t, flags.IsOutboundEnabled) + require.Equal(t, gasPriceIncreaseFlags, *flags.GasPriceIncreaseFlags) + }) + + t.Run("can disable only outbound flag", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + gasPriceIncreaseFlags := sample.GasPriceIncreaseFlags() + k.SetCrosschainFlags(ctx, types.CrosschainFlags{ + IsInboundEnabled: true, + IsOutboundEnabled: true, + GasPriceIncreaseFlags: &gasPriceIncreaseFlags, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgDisableCCTX{ + Creator: admin, + DisableOutbound: true, + DisableInbound: false, + } + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, true) + + _, err := srv.DisableCCTX(sdk.WrapSDKContext(ctx), msg) + require.NoError(t, err) + + flags, found := k.GetCrosschainFlags(ctx) + require.True(t, found) + require.True(t, flags.IsInboundEnabled) + require.False(t, flags.IsOutboundEnabled) + require.Equal(t, gasPriceIncreaseFlags, *flags.GasPriceIncreaseFlags) + }) + + t.Run("can disable only inbound flag", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + gasPriceIncreaseFlags := sample.GasPriceIncreaseFlags() + k.SetCrosschainFlags(ctx, types.CrosschainFlags{ + IsInboundEnabled: true, + IsOutboundEnabled: true, + GasPriceIncreaseFlags: &gasPriceIncreaseFlags, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgDisableCCTX{ + Creator: admin, + DisableOutbound: false, + DisableInbound: true, + } + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, true) + + _, err := srv.DisableCCTX(sdk.WrapSDKContext(ctx), msg) + require.NoError(t, err) + + flags, found := k.GetCrosschainFlags(ctx) + require.True(t, found) + require.False(t, flags.IsInboundEnabled) + require.True(t, flags.IsOutboundEnabled) + require.Equal(t, gasPriceIncreaseFlags, *flags.GasPriceIncreaseFlags) + }) + + t.Run("cannot disable cctx flags if not correct address", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgDisableCCTX{ + Creator: admin, + DisableOutbound: true, + DisableInbound: false, + } + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, false) + + _, err := srv.DisableCCTX(sdk.WrapSDKContext(ctx), msg) + require.ErrorIs(t, authoritytypes.ErrUnauthorized, err) + + _, found := k.GetCrosschainFlags(ctx) + require.False(t, found) + }) +} diff --git a/x/observer/keeper/msg_server_enable_cctx_flags.go b/x/observer/keeper/msg_server_enable_cctx_flags.go new file mode 100644 index 0000000000..a361af6708 --- /dev/null +++ b/x/observer/keeper/msg_server_enable_cctx_flags.go @@ -0,0 +1,55 @@ +package keeper + +import ( + "context" + + sdk "github.com/cosmos/cosmos-sdk/types" + + authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" + "github.com/zeta-chain/zetacore/x/observer/types" +) + +// EnableCCTX enables the IsInboundEnabled and IsOutboundEnabled flags.These flags control the creation of inbounds and outbounds. +// The flags are enabled by the policy account with the groupOperational policy type. +func (k msgServer) EnableCCTX( + goCtx context.Context, + msg *types.MsgEnableCCTX, +) (*types.MsgEnableCCTXResponse, error) { + ctx := sdk.UnwrapSDKContext(goCtx) + + // check permission + if !k.GetAuthorityKeeper().IsAuthorized(ctx, msg.Creator, authoritytypes.PolicyType_groupOperational) { + return &types.MsgEnableCCTXResponse{}, authoritytypes.ErrUnauthorized.Wrap( + "EnableCCTX can only be executed by the correct policy account", + ) + } + + // check if the value exists, + // if not, set the default value for the Inbound and Outbound flags only + flags, isFound := k.GetCrosschainFlags(ctx) + if !isFound { + flags = *types.DefaultCrosschainFlags() + flags.GasPriceIncreaseFlags = nil + } + + if msg.EnableInbound { + flags.IsInboundEnabled = true + } + if msg.EnableOutbound { + flags.IsOutboundEnabled = true + } + + k.SetCrosschainFlags(ctx, flags) + + err := ctx.EventManager().EmitTypedEvents(&types.EventCCTXEnabled{ + MsgTypeUrl: sdk.MsgTypeURL(&types.MsgEnableCCTX{}), + IsInboundEnabled: flags.IsInboundEnabled, + IsOutboundEnabled: flags.IsOutboundEnabled, + }) + + if err != nil { + ctx.Logger().Error("Error emitting EventCCTXEnabled :", err) + } + + return &types.MsgEnableCCTXResponse{}, nil +} diff --git a/x/observer/keeper/msg_server_enable_cctx_flags_test.go b/x/observer/keeper/msg_server_enable_cctx_flags_test.go new file mode 100644 index 0000000000..8bb3346f91 --- /dev/null +++ b/x/observer/keeper/msg_server_enable_cctx_flags_test.go @@ -0,0 +1,152 @@ +package keeper_test + +import ( + "testing" + + sdk "github.com/cosmos/cosmos-sdk/types" + "github.com/stretchr/testify/require" + + keepertest "github.com/zeta-chain/zetacore/testutil/keeper" + "github.com/zeta-chain/zetacore/testutil/sample" + authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" + "github.com/zeta-chain/zetacore/x/observer/keeper" + "github.com/zeta-chain/zetacore/x/observer/types" +) + +func TestMsgServer_EnableCCTX(t *testing.T) { + t.Run("can enable cctx flags if flags dont exist", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgEnableCCTX{ + Creator: admin, + EnableInbound: true, + EnableOutbound: true, + } + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + _, err := srv.EnableCCTX(sdk.WrapSDKContext(ctx), msg) + require.NoError(t, err) + + flags, found := k.GetCrosschainFlags(ctx) + require.True(t, found) + require.True(t, flags.IsInboundEnabled) + require.True(t, flags.IsOutboundEnabled) + require.Nil(t, flags.GasPriceIncreaseFlags) + }) + + t.Run("can enable cctx flags if flags set to false", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + gasPriceIncreaseFlags := sample.GasPriceIncreaseFlags() + k.SetCrosschainFlags(ctx, types.CrosschainFlags{ + IsInboundEnabled: false, + IsOutboundEnabled: false, + GasPriceIncreaseFlags: &gasPriceIncreaseFlags, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgEnableCCTX{ + Creator: admin, + EnableInbound: true, + EnableOutbound: true, + } + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + _, err := srv.EnableCCTX(sdk.WrapSDKContext(ctx), msg) + require.NoError(t, err) + + flags, found := k.GetCrosschainFlags(ctx) + require.True(t, found) + require.True(t, flags.IsInboundEnabled) + require.True(t, flags.IsOutboundEnabled) + require.Equal(t, gasPriceIncreaseFlags, *flags.GasPriceIncreaseFlags) + }) + + t.Run("can enable cctx flags only inbound flag", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + gasPriceIncreaseFlags := sample.GasPriceIncreaseFlags() + k.SetCrosschainFlags(ctx, types.CrosschainFlags{ + IsInboundEnabled: false, + IsOutboundEnabled: false, + GasPriceIncreaseFlags: &gasPriceIncreaseFlags, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgEnableCCTX{ + Creator: admin, + EnableInbound: true, + EnableOutbound: false, + } + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + _, err := srv.EnableCCTX(sdk.WrapSDKContext(ctx), msg) + require.NoError(t, err) + + flags, found := k.GetCrosschainFlags(ctx) + require.True(t, found) + require.True(t, flags.IsInboundEnabled) + require.False(t, flags.IsOutboundEnabled) + require.Equal(t, gasPriceIncreaseFlags, *flags.GasPriceIncreaseFlags) + }) + + t.Run("can enable cctx flags only outbound flag", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + gasPriceIncreaseFlags := sample.GasPriceIncreaseFlags() + k.SetCrosschainFlags(ctx, types.CrosschainFlags{ + IsInboundEnabled: false, + IsOutboundEnabled: false, + GasPriceIncreaseFlags: &gasPriceIncreaseFlags, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgEnableCCTX{ + Creator: admin, + EnableInbound: false, + EnableOutbound: true, + } + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + _, err := srv.EnableCCTX(sdk.WrapSDKContext(ctx), msg) + require.NoError(t, err) + + flags, found := k.GetCrosschainFlags(ctx) + require.True(t, found) + require.False(t, flags.IsInboundEnabled) + require.True(t, flags.IsOutboundEnabled) + require.Equal(t, gasPriceIncreaseFlags, *flags.GasPriceIncreaseFlags) + }) + + t.Run("cannot enable cctx flags if not correct address", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgEnableCCTX{ + Creator: admin, + EnableInbound: true, + EnableOutbound: false, + } + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, false) + + _, err := srv.EnableCCTX(sdk.WrapSDKContext(ctx), msg) + require.ErrorIs(t, authoritytypes.ErrUnauthorized, err) + + _, found := k.GetCrosschainFlags(ctx) + require.False(t, found) + }) +} diff --git a/x/observer/keeper/msg_server_update_crosschain_flags.go b/x/observer/keeper/msg_server_update_crosschain_flags.go deleted file mode 100644 index 045b21dd7d..0000000000 --- a/x/observer/keeper/msg_server_update_crosschain_flags.go +++ /dev/null @@ -1,55 +0,0 @@ -package keeper - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - - authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" - "github.com/zeta-chain/zetacore/x/observer/types" -) - -// UpdateCrosschainFlags updates the crosschain related flags. -// -// Aurthorized: admin policy group 1 (except enabling/disabled -// inbounds/outbounds and gas price increase), admin policy group 2 (all). -func (k msgServer) UpdateCrosschainFlags( - goCtx context.Context, - msg *types.MsgUpdateCrosschainFlags, -) (*types.MsgUpdateCrosschainFlagsResponse, error) { - ctx := sdk.UnwrapSDKContext(goCtx) - - // check permission - if !k.GetAuthorityKeeper().IsAuthorized(ctx, msg.Creator, msg.GetRequiredPolicyType()) { - return &types.MsgUpdateCrosschainFlagsResponse{}, authoritytypes.ErrUnauthorized - } - - // check if the value exists - flags, isFound := k.GetCrosschainFlags(ctx) - if !isFound { - flags = *types.DefaultCrosschainFlags() - } - - // update values - flags.IsInboundEnabled = msg.IsInboundEnabled - flags.IsOutboundEnabled = msg.IsOutboundEnabled - - if msg.GasPriceIncreaseFlags != nil { - flags.GasPriceIncreaseFlags = msg.GasPriceIncreaseFlags - } - - k.SetCrosschainFlags(ctx, flags) - - err := ctx.EventManager().EmitTypedEvents(&types.EventCrosschainFlagsUpdated{ - MsgTypeUrl: sdk.MsgTypeURL(&types.MsgUpdateCrosschainFlags{}), - IsInboundEnabled: msg.IsInboundEnabled, - IsOutboundEnabled: msg.IsOutboundEnabled, - GasPriceIncreaseFlags: msg.GasPriceIncreaseFlags, - Signer: msg.Creator, - }) - if err != nil { - ctx.Logger().Error("Error emitting EventCrosschainFlagsUpdated :", err) - } - - return &types.MsgUpdateCrosschainFlagsResponse{}, nil -} diff --git a/x/observer/keeper/msg_server_update_crosschain_flags_test.go b/x/observer/keeper/msg_server_update_crosschain_flags_test.go deleted file mode 100644 index b4a5f1f516..0000000000 --- a/x/observer/keeper/msg_server_update_crosschain_flags_test.go +++ /dev/null @@ -1,165 +0,0 @@ -package keeper_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/stretchr/testify/require" - - keepertest "github.com/zeta-chain/zetacore/testutil/keeper" - "github.com/zeta-chain/zetacore/testutil/sample" - authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" - "github.com/zeta-chain/zetacore/x/observer/keeper" - "github.com/zeta-chain/zetacore/x/observer/types" -) - -func TestMsgServer_UpdateCrosschainFlags(t *testing.T) { - t.Run("can update crosschain flags", func(t *testing.T) { - k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ - UseAuthorityMock: true, - }) - srv := keeper.NewMsgServerImpl(*k) - admin := sample.AccAddress() - - // mock the authority keeper for authorization - authorityMock := keepertest.GetObserverAuthorityMock(t, k) - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) - - _, err := srv.UpdateCrosschainFlags(sdk.WrapSDKContext(ctx), &types.MsgUpdateCrosschainFlags{ - Creator: admin, - IsInboundEnabled: false, - IsOutboundEnabled: false, - GasPriceIncreaseFlags: &types.GasPriceIncreaseFlags{ - EpochLength: 42, - RetryInterval: time.Minute * 42, - GasPriceIncreasePercent: 42, - }, - }) - require.NoError(t, err) - - flags, found := k.GetCrosschainFlags(ctx) - require.True(t, found) - require.False(t, flags.IsInboundEnabled) - require.False(t, flags.IsOutboundEnabled) - require.Equal(t, int64(42), flags.GasPriceIncreaseFlags.EpochLength) - require.Equal(t, time.Minute*42, flags.GasPriceIncreaseFlags.RetryInterval) - require.Equal(t, uint32(42), flags.GasPriceIncreaseFlags.GasPriceIncreasePercent) - - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) - - // can update flags again - _, err = srv.UpdateCrosschainFlags(sdk.WrapSDKContext(ctx), &types.MsgUpdateCrosschainFlags{ - Creator: admin, - IsInboundEnabled: true, - IsOutboundEnabled: true, - GasPriceIncreaseFlags: &types.GasPriceIncreaseFlags{ - EpochLength: 43, - RetryInterval: time.Minute * 43, - GasPriceIncreasePercent: 43, - }, - }) - require.NoError(t, err) - - flags, found = k.GetCrosschainFlags(ctx) - require.True(t, found) - require.True(t, flags.IsInboundEnabled) - require.True(t, flags.IsOutboundEnabled) - require.Equal(t, int64(43), flags.GasPriceIncreaseFlags.EpochLength) - require.Equal(t, time.Minute*43, flags.GasPriceIncreaseFlags.RetryInterval) - require.Equal(t, uint32(43), flags.GasPriceIncreaseFlags.GasPriceIncreasePercent) - - // group 1 should be able to disable inbound and outbound - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, true) - - // if gas price increase flags is nil, it should not be updated - _, err = srv.UpdateCrosschainFlags(sdk.WrapSDKContext(ctx), &types.MsgUpdateCrosschainFlags{ - Creator: admin, - IsInboundEnabled: false, - IsOutboundEnabled: false, - }) - require.NoError(t, err) - - flags, found = k.GetCrosschainFlags(ctx) - require.True(t, found) - require.False(t, flags.IsInboundEnabled) - require.False(t, flags.IsOutboundEnabled) - require.Equal(t, int64(43), flags.GasPriceIncreaseFlags.EpochLength) - require.Equal(t, time.Minute*43, flags.GasPriceIncreaseFlags.RetryInterval) - require.Equal(t, uint32(43), flags.GasPriceIncreaseFlags.GasPriceIncreasePercent) - - // group 1 should be able to disable header verification - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, true) - - // if gas price increase flags is nil, it should not be updated - _, err = srv.UpdateCrosschainFlags(sdk.WrapSDKContext(ctx), &types.MsgUpdateCrosschainFlags{ - Creator: admin, - IsInboundEnabled: false, - IsOutboundEnabled: false, - }) - require.NoError(t, err) - - flags, found = k.GetCrosschainFlags(ctx) - require.True(t, found) - require.False(t, flags.IsInboundEnabled) - require.False(t, flags.IsOutboundEnabled) - require.Equal(t, int64(43), flags.GasPriceIncreaseFlags.EpochLength) - require.Equal(t, time.Minute*43, flags.GasPriceIncreaseFlags.RetryInterval) - require.Equal(t, uint32(43), flags.GasPriceIncreaseFlags.GasPriceIncreasePercent) - - // if flags are not defined, default should be used - k.RemoveCrosschainFlags(ctx) - _, found = k.GetCrosschainFlags(ctx) - require.False(t, found) - - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) - - _, err = srv.UpdateCrosschainFlags(sdk.WrapSDKContext(ctx), &types.MsgUpdateCrosschainFlags{ - Creator: admin, - IsInboundEnabled: false, - IsOutboundEnabled: true, - }) - require.NoError(t, err) - - flags, found = k.GetCrosschainFlags(ctx) - require.True(t, found) - require.False(t, flags.IsInboundEnabled) - require.True(t, flags.IsOutboundEnabled) - require.Equal(t, types.DefaultGasPriceIncreaseFlags.EpochLength, flags.GasPriceIncreaseFlags.EpochLength) - require.Equal(t, types.DefaultGasPriceIncreaseFlags.RetryInterval, flags.GasPriceIncreaseFlags.RetryInterval) - require.Equal( - t, - types.DefaultGasPriceIncreaseFlags.GasPriceIncreasePercent, - flags.GasPriceIncreaseFlags.GasPriceIncreasePercent, - ) - }) - - t.Run("cannot update crosschain flags if not authorized", func(t *testing.T) { - k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ - UseAuthorityMock: true, - }) - srv := keeper.NewMsgServerImpl(*k) - - admin := sample.AccAddress() - authorityMock := keepertest.GetObserverAuthorityMock(t, k) - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupEmergency, false) - - _, err := srv.UpdateCrosschainFlags(sdk.WrapSDKContext(ctx), &types.MsgUpdateCrosschainFlags{ - Creator: admin, - IsInboundEnabled: false, - IsOutboundEnabled: false, - }) - require.Error(t, err) - require.Equal(t, authoritytypes.ErrUnauthorized, err) - - keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, false) - - _, err = srv.UpdateCrosschainFlags(sdk.WrapSDKContext(ctx), &types.MsgUpdateCrosschainFlags{ - Creator: admin, - IsInboundEnabled: false, - IsOutboundEnabled: true, - }) - require.Error(t, err) - require.Equal(t, authoritytypes.ErrUnauthorized, err) - }) -} diff --git a/x/observer/keeper/msg_server_update_gas_price_increase_flags.go b/x/observer/keeper/msg_server_update_gas_price_increase_flags.go new file mode 100644 index 0000000000..7402ab0cc7 --- /dev/null +++ b/x/observer/keeper/msg_server_update_gas_price_increase_flags.go @@ -0,0 +1,54 @@ +package keeper + +import ( + "context" + + sdk "github.com/cosmos/cosmos-sdk/types" + + authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" + "github.com/zeta-chain/zetacore/x/observer/types" +) + +// UpdateGasPriceIncreaseFlags updates the GasPriceIncreaseFlags. These flags control the increase of gas prices. +// The flags are updated by the policy account with the groupOperational policy type. +func (k msgServer) UpdateGasPriceIncreaseFlags( + goCtx context.Context, + msg *types.MsgUpdateGasPriceIncreaseFlags, +) (*types.MsgUpdateGasPriceIncreaseFlagsResponse, error) { + ctx := sdk.UnwrapSDKContext(goCtx) + + // check permission + if !k.GetAuthorityKeeper().IsAuthorized(ctx, msg.Creator, authoritytypes.PolicyType_groupOperational) { + return &types.MsgUpdateGasPriceIncreaseFlagsResponse{}, authoritytypes.ErrUnauthorized.Wrap( + "UpdateGasPriceIncreaseFlags can only be executed by the correct policy account", + ) + } + // check if the value exists, + // if not, set the default value for the GasPriceIncreaseFlags only + // Set Inbound and Outbound flags to false + flags, isFound := k.GetCrosschainFlags(ctx) + if !isFound { + flags = *types.DefaultCrosschainFlags() + flags.IsInboundEnabled = false + flags.IsOutboundEnabled = false + } + + err := msg.GasPriceIncreaseFlags.Validate() + if err != nil { + return &types.MsgUpdateGasPriceIncreaseFlagsResponse{}, err + } + + flags.GasPriceIncreaseFlags = &msg.GasPriceIncreaseFlags + k.SetCrosschainFlags(ctx, flags) + + err = ctx.EventManager().EmitTypedEvents(&types.EventGasPriceIncreaseFlagsUpdated{ + MsgTypeUrl: sdk.MsgTypeURL(&types.MsgUpdateGasPriceIncreaseFlags{}), + GasPriceIncreaseFlags: flags.GasPriceIncreaseFlags, + }) + + if err != nil { + ctx.Logger().Error("Error emitting EventGasPriceIncreaseFlagsUpdated :", err) + } + + return &types.MsgUpdateGasPriceIncreaseFlagsResponse{}, nil +} diff --git a/x/observer/keeper/msg_server_update_gas_price_increase_flags_test.go b/x/observer/keeper/msg_server_update_gas_price_increase_flags_test.go new file mode 100644 index 0000000000..63fcec7acf --- /dev/null +++ b/x/observer/keeper/msg_server_update_gas_price_increase_flags_test.go @@ -0,0 +1,116 @@ +package keeper_test + +import ( + "testing" + + sdk "github.com/cosmos/cosmos-sdk/types" + "github.com/stretchr/testify/require" + + keepertest "github.com/zeta-chain/zetacore/testutil/keeper" + "github.com/zeta-chain/zetacore/testutil/sample" + authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" + "github.com/zeta-chain/zetacore/x/observer/keeper" + "github.com/zeta-chain/zetacore/x/observer/types" +) + +func TestKeeper_UpdateGasPriceIncreaseFlags(t *testing.T) { + t.Run("can update gas price increase flags if crosschain flags dont exist", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + updatedFlags := sample.GasPriceIncreaseFlags() + msg := &types.MsgUpdateGasPriceIncreaseFlags{ + Creator: admin, + GasPriceIncreaseFlags: updatedFlags, + } + + // mock the authority keeper for authorization + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + _, err := srv.UpdateGasPriceIncreaseFlags(sdk.WrapSDKContext(ctx), msg) + require.NoError(t, err) + + flags, found := k.GetCrosschainFlags(ctx) + require.True(t, found) + require.Equal(t, updatedFlags, *flags.GasPriceIncreaseFlags) + require.False(t, flags.IsInboundEnabled) + require.False(t, flags.IsOutboundEnabled) + }) + + t.Run("can update gas price increase flags if crosschain flags exist", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + defaultCrosschainFlags := types.DefaultCrosschainFlags() + k.SetCrosschainFlags(ctx, *defaultCrosschainFlags) + updatedFlags := sample.GasPriceIncreaseFlags() + msg := &types.MsgUpdateGasPriceIncreaseFlags{ + Creator: admin, + GasPriceIncreaseFlags: updatedFlags, + } + + // mock the authority keeper for authorization + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + _, err := srv.UpdateGasPriceIncreaseFlags(sdk.WrapSDKContext(ctx), msg) + require.NoError(t, err) + + flags, found := k.GetCrosschainFlags(ctx) + require.True(t, found) + require.Equal(t, updatedFlags, *flags.GasPriceIncreaseFlags) + require.Equal(t, defaultCrosschainFlags.IsInboundEnabled, flags.IsInboundEnabled) + require.Equal(t, defaultCrosschainFlags.IsOutboundEnabled, flags.IsOutboundEnabled) + }) + + t.Run("cannot update invalid gas price increase flags", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgUpdateGasPriceIncreaseFlags{ + Creator: admin, + GasPriceIncreaseFlags: types.GasPriceIncreaseFlags{ + EpochLength: -1, + RetryInterval: 1, + GasPriceIncreasePercent: 1, + }, + } + + // mock the authority keeper for authorization + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, true) + + _, err := srv.UpdateGasPriceIncreaseFlags(sdk.WrapSDKContext(ctx), msg) + require.ErrorContains(t, err, "epoch length must be positive") + + _, found := k.GetCrosschainFlags(ctx) + require.False(t, found) + + }) + + t.Run("cannot update gas price increase flags if not authorized", func(t *testing.T) { + k, ctx, _, _ := keepertest.ObserverKeeperWithMocks(t, keepertest.ObserverMockOptions{ + UseAuthorityMock: true, + }) + srv := keeper.NewMsgServerImpl(*k) + admin := sample.AccAddress() + msg := &types.MsgUpdateGasPriceIncreaseFlags{ + Creator: admin, + GasPriceIncreaseFlags: sample.GasPriceIncreaseFlags(), + } + + // mock the authority keeper for authorization + authorityMock := keepertest.GetObserverAuthorityMock(t, k) + keepertest.MockIsAuthorized(&authorityMock.Mock, admin, authoritytypes.PolicyType_groupOperational, false) + + _, err := srv.UpdateGasPriceIncreaseFlags(sdk.WrapSDKContext(ctx), msg) + require.ErrorContains(t, err, "sender not authorized") + }) +} diff --git a/x/observer/types/codec.go b/x/observer/types/codec.go index 91cc9725db..9db4078a11 100644 --- a/x/observer/types/codec.go +++ b/x/observer/types/codec.go @@ -13,11 +13,13 @@ func RegisterCodec(cdc *codec.LegacyAmino) { cdc.RegisterConcrete(&MsgRemoveChainParams{}, "observer/RemoveChainParams", nil) cdc.RegisterConcrete(&MsgVoteBlockHeader{}, "observer/VoteBlockHeader", nil) cdc.RegisterConcrete(&MsgAddBlameVote{}, "observer/AddBlameVote", nil) - cdc.RegisterConcrete(&MsgUpdateCrosschainFlags{}, "observer/UpdateCrosschainFlags", nil) cdc.RegisterConcrete(&MsgUpdateKeygen{}, "observer/UpdateKeygen", nil) cdc.RegisterConcrete(&MsgUpdateObserver{}, "observer/UpdateObserver", nil) cdc.RegisterConcrete(&MsgResetChainNonces{}, "observer/ResetChainNonces", nil) cdc.RegisterConcrete(&MsgVoteTSS{}, "observer/VoteTSS", nil) + cdc.RegisterConcrete(&MsgEnableCCTX{}, "observer/EnableCCTX", nil) + cdc.RegisterConcrete(&MsgDisableCCTX{}, "observer/DisableCCTX", nil) + cdc.RegisterConcrete(&MsgUpdateGasPriceIncreaseFlags{}, "observer/UpdateGasPriceIncreaseFlags", nil) } func RegisterInterfaces(registry cdctypes.InterfaceRegistry) { @@ -26,12 +28,14 @@ func RegisterInterfaces(registry cdctypes.InterfaceRegistry) { &MsgUpdateChainParams{}, &MsgRemoveChainParams{}, &MsgAddBlameVote{}, - &MsgUpdateCrosschainFlags{}, &MsgUpdateKeygen{}, &MsgVoteBlockHeader{}, &MsgUpdateObserver{}, &MsgResetChainNonces{}, &MsgVoteTSS{}, + &MsgEnableCCTX{}, + &MsgDisableCCTX{}, + &MsgUpdateGasPriceIncreaseFlags{}, ) msgservice.RegisterMsgServiceDesc(registry, &_Msg_serviceDesc) diff --git a/x/observer/types/events.pb.go b/x/observer/types/events.pb.go index ed991d3821..e1dde9feb0 100644 --- a/x/observer/types/events.pb.go +++ b/x/observer/types/events.pb.go @@ -235,26 +235,24 @@ func (m *EventNewObserverAdded) GetObserverLastBlockCount() uint64 { return 0 } -type EventCrosschainFlagsUpdated struct { - MsgTypeUrl string `protobuf:"bytes,1,opt,name=msg_type_url,json=msgTypeUrl,proto3" json:"msg_type_url,omitempty"` - IsInboundEnabled bool `protobuf:"varint,2,opt,name=isInboundEnabled,proto3" json:"isInboundEnabled,omitempty"` - IsOutboundEnabled bool `protobuf:"varint,3,opt,name=isOutboundEnabled,proto3" json:"isOutboundEnabled,omitempty"` - GasPriceIncreaseFlags *GasPriceIncreaseFlags `protobuf:"bytes,4,opt,name=gasPriceIncreaseFlags,proto3" json:"gasPriceIncreaseFlags,omitempty"` - Signer string `protobuf:"bytes,5,opt,name=signer,proto3" json:"signer,omitempty"` +type EventCCTXDisabled struct { + MsgTypeUrl string `protobuf:"bytes,1,opt,name=msg_type_url,json=msgTypeUrl,proto3" json:"msg_type_url,omitempty"` + IsInboundEnabled bool `protobuf:"varint,2,opt,name=isInboundEnabled,proto3" json:"isInboundEnabled,omitempty"` + IsOutboundEnabled bool `protobuf:"varint,3,opt,name=isOutboundEnabled,proto3" json:"isOutboundEnabled,omitempty"` } -func (m *EventCrosschainFlagsUpdated) Reset() { *m = EventCrosschainFlagsUpdated{} } -func (m *EventCrosschainFlagsUpdated) String() string { return proto.CompactTextString(m) } -func (*EventCrosschainFlagsUpdated) ProtoMessage() {} -func (*EventCrosschainFlagsUpdated) Descriptor() ([]byte, []int) { +func (m *EventCCTXDisabled) Reset() { *m = EventCCTXDisabled{} } +func (m *EventCCTXDisabled) String() string { return proto.CompactTextString(m) } +func (*EventCCTXDisabled) ProtoMessage() {} +func (*EventCCTXDisabled) Descriptor() ([]byte, []int) { return fileDescriptor_067e682d8234d605, []int{3} } -func (m *EventCrosschainFlagsUpdated) XXX_Unmarshal(b []byte) error { +func (m *EventCCTXDisabled) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) } -func (m *EventCrosschainFlagsUpdated) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { +func (m *EventCCTXDisabled) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { if deterministic { - return xxx_messageInfo_EventCrosschainFlagsUpdated.Marshal(b, m, deterministic) + return xxx_messageInfo_EventCCTXDisabled.Marshal(b, m, deterministic) } else { b = b[:cap(b)] n, err := m.MarshalToSizedBuffer(b) @@ -264,58 +262,158 @@ func (m *EventCrosschainFlagsUpdated) XXX_Marshal(b []byte, deterministic bool) return b[:n], nil } } -func (m *EventCrosschainFlagsUpdated) XXX_Merge(src proto.Message) { - xxx_messageInfo_EventCrosschainFlagsUpdated.Merge(m, src) +func (m *EventCCTXDisabled) XXX_Merge(src proto.Message) { + xxx_messageInfo_EventCCTXDisabled.Merge(m, src) } -func (m *EventCrosschainFlagsUpdated) XXX_Size() int { +func (m *EventCCTXDisabled) XXX_Size() int { return m.Size() } -func (m *EventCrosschainFlagsUpdated) XXX_DiscardUnknown() { - xxx_messageInfo_EventCrosschainFlagsUpdated.DiscardUnknown(m) +func (m *EventCCTXDisabled) XXX_DiscardUnknown() { + xxx_messageInfo_EventCCTXDisabled.DiscardUnknown(m) } -var xxx_messageInfo_EventCrosschainFlagsUpdated proto.InternalMessageInfo +var xxx_messageInfo_EventCCTXDisabled proto.InternalMessageInfo -func (m *EventCrosschainFlagsUpdated) GetMsgTypeUrl() string { +func (m *EventCCTXDisabled) GetMsgTypeUrl() string { if m != nil { return m.MsgTypeUrl } return "" } -func (m *EventCrosschainFlagsUpdated) GetIsInboundEnabled() bool { +func (m *EventCCTXDisabled) GetIsInboundEnabled() bool { if m != nil { return m.IsInboundEnabled } return false } -func (m *EventCrosschainFlagsUpdated) GetIsOutboundEnabled() bool { +func (m *EventCCTXDisabled) GetIsOutboundEnabled() bool { if m != nil { return m.IsOutboundEnabled } return false } -func (m *EventCrosschainFlagsUpdated) GetGasPriceIncreaseFlags() *GasPriceIncreaseFlags { +type EventCCTXEnabled struct { + MsgTypeUrl string `protobuf:"bytes,1,opt,name=msg_type_url,json=msgTypeUrl,proto3" json:"msg_type_url,omitempty"` + IsInboundEnabled bool `protobuf:"varint,2,opt,name=isInboundEnabled,proto3" json:"isInboundEnabled,omitempty"` + IsOutboundEnabled bool `protobuf:"varint,3,opt,name=isOutboundEnabled,proto3" json:"isOutboundEnabled,omitempty"` +} + +func (m *EventCCTXEnabled) Reset() { *m = EventCCTXEnabled{} } +func (m *EventCCTXEnabled) String() string { return proto.CompactTextString(m) } +func (*EventCCTXEnabled) ProtoMessage() {} +func (*EventCCTXEnabled) Descriptor() ([]byte, []int) { + return fileDescriptor_067e682d8234d605, []int{4} +} +func (m *EventCCTXEnabled) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *EventCCTXEnabled) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_EventCCTXEnabled.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 *EventCCTXEnabled) XXX_Merge(src proto.Message) { + xxx_messageInfo_EventCCTXEnabled.Merge(m, src) +} +func (m *EventCCTXEnabled) XXX_Size() int { + return m.Size() +} +func (m *EventCCTXEnabled) XXX_DiscardUnknown() { + xxx_messageInfo_EventCCTXEnabled.DiscardUnknown(m) +} + +var xxx_messageInfo_EventCCTXEnabled proto.InternalMessageInfo + +func (m *EventCCTXEnabled) GetMsgTypeUrl() string { if m != nil { - return m.GasPriceIncreaseFlags + return m.MsgTypeUrl } - return nil + return "" +} + +func (m *EventCCTXEnabled) GetIsInboundEnabled() bool { + if m != nil { + return m.IsInboundEnabled + } + return false } -func (m *EventCrosschainFlagsUpdated) GetSigner() string { +func (m *EventCCTXEnabled) GetIsOutboundEnabled() bool { if m != nil { - return m.Signer + return m.IsOutboundEnabled + } + return false +} + +type EventGasPriceIncreaseFlagsUpdated struct { + MsgTypeUrl string `protobuf:"bytes,1,opt,name=msg_type_url,json=msgTypeUrl,proto3" json:"msg_type_url,omitempty"` + GasPriceIncreaseFlags *GasPriceIncreaseFlags `protobuf:"bytes,2,opt,name=gasPriceIncreaseFlags,proto3" json:"gasPriceIncreaseFlags,omitempty"` +} + +func (m *EventGasPriceIncreaseFlagsUpdated) Reset() { *m = EventGasPriceIncreaseFlagsUpdated{} } +func (m *EventGasPriceIncreaseFlagsUpdated) String() string { return proto.CompactTextString(m) } +func (*EventGasPriceIncreaseFlagsUpdated) ProtoMessage() {} +func (*EventGasPriceIncreaseFlagsUpdated) Descriptor() ([]byte, []int) { + return fileDescriptor_067e682d8234d605, []int{5} +} +func (m *EventGasPriceIncreaseFlagsUpdated) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *EventGasPriceIncreaseFlagsUpdated) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_EventGasPriceIncreaseFlagsUpdated.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 *EventGasPriceIncreaseFlagsUpdated) XXX_Merge(src proto.Message) { + xxx_messageInfo_EventGasPriceIncreaseFlagsUpdated.Merge(m, src) +} +func (m *EventGasPriceIncreaseFlagsUpdated) XXX_Size() int { + return m.Size() +} +func (m *EventGasPriceIncreaseFlagsUpdated) XXX_DiscardUnknown() { + xxx_messageInfo_EventGasPriceIncreaseFlagsUpdated.DiscardUnknown(m) +} + +var xxx_messageInfo_EventGasPriceIncreaseFlagsUpdated proto.InternalMessageInfo + +func (m *EventGasPriceIncreaseFlagsUpdated) GetMsgTypeUrl() string { + if m != nil { + return m.MsgTypeUrl } return "" } +func (m *EventGasPriceIncreaseFlagsUpdated) GetGasPriceIncreaseFlags() *GasPriceIncreaseFlags { + if m != nil { + return m.GasPriceIncreaseFlags + } + return nil +} + func init() { proto.RegisterType((*EventBallotCreated)(nil), "zetachain.zetacore.observer.EventBallotCreated") proto.RegisterType((*EventKeygenBlockUpdated)(nil), "zetachain.zetacore.observer.EventKeygenBlockUpdated") proto.RegisterType((*EventNewObserverAdded)(nil), "zetachain.zetacore.observer.EventNewObserverAdded") - proto.RegisterType((*EventCrosschainFlagsUpdated)(nil), "zetachain.zetacore.observer.EventCrosschainFlagsUpdated") + proto.RegisterType((*EventCCTXDisabled)(nil), "zetachain.zetacore.observer.EventCCTXDisabled") + proto.RegisterType((*EventCCTXEnabled)(nil), "zetachain.zetacore.observer.EventCCTXEnabled") + proto.RegisterType((*EventGasPriceIncreaseFlagsUpdated)(nil), "zetachain.zetacore.observer.EventGasPriceIncreaseFlagsUpdated") } func init() { @@ -323,43 +421,44 @@ func init() { } var fileDescriptor_067e682d8234d605 = []byte{ - // 566 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x53, 0xbf, 0x6f, 0xd3, 0x40, - 0x14, 0x8e, 0xd3, 0x52, 0xc1, 0xa5, 0xd0, 0xf4, 0x44, 0x5b, 0x37, 0x95, 0x4c, 0x89, 0x84, 0x54, - 0x0a, 0x38, 0x52, 0x98, 0x40, 0x2c, 0x24, 0x2a, 0x25, 0x02, 0xd1, 0x2a, 0xa2, 0x0b, 0x8b, 0x75, - 0xb6, 0x5f, 0x6d, 0x2b, 0xce, 0x5d, 0x74, 0x77, 0x2e, 0x84, 0x9d, 0x9d, 0x15, 0xf1, 0x0f, 0x31, - 0x76, 0x64, 0x60, 0x40, 0xc9, 0x3f, 0x82, 0xee, 0xce, 0x71, 0x42, 0x13, 0x45, 0xd9, 0xce, 0xdf, - 0xfb, 0xbe, 0xe7, 0xef, 0xfd, 0x42, 0x47, 0x5f, 0x41, 0x92, 0x20, 0x26, 0x09, 0x6d, 0xe8, 0x17, - 0xe3, 0xd0, 0x60, 0xbe, 0x00, 0x7e, 0x05, 0xbc, 0x01, 0x57, 0x40, 0xa5, 0x70, 0x07, 0x9c, 0x49, - 0x86, 0x0f, 0x0a, 0xa6, 0x3b, 0x61, 0xba, 0x13, 0x66, 0xed, 0x7e, 0xc4, 0x22, 0xa6, 0x79, 0x0d, - 0xf5, 0x32, 0x92, 0x5a, 0x73, 0x59, 0xf2, 0x80, 0x33, 0x21, 0x74, 0xd0, 0xbb, 0x4c, 0x49, 0x94, - 0xff, 0xa6, 0x76, 0xbc, 0x4c, 0x33, 0x79, 0x18, 0x6e, 0xfd, 0x8f, 0x85, 0xf0, 0x89, 0xf2, 0xd8, - 0x22, 0x69, 0xca, 0x64, 0x9b, 0x03, 0x91, 0x10, 0xe2, 0x43, 0xb4, 0xd9, 0x17, 0x91, 0x27, 0x87, - 0x03, 0xf0, 0x32, 0x9e, 0xda, 0xd6, 0xa1, 0x75, 0x74, 0xa7, 0x8b, 0xfa, 0x22, 0xfa, 0x38, 0x1c, - 0xc0, 0x05, 0x4f, 0xf1, 0x13, 0xb4, 0xed, 0x6b, 0x89, 0x97, 0x84, 0x40, 0x65, 0x72, 0x99, 0x00, - 0xb7, 0xcb, 0x9a, 0x56, 0x35, 0x81, 0x4e, 0x81, 0xe3, 0xc7, 0xa8, 0x6a, 0xfe, 0x4b, 0x64, 0xc2, - 0xa8, 0x17, 0x13, 0x11, 0xdb, 0x6b, 0x9a, 0xbb, 0x35, 0x83, 0xbf, 0x25, 0x22, 0x56, 0x79, 0x67, - 0xa9, 0xba, 0x0c, 0x7b, 0xdd, 0xe4, 0x9d, 0x09, 0xb4, 0x15, 0x8e, 0x1f, 0xa0, 0x4a, 0x6e, 0x42, - 0x39, 0xb5, 0x6f, 0x19, 0x97, 0x06, 0x52, 0x46, 0xeb, 0xdf, 0x2c, 0xb4, 0xa7, 0xcb, 0x7b, 0x07, - 0xc3, 0x08, 0x68, 0x2b, 0x65, 0x41, 0xef, 0x62, 0x10, 0xae, 0x58, 0xe3, 0x43, 0xb4, 0xd9, 0xd3, - 0x3a, 0xcf, 0x57, 0xc2, 0xbc, 0xbc, 0x4a, 0x6f, 0x9a, 0x0b, 0x3f, 0x42, 0xf7, 0x72, 0xca, 0x20, - 0xf3, 0x7b, 0x30, 0x14, 0x79, 0x5d, 0x77, 0x0d, 0x7a, 0x6e, 0xc0, 0xfa, 0x8f, 0x32, 0xda, 0xd1, - 0x3e, 0x3e, 0xc0, 0xe7, 0xb3, 0x7c, 0x02, 0xaf, 0xc3, 0x70, 0x25, 0x17, 0x45, 0xf3, 0x80, 0x7b, - 0x24, 0x0c, 0x39, 0x08, 0x91, 0x3b, 0xd9, 0x62, 0xd3, 0x54, 0x0a, 0xc6, 0xaf, 0x50, 0x4d, 0x4f, - 0x3c, 0x4d, 0x80, 0x4a, 0x2f, 0xe2, 0x84, 0x4a, 0x80, 0x42, 0x64, 0x9c, 0xd9, 0x53, 0xc6, 0xa9, - 0x21, 0x4c, 0xd4, 0x2f, 0xd1, 0xfe, 0x02, 0xb5, 0xa9, 0x2b, 0x1f, 0xc1, 0xde, 0x9c, 0xd8, 0x54, - 0x88, 0x5f, 0xa0, 0xfd, 0xc2, 0x64, 0x4a, 0x84, 0x34, 0x1d, 0xf3, 0x02, 0x96, 0x51, 0xa9, 0xe7, - 0xb2, 0xde, 0xdd, 0x9d, 0x10, 0xde, 0x13, 0x21, 0x75, 0xf7, 0xda, 0x2a, 0x5a, 0xff, 0x59, 0x46, - 0x07, 0xba, 0x37, 0xed, 0x62, 0x9d, 0xdf, 0xa8, 0x6d, 0x5e, 0x7d, 0x4e, 0xc7, 0xa8, 0x9a, 0x88, - 0x0e, 0xf5, 0x59, 0x46, 0xc3, 0x13, 0x4a, 0xfc, 0x14, 0x42, 0xdd, 0xa1, 0xdb, 0xdd, 0x39, 0x1c, - 0x3f, 0x45, 0xdb, 0x89, 0x38, 0xcb, 0xe4, 0x7f, 0xe4, 0x35, 0x4d, 0x9e, 0x0f, 0xe0, 0x18, 0xed, - 0x44, 0x44, 0x9c, 0xf3, 0x24, 0x80, 0x0e, 0x0d, 0x38, 0x10, 0x01, 0xda, 0x9b, 0x6e, 0x47, 0xa5, - 0xd9, 0x74, 0x97, 0x5c, 0xb4, 0x7b, 0xba, 0x48, 0xd9, 0x5d, 0x9c, 0x10, 0xef, 0xa2, 0x0d, 0x91, - 0x44, 0x14, 0x78, 0xbe, 0xc5, 0xf9, 0x57, 0xab, 0xf3, 0x6b, 0xe4, 0x58, 0xd7, 0x23, 0xc7, 0xfa, - 0x3b, 0x72, 0xac, 0xef, 0x63, 0xa7, 0x74, 0x3d, 0x76, 0x4a, 0xbf, 0xc7, 0x4e, 0xe9, 0x53, 0x23, - 0x4a, 0x64, 0x9c, 0xf9, 0x6e, 0xc0, 0xfa, 0xfa, 0xce, 0x9f, 0xdd, 0x38, 0xf9, 0x2f, 0xd3, 0xa3, - 0x57, 0xbd, 0x13, 0xfe, 0x86, 0x3e, 0xf9, 0xe7, 0xff, 0x02, 0x00, 0x00, 0xff, 0xff, 0x7f, 0xe4, - 0xf6, 0x72, 0xb1, 0x04, 0x00, 0x00, + // 582 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xc4, 0x54, 0x41, 0x6f, 0xd3, 0x30, + 0x14, 0x6e, 0xb6, 0x81, 0xc0, 0x1d, 0xac, 0x8d, 0x18, 0xcb, 0x8a, 0x14, 0xb6, 0x4a, 0x48, 0x63, + 0x40, 0x2a, 0x95, 0x13, 0x88, 0x0b, 0x2d, 0x63, 0x54, 0x20, 0x36, 0x55, 0x9b, 0x84, 0xb8, 0x44, + 0x4e, 0xf2, 0x96, 0x44, 0x4d, 0xed, 0xca, 0x76, 0x06, 0xe5, 0xce, 0x15, 0xb8, 0xf2, 0x2b, 0xf8, + 0x1b, 0x1c, 0x77, 0xe4, 0xc0, 0x01, 0xb5, 0x7f, 0x04, 0xd9, 0x4e, 0xd2, 0x42, 0xab, 0xaa, 0xb7, + 0xdd, 0xac, 0xf7, 0xbe, 0xef, 0xf3, 0xf7, 0x3d, 0x27, 0x0f, 0xed, 0x7d, 0x02, 0x81, 0xfd, 0x08, + 0xc7, 0xa4, 0xa1, 0x4e, 0x94, 0x41, 0x83, 0x7a, 0x1c, 0xd8, 0x39, 0xb0, 0x06, 0x9c, 0x03, 0x11, + 0xdc, 0x19, 0x30, 0x2a, 0xa8, 0x79, 0xa7, 0x40, 0x3a, 0x39, 0xd2, 0xc9, 0x91, 0xb5, 0x5b, 0x21, + 0x0d, 0xa9, 0xc2, 0x35, 0xe4, 0x49, 0x53, 0x6a, 0xcd, 0x45, 0xe2, 0x3e, 0xa3, 0x9c, 0xab, 0xa6, + 0x7b, 0x96, 0xe0, 0x30, 0xbb, 0xa6, 0xb6, 0xbf, 0x88, 0x93, 0x1f, 0x34, 0xb6, 0xfe, 0xdb, 0x40, + 0xe6, 0x81, 0xf4, 0xd8, 0xc2, 0x49, 0x42, 0x45, 0x9b, 0x01, 0x16, 0x10, 0x98, 0x3b, 0x68, 0xbd, + 0xcf, 0x43, 0x57, 0x0c, 0x07, 0xe0, 0xa6, 0x2c, 0xb1, 0x8c, 0x1d, 0x63, 0xef, 0x7a, 0x17, 0xf5, + 0x79, 0x78, 0x32, 0x1c, 0xc0, 0x29, 0x4b, 0xcc, 0x07, 0xa8, 0xea, 0x29, 0x8a, 0x1b, 0x07, 0x40, + 0x44, 0x7c, 0x16, 0x03, 0xb3, 0x56, 0x14, 0xac, 0xa2, 0x1b, 0x9d, 0xa2, 0x6e, 0xde, 0x47, 0x15, + 0x7d, 0x2f, 0x16, 0x31, 0x25, 0x6e, 0x84, 0x79, 0x64, 0xad, 0x2a, 0xec, 0xc6, 0x54, 0xfd, 0x15, + 0xe6, 0x91, 0xd4, 0x9d, 0x86, 0xaa, 0x18, 0xd6, 0x9a, 0xd6, 0x9d, 0x6a, 0xb4, 0x65, 0xdd, 0xbc, + 0x8b, 0xca, 0x99, 0x09, 0xe9, 0xd4, 0xba, 0xa2, 0x5d, 0xea, 0x92, 0x34, 0x5a, 0xff, 0x6c, 0xa0, + 0x2d, 0x15, 0xef, 0x35, 0x0c, 0x43, 0x20, 0xad, 0x84, 0xfa, 0xbd, 0xd3, 0x41, 0xb0, 0x64, 0xc6, + 0x5d, 0xb4, 0xde, 0x53, 0x3c, 0xd7, 0x93, 0xc4, 0x2c, 0x5e, 0xb9, 0x37, 0xd1, 0x32, 0xef, 0xa1, + 0x9b, 0x19, 0x64, 0x90, 0x7a, 0x3d, 0x18, 0xf2, 0x2c, 0xd7, 0x0d, 0x5d, 0x3d, 0xd6, 0xc5, 0xfa, + 0xf7, 0x15, 0xb4, 0xa9, 0x7c, 0xbc, 0x85, 0x0f, 0x47, 0xd9, 0x0b, 0x3c, 0x0f, 0x82, 0xa5, 0x5c, + 0x14, 0xc3, 0x03, 0xe6, 0xe2, 0x20, 0x60, 0xc0, 0x79, 0xe6, 0x64, 0x83, 0x4e, 0xa4, 0x64, 0xd9, + 0x7c, 0x86, 0x6a, 0xea, 0xc5, 0x93, 0x18, 0x88, 0x70, 0x43, 0x86, 0x89, 0x00, 0x28, 0x48, 0xda, + 0x99, 0x35, 0x41, 0x1c, 0x6a, 0x40, 0xce, 0x7e, 0x8a, 0xb6, 0xe7, 0xb0, 0x75, 0xae, 0xec, 0x09, + 0xb6, 0x66, 0xc8, 0x3a, 0xa1, 0xf9, 0x04, 0x6d, 0x17, 0x26, 0x13, 0xcc, 0x85, 0x9e, 0x98, 0xeb, + 0xd3, 0x94, 0x08, 0xf5, 0x2e, 0x6b, 0xdd, 0xdb, 0x39, 0xe0, 0x0d, 0xe6, 0x42, 0x4d, 0xaf, 0x2d, + 0xbb, 0xf5, 0xaf, 0x06, 0xaa, 0xaa, 0xd9, 0xb4, 0xdb, 0x27, 0xef, 0x5e, 0xc4, 0x1c, 0x7b, 0xc9, + 0x52, 0x73, 0xd9, 0x47, 0x95, 0x98, 0x77, 0x88, 0x47, 0x53, 0x12, 0x1c, 0x10, 0xc5, 0x52, 0x73, + 0xb9, 0xd6, 0x9d, 0xa9, 0x9b, 0x0f, 0x51, 0x35, 0xe6, 0x47, 0xa9, 0xf8, 0x07, 0xbc, 0xaa, 0xc0, + 0xb3, 0x8d, 0xfa, 0x17, 0x03, 0x55, 0x0a, 0x47, 0xb9, 0xc4, 0x65, 0x1a, 0xfa, 0x61, 0xa0, 0x5d, + 0x65, 0xe8, 0x10, 0xf3, 0x63, 0x16, 0xfb, 0xd0, 0x21, 0x3e, 0x03, 0xcc, 0xe1, 0xa5, 0xfc, 0xed, + 0x97, 0xff, 0xa0, 0x23, 0xb4, 0x19, 0xce, 0x53, 0x50, 0x36, 0xcb, 0xcd, 0xa6, 0xb3, 0x60, 0x41, + 0x39, 0x73, 0xef, 0xee, 0xce, 0x17, 0x6c, 0x75, 0x7e, 0x8e, 0x6c, 0xe3, 0x62, 0x64, 0x1b, 0x7f, + 0x46, 0xb6, 0xf1, 0x6d, 0x6c, 0x97, 0x2e, 0xc6, 0x76, 0xe9, 0xd7, 0xd8, 0x2e, 0xbd, 0x6f, 0x84, + 0xb1, 0x88, 0x52, 0xcf, 0xf1, 0x69, 0x5f, 0xad, 0xa7, 0x47, 0xff, 0x6d, 0xaa, 0x8f, 0x93, 0x5d, + 0x25, 0x93, 0x70, 0xef, 0xaa, 0xda, 0x54, 0x8f, 0xff, 0x06, 0x00, 0x00, 0xff, 0xff, 0x12, 0xe0, + 0x05, 0x6e, 0x68, 0x05, 0x00, 0x00, } func (m *EventBallotCreated) Marshal() (dAtA []byte, err error) { @@ -520,7 +619,7 @@ func (m *EventNewObserverAdded) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } -func (m *EventCrosschainFlagsUpdated) Marshal() (dAtA []byte, err error) { +func (m *EventCCTXDisabled) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) n, err := m.MarshalToSizedBuffer(dAtA[:size]) @@ -530,35 +629,66 @@ func (m *EventCrosschainFlagsUpdated) Marshal() (dAtA []byte, err error) { return dAtA[:n], nil } -func (m *EventCrosschainFlagsUpdated) MarshalTo(dAtA []byte) (int, error) { +func (m *EventCCTXDisabled) MarshalTo(dAtA []byte) (int, error) { size := m.Size() return m.MarshalToSizedBuffer(dAtA[:size]) } -func (m *EventCrosschainFlagsUpdated) MarshalToSizedBuffer(dAtA []byte) (int, error) { +func (m *EventCCTXDisabled) MarshalToSizedBuffer(dAtA []byte) (int, error) { i := len(dAtA) _ = i var l int _ = l - if len(m.Signer) > 0 { - i -= len(m.Signer) - copy(dAtA[i:], m.Signer) - i = encodeVarintEvents(dAtA, i, uint64(len(m.Signer))) + if m.IsOutboundEnabled { i-- - dAtA[i] = 0x2a + if m.IsOutboundEnabled { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x18 } - if m.GasPriceIncreaseFlags != nil { - { - size, err := m.GasPriceIncreaseFlags.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintEvents(dAtA, i, uint64(size)) + if m.IsInboundEnabled { + i-- + if m.IsInboundEnabled { + dAtA[i] = 1 + } else { + dAtA[i] = 0 } i-- - dAtA[i] = 0x22 + dAtA[i] = 0x10 + } + if len(m.MsgTypeUrl) > 0 { + i -= len(m.MsgTypeUrl) + copy(dAtA[i:], m.MsgTypeUrl) + i = encodeVarintEvents(dAtA, i, uint64(len(m.MsgTypeUrl))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *EventCCTXEnabled) 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 *EventCCTXEnabled) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *EventCCTXEnabled) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l if m.IsOutboundEnabled { i-- if m.IsOutboundEnabled { @@ -589,6 +719,48 @@ func (m *EventCrosschainFlagsUpdated) MarshalToSizedBuffer(dAtA []byte) (int, er return len(dAtA) - i, nil } +func (m *EventGasPriceIncreaseFlagsUpdated) 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 *EventGasPriceIncreaseFlagsUpdated) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *EventGasPriceIncreaseFlagsUpdated) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.GasPriceIncreaseFlags != nil { + { + size, err := m.GasPriceIncreaseFlags.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintEvents(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + } + if len(m.MsgTypeUrl) > 0 { + i -= len(m.MsgTypeUrl) + copy(dAtA[i:], m.MsgTypeUrl) + i = encodeVarintEvents(dAtA, i, uint64(len(m.MsgTypeUrl))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + func encodeVarintEvents(dAtA []byte, offset int, v uint64) int { offset -= sovEvents(v) base := offset @@ -678,7 +850,7 @@ func (m *EventNewObserverAdded) Size() (n int) { return n } -func (m *EventCrosschainFlagsUpdated) Size() (n int) { +func (m *EventCCTXDisabled) Size() (n int) { if m == nil { return 0 } @@ -694,14 +866,42 @@ func (m *EventCrosschainFlagsUpdated) Size() (n int) { if m.IsOutboundEnabled { n += 2 } - if m.GasPriceIncreaseFlags != nil { - l = m.GasPriceIncreaseFlags.Size() + return n +} + +func (m *EventCCTXEnabled) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.MsgTypeUrl) + if l > 0 { n += 1 + l + sovEvents(uint64(l)) } - l = len(m.Signer) + if m.IsInboundEnabled { + n += 2 + } + if m.IsOutboundEnabled { + n += 2 + } + return n +} + +func (m *EventGasPriceIncreaseFlagsUpdated) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.MsgTypeUrl) if l > 0 { n += 1 + l + sovEvents(uint64(l)) } + if m.GasPriceIncreaseFlags != nil { + l = m.GasPriceIncreaseFlags.Size() + n += 1 + l + sovEvents(uint64(l)) + } return n } @@ -1264,7 +1464,7 @@ func (m *EventNewObserverAdded) Unmarshal(dAtA []byte) error { } return nil } -func (m *EventCrosschainFlagsUpdated) Unmarshal(dAtA []byte) error { +func (m *EventCCTXDisabled) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -1287,10 +1487,10 @@ func (m *EventCrosschainFlagsUpdated) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: EventCrosschainFlagsUpdated: wiretype end group for non-group") + return fmt.Errorf("proto: EventCCTXDisabled: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: EventCrosschainFlagsUpdated: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: EventCCTXDisabled: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -1365,11 +1565,61 @@ func (m *EventCrosschainFlagsUpdated) Unmarshal(dAtA []byte) error { } } m.IsOutboundEnabled = bool(v != 0) - case 4: + default: + iNdEx = preIndex + skippy, err := skipEvents(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthEvents + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *EventCCTXEnabled) 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 ErrIntOverflowEvents + } + 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: EventCCTXEnabled: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: EventCCTXEnabled: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field GasPriceIncreaseFlags", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field MsgTypeUrl", wireType) } - var msglen int + var stringLen uint64 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowEvents @@ -1379,31 +1629,117 @@ func (m *EventCrosschainFlagsUpdated) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + stringLen |= uint64(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + intStringLen := int(stringLen) + if intStringLen < 0 { return ErrInvalidLengthEvents } - postIndex := iNdEx + msglen + postIndex := iNdEx + intStringLen if postIndex < 0 { return ErrInvalidLengthEvents } if postIndex > l { return io.ErrUnexpectedEOF } - if m.GasPriceIncreaseFlags == nil { - m.GasPriceIncreaseFlags = &GasPriceIncreaseFlags{} + m.MsgTypeUrl = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field IsInboundEnabled", wireType) } - if err := m.GasPriceIncreaseFlags.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.IsInboundEnabled = bool(v != 0) + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field IsOutboundEnabled", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.IsOutboundEnabled = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipEvents(dAtA[iNdEx:]) + if err != nil { return err } - iNdEx = postIndex - case 5: + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthEvents + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *EventGasPriceIncreaseFlagsUpdated) 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 ErrIntOverflowEvents + } + 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: EventGasPriceIncreaseFlagsUpdated: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: EventGasPriceIncreaseFlagsUpdated: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Signer", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field MsgTypeUrl", wireType) } var stringLen uint64 for shift := uint(0); ; shift += 7 { @@ -1431,7 +1767,43 @@ func (m *EventCrosschainFlagsUpdated) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - m.Signer = string(dAtA[iNdEx:postIndex]) + m.MsgTypeUrl = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field GasPriceIncreaseFlags", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvents + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthEvents + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthEvents + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.GasPriceIncreaseFlags == nil { + m.GasPriceIncreaseFlags = &GasPriceIncreaseFlags{} + } + if err := m.GasPriceIncreaseFlags.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } iNdEx = postIndex default: iNdEx = preIndex diff --git a/x/observer/types/message_disable_cctx_flags.go b/x/observer/types/message_disable_cctx_flags.go new file mode 100644 index 0000000000..dd5eb1bedb --- /dev/null +++ b/x/observer/types/message_disable_cctx_flags.go @@ -0,0 +1,55 @@ +package types + +import ( + cosmoserrors "cosmossdk.io/errors" + sdk "github.com/cosmos/cosmos-sdk/types" + sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" +) + +const ( + TypeMsgDisableCCTX = "disable_crosschain" +) + +var _ sdk.Msg = &MsgDisableCCTX{} + +func NewMsgDisableCCTX(creator string, disableOutbound, disableInbound bool) *MsgDisableCCTX { + return &MsgDisableCCTX{ + Creator: creator, + DisableInbound: disableInbound, + DisableOutbound: disableOutbound, + } +} + +func (msg *MsgDisableCCTX) Route() string { + return RouterKey +} + +func (msg *MsgDisableCCTX) Type() string { + return TypeMsgDisableCCTX +} + +func (msg *MsgDisableCCTX) GetSigners() []sdk.AccAddress { + creator, err := sdk.AccAddressFromBech32(msg.Creator) + if err != nil { + panic(err) + } + return []sdk.AccAddress{creator} +} + +func (msg *MsgDisableCCTX) GetSignBytes() []byte { + bz := ModuleCdc.MustMarshalJSON(msg) + return sdk.MustSortJSON(bz) +} + +func (msg *MsgDisableCCTX) ValidateBasic() error { + if _, err := sdk.AccAddressFromBech32(msg.Creator); err != nil { + return cosmoserrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) + } + if !msg.DisableInbound && !msg.DisableOutbound { + return cosmoserrors.Wrap( + sdkerrors.ErrInvalidRequest, + "at least one of DisableInbound or DisableOutbound must be true", + ) + } + return nil +} diff --git a/x/observer/types/message_disable_cctx_flags_test.go b/x/observer/types/message_disable_cctx_flags_test.go new file mode 100644 index 0000000000..40a4d023d2 --- /dev/null +++ b/x/observer/types/message_disable_cctx_flags_test.go @@ -0,0 +1,104 @@ +package types_test + +import ( + "testing" + + sdk "github.com/cosmos/cosmos-sdk/types" + "github.com/stretchr/testify/require" + + "github.com/zeta-chain/zetacore/testutil/sample" + "github.com/zeta-chain/zetacore/x/observer/types" +) + +func TestMsgDisableCCTX_ValidateBasic(t *testing.T) { + tt := []struct { + name string + msg *types.MsgDisableCCTX + err require.ErrorAssertionFunc + }{ + { + name: "invalid creator address", + msg: types.NewMsgDisableCCTX("invalid", true, true), + err: func(t require.TestingT, err error, i ...interface{}) { + require.Contains(t, err.Error(), "invalid creator address") + }, + }, + { + name: "invalid flags", + msg: types.NewMsgDisableCCTX(sample.AccAddress(), false, false), + err: func(t require.TestingT, err error, i ...interface{}) { + require.Contains(t, err.Error(), "at least one of DisableInbound or DisableOutbound must be true") + }, + }, + { + name: "valid", + msg: types.NewMsgDisableCCTX(sample.AccAddress(), true, true), + err: require.NoError, + }, + } + for _, tc := range tt { + t.Run(tc.name, func(t *testing.T) { + tc.err(t, tc.msg.ValidateBasic()) + }) + } +} + +func TestMsgDisableCCTX_GetSigners(t *testing.T) { + signer := sample.AccAddress() + tests := []struct { + name string + msg types.MsgDisableCCTX + panics bool + }{ + { + name: "valid signer", + msg: types.MsgDisableCCTX{ + Creator: signer, + }, + panics: false, + }, + { + name: "invalid signer", + msg: types.MsgDisableCCTX{ + Creator: "invalid", + }, + panics: true, + }, + } + + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + if !tt.panics { + signers := tt.msg.GetSigners() + require.Equal(t, []sdk.AccAddress{sdk.MustAccAddressFromBech32(signer)}, signers) + } else { + require.Panics(t, func() { + tt.msg.GetSigners() + }) + } + }) + } +} + +func TestMsgDisableCCTX_Type(t *testing.T) { + msg := types.MsgDisableCCTX{ + Creator: sample.AccAddress(), + } + require.Equal(t, types.TypeMsgDisableCCTX, msg.Type()) +} + +func TestMsgDisableCCTX_Route(t *testing.T) { + msg := types.MsgDisableCCTX{ + Creator: sample.AccAddress(), + } + require.Equal(t, types.RouterKey, msg.Route()) +} + +func TestMsgDisableCCTX_GetSignBytes(t *testing.T) { + msg := types.MsgDisableCCTX{ + Creator: sample.AccAddress(), + } + require.NotPanics(t, func() { + msg.GetSignBytes() + }) +} diff --git a/x/observer/types/message_enable_cctx_flags.go b/x/observer/types/message_enable_cctx_flags.go new file mode 100644 index 0000000000..d85117fb34 --- /dev/null +++ b/x/observer/types/message_enable_cctx_flags.go @@ -0,0 +1,55 @@ +package types + +import ( + cosmoserrors "cosmossdk.io/errors" + sdk "github.com/cosmos/cosmos-sdk/types" + sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" +) + +const ( + TypeMsgEnableCCTX = "enable_crosschain" +) + +var _ sdk.Msg = &MsgEnableCCTX{} + +func NewMsgEnableCCTX(creator string, enableInbound, enableOutbound bool) *MsgEnableCCTX { + return &MsgEnableCCTX{ + Creator: creator, + EnableInbound: enableInbound, + EnableOutbound: enableOutbound, + } +} + +func (msg *MsgEnableCCTX) Route() string { + return RouterKey +} + +func (msg *MsgEnableCCTX) Type() string { + return TypeMsgEnableCCTX +} + +func (msg *MsgEnableCCTX) GetSigners() []sdk.AccAddress { + creator, err := sdk.AccAddressFromBech32(msg.Creator) + if err != nil { + panic(err) + } + return []sdk.AccAddress{creator} +} + +func (msg *MsgEnableCCTX) GetSignBytes() []byte { + bz := ModuleCdc.MustMarshalJSON(msg) + return sdk.MustSortJSON(bz) +} + +func (msg *MsgEnableCCTX) ValidateBasic() error { + if _, err := sdk.AccAddressFromBech32(msg.Creator); err != nil { + return cosmoserrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) + } + if !msg.EnableInbound && !msg.EnableOutbound { + return cosmoserrors.Wrap( + sdkerrors.ErrInvalidRequest, + "at least one of EnableInbound or EnableOutbound must be true", + ) + } + return nil +} diff --git a/x/observer/types/message_enable_cctx_flags_test.go b/x/observer/types/message_enable_cctx_flags_test.go new file mode 100644 index 0000000000..2033837e7d --- /dev/null +++ b/x/observer/types/message_enable_cctx_flags_test.go @@ -0,0 +1,104 @@ +package types_test + +import ( + "testing" + + sdk "github.com/cosmos/cosmos-sdk/types" + "github.com/stretchr/testify/require" + + "github.com/zeta-chain/zetacore/testutil/sample" + "github.com/zeta-chain/zetacore/x/observer/types" +) + +func TestMsgEnableCCTX_ValidateBasic(t *testing.T) { + tt := []struct { + name string + msg *types.MsgEnableCCTX + err require.ErrorAssertionFunc + }{ + { + name: "invalid creator address", + msg: types.NewMsgEnableCCTX("invalid", true, true), + err: func(t require.TestingT, err error, i ...interface{}) { + require.Contains(t, err.Error(), "invalid creator address") + }, + }, + { + name: "invalid flags", + msg: types.NewMsgEnableCCTX(sample.AccAddress(), false, false), + err: func(t require.TestingT, err error, i ...interface{}) { + require.Contains(t, err.Error(), "at least one of EnableInbound or EnableOutbound must be true") + }, + }, + { + name: "valid", + msg: types.NewMsgEnableCCTX(sample.AccAddress(), true, true), + err: require.NoError, + }, + } + for _, tc := range tt { + t.Run(tc.name, func(t *testing.T) { + tc.err(t, tc.msg.ValidateBasic()) + }) + } +} + +func TestMsgEnableCCTX_GetSigners(t *testing.T) { + signer := sample.AccAddress() + tests := []struct { + name string + msg types.MsgEnableCCTX + panics bool + }{ + { + name: "valid signer", + msg: types.MsgEnableCCTX{ + Creator: signer, + }, + panics: false, + }, + { + name: "invalid signer", + msg: types.MsgEnableCCTX{ + Creator: "invalid", + }, + panics: true, + }, + } + + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + if !tt.panics { + signers := tt.msg.GetSigners() + require.Equal(t, []sdk.AccAddress{sdk.MustAccAddressFromBech32(signer)}, signers) + } else { + require.Panics(t, func() { + tt.msg.GetSigners() + }) + } + }) + } +} + +func TestMsgEnableCCTX_Type(t *testing.T) { + msg := types.MsgEnableCCTX{ + Creator: sample.AccAddress(), + } + require.Equal(t, types.TypeMsgEnableCCTX, msg.Type()) +} + +func TestMsgEnableCCTX_Route(t *testing.T) { + msg := types.MsgEnableCCTX{ + Creator: sample.AccAddress(), + } + require.Equal(t, types.RouterKey, msg.Route()) +} + +func TestMsgEnableCCTX_GetSignBytes(t *testing.T) { + msg := types.MsgEnableCCTX{ + Creator: sample.AccAddress(), + } + require.NotPanics(t, func() { + msg.GetSignBytes() + }) +} diff --git a/x/observer/types/message_update_crosschain_flags.go b/x/observer/types/message_update_crosschain_flags.go deleted file mode 100644 index 472d9ffdf6..0000000000 --- a/x/observer/types/message_update_crosschain_flags.go +++ /dev/null @@ -1,86 +0,0 @@ -package types - -import ( - "errors" - - cosmoserrors "cosmossdk.io/errors" - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - - authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" -) - -const ( - TypeMsgUpdateCrosschainFlags = "update_crosschain_flags" -) - -var _ sdk.Msg = &MsgUpdateCrosschainFlags{} - -func NewMsgUpdateCrosschainFlags(creator string, isInboundEnabled, isOutboundEnabled bool) *MsgUpdateCrosschainFlags { - return &MsgUpdateCrosschainFlags{ - Creator: creator, - IsInboundEnabled: isInboundEnabled, - IsOutboundEnabled: isOutboundEnabled, - } -} - -func (msg *MsgUpdateCrosschainFlags) Route() string { - return RouterKey -} - -func (msg *MsgUpdateCrosschainFlags) Type() string { - return TypeMsgUpdateCrosschainFlags -} - -func (msg *MsgUpdateCrosschainFlags) GetSigners() []sdk.AccAddress { - creator, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - panic(err) - } - return []sdk.AccAddress{creator} -} - -func (msg *MsgUpdateCrosschainFlags) GetSignBytes() []byte { - bz := ModuleCdc.MustMarshalJSON(msg) - return sdk.MustSortJSON(bz) -} - -func (msg *MsgUpdateCrosschainFlags) ValidateBasic() error { - if _, err := sdk.AccAddressFromBech32(msg.Creator); err != nil { - return cosmoserrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) - } - - if msg.GasPriceIncreaseFlags != nil { - if err := msg.GasPriceIncreaseFlags.Validate(); err != nil { - return cosmoserrors.Wrap(sdkerrors.ErrInvalidRequest, err.Error()) - } - } - - return nil -} - -func (gpf GasPriceIncreaseFlags) Validate() error { - if gpf.EpochLength <= 0 { - return errors.New("epoch length must be positive") - } - if gpf.RetryInterval <= 0 { - return errors.New("retry interval must be positive") - } - return nil -} - -// GetRequiredPolicyType returns the required policy type for the message to execute the message -// Group emergency should only be able to stop or disable functionalities in case of emergency -// this concerns disabling inbound and outbound txs or block header verification -// every other action requires group admin -// TODO: add separate message for each group -// https://github.com/zeta-chain/node/issues/1562 -func (msg *MsgUpdateCrosschainFlags) GetRequiredPolicyType() authoritytypes.PolicyType { - if msg.IsInboundEnabled || msg.IsOutboundEnabled { - return authoritytypes.PolicyType_groupOperational - } - if msg.GasPriceIncreaseFlags != nil { - return authoritytypes.PolicyType_groupOperational - } - return authoritytypes.PolicyType_groupEmergency -} diff --git a/x/observer/types/message_update_crosschain_flags_test.go b/x/observer/types/message_update_crosschain_flags_test.go deleted file mode 100644 index ae529d7d02..0000000000 --- a/x/observer/types/message_update_crosschain_flags_test.go +++ /dev/null @@ -1,246 +0,0 @@ -package types_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/stretchr/testify/require" - - "github.com/zeta-chain/zetacore/testutil/sample" - authoritytypes "github.com/zeta-chain/zetacore/x/authority/types" - "github.com/zeta-chain/zetacore/x/observer/types" -) - -func TestMsgUpdateCrosschainFlags_ValidateBasic(t *testing.T) { - tests := []struct { - name string - msg types.MsgUpdateCrosschainFlags - err error - }{ - { - name: "invalid address", - msg: types.MsgUpdateCrosschainFlags{ - Creator: "invalid_address", - }, - err: sdkerrors.ErrInvalidAddress, - }, - { - name: "invalid gas price increase flags", - msg: types.MsgUpdateCrosschainFlags{ - Creator: sample.AccAddress(), - GasPriceIncreaseFlags: &types.GasPriceIncreaseFlags{ - EpochLength: -1, - RetryInterval: 1, - GasPriceIncreasePercent: 1, - }, - }, - err: sdkerrors.ErrInvalidRequest, - }, - { - name: "valid address", - msg: types.MsgUpdateCrosschainFlags{ - Creator: sample.AccAddress(), - GasPriceIncreaseFlags: &types.GasPriceIncreaseFlags{ - EpochLength: 1, - RetryInterval: 1, - GasPriceIncreasePercent: 1, - }, - }, - }, - { - name: "gas price increase flags can be nil", - msg: types.MsgUpdateCrosschainFlags{ - Creator: sample.AccAddress(), - }, - }, - } - for _, tt := range tests { - t.Run(tt.name, func(t *testing.T) { - err := tt.msg.ValidateBasic() - if tt.err != nil { - require.ErrorIs(t, err, tt.err) - return - } - require.NoError(t, err) - }) - } -} - -func TestGasPriceIncreaseFlags_Validate(t *testing.T) { - tests := []struct { - name string - gpf types.GasPriceIncreaseFlags - errContains string - }{ - { - name: "invalid epoch length", - gpf: types.GasPriceIncreaseFlags{ - EpochLength: -1, - RetryInterval: 1, - GasPriceIncreasePercent: 1, - }, - errContains: "epoch length must be positive", - }, - { - name: "invalid retry interval", - gpf: types.GasPriceIncreaseFlags{ - EpochLength: 1, - RetryInterval: -1, - GasPriceIncreasePercent: 1, - }, - errContains: "retry interval must be positive", - }, - { - name: "valid", - gpf: types.GasPriceIncreaseFlags{ - EpochLength: 1, - RetryInterval: 1, - GasPriceIncreasePercent: 1, - }, - }, - { - name: "percent can be 0", - gpf: types.GasPriceIncreaseFlags{ - EpochLength: 1, - RetryInterval: 1, - GasPriceIncreasePercent: 0, - }, - }, - } - for _, tt := range tests { - t.Run(tt.name, func(t *testing.T) { - err := tt.gpf.Validate() - if tt.errContains != "" { - require.ErrorContains(t, err, tt.errContains) - return - } - require.NoError(t, err) - }) - } -} - -func TestMsgUpdateCrosschainFlags_GetRequiredPolicyType(t *testing.T) { - tests := []struct { - name string - msg types.MsgUpdateCrosschainFlags - want authoritytypes.PolicyType - }{ - { - name: "disabling outbound and inbound allows group 1", - msg: types.MsgUpdateCrosschainFlags{ - Creator: sample.AccAddress(), - IsInboundEnabled: false, - IsOutboundEnabled: false, - GasPriceIncreaseFlags: nil, - }, - want: authoritytypes.PolicyType_groupEmergency, - }, - - { - name: "updating gas price increase flags asserts group 2", - msg: types.MsgUpdateCrosschainFlags{ - Creator: sample.AccAddress(), - IsInboundEnabled: false, - IsOutboundEnabled: false, - GasPriceIncreaseFlags: &types.GasPriceIncreaseFlags{ - EpochLength: 1, - RetryInterval: 1, - GasPriceIncreasePercent: 1, - MaxPendingCctxs: 100, - }, - }, - want: authoritytypes.PolicyType_groupOperational, - }, - { - name: "enabling inbound asserts group 2", - msg: types.MsgUpdateCrosschainFlags{ - Creator: sample.AccAddress(), - IsInboundEnabled: true, - IsOutboundEnabled: false, - GasPriceIncreaseFlags: nil, - }, - want: authoritytypes.PolicyType_groupOperational, - }, - { - name: "enabling outbound asserts group 2", - msg: types.MsgUpdateCrosschainFlags{ - Creator: sample.AccAddress(), - IsInboundEnabled: false, - IsOutboundEnabled: true, - GasPriceIncreaseFlags: nil, - }, - want: authoritytypes.PolicyType_groupOperational, - }, - } - - for _, tt := range tests { - t.Run(tt.name, func(t *testing.T) { - require.EqualValues(t, tt.want, tt.msg.GetRequiredPolicyType()) - }) - } -} - -func TestMsgUpdateCrosschainFlags_GetSigners(t *testing.T) { - signer := sample.AccAddress() - tests := []struct { - name string - msg *types.MsgUpdateCrosschainFlags - panics bool - }{ - { - name: "valid signer", - msg: types.NewMsgUpdateCrosschainFlags( - signer, - true, - true, - ), - panics: false, - }, - { - name: "invalid signer", - msg: types.NewMsgUpdateCrosschainFlags( - "invalid", - true, - true, - ), - panics: true, - }, - } - - for _, tt := range tests { - t.Run(tt.name, func(t *testing.T) { - if !tt.panics { - signers := tt.msg.GetSigners() - require.Equal(t, []sdk.AccAddress{sdk.MustAccAddressFromBech32(signer)}, signers) - } else { - require.Panics(t, func() { - tt.msg.GetSigners() - }) - } - }) - } -} - -func TestMsgUpdateCrosschainFlags_Type(t *testing.T) { - msg := types.MsgUpdateCrosschainFlags{ - Creator: sample.AccAddress(), - } - require.Equal(t, types.TypeMsgUpdateCrosschainFlags, msg.Type()) -} - -func TestMsgUpdateCrosschainFlags_Route(t *testing.T) { - msg := types.MsgUpdateCrosschainFlags{ - Creator: sample.AccAddress(), - } - require.Equal(t, types.RouterKey, msg.Route()) -} - -func TestMsgUpdateCrosschainFlags_GetSignBytes(t *testing.T) { - msg := types.MsgUpdateCrosschainFlags{ - Creator: sample.AccAddress(), - } - require.NotPanics(t, func() { - msg.GetSignBytes() - }) -} diff --git a/x/observer/types/message_update_gas_price_increase_flags.go b/x/observer/types/message_update_gas_price_increase_flags.go new file mode 100644 index 0000000000..57d3bdf38d --- /dev/null +++ b/x/observer/types/message_update_gas_price_increase_flags.go @@ -0,0 +1,64 @@ +package types + +import ( + cosmoserrors "cosmossdk.io/errors" + sdk "github.com/cosmos/cosmos-sdk/types" + sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" + "github.com/pkg/errors" +) + +const ( + TypeMsgUpdateGasPriceIncreaseFlags = "update_gas_price_increase_flags" +) + +var _ sdk.Msg = &MsgUpdateGasPriceIncreaseFlags{} + +func NewMsgUpdateGasPriceIncreaseFlags(creator string, flags GasPriceIncreaseFlags) *MsgUpdateGasPriceIncreaseFlags { + return &MsgUpdateGasPriceIncreaseFlags{ + Creator: creator, + GasPriceIncreaseFlags: flags, + } +} + +func (msg *MsgUpdateGasPriceIncreaseFlags) Route() string { + return RouterKey +} + +func (msg *MsgUpdateGasPriceIncreaseFlags) Type() string { + return TypeMsgUpdateGasPriceIncreaseFlags +} + +func (msg *MsgUpdateGasPriceIncreaseFlags) GetSigners() []sdk.AccAddress { + creator, err := sdk.AccAddressFromBech32(msg.Creator) + if err != nil { + panic(err) + } + return []sdk.AccAddress{creator} +} + +func (msg *MsgUpdateGasPriceIncreaseFlags) GetSignBytes() []byte { + bz := ModuleCdc.MustMarshalJSON(msg) + return sdk.MustSortJSON(bz) +} + +func (msg *MsgUpdateGasPriceIncreaseFlags) ValidateBasic() error { + if _, err := sdk.AccAddressFromBech32(msg.Creator); err != nil { + return cosmoserrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) + } + + err := msg.GasPriceIncreaseFlags.Validate() + if err != nil { + return cosmoserrors.Wrap(sdkerrors.ErrInvalidRequest, err.Error()) + } + return nil +} + +func (gpf GasPriceIncreaseFlags) Validate() error { + if gpf.EpochLength <= 0 { + return errors.New("epoch length must be positive") + } + if gpf.RetryInterval <= 0 { + return errors.New("retry interval must be positive") + } + return nil +} diff --git a/x/observer/types/message_update_gas_price_increase_flags_test.go b/x/observer/types/message_update_gas_price_increase_flags_test.go new file mode 100644 index 0000000000..d432835b62 --- /dev/null +++ b/x/observer/types/message_update_gas_price_increase_flags_test.go @@ -0,0 +1,164 @@ +package types_test + +import ( + "testing" + + sdk "github.com/cosmos/cosmos-sdk/types" + "github.com/stretchr/testify/require" + + "github.com/zeta-chain/zetacore/testutil/sample" + "github.com/zeta-chain/zetacore/x/observer/types" +) + +func TestMsgUpdateGasPriceIncreaseFlags_ValidateBasic(t *testing.T) { + tt := []struct { + name string + msg *types.MsgUpdateGasPriceIncreaseFlags + err require.ErrorAssertionFunc + }{ + { + name: "invalid creator address", + msg: types.NewMsgUpdateGasPriceIncreaseFlags("invalid", types.DefaultGasPriceIncreaseFlags), + err: func(t require.TestingT, err error, i ...interface{}) { + require.Contains(t, err.Error(), "invalid creator address") + }, + }, + { + name: "invalid gas price increase flags", + msg: types.NewMsgUpdateGasPriceIncreaseFlags( + sample.AccAddress(), + types.GasPriceIncreaseFlags{ + EpochLength: -1, + RetryInterval: 1, + GasPriceIncreasePercent: 1, + }, + ), + err: func(t require.TestingT, err error, i ...interface{}) { + require.Contains(t, err.Error(), "invalid request") + }, + }, + { + name: "valid", + msg: types.NewMsgUpdateGasPriceIncreaseFlags(sample.AccAddress(), sample.GasPriceIncreaseFlags()), + err: require.NoError, + }, + } + for _, tc := range tt { + t.Run(tc.name, func(t *testing.T) { + tc.err(t, tc.msg.ValidateBasic()) + }) + } +} + +func TestMsgUpdateGasPriceIncreaseFlags_GetSigners(t *testing.T) { + signer := sample.AccAddress() + tests := []struct { + name string + msg types.MsgUpdateGasPriceIncreaseFlags + panics bool + }{ + { + name: "valid signer", + msg: types.MsgUpdateGasPriceIncreaseFlags{ + Creator: signer, + }, + panics: false, + }, + { + name: "invalid signer", + msg: types.MsgUpdateGasPriceIncreaseFlags{ + Creator: "invalid", + }, + panics: true, + }, + } + + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + if !tt.panics { + signers := tt.msg.GetSigners() + require.Equal(t, []sdk.AccAddress{sdk.MustAccAddressFromBech32(signer)}, signers) + } else { + require.Panics(t, func() { + tt.msg.GetSigners() + }) + } + }) + } +} + +func TestMsgUpdateGasPriceIncreaseFlags_Type(t *testing.T) { + msg := types.MsgUpdateGasPriceIncreaseFlags{ + Creator: sample.AccAddress(), + } + require.Equal(t, types.TypeMsgUpdateGasPriceIncreaseFlags, msg.Type()) +} + +func TestMsgUpdateGasPriceIncreaseFlags_Route(t *testing.T) { + msg := types.MsgUpdateGasPriceIncreaseFlags{ + Creator: sample.AccAddress(), + } + require.Equal(t, types.RouterKey, msg.Route()) +} + +func TestMsgUpdateGasPriceIncreaseFlags_GetSignBytes(t *testing.T) { + msg := types.MsgUpdateGasPriceIncreaseFlags{ + Creator: sample.AccAddress(), + } + require.NotPanics(t, func() { + msg.GetSignBytes() + }) +} + +func TestGasPriceIncreaseFlags_Validate(t *testing.T) { + tests := []struct { + name string + gpf types.GasPriceIncreaseFlags + errContains string + }{ + { + name: "invalid epoch length", + gpf: types.GasPriceIncreaseFlags{ + EpochLength: -1, + RetryInterval: 1, + GasPriceIncreasePercent: 1, + }, + errContains: "epoch length must be positive", + }, + { + name: "invalid retry interval", + gpf: types.GasPriceIncreaseFlags{ + EpochLength: 1, + RetryInterval: -1, + GasPriceIncreasePercent: 1, + }, + errContains: "retry interval must be positive", + }, + { + name: "valid", + gpf: types.GasPriceIncreaseFlags{ + EpochLength: 1, + RetryInterval: 1, + GasPriceIncreasePercent: 1, + }, + }, + { + name: "percent can be 0", + gpf: types.GasPriceIncreaseFlags{ + EpochLength: 1, + RetryInterval: 1, + GasPriceIncreasePercent: 0, + }, + }, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + err := tt.gpf.Validate() + if tt.errContains != "" { + require.ErrorContains(t, err, tt.errContains) + return + } + require.NoError(t, err) + }) + } +} diff --git a/x/observer/types/tx.pb.go b/x/observer/types/tx.pb.go index cb1d69eac1..cc79b9c3c2 100644 --- a/x/observer/types/tx.pb.go +++ b/x/observer/types/tx.pb.go @@ -638,110 +638,6 @@ func (m *MsgAddBlameVoteResponse) XXX_DiscardUnknown() { var xxx_messageInfo_MsgAddBlameVoteResponse proto.InternalMessageInfo -type MsgUpdateCrosschainFlags struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` - IsInboundEnabled bool `protobuf:"varint,3,opt,name=isInboundEnabled,proto3" json:"isInboundEnabled,omitempty"` - IsOutboundEnabled bool `protobuf:"varint,4,opt,name=isOutboundEnabled,proto3" json:"isOutboundEnabled,omitempty"` - GasPriceIncreaseFlags *GasPriceIncreaseFlags `protobuf:"bytes,5,opt,name=gasPriceIncreaseFlags,proto3" json:"gasPriceIncreaseFlags,omitempty"` -} - -func (m *MsgUpdateCrosschainFlags) Reset() { *m = MsgUpdateCrosschainFlags{} } -func (m *MsgUpdateCrosschainFlags) String() string { return proto.CompactTextString(m) } -func (*MsgUpdateCrosschainFlags) ProtoMessage() {} -func (*MsgUpdateCrosschainFlags) Descriptor() ([]byte, []int) { - return fileDescriptor_eda6e3b1d16a4021, []int{12} -} -func (m *MsgUpdateCrosschainFlags) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgUpdateCrosschainFlags) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgUpdateCrosschainFlags.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 *MsgUpdateCrosschainFlags) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUpdateCrosschainFlags.Merge(m, src) -} -func (m *MsgUpdateCrosschainFlags) XXX_Size() int { - return m.Size() -} -func (m *MsgUpdateCrosschainFlags) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUpdateCrosschainFlags.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgUpdateCrosschainFlags proto.InternalMessageInfo - -func (m *MsgUpdateCrosschainFlags) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *MsgUpdateCrosschainFlags) GetIsInboundEnabled() bool { - if m != nil { - return m.IsInboundEnabled - } - return false -} - -func (m *MsgUpdateCrosschainFlags) GetIsOutboundEnabled() bool { - if m != nil { - return m.IsOutboundEnabled - } - return false -} - -func (m *MsgUpdateCrosschainFlags) GetGasPriceIncreaseFlags() *GasPriceIncreaseFlags { - if m != nil { - return m.GasPriceIncreaseFlags - } - return nil -} - -type MsgUpdateCrosschainFlagsResponse struct { -} - -func (m *MsgUpdateCrosschainFlagsResponse) Reset() { *m = MsgUpdateCrosschainFlagsResponse{} } -func (m *MsgUpdateCrosschainFlagsResponse) String() string { return proto.CompactTextString(m) } -func (*MsgUpdateCrosschainFlagsResponse) ProtoMessage() {} -func (*MsgUpdateCrosschainFlagsResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_eda6e3b1d16a4021, []int{13} -} -func (m *MsgUpdateCrosschainFlagsResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgUpdateCrosschainFlagsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgUpdateCrosschainFlagsResponse.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 *MsgUpdateCrosschainFlagsResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUpdateCrosschainFlagsResponse.Merge(m, src) -} -func (m *MsgUpdateCrosschainFlagsResponse) XXX_Size() int { - return m.Size() -} -func (m *MsgUpdateCrosschainFlagsResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUpdateCrosschainFlagsResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgUpdateCrosschainFlagsResponse proto.InternalMessageInfo - type MsgUpdateKeygen struct { Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` Block int64 `protobuf:"varint,2,opt,name=block,proto3" json:"block,omitempty"` @@ -751,7 +647,7 @@ func (m *MsgUpdateKeygen) Reset() { *m = MsgUpdateKeygen{} } func (m *MsgUpdateKeygen) String() string { return proto.CompactTextString(m) } func (*MsgUpdateKeygen) ProtoMessage() {} func (*MsgUpdateKeygen) Descriptor() ([]byte, []int) { - return fileDescriptor_eda6e3b1d16a4021, []int{14} + return fileDescriptor_eda6e3b1d16a4021, []int{12} } func (m *MsgUpdateKeygen) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -801,7 +697,7 @@ func (m *MsgUpdateKeygenResponse) Reset() { *m = MsgUpdateKeygenResponse func (m *MsgUpdateKeygenResponse) String() string { return proto.CompactTextString(m) } func (*MsgUpdateKeygenResponse) ProtoMessage() {} func (*MsgUpdateKeygenResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_eda6e3b1d16a4021, []int{15} + return fileDescriptor_eda6e3b1d16a4021, []int{13} } func (m *MsgUpdateKeygenResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -841,7 +737,7 @@ func (m *MsgResetChainNonces) Reset() { *m = MsgResetChainNonces{} } func (m *MsgResetChainNonces) String() string { return proto.CompactTextString(m) } func (*MsgResetChainNonces) ProtoMessage() {} func (*MsgResetChainNonces) Descriptor() ([]byte, []int) { - return fileDescriptor_eda6e3b1d16a4021, []int{16} + return fileDescriptor_eda6e3b1d16a4021, []int{14} } func (m *MsgResetChainNonces) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -905,7 +801,7 @@ func (m *MsgResetChainNoncesResponse) Reset() { *m = MsgResetChainNonces func (m *MsgResetChainNoncesResponse) String() string { return proto.CompactTextString(m) } func (*MsgResetChainNoncesResponse) ProtoMessage() {} func (*MsgResetChainNoncesResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_eda6e3b1d16a4021, []int{17} + return fileDescriptor_eda6e3b1d16a4021, []int{15} } func (m *MsgResetChainNoncesResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -945,7 +841,7 @@ func (m *MsgVoteTSS) Reset() { *m = MsgVoteTSS{} } func (m *MsgVoteTSS) String() string { return proto.CompactTextString(m) } func (*MsgVoteTSS) ProtoMessage() {} func (*MsgVoteTSS) Descriptor() ([]byte, []int) { - return fileDescriptor_eda6e3b1d16a4021, []int{18} + return fileDescriptor_eda6e3b1d16a4021, []int{16} } func (m *MsgVoteTSS) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1012,7 +908,7 @@ func (m *MsgVoteTSSResponse) Reset() { *m = MsgVoteTSSResponse{} } func (m *MsgVoteTSSResponse) String() string { return proto.CompactTextString(m) } func (*MsgVoteTSSResponse) ProtoMessage() {} func (*MsgVoteTSSResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_eda6e3b1d16a4021, []int{19} + return fileDescriptor_eda6e3b1d16a4021, []int{17} } func (m *MsgVoteTSSResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1062,6 +958,288 @@ func (m *MsgVoteTSSResponse) GetKeygenSuccess() bool { return false } +type MsgEnableCCTX struct { + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + EnableInbound bool `protobuf:"varint,2,opt,name=enableInbound,proto3" json:"enableInbound,omitempty"` + EnableOutbound bool `protobuf:"varint,3,opt,name=enableOutbound,proto3" json:"enableOutbound,omitempty"` +} + +func (m *MsgEnableCCTX) Reset() { *m = MsgEnableCCTX{} } +func (m *MsgEnableCCTX) String() string { return proto.CompactTextString(m) } +func (*MsgEnableCCTX) ProtoMessage() {} +func (*MsgEnableCCTX) Descriptor() ([]byte, []int) { + return fileDescriptor_eda6e3b1d16a4021, []int{18} +} +func (m *MsgEnableCCTX) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MsgEnableCCTX) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_MsgEnableCCTX.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 *MsgEnableCCTX) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgEnableCCTX.Merge(m, src) +} +func (m *MsgEnableCCTX) XXX_Size() int { + return m.Size() +} +func (m *MsgEnableCCTX) XXX_DiscardUnknown() { + xxx_messageInfo_MsgEnableCCTX.DiscardUnknown(m) +} + +var xxx_messageInfo_MsgEnableCCTX proto.InternalMessageInfo + +func (m *MsgEnableCCTX) GetCreator() string { + if m != nil { + return m.Creator + } + return "" +} + +func (m *MsgEnableCCTX) GetEnableInbound() bool { + if m != nil { + return m.EnableInbound + } + return false +} + +func (m *MsgEnableCCTX) GetEnableOutbound() bool { + if m != nil { + return m.EnableOutbound + } + return false +} + +type MsgEnableCCTXResponse struct { +} + +func (m *MsgEnableCCTXResponse) Reset() { *m = MsgEnableCCTXResponse{} } +func (m *MsgEnableCCTXResponse) String() string { return proto.CompactTextString(m) } +func (*MsgEnableCCTXResponse) ProtoMessage() {} +func (*MsgEnableCCTXResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_eda6e3b1d16a4021, []int{19} +} +func (m *MsgEnableCCTXResponse) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MsgEnableCCTXResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_MsgEnableCCTXResponse.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 *MsgEnableCCTXResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgEnableCCTXResponse.Merge(m, src) +} +func (m *MsgEnableCCTXResponse) XXX_Size() int { + return m.Size() +} +func (m *MsgEnableCCTXResponse) XXX_DiscardUnknown() { + xxx_messageInfo_MsgEnableCCTXResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_MsgEnableCCTXResponse proto.InternalMessageInfo + +type MsgDisableCCTX struct { + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + DisableInbound bool `protobuf:"varint,2,opt,name=disableInbound,proto3" json:"disableInbound,omitempty"` + DisableOutbound bool `protobuf:"varint,3,opt,name=disableOutbound,proto3" json:"disableOutbound,omitempty"` +} + +func (m *MsgDisableCCTX) Reset() { *m = MsgDisableCCTX{} } +func (m *MsgDisableCCTX) String() string { return proto.CompactTextString(m) } +func (*MsgDisableCCTX) ProtoMessage() {} +func (*MsgDisableCCTX) Descriptor() ([]byte, []int) { + return fileDescriptor_eda6e3b1d16a4021, []int{20} +} +func (m *MsgDisableCCTX) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MsgDisableCCTX) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_MsgDisableCCTX.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 *MsgDisableCCTX) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgDisableCCTX.Merge(m, src) +} +func (m *MsgDisableCCTX) XXX_Size() int { + return m.Size() +} +func (m *MsgDisableCCTX) XXX_DiscardUnknown() { + xxx_messageInfo_MsgDisableCCTX.DiscardUnknown(m) +} + +var xxx_messageInfo_MsgDisableCCTX proto.InternalMessageInfo + +func (m *MsgDisableCCTX) GetCreator() string { + if m != nil { + return m.Creator + } + return "" +} + +func (m *MsgDisableCCTX) GetDisableInbound() bool { + if m != nil { + return m.DisableInbound + } + return false +} + +func (m *MsgDisableCCTX) GetDisableOutbound() bool { + if m != nil { + return m.DisableOutbound + } + return false +} + +type MsgDisableCCTXResponse struct { +} + +func (m *MsgDisableCCTXResponse) Reset() { *m = MsgDisableCCTXResponse{} } +func (m *MsgDisableCCTXResponse) String() string { return proto.CompactTextString(m) } +func (*MsgDisableCCTXResponse) ProtoMessage() {} +func (*MsgDisableCCTXResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_eda6e3b1d16a4021, []int{21} +} +func (m *MsgDisableCCTXResponse) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MsgDisableCCTXResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_MsgDisableCCTXResponse.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 *MsgDisableCCTXResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgDisableCCTXResponse.Merge(m, src) +} +func (m *MsgDisableCCTXResponse) XXX_Size() int { + return m.Size() +} +func (m *MsgDisableCCTXResponse) XXX_DiscardUnknown() { + xxx_messageInfo_MsgDisableCCTXResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_MsgDisableCCTXResponse proto.InternalMessageInfo + +type MsgUpdateGasPriceIncreaseFlags struct { + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + GasPriceIncreaseFlags GasPriceIncreaseFlags `protobuf:"bytes,2,opt,name=gasPriceIncreaseFlags,proto3" json:"gasPriceIncreaseFlags"` +} + +func (m *MsgUpdateGasPriceIncreaseFlags) Reset() { *m = MsgUpdateGasPriceIncreaseFlags{} } +func (m *MsgUpdateGasPriceIncreaseFlags) String() string { return proto.CompactTextString(m) } +func (*MsgUpdateGasPriceIncreaseFlags) ProtoMessage() {} +func (*MsgUpdateGasPriceIncreaseFlags) Descriptor() ([]byte, []int) { + return fileDescriptor_eda6e3b1d16a4021, []int{22} +} +func (m *MsgUpdateGasPriceIncreaseFlags) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MsgUpdateGasPriceIncreaseFlags) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_MsgUpdateGasPriceIncreaseFlags.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 *MsgUpdateGasPriceIncreaseFlags) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgUpdateGasPriceIncreaseFlags.Merge(m, src) +} +func (m *MsgUpdateGasPriceIncreaseFlags) XXX_Size() int { + return m.Size() +} +func (m *MsgUpdateGasPriceIncreaseFlags) XXX_DiscardUnknown() { + xxx_messageInfo_MsgUpdateGasPriceIncreaseFlags.DiscardUnknown(m) +} + +var xxx_messageInfo_MsgUpdateGasPriceIncreaseFlags proto.InternalMessageInfo + +func (m *MsgUpdateGasPriceIncreaseFlags) GetCreator() string { + if m != nil { + return m.Creator + } + return "" +} + +func (m *MsgUpdateGasPriceIncreaseFlags) GetGasPriceIncreaseFlags() GasPriceIncreaseFlags { + if m != nil { + return m.GasPriceIncreaseFlags + } + return GasPriceIncreaseFlags{} +} + +type MsgUpdateGasPriceIncreaseFlagsResponse struct { +} + +func (m *MsgUpdateGasPriceIncreaseFlagsResponse) Reset() { + *m = MsgUpdateGasPriceIncreaseFlagsResponse{} +} +func (m *MsgUpdateGasPriceIncreaseFlagsResponse) String() string { return proto.CompactTextString(m) } +func (*MsgUpdateGasPriceIncreaseFlagsResponse) ProtoMessage() {} +func (*MsgUpdateGasPriceIncreaseFlagsResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_eda6e3b1d16a4021, []int{23} +} +func (m *MsgUpdateGasPriceIncreaseFlagsResponse) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *MsgUpdateGasPriceIncreaseFlagsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_MsgUpdateGasPriceIncreaseFlagsResponse.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 *MsgUpdateGasPriceIncreaseFlagsResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_MsgUpdateGasPriceIncreaseFlagsResponse.Merge(m, src) +} +func (m *MsgUpdateGasPriceIncreaseFlagsResponse) XXX_Size() int { + return m.Size() +} +func (m *MsgUpdateGasPriceIncreaseFlagsResponse) XXX_DiscardUnknown() { + xxx_messageInfo_MsgUpdateGasPriceIncreaseFlagsResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_MsgUpdateGasPriceIncreaseFlagsResponse proto.InternalMessageInfo + func init() { proto.RegisterType((*MsgUpdateObserver)(nil), "zetachain.zetacore.observer.MsgUpdateObserver") proto.RegisterType((*MsgUpdateObserverResponse)(nil), "zetachain.zetacore.observer.MsgUpdateObserverResponse") @@ -1075,14 +1253,18 @@ func init() { proto.RegisterType((*MsgAddObserverResponse)(nil), "zetachain.zetacore.observer.MsgAddObserverResponse") proto.RegisterType((*MsgAddBlameVote)(nil), "zetachain.zetacore.observer.MsgAddBlameVote") proto.RegisterType((*MsgAddBlameVoteResponse)(nil), "zetachain.zetacore.observer.MsgAddBlameVoteResponse") - proto.RegisterType((*MsgUpdateCrosschainFlags)(nil), "zetachain.zetacore.observer.MsgUpdateCrosschainFlags") - proto.RegisterType((*MsgUpdateCrosschainFlagsResponse)(nil), "zetachain.zetacore.observer.MsgUpdateCrosschainFlagsResponse") proto.RegisterType((*MsgUpdateKeygen)(nil), "zetachain.zetacore.observer.MsgUpdateKeygen") proto.RegisterType((*MsgUpdateKeygenResponse)(nil), "zetachain.zetacore.observer.MsgUpdateKeygenResponse") proto.RegisterType((*MsgResetChainNonces)(nil), "zetachain.zetacore.observer.MsgResetChainNonces") proto.RegisterType((*MsgResetChainNoncesResponse)(nil), "zetachain.zetacore.observer.MsgResetChainNoncesResponse") proto.RegisterType((*MsgVoteTSS)(nil), "zetachain.zetacore.observer.MsgVoteTSS") proto.RegisterType((*MsgVoteTSSResponse)(nil), "zetachain.zetacore.observer.MsgVoteTSSResponse") + proto.RegisterType((*MsgEnableCCTX)(nil), "zetachain.zetacore.observer.MsgEnableCCTX") + proto.RegisterType((*MsgEnableCCTXResponse)(nil), "zetachain.zetacore.observer.MsgEnableCCTXResponse") + proto.RegisterType((*MsgDisableCCTX)(nil), "zetachain.zetacore.observer.MsgDisableCCTX") + proto.RegisterType((*MsgDisableCCTXResponse)(nil), "zetachain.zetacore.observer.MsgDisableCCTXResponse") + proto.RegisterType((*MsgUpdateGasPriceIncreaseFlags)(nil), "zetachain.zetacore.observer.MsgUpdateGasPriceIncreaseFlags") + proto.RegisterType((*MsgUpdateGasPriceIncreaseFlagsResponse)(nil), "zetachain.zetacore.observer.MsgUpdateGasPriceIncreaseFlagsResponse") } func init() { @@ -1090,81 +1272,86 @@ func init() { } var fileDescriptor_eda6e3b1d16a4021 = []byte{ - // 1176 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x57, 0xcb, 0x73, 0xdb, 0x44, - 0x18, 0x8f, 0x48, 0x9b, 0x38, 0x5f, 0xde, 0x22, 0x69, 0x1d, 0x85, 0x98, 0x8c, 0x86, 0x52, 0xb7, - 0x04, 0x3b, 0x71, 0x79, 0xcf, 0x70, 0x48, 0x5a, 0x9a, 0x84, 0x92, 0x26, 0x23, 0x87, 0x1e, 0x7a, - 0xd1, 0xac, 0xa5, 0x8d, 0x24, 0xa2, 0xec, 0x7a, 0xb4, 0xeb, 0x3c, 0x0a, 0xc3, 0x0c, 0x47, 0x0e, - 0x0c, 0xfc, 0x01, 0xfc, 0x23, 0xdc, 0x39, 0x94, 0x5b, 0x87, 0x13, 0x27, 0x86, 0x49, 0x4e, 0xfc, - 0x07, 0x1c, 0x19, 0xed, 0xae, 0x14, 0xbf, 0x22, 0xdb, 0x99, 0xe9, 0xc9, 0xd2, 0xb7, 0xbf, 0xdf, - 0xf7, 0xda, 0xef, 0x61, 0xc1, 0x3b, 0x2f, 0x30, 0x47, 0x8e, 0x8f, 0x02, 0x52, 0x16, 0x4f, 0x34, - 0xc2, 0x65, 0x5a, 0x63, 0x38, 0x3a, 0xc6, 0x51, 0x99, 0x9f, 0x96, 0xea, 0x11, 0xe5, 0x54, 0x5f, - 0x4c, 0x51, 0xa5, 0x04, 0x55, 0x4a, 0x50, 0xc6, 0x9c, 0x47, 0x3d, 0x2a, 0x70, 0xe5, 0xf8, 0x49, - 0x52, 0x8c, 0xbb, 0x59, 0x8a, 0x6b, 0x21, 0x3a, 0xc2, 0x0a, 0x58, 0xc9, 0x02, 0x3a, 0x11, 0x65, - 0x4c, 0x1c, 0xda, 0x07, 0x21, 0xf2, 0x98, 0xe2, 0xdc, 0xcf, 0xe2, 0x24, 0x0f, 0x0a, 0x5b, 0xcc, - 0xc2, 0xd6, 0x51, 0x84, 0x8e, 0x12, 0xad, 0xab, 0x99, 0x48, 0x4c, 0xdc, 0x80, 0x78, 0x36, 0xa1, - 0xc4, 0xc1, 0x09, 0xe3, 0x4e, 0x66, 0xf6, 0x58, 0x96, 0xbb, 0xf5, 0x43, 0xaf, 0x2c, 0x44, 0x4c, - 0xfd, 0xf4, 0xc0, 0xd6, 0x23, 0x4a, 0x0f, 0x98, 0xfa, 0x91, 0x58, 0xf3, 0x5f, 0x0d, 0x66, 0x77, - 0x98, 0xf7, 0x75, 0xdd, 0x45, 0x1c, 0xef, 0x2a, 0xbb, 0x7a, 0x1e, 0x46, 0x9d, 0x08, 0x23, 0x4e, - 0xa3, 0xbc, 0xb6, 0xac, 0x15, 0xc7, 0xac, 0xe4, 0x55, 0x5f, 0x85, 0x39, 0x1a, 0xba, 0x76, 0xe2, - 0xa1, 0x8d, 0x5c, 0x37, 0xc2, 0x8c, 0xe5, 0xdf, 0x10, 0x30, 0x9d, 0x86, 0x6e, 0xa2, 0x64, 0x5d, - 0x9e, 0xc4, 0x0c, 0x82, 0x4f, 0x3a, 0x19, 0xc3, 0x92, 0x41, 0xf0, 0x49, 0x3b, 0xe3, 0x19, 0x4c, - 0x36, 0x84, 0x3f, 0x76, 0x84, 0x11, 0xa3, 0x24, 0x7f, 0x63, 0x59, 0x2b, 0x4e, 0x55, 0xd6, 0x4a, - 0x19, 0x25, 0x54, 0x4a, 0x94, 0xc8, 0x48, 0x2c, 0x41, 0xb4, 0x26, 0x1a, 0x4d, 0x6f, 0xe6, 0x22, - 0x2c, 0x74, 0x84, 0x6a, 0x61, 0x56, 0xa7, 0x84, 0x61, 0xf3, 0x0f, 0x0d, 0xf4, 0x1d, 0xe6, 0x3d, - 0xa3, 0x1c, 0x6f, 0x84, 0xd4, 0x39, 0xdc, 0xc2, 0xc8, 0xcd, 0xcc, 0xc4, 0x02, 0xe4, 0x64, 0x55, - 0x05, 0xae, 0x88, 0x7e, 0xd8, 0x1a, 0x15, 0xef, 0xdb, 0xae, 0xbe, 0x04, 0x50, 0x8b, 0x75, 0xd8, - 0x3e, 0x62, 0xbe, 0x08, 0x74, 0xc2, 0x1a, 0x13, 0x92, 0x2d, 0xc4, 0x7c, 0xfd, 0x16, 0x8c, 0xf8, - 0x38, 0xf0, 0x7c, 0x2e, 0x02, 0x1b, 0xb6, 0xd4, 0x9b, 0xbe, 0x19, 0xcb, 0x63, 0xab, 0xf9, 0x9b, - 0xcb, 0x5a, 0x71, 0xbc, 0x72, 0xaf, 0x5b, 0xc0, 0xf5, 0x43, 0xaf, 0xa4, 0x6e, 0x50, 0xba, 0xf8, - 0x08, 0x71, 0xb4, 0x71, 0xe3, 0xe5, 0xdf, 0x6f, 0x0f, 0x59, 0x8a, 0x6e, 0x7e, 0x03, 0x46, 0x67, - 0x28, 0x49, 0xa4, 0xfa, 0x1d, 0x98, 0xaa, 0xa1, 0x30, 0xa4, 0xdc, 0x16, 0xa1, 0x60, 0x57, 0x44, - 0x96, 0xb3, 0x26, 0xa5, 0xf4, 0xa1, 0x14, 0xc6, 0xb0, 0x63, 0xca, 0xb1, 0x7d, 0x10, 0x10, 0x14, - 0x06, 0x2f, 0xb0, 0x8c, 0x32, 0x67, 0x4d, 0xc6, 0xd2, 0xc7, 0x89, 0xd0, 0xfc, 0x0e, 0xe6, 0xd2, - 0xa4, 0x3e, 0x8c, 0x5d, 0xdd, 0x13, 0xfd, 0x90, 0x91, 0xb8, 0x2f, 0x61, 0xdc, 0xb9, 0x04, 0x0a, - 0xad, 0xe3, 0x95, 0x62, 0xe6, 0xe5, 0x36, 0x29, 0xb6, 0x9a, 0xc9, 0x66, 0x01, 0xde, 0xea, 0x66, - 0x3d, 0xbd, 0xd5, 0x27, 0xc2, 0x3b, 0x0b, 0x1f, 0xd1, 0xe3, 0x3e, 0xbd, 0xbb, 0xfa, 0x5a, 0x95, - 0xb1, 0x0e, 0x65, 0xa9, 0xb1, 0xdf, 0x35, 0x98, 0xda, 0x61, 0xde, 0xba, 0xeb, 0xf6, 0xd1, 0x48, - 0xf7, 0x60, 0xe6, 0x8a, 0x26, 0x9a, 0xa6, 0x6d, 0xfd, 0xf0, 0x19, 0x2c, 0x88, 0x94, 0x84, 0x01, - 0x26, 0xdc, 0xf6, 0x22, 0x44, 0x38, 0xc6, 0x76, 0xbd, 0x51, 0x3b, 0xc4, 0x67, 0xaa, 0x8d, 0x6e, - 0x5f, 0x02, 0x36, 0xe5, 0xf9, 0x9e, 0x38, 0xd6, 0xd7, 0x60, 0x1e, 0xb9, 0xae, 0x4d, 0xa8, 0x8b, - 0x6d, 0xe4, 0x38, 0xb4, 0x41, 0xb8, 0x4d, 0x49, 0x78, 0x26, 0x4a, 0x2f, 0x67, 0xe9, 0xc8, 0x75, - 0x9f, 0x52, 0x17, 0xaf, 0xcb, 0xa3, 0x5d, 0x12, 0x9e, 0x99, 0x79, 0xb8, 0xd5, 0x1a, 0x45, 0x1a, - 0xe0, 0xcf, 0x1a, 0x4c, 0xcb, 0xa3, 0x8d, 0x78, 0xfa, 0xc6, 0x05, 0x76, 0xbd, 0x06, 0xd9, 0x8c, - 0x1b, 0x04, 0x1d, 0x61, 0x3b, 0x20, 0x07, 0x54, 0x84, 0x30, 0x5e, 0x31, 0x33, 0x2b, 0x40, 0x18, - 0x54, 0x65, 0x3e, 0x26, 0xb8, 0xdb, 0xe4, 0x80, 0x9a, 0x0b, 0x70, 0xbb, 0xcd, 0xa1, 0xd4, 0xd9, - 0xff, 0x34, 0xc8, 0x5f, 0xd6, 0x46, 0xba, 0x04, 0x1e, 0xc7, 0x3b, 0x20, 0xc3, 0xeb, 0xfb, 0x30, - 0x13, 0xb0, 0x6d, 0x52, 0xa3, 0x0d, 0xe2, 0x7e, 0x41, 0x50, 0x2d, 0xc4, 0xae, 0x70, 0x30, 0x67, - 0x75, 0xc8, 0xf5, 0x15, 0x98, 0x0d, 0xd8, 0x6e, 0x83, 0xb7, 0x80, 0x65, 0x62, 0x3b, 0x0f, 0x74, - 0x1f, 0xe6, 0x3d, 0xc4, 0xf6, 0xa2, 0xc0, 0xc1, 0xdb, 0x24, 0x36, 0xc7, 0xb0, 0x70, 0x46, 0x75, - 0x7b, 0x25, 0x33, 0xfe, 0xcd, 0x6e, 0x4c, 0xab, 0xbb, 0x42, 0xd3, 0x84, 0xe5, 0xab, 0x22, 0x4f, - 0xd3, 0xb3, 0x2e, 0xae, 0x52, 0x62, 0x9e, 0xe0, 0x33, 0x0f, 0x93, 0x8c, 0xa4, 0xcc, 0xc1, 0x4d, - 0x31, 0xbe, 0xd4, 0x3d, 0xca, 0x17, 0x95, 0xfc, 0x66, 0x15, 0xa9, 0xf6, 0x5f, 0x35, 0x78, 0x53, - 0xf4, 0x0a, 0xc3, 0x5c, 0xb4, 0xca, 0x53, 0xb1, 0xf3, 0xae, 0x57, 0x2d, 0xef, 0xc2, 0xb4, 0x3c, - 0x12, 0x8b, 0xd3, 0x0e, 0xe9, 0x89, 0xb8, 0x91, 0x61, 0x6b, 0xd2, 0x49, 0x55, 0x7f, 0x45, 0x4f, - 0xf4, 0x22, 0xcc, 0x34, 0xe3, 0xfc, 0xc0, 0xf3, 0xd5, 0x84, 0x9d, 0xba, 0x04, 0x6e, 0x05, 0x9e, - 0x6f, 0x2e, 0xc1, 0x62, 0x17, 0xef, 0x52, 0xef, 0x7f, 0xd3, 0x00, 0xd4, 0x00, 0xdd, 0xaf, 0x56, - 0x33, 0x9c, 0x5e, 0x02, 0xe0, 0x8c, 0x25, 0xad, 0x28, 0xdb, 0x77, 0x8c, 0x33, 0xa6, 0x9a, 0x6f, - 0x05, 0xf4, 0x43, 0x91, 0x17, 0x3b, 0xbe, 0x50, 0x5b, 0x0d, 0x7d, 0xe9, 0xfb, 0x8c, 0x3c, 0x79, - 0x8e, 0x39, 0xda, 0x92, 0xe3, 0xff, 0x11, 0x8c, 0x30, 0x8e, 0x78, 0x83, 0xa9, 0x7d, 0xb7, 0x72, - 0xd5, 0xf8, 0x57, 0xcb, 0xde, 0xc2, 0x0e, 0x0e, 0x8e, 0x71, 0x55, 0x70, 0x2c, 0xc5, 0x35, 0x7f, - 0xbc, 0xdc, 0x63, 0xfb, 0xd5, 0xea, 0xeb, 0x19, 0xfa, 0x31, 0x4c, 0x05, 0xc6, 0x1a, 0x8e, 0x93, - 0x6c, 0xf3, 0x9c, 0x35, 0x29, 0xa5, 0x55, 0x29, 0xac, 0xfc, 0x39, 0x06, 0xc3, 0x3b, 0xcc, 0xd3, - 0x29, 0x8c, 0x37, 0x0f, 0xc5, 0xf7, 0x32, 0x2b, 0xbd, 0x75, 0xf6, 0x18, 0x0f, 0x06, 0x00, 0xa7, - 0xd1, 0x9e, 0xc2, 0x54, 0xdb, 0x3f, 0x9a, 0x52, 0x2f, 0x35, 0xad, 0x78, 0xe3, 0xa3, 0xc1, 0xf0, - 0xa9, 0xe5, 0x1f, 0x34, 0x98, 0xed, 0x5c, 0x86, 0x6b, 0xfd, 0x69, 0x6b, 0xa2, 0x18, 0x9f, 0x0e, - 0x4c, 0x69, 0xf1, 0xa1, 0x73, 0xe5, 0xf5, 0xf4, 0xa1, 0x83, 0xd2, 0xdb, 0x87, 0x2b, 0x77, 0xa1, - 0x1e, 0xc1, 0x44, 0xcb, 0x9a, 0x58, 0xe9, 0xe3, 0x1a, 0x53, 0xb4, 0xf1, 0xc1, 0x20, 0xe8, 0xd4, - 0xe6, 0x4f, 0x1a, 0xcc, 0x77, 0x1f, 0xf7, 0x1f, 0xf6, 0x99, 0xcc, 0x56, 0x9a, 0xf1, 0xf9, 0xb5, - 0x68, 0xcd, 0x39, 0x68, 0x99, 0xaf, 0x2b, 0xfd, 0xa9, 0x93, 0xe8, 0xde, 0x39, 0xe8, 0x36, 0x78, - 0xf5, 0x6f, 0x61, 0xba, 0xfd, 0x2f, 0x6c, 0xb9, 0x97, 0xa2, 0x36, 0x82, 0xf1, 0xf1, 0x80, 0x84, - 0xd4, 0xf8, 0xf7, 0x30, 0xd3, 0x31, 0xf1, 0x57, 0x7b, 0xd7, 0x50, 0x2b, 0xc3, 0xf8, 0x64, 0x50, - 0x46, 0x6a, 0xdf, 0x81, 0xd1, 0x64, 0x66, 0xdf, 0xed, 0x27, 0x86, 0xfd, 0x6a, 0xd5, 0x28, 0xf7, - 0x09, 0x4c, 0x8c, 0x6c, 0x6c, 0xbf, 0x3c, 0x2f, 0x68, 0xaf, 0xce, 0x0b, 0xda, 0x3f, 0xe7, 0x05, - 0xed, 0x97, 0x8b, 0xc2, 0xd0, 0xab, 0x8b, 0xc2, 0xd0, 0x5f, 0x17, 0x85, 0xa1, 0xe7, 0x65, 0x2f, - 0xe0, 0x7e, 0xa3, 0x56, 0x72, 0xe8, 0x91, 0xf8, 0xf0, 0x7a, 0xbf, 0xed, 0x1b, 0xec, 0xb4, 0xe9, - 0xc3, 0xee, 0xac, 0x8e, 0x59, 0x6d, 0x44, 0x7c, 0x83, 0x3d, 0xf8, 0x3f, 0x00, 0x00, 0xff, 0xff, - 0x57, 0xa3, 0x79, 0xf2, 0x42, 0x0f, 0x00, 0x00, + // 1257 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x57, 0x4b, 0x6f, 0xdb, 0x46, + 0x10, 0x36, 0xeb, 0xc4, 0x8f, 0x91, 0x25, 0x3b, 0xac, 0x1d, 0xcb, 0x74, 0xad, 0x1a, 0x44, 0xe2, + 0x28, 0xa9, 0x2b, 0xd9, 0x4a, 0xd1, 0xe7, 0xc9, 0x8f, 0xc6, 0x76, 0x53, 0xc7, 0x06, 0xe5, 0x06, + 0x45, 0x2e, 0xc4, 0x8a, 0x5c, 0x53, 0xac, 0xe9, 0x5d, 0x81, 0x4b, 0xf9, 0x91, 0x06, 0x05, 0x7a, + 0xec, 0xa9, 0xfd, 0x01, 0x05, 0x7a, 0xef, 0x3f, 0xe8, 0xb9, 0x3d, 0xa4, 0xb7, 0x1c, 0x7b, 0x2a, + 0x0a, 0xfb, 0xd4, 0x7f, 0x51, 0x70, 0x77, 0x49, 0x53, 0x0f, 0x53, 0x52, 0x8a, 0x9c, 0x24, 0xce, + 0x7e, 0xdf, 0xcc, 0x37, 0xbb, 0xb3, 0x33, 0x24, 0xdc, 0x79, 0x8e, 0x03, 0x64, 0xd5, 0x91, 0x4b, + 0xca, 0xfc, 0x1f, 0xf5, 0x71, 0x99, 0xd6, 0x18, 0xf6, 0x4f, 0xb0, 0x5f, 0x0e, 0xce, 0x4a, 0x0d, + 0x9f, 0x06, 0x54, 0x9d, 0x8f, 0x51, 0xa5, 0x08, 0x55, 0x8a, 0x50, 0xda, 0xb4, 0x43, 0x1d, 0xca, + 0x71, 0xe5, 0xf0, 0x9f, 0xa0, 0x68, 0xf7, 0xd2, 0x1c, 0xd7, 0x3c, 0x74, 0x8c, 0x25, 0xb0, 0x92, + 0x06, 0xb4, 0x7c, 0xca, 0x18, 0x5f, 0x34, 0x0f, 0x3d, 0xe4, 0x30, 0xc9, 0x79, 0x90, 0xc6, 0x89, + 0xfe, 0x48, 0x6c, 0x31, 0x0d, 0xdb, 0x40, 0x3e, 0x3a, 0x8e, 0xbc, 0xae, 0xa4, 0x22, 0x31, 0xb1, + 0x5d, 0xe2, 0x98, 0x84, 0x12, 0x0b, 0x47, 0x8c, 0xbb, 0xa9, 0xbb, 0xc7, 0xd2, 0xe4, 0x36, 0x8e, + 0x9c, 0x32, 0x37, 0x31, 0xf9, 0xd3, 0x03, 0xdb, 0xf0, 0x29, 0x3d, 0x64, 0xf2, 0x47, 0x60, 0xf5, + 0x7f, 0x15, 0xb8, 0xb5, 0xcb, 0x9c, 0xaf, 0x1a, 0x36, 0x0a, 0xf0, 0x9e, 0x8c, 0xab, 0xe6, 0x61, + 0xd4, 0xf2, 0x31, 0x0a, 0xa8, 0x9f, 0x57, 0x16, 0x95, 0xe2, 0xb8, 0x11, 0x3d, 0xaa, 0x2b, 0x30, + 0x4d, 0x3d, 0xdb, 0x8c, 0x14, 0x9a, 0xc8, 0xb6, 0x7d, 0xcc, 0x58, 0xfe, 0x2d, 0x0e, 0x53, 0xa9, + 0x67, 0x47, 0x4e, 0xd6, 0xc4, 0x4a, 0xc8, 0x20, 0xf8, 0xb4, 0x93, 0x31, 0x2c, 0x18, 0x04, 0x9f, + 0xb6, 0x33, 0x9e, 0x42, 0xb6, 0xc9, 0xf5, 0x98, 0x3e, 0x46, 0x8c, 0x92, 0xfc, 0x8d, 0x45, 0xa5, + 0x98, 0xab, 0xac, 0x96, 0x52, 0x4a, 0xa8, 0x14, 0x39, 0x11, 0x99, 0x18, 0x9c, 0x68, 0x4c, 0x34, + 0x13, 0x4f, 0xfa, 0x3c, 0xcc, 0x75, 0xa4, 0x6a, 0x60, 0xd6, 0xa0, 0x84, 0x61, 0xfd, 0x4f, 0x05, + 0xd4, 0x5d, 0xe6, 0x3c, 0xa5, 0x01, 0x5e, 0xf7, 0xa8, 0x75, 0xb4, 0x8d, 0x91, 0x9d, 0xba, 0x13, + 0x73, 0x30, 0x26, 0xaa, 0xca, 0xb5, 0x79, 0xf6, 0xc3, 0xc6, 0x28, 0x7f, 0xde, 0xb1, 0xd5, 0x05, + 0x80, 0x5a, 0xe8, 0xc3, 0xac, 0x23, 0x56, 0xe7, 0x89, 0x4e, 0x18, 0xe3, 0xdc, 0xb2, 0x8d, 0x58, + 0x5d, 0xbd, 0x0d, 0x23, 0x75, 0xec, 0x3a, 0xf5, 0x80, 0x27, 0x36, 0x6c, 0xc8, 0x27, 0x75, 0x2b, + 0xb4, 0x87, 0x51, 0xf3, 0x37, 0x17, 0x95, 0x62, 0xa6, 0x72, 0xbf, 0x5b, 0xc2, 0x8d, 0x23, 0xa7, + 0x24, 0x4f, 0x50, 0x48, 0xdc, 0x44, 0x01, 0x5a, 0xbf, 0xf1, 0xf2, 0xef, 0x77, 0x87, 0x0c, 0x49, + 0xd7, 0xbf, 0x01, 0xad, 0x33, 0x95, 0x28, 0x53, 0xf5, 0x2e, 0xe4, 0x6a, 0xc8, 0xf3, 0x68, 0x60, + 0xf2, 0x54, 0xb0, 0xcd, 0x33, 0x1b, 0x33, 0xb2, 0xc2, 0xba, 0x21, 0x8c, 0x21, 0xec, 0x84, 0x06, + 0xd8, 0x3c, 0x74, 0x09, 0xf2, 0xdc, 0xe7, 0x58, 0x64, 0x39, 0x66, 0x64, 0x43, 0xeb, 0xa3, 0xc8, + 0xa8, 0xbf, 0x80, 0xe9, 0x78, 0x53, 0x37, 0x42, 0xa9, 0xfb, 0xfc, 0x3e, 0xa4, 0x6c, 0xdc, 0x17, + 0x90, 0xb1, 0xae, 0x80, 0xdc, 0x6b, 0xa6, 0x52, 0x4c, 0x3d, 0xdc, 0x84, 0x63, 0x23, 0x49, 0xd6, + 0x0b, 0xf0, 0x4e, 0xb7, 0xe8, 0xf1, 0xa9, 0x3e, 0xe6, 0xea, 0x0c, 0x7c, 0x4c, 0x4f, 0xfa, 0x54, + 0x77, 0xfd, 0xb1, 0xca, 0x60, 0x1d, 0xce, 0xe2, 0x60, 0x7f, 0x28, 0x90, 0xdb, 0x65, 0xce, 0x9a, + 0x6d, 0xf7, 0x71, 0x91, 0xee, 0xc3, 0xd4, 0x35, 0x97, 0x68, 0x92, 0xb6, 0xdd, 0x87, 0x4f, 0x61, + 0x8e, 0x6f, 0x89, 0xe7, 0x62, 0x12, 0x98, 0x8e, 0x8f, 0x48, 0x80, 0xb1, 0xd9, 0x68, 0xd6, 0x8e, + 0xf0, 0xb9, 0xbc, 0x46, 0xb3, 0x57, 0x80, 0x2d, 0xb1, 0xbe, 0xcf, 0x97, 0xd5, 0x55, 0x98, 0x41, + 0xb6, 0x6d, 0x12, 0x6a, 0x63, 0x13, 0x59, 0x16, 0x6d, 0x92, 0xc0, 0xa4, 0xc4, 0x3b, 0xe7, 0xa5, + 0x37, 0x66, 0xa8, 0xc8, 0xb6, 0x9f, 0x50, 0x1b, 0xaf, 0x89, 0xa5, 0x3d, 0xe2, 0x9d, 0xeb, 0x79, + 0xb8, 0xdd, 0x9a, 0x45, 0x9c, 0xe0, 0x8f, 0x0a, 0x4c, 0x8a, 0xa5, 0xf5, 0xb0, 0xfb, 0x86, 0x05, + 0xf6, 0x7a, 0x17, 0x64, 0x2b, 0xbc, 0x20, 0xe8, 0x18, 0x9b, 0x2e, 0x39, 0xa4, 0x3c, 0x85, 0x4c, + 0x45, 0x4f, 0xad, 0x00, 0x1e, 0x50, 0x96, 0xf9, 0x38, 0xe7, 0xee, 0x90, 0x43, 0xaa, 0xcf, 0xc1, + 0x6c, 0x9b, 0xa0, 0x58, 0xec, 0x1a, 0xd7, 0x2a, 0x4a, 0xe3, 0x31, 0x3e, 0x77, 0x30, 0x49, 0xd1, + 0x3a, 0x0d, 0x37, 0xf9, 0xfd, 0x94, 0x42, 0xc5, 0x83, 0xf4, 0x9e, 0x74, 0x11, 0x7b, 0xff, 0x59, + 0x81, 0xb7, 0x79, 0x31, 0x30, 0x1c, 0xf0, 0x5a, 0x78, 0xc2, 0x9b, 0xfa, 0xeb, 0x6d, 0xc7, 0x12, + 0x4c, 0x8a, 0x25, 0x3e, 0x19, 0x4c, 0x8f, 0x9e, 0xf2, 0x3d, 0x19, 0x36, 0xb2, 0x56, 0xec, 0xfa, + 0x4b, 0x7a, 0xaa, 0x16, 0x61, 0x2a, 0x89, 0xab, 0xbb, 0x4e, 0x5d, 0xb6, 0x90, 0xdc, 0x15, 0x70, + 0xdb, 0x75, 0xea, 0xfa, 0x02, 0xcc, 0x77, 0x51, 0x17, 0xab, 0xff, 0x4d, 0x01, 0x90, 0x1d, 0xe2, + 0xa0, 0x5a, 0x4d, 0x11, 0xbd, 0x00, 0x10, 0x30, 0x16, 0xd5, 0x9a, 0xa8, 0xcf, 0xf1, 0x80, 0x31, + 0x59, 0x5d, 0xcb, 0xa0, 0x1e, 0xf1, 0x7d, 0x31, 0xc3, 0x13, 0x33, 0x65, 0x57, 0x13, 0xda, 0xa7, + 0xc4, 0xca, 0x33, 0x1c, 0xa0, 0x6d, 0xd1, 0xdf, 0x36, 0x61, 0x84, 0x05, 0x28, 0x68, 0x32, 0xd9, + 0xd0, 0x97, 0xaf, 0xeb, 0x6f, 0x72, 0x9a, 0x19, 0xd8, 0xc2, 0xee, 0x09, 0xae, 0x72, 0x8e, 0x21, + 0xb9, 0xfa, 0x0f, 0x57, 0x8d, 0xfa, 0xa0, 0x5a, 0x7d, 0x33, 0x5d, 0x2d, 0x84, 0xc9, 0xc4, 0x58, + 0xd3, 0xb2, 0xa2, 0x71, 0x35, 0x66, 0x64, 0x85, 0xb5, 0x2a, 0x8c, 0xfa, 0x29, 0x64, 0x77, 0x99, + 0xf3, 0x39, 0x41, 0x35, 0x0f, 0x6f, 0x6c, 0x1c, 0x7c, 0x9d, 0xb2, 0x93, 0x77, 0x20, 0x8b, 0x39, + 0x6e, 0x87, 0xd4, 0x68, 0x93, 0xc4, 0x71, 0x5b, 0x8c, 0xea, 0x12, 0xe4, 0x84, 0x61, 0xaf, 0x19, + 0x08, 0x98, 0x88, 0xdb, 0x66, 0xd5, 0x67, 0x61, 0xa6, 0x25, 0x70, 0x7c, 0xb2, 0x2f, 0x78, 0x0b, + 0xda, 0x74, 0x59, 0x1f, 0x92, 0x96, 0x20, 0x67, 0x0b, 0x60, 0xab, 0xa6, 0x36, 0xab, 0x5a, 0x84, + 0x49, 0x69, 0x69, 0x53, 0xd5, 0x6e, 0x96, 0xad, 0x23, 0x11, 0x3d, 0xd6, 0xf5, 0xab, 0x02, 0x85, + 0xf8, 0x2e, 0x6d, 0x21, 0xb6, 0xef, 0xbb, 0x16, 0xde, 0x21, 0xa1, 0x14, 0x86, 0x1f, 0x85, 0xef, + 0x65, 0x29, 0x42, 0x09, 0xcc, 0x38, 0xdd, 0x28, 0x72, 0x76, 0x54, 0x52, 0x3b, 0x47, 0xd7, 0x60, + 0xb2, 0x93, 0x74, 0x77, 0xab, 0x17, 0x61, 0x29, 0x5d, 0x6b, 0x94, 0x56, 0xe5, 0xf7, 0x0c, 0x0c, + 0xef, 0x32, 0x47, 0xa5, 0x90, 0x49, 0xb6, 0xfd, 0xf7, 0x52, 0x15, 0xb5, 0x76, 0x57, 0xed, 0xe1, + 0x00, 0xe0, 0xb8, 0xdc, 0xcf, 0x20, 0xd7, 0xf6, 0xce, 0x56, 0xea, 0xe5, 0xa6, 0x15, 0xaf, 0x7d, + 0x38, 0x18, 0x3e, 0x8e, 0xfc, 0xbd, 0x02, 0xb7, 0x3a, 0xc7, 0xfd, 0x6a, 0x7f, 0xde, 0x12, 0x14, + 0xed, 0x93, 0x81, 0x29, 0x2d, 0x1a, 0x3a, 0x87, 0x7a, 0x4f, 0x0d, 0x1d, 0x94, 0xde, 0x1a, 0xae, + 0x9d, 0xf6, 0xaa, 0x0f, 0x13, 0x2d, 0x83, 0x70, 0xb9, 0x8f, 0x63, 0x8c, 0xd1, 0xda, 0x07, 0x83, + 0xa0, 0x93, 0x31, 0x5b, 0x06, 0xda, 0x72, 0x7f, 0x5b, 0x28, 0xd0, 0xbd, 0x63, 0x76, 0x9b, 0x74, + 0xea, 0xb7, 0x30, 0xd9, 0xfe, 0x52, 0x5c, 0xee, 0xe5, 0xa8, 0x8d, 0xa0, 0x7d, 0x34, 0x20, 0x21, + 0x0e, 0xfe, 0x1d, 0x4c, 0x75, 0x8c, 0xd8, 0x95, 0xde, 0x67, 0xd6, 0xca, 0xd0, 0x3e, 0x1e, 0x94, + 0x11, 0xc7, 0xb7, 0x60, 0x34, 0x1a, 0x92, 0xf7, 0xfa, 0xc9, 0xe1, 0xa0, 0x5a, 0xd5, 0xca, 0x7d, + 0x02, 0xe3, 0x20, 0x1e, 0x40, 0x62, 0x84, 0x3c, 0xe8, 0x45, 0xbf, 0xc2, 0x6a, 0x95, 0xfe, 0xb1, + 0x71, 0x34, 0x0a, 0x99, 0xe4, 0x78, 0xe8, 0xd9, 0xaa, 0x12, 0xe0, 0xde, 0xad, 0xaa, 0x4b, 0xeb, + 0x57, 0x7f, 0x51, 0x60, 0x3e, 0xad, 0xef, 0x7f, 0xd6, 0x5f, 0x59, 0x76, 0x25, 0x6b, 0x1b, 0xff, + 0x83, 0x1c, 0x29, 0x5c, 0xdf, 0x79, 0x79, 0x51, 0x50, 0x5e, 0x5d, 0x14, 0x94, 0x7f, 0x2e, 0x0a, + 0xca, 0x4f, 0x97, 0x85, 0xa1, 0x57, 0x97, 0x85, 0xa1, 0xbf, 0x2e, 0x0b, 0x43, 0xcf, 0xca, 0x8e, + 0x1b, 0xd4, 0x9b, 0xb5, 0x92, 0x45, 0x8f, 0xf9, 0xb7, 0xf4, 0xfb, 0x6d, 0x9f, 0xd5, 0x67, 0x89, + 0x6f, 0xf5, 0xf3, 0x06, 0x66, 0xb5, 0x11, 0xfe, 0x59, 0xfd, 0xf0, 0xbf, 0x00, 0x00, 0x00, 0xff, + 0xff, 0xd6, 0x91, 0x58, 0xd4, 0x15, 0x11, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -1184,11 +1371,13 @@ type MsgClient interface { UpdateChainParams(ctx context.Context, in *MsgUpdateChainParams, opts ...grpc.CallOption) (*MsgUpdateChainParamsResponse, error) RemoveChainParams(ctx context.Context, in *MsgRemoveChainParams, opts ...grpc.CallOption) (*MsgRemoveChainParamsResponse, error) AddBlameVote(ctx context.Context, in *MsgAddBlameVote, opts ...grpc.CallOption) (*MsgAddBlameVoteResponse, error) - UpdateCrosschainFlags(ctx context.Context, in *MsgUpdateCrosschainFlags, opts ...grpc.CallOption) (*MsgUpdateCrosschainFlagsResponse, error) UpdateKeygen(ctx context.Context, in *MsgUpdateKeygen, opts ...grpc.CallOption) (*MsgUpdateKeygenResponse, error) VoteBlockHeader(ctx context.Context, in *MsgVoteBlockHeader, opts ...grpc.CallOption) (*MsgVoteBlockHeaderResponse, error) ResetChainNonces(ctx context.Context, in *MsgResetChainNonces, opts ...grpc.CallOption) (*MsgResetChainNoncesResponse, error) VoteTSS(ctx context.Context, in *MsgVoteTSS, opts ...grpc.CallOption) (*MsgVoteTSSResponse, error) + EnableCCTX(ctx context.Context, in *MsgEnableCCTX, opts ...grpc.CallOption) (*MsgEnableCCTXResponse, error) + DisableCCTX(ctx context.Context, in *MsgDisableCCTX, opts ...grpc.CallOption) (*MsgDisableCCTXResponse, error) + UpdateGasPriceIncreaseFlags(ctx context.Context, in *MsgUpdateGasPriceIncreaseFlags, opts ...grpc.CallOption) (*MsgUpdateGasPriceIncreaseFlagsResponse, error) } type msgClient struct { @@ -1244,18 +1433,9 @@ func (c *msgClient) AddBlameVote(ctx context.Context, in *MsgAddBlameVote, opts return out, nil } -func (c *msgClient) UpdateCrosschainFlags(ctx context.Context, in *MsgUpdateCrosschainFlags, opts ...grpc.CallOption) (*MsgUpdateCrosschainFlagsResponse, error) { - out := new(MsgUpdateCrosschainFlagsResponse) - err := c.cc.Invoke(ctx, "/zetachain.zetacore.observer.Msg/UpdateCrosschainFlags", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *msgClient) UpdateKeygen(ctx context.Context, in *MsgUpdateKeygen, opts ...grpc.CallOption) (*MsgUpdateKeygenResponse, error) { - out := new(MsgUpdateKeygenResponse) - err := c.cc.Invoke(ctx, "/zetachain.zetacore.observer.Msg/UpdateKeygen", in, out, opts...) +func (c *msgClient) UpdateKeygen(ctx context.Context, in *MsgUpdateKeygen, opts ...grpc.CallOption) (*MsgUpdateKeygenResponse, error) { + out := new(MsgUpdateKeygenResponse) + err := c.cc.Invoke(ctx, "/zetachain.zetacore.observer.Msg/UpdateKeygen", in, out, opts...) if err != nil { return nil, err } @@ -1289,6 +1469,33 @@ func (c *msgClient) VoteTSS(ctx context.Context, in *MsgVoteTSS, opts ...grpc.Ca return out, nil } +func (c *msgClient) EnableCCTX(ctx context.Context, in *MsgEnableCCTX, opts ...grpc.CallOption) (*MsgEnableCCTXResponse, error) { + out := new(MsgEnableCCTXResponse) + err := c.cc.Invoke(ctx, "/zetachain.zetacore.observer.Msg/EnableCCTX", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *msgClient) DisableCCTX(ctx context.Context, in *MsgDisableCCTX, opts ...grpc.CallOption) (*MsgDisableCCTXResponse, error) { + out := new(MsgDisableCCTXResponse) + err := c.cc.Invoke(ctx, "/zetachain.zetacore.observer.Msg/DisableCCTX", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *msgClient) UpdateGasPriceIncreaseFlags(ctx context.Context, in *MsgUpdateGasPriceIncreaseFlags, opts ...grpc.CallOption) (*MsgUpdateGasPriceIncreaseFlagsResponse, error) { + out := new(MsgUpdateGasPriceIncreaseFlagsResponse) + err := c.cc.Invoke(ctx, "/zetachain.zetacore.observer.Msg/UpdateGasPriceIncreaseFlags", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + // MsgServer is the server API for Msg service. type MsgServer interface { AddObserver(context.Context, *MsgAddObserver) (*MsgAddObserverResponse, error) @@ -1296,11 +1503,13 @@ type MsgServer interface { UpdateChainParams(context.Context, *MsgUpdateChainParams) (*MsgUpdateChainParamsResponse, error) RemoveChainParams(context.Context, *MsgRemoveChainParams) (*MsgRemoveChainParamsResponse, error) AddBlameVote(context.Context, *MsgAddBlameVote) (*MsgAddBlameVoteResponse, error) - UpdateCrosschainFlags(context.Context, *MsgUpdateCrosschainFlags) (*MsgUpdateCrosschainFlagsResponse, error) UpdateKeygen(context.Context, *MsgUpdateKeygen) (*MsgUpdateKeygenResponse, error) VoteBlockHeader(context.Context, *MsgVoteBlockHeader) (*MsgVoteBlockHeaderResponse, error) ResetChainNonces(context.Context, *MsgResetChainNonces) (*MsgResetChainNoncesResponse, error) VoteTSS(context.Context, *MsgVoteTSS) (*MsgVoteTSSResponse, error) + EnableCCTX(context.Context, *MsgEnableCCTX) (*MsgEnableCCTXResponse, error) + DisableCCTX(context.Context, *MsgDisableCCTX) (*MsgDisableCCTXResponse, error) + UpdateGasPriceIncreaseFlags(context.Context, *MsgUpdateGasPriceIncreaseFlags) (*MsgUpdateGasPriceIncreaseFlagsResponse, error) } // UnimplementedMsgServer can be embedded to have forward compatible implementations. @@ -1322,9 +1531,6 @@ func (*UnimplementedMsgServer) RemoveChainParams(ctx context.Context, req *MsgRe func (*UnimplementedMsgServer) AddBlameVote(ctx context.Context, req *MsgAddBlameVote) (*MsgAddBlameVoteResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method AddBlameVote not implemented") } -func (*UnimplementedMsgServer) UpdateCrosschainFlags(ctx context.Context, req *MsgUpdateCrosschainFlags) (*MsgUpdateCrosschainFlagsResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method UpdateCrosschainFlags not implemented") -} func (*UnimplementedMsgServer) UpdateKeygen(ctx context.Context, req *MsgUpdateKeygen) (*MsgUpdateKeygenResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method UpdateKeygen not implemented") } @@ -1337,6 +1543,15 @@ func (*UnimplementedMsgServer) ResetChainNonces(ctx context.Context, req *MsgRes func (*UnimplementedMsgServer) VoteTSS(ctx context.Context, req *MsgVoteTSS) (*MsgVoteTSSResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method VoteTSS not implemented") } +func (*UnimplementedMsgServer) EnableCCTX(ctx context.Context, req *MsgEnableCCTX) (*MsgEnableCCTXResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method EnableCCTX not implemented") +} +func (*UnimplementedMsgServer) DisableCCTX(ctx context.Context, req *MsgDisableCCTX) (*MsgDisableCCTXResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method DisableCCTX not implemented") +} +func (*UnimplementedMsgServer) UpdateGasPriceIncreaseFlags(ctx context.Context, req *MsgUpdateGasPriceIncreaseFlags) (*MsgUpdateGasPriceIncreaseFlagsResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method UpdateGasPriceIncreaseFlags not implemented") +} func RegisterMsgServer(s grpc1.Server, srv MsgServer) { s.RegisterService(&_Msg_serviceDesc, srv) @@ -1432,24 +1647,6 @@ func _Msg_AddBlameVote_Handler(srv interface{}, ctx context.Context, dec func(in return interceptor(ctx, in, info, handler) } -func _Msg_UpdateCrosschainFlags_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgUpdateCrosschainFlags) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(MsgServer).UpdateCrosschainFlags(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/zetachain.zetacore.observer.Msg/UpdateCrosschainFlags", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).UpdateCrosschainFlags(ctx, req.(*MsgUpdateCrosschainFlags)) - } - return interceptor(ctx, in, info, handler) -} - func _Msg_UpdateKeygen_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { in := new(MsgUpdateKeygen) if err := dec(in); err != nil { @@ -1522,6 +1719,60 @@ func _Msg_VoteTSS_Handler(srv interface{}, ctx context.Context, dec func(interfa return interceptor(ctx, in, info, handler) } +func _Msg_EnableCCTX_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(MsgEnableCCTX) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(MsgServer).EnableCCTX(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/zetachain.zetacore.observer.Msg/EnableCCTX", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(MsgServer).EnableCCTX(ctx, req.(*MsgEnableCCTX)) + } + return interceptor(ctx, in, info, handler) +} + +func _Msg_DisableCCTX_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(MsgDisableCCTX) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(MsgServer).DisableCCTX(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/zetachain.zetacore.observer.Msg/DisableCCTX", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(MsgServer).DisableCCTX(ctx, req.(*MsgDisableCCTX)) + } + return interceptor(ctx, in, info, handler) +} + +func _Msg_UpdateGasPriceIncreaseFlags_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(MsgUpdateGasPriceIncreaseFlags) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(MsgServer).UpdateGasPriceIncreaseFlags(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/zetachain.zetacore.observer.Msg/UpdateGasPriceIncreaseFlags", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(MsgServer).UpdateGasPriceIncreaseFlags(ctx, req.(*MsgUpdateGasPriceIncreaseFlags)) + } + return interceptor(ctx, in, info, handler) +} + var _Msg_serviceDesc = grpc.ServiceDesc{ ServiceName: "zetachain.zetacore.observer.Msg", HandlerType: (*MsgServer)(nil), @@ -1546,10 +1797,6 @@ var _Msg_serviceDesc = grpc.ServiceDesc{ MethodName: "AddBlameVote", Handler: _Msg_AddBlameVote_Handler, }, - { - MethodName: "UpdateCrosschainFlags", - Handler: _Msg_UpdateCrosschainFlags_Handler, - }, { MethodName: "UpdateKeygen", Handler: _Msg_UpdateKeygen_Handler, @@ -1566,6 +1813,18 @@ var _Msg_serviceDesc = grpc.ServiceDesc{ MethodName: "VoteTSS", Handler: _Msg_VoteTSS_Handler, }, + { + MethodName: "EnableCCTX", + Handler: _Msg_EnableCCTX_Handler, + }, + { + MethodName: "DisableCCTX", + Handler: _Msg_DisableCCTX_Handler, + }, + { + MethodName: "UpdateGasPriceIncreaseFlags", + Handler: _Msg_UpdateGasPriceIncreaseFlags_Handler, + }, }, Streams: []grpc.StreamDesc{}, Metadata: "zetachain/zetacore/observer/tx.proto", @@ -2011,91 +2270,6 @@ func (m *MsgAddBlameVoteResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) return len(dAtA) - i, nil } -func (m *MsgUpdateCrosschainFlags) 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 *MsgUpdateCrosschainFlags) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgUpdateCrosschainFlags) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.GasPriceIncreaseFlags != nil { - { - size, err := m.GasPriceIncreaseFlags.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x2a - } - if m.IsOutboundEnabled { - i-- - if m.IsOutboundEnabled { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x20 - } - if m.IsInboundEnabled { - i-- - if m.IsInboundEnabled { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x18 - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgUpdateCrosschainFlagsResponse) 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 *MsgUpdateCrosschainFlagsResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgUpdateCrosschainFlagsResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - return len(dAtA) - i, nil -} - func (m *MsgUpdateKeygen) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) @@ -2322,62 +2496,271 @@ func (m *MsgVoteTSSResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } -func encodeVarintTx(dAtA []byte, offset int, v uint64) int { - offset -= sovTx(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ +func (m *MsgEnableCCTX) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err } - dAtA[offset] = uint8(v) - return base + return dAtA[:n], nil } -func (m *MsgUpdateObserver) Size() (n int) { - if m == nil { - return 0 - } + +func (m *MsgEnableCCTX) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MsgEnableCCTX) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i var l int _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - l = len(m.OldObserverAddress) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) + if m.EnableOutbound { + i-- + if m.EnableOutbound { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x18 } - l = len(m.NewObserverAddress) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) + if m.EnableInbound { + i-- + if m.EnableInbound { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x10 } - if m.UpdateReason != 0 { - n += 1 + sovTx(uint64(m.UpdateReason)) + if len(m.Creator) > 0 { + i -= len(m.Creator) + copy(dAtA[i:], m.Creator) + i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) + i-- + dAtA[i] = 0xa } - return n + return len(dAtA) - i, nil } -func (m *MsgUpdateObserverResponse) Size() (n int) { - if m == nil { - return 0 +func (m *MsgEnableCCTXResponse) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err } - var l int - _ = l - return n + return dAtA[:n], nil } -func (m *MsgVoteBlockHeader) Size() (n int) { - if m == nil { - return 0 - } +func (m *MsgEnableCCTXResponse) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MsgEnableCCTXResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i var l int _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) + return len(dAtA) - i, nil +} + +func (m *MsgDisableCCTX) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err } - if m.ChainId != 0 { - n += 1 + sovTx(uint64(m.ChainId)) + return dAtA[:n], nil +} + +func (m *MsgDisableCCTX) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MsgDisableCCTX) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.DisableOutbound { + i-- + if m.DisableOutbound { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x18 + } + if m.DisableInbound { + i-- + if m.DisableInbound { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x10 + } + if len(m.Creator) > 0 { + i -= len(m.Creator) + copy(dAtA[i:], m.Creator) + i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *MsgDisableCCTXResponse) 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 *MsgDisableCCTXResponse) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MsgDisableCCTXResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + return len(dAtA) - i, nil +} + +func (m *MsgUpdateGasPriceIncreaseFlags) 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 *MsgUpdateGasPriceIncreaseFlags) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MsgUpdateGasPriceIncreaseFlags) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.GasPriceIncreaseFlags.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintTx(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x12 + if len(m.Creator) > 0 { + i -= len(m.Creator) + copy(dAtA[i:], m.Creator) + i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *MsgUpdateGasPriceIncreaseFlagsResponse) 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 *MsgUpdateGasPriceIncreaseFlagsResponse) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *MsgUpdateGasPriceIncreaseFlagsResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + return len(dAtA) - i, nil +} + +func encodeVarintTx(dAtA []byte, offset int, v uint64) int { + offset -= sovTx(v) + base := offset + for v >= 1<<7 { + dAtA[offset] = uint8(v&0x7f | 0x80) + v >>= 7 + offset++ + } + dAtA[offset] = uint8(v) + return base +} +func (m *MsgUpdateObserver) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Creator) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = len(m.OldObserverAddress) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = len(m.NewObserverAddress) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + if m.UpdateReason != 0 { + n += 1 + sovTx(uint64(m.UpdateReason)) + } + return n +} + +func (m *MsgUpdateObserverResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n +} + +func (m *MsgVoteBlockHeader) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Creator) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + if m.ChainId != 0 { + n += 1 + sovTx(uint64(m.ChainId)) } l = len(m.BlockHash) if l > 0 { @@ -2517,38 +2900,6 @@ func (m *MsgAddBlameVoteResponse) Size() (n int) { return n } -func (m *MsgUpdateCrosschainFlags) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - if m.IsInboundEnabled { - n += 2 - } - if m.IsOutboundEnabled { - n += 2 - } - if m.GasPriceIncreaseFlags != nil { - l = m.GasPriceIncreaseFlags.Size() - n += 1 + l + sovTx(uint64(l)) - } - return n -} - -func (m *MsgUpdateCrosschainFlagsResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - return n -} - func (m *MsgUpdateKeygen) Size() (n int) { if m == nil { return 0 @@ -2646,49 +2997,344 @@ func (m *MsgVoteTSSResponse) Size() (n int) { return n } -func sovTx(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 +func (m *MsgEnableCCTX) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Creator) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + if m.EnableInbound { + n += 2 + } + if m.EnableOutbound { + n += 2 + } + return n } -func sozTx(x uint64) (n int) { - return sovTx(uint64((x << 1) ^ uint64((int64(x) >> 63)))) + +func (m *MsgEnableCCTXResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n } -func (m *MsgUpdateObserver) 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 ErrIntOverflowTx - } - 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: MsgUpdateObserver: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateObserver: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx + +func (m *MsgDisableCCTX) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Creator) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + if m.DisableInbound { + n += 2 + } + if m.DisableOutbound { + n += 2 + } + return n +} + +func (m *MsgDisableCCTXResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n +} + +func (m *MsgUpdateGasPriceIncreaseFlags) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Creator) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = m.GasPriceIncreaseFlags.Size() + n += 1 + l + sovTx(uint64(l)) + return n +} + +func (m *MsgUpdateGasPriceIncreaseFlagsResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n +} + +func sovTx(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozTx(x uint64) (n int) { + return sovTx(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (m *MsgUpdateObserver) 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 ErrIntOverflowTx + } + 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: MsgUpdateObserver: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MsgUpdateObserver: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Creator", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + 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 ErrInvalidLengthTx + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Creator = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field OldObserverAddress", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + 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 ErrInvalidLengthTx + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.OldObserverAddress = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field NewObserverAddress", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + 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 ErrInvalidLengthTx + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.NewObserverAddress = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field UpdateReason", wireType) + } + m.UpdateReason = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.UpdateReason |= ObserverUpdateReason(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipTx(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthTx + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *MsgUpdateObserverResponse) 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 ErrIntOverflowTx + } + 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: MsgUpdateObserverResponse: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MsgUpdateObserverResponse: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + default: + iNdEx = preIndex + skippy, err := skipTx(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthTx + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *MsgVoteBlockHeader) 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 ErrIntOverflowTx + } + 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: MsgVoteBlockHeader: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MsgVoteBlockHeader: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Creator", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx } if iNdEx >= l { return io.ErrUnexpectedEOF @@ -2714,8 +3360,253 @@ func (m *MsgUpdateObserver) Unmarshal(dAtA []byte) error { m.Creator = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex 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 ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ChainId |= int64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field BlockHash", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(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.BlockHash = append(m.BlockHash[:0], dAtA[iNdEx:postIndex]...) + if m.BlockHash == nil { + m.BlockHash = []byte{} + } + iNdEx = postIndex + case 4: + 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 ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Height |= 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 ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + 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:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthTx + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *MsgVoteBlockHeaderResponse) 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 ErrIntOverflowTx + } + 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: MsgVoteBlockHeaderResponse: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MsgVoteBlockHeaderResponse: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field BallotCreated", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.BallotCreated = bool(v != 0) + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field VoteFinalized", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.VoteFinalized = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipTx(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthTx + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *MsgUpdateChainParams) 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 ErrIntOverflowTx + } + 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: MsgUpdateChainParams: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: MsgUpdateChainParams: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field OldObserverAddress", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field Creator", wireType) } var stringLen uint64 for shift := uint(0); ; shift += 7 { @@ -2743,13 +3634,13 @@ func (m *MsgUpdateObserver) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - m.OldObserverAddress = string(dAtA[iNdEx:postIndex]) + m.Creator = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex - case 3: + case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field NewObserverAddress", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field ChainParams", wireType) } - var stringLen uint64 + var msglen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -2759,43 +3650,28 @@ func (m *MsgUpdateObserver) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - stringLen |= uint64(b&0x7F) << shift + msglen |= int(b&0x7F) << shift if b < 0x80 { break } } - intStringLen := int(stringLen) - if intStringLen < 0 { + if msglen < 0 { return ErrInvalidLengthTx } - postIndex := iNdEx + intStringLen + postIndex := iNdEx + msglen if postIndex < 0 { return ErrInvalidLengthTx } if postIndex > l { return io.ErrUnexpectedEOF } - m.NewObserverAddress = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field UpdateReason", wireType) + if m.ChainParams == nil { + m.ChainParams = &ChainParams{} } - m.UpdateReason = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.UpdateReason |= ObserverUpdateReason(b&0x7F) << shift - if b < 0x80 { - break - } + if err := m.ChainParams.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -2817,7 +3693,7 @@ func (m *MsgUpdateObserver) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateObserverResponse) Unmarshal(dAtA []byte) error { +func (m *MsgUpdateChainParamsResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -2840,10 +3716,10 @@ func (m *MsgUpdateObserverResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateObserverResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgUpdateChainParamsResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateObserverResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgUpdateChainParamsResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { default: @@ -2867,7 +3743,7 @@ func (m *MsgUpdateObserverResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgVoteBlockHeader) Unmarshal(dAtA []byte) error { +func (m *MsgRemoveChainParams) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -2890,10 +3766,10 @@ func (m *MsgVoteBlockHeader) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgVoteBlockHeader: wiretype end group for non-group") + return fmt.Errorf("proto: MsgRemoveChainParams: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgVoteBlockHeader: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgRemoveChainParams: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -2947,92 +3823,6 @@ func (m *MsgVoteBlockHeader) Unmarshal(dAtA []byte) error { break } } - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field BlockHash", wireType) - } - var byteLen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - byteLen |= int(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.BlockHash = append(m.BlockHash[:0], dAtA[iNdEx:postIndex]...) - if m.BlockHash == nil { - m.BlockHash = []byte{} - } - iNdEx = postIndex - case 4: - 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 ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Height |= 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 ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - 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:]) @@ -3054,7 +3844,7 @@ func (m *MsgVoteBlockHeader) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgVoteBlockHeaderResponse) Unmarshal(dAtA []byte) error { +func (m *MsgRemoveChainParamsResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3077,52 +3867,12 @@ func (m *MsgVoteBlockHeaderResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgVoteBlockHeaderResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgRemoveChainParamsResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgVoteBlockHeaderResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgRemoveChainParamsResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field BallotCreated", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.BallotCreated = bool(v != 0) - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field VoteFinalized", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.VoteFinalized = bool(v != 0) default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -3144,7 +3894,7 @@ func (m *MsgVoteBlockHeaderResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateChainParams) Unmarshal(dAtA []byte) error { +func (m *MsgAddObserver) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3167,10 +3917,10 @@ func (m *MsgUpdateChainParams) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateChainParams: wiretype end group for non-group") + return fmt.Errorf("proto: MsgAddObserver: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateChainParams: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgAddObserver: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -3207,9 +3957,9 @@ func (m *MsgUpdateChainParams) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ChainParams", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field ObserverAddress", wireType) } - var msglen int + var stringLen uint64 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -3219,28 +3969,76 @@ func (m *MsgUpdateChainParams) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + stringLen |= uint64(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + intStringLen := int(stringLen) + if intStringLen < 0 { return ErrInvalidLengthTx } - postIndex := iNdEx + msglen + postIndex := iNdEx + intStringLen if postIndex < 0 { return ErrInvalidLengthTx } if postIndex > l { return io.ErrUnexpectedEOF } - if m.ChainParams == nil { - m.ChainParams = &ChainParams{} + m.ObserverAddress = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ZetaclientGranteePubkey", wireType) } - if err := m.ChainParams.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + 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 ErrInvalidLengthTx + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ZetaclientGranteePubkey = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field AddNodeAccountOnly", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } } - iNdEx = postIndex + m.AddNodeAccountOnly = bool(v != 0) default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -3262,7 +4060,7 @@ func (m *MsgUpdateChainParams) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateChainParamsResponse) Unmarshal(dAtA []byte) error { +func (m *MsgAddObserverResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3285,10 +4083,10 @@ func (m *MsgUpdateChainParamsResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateChainParamsResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgAddObserverResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateChainParamsResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgAddObserverResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { default: @@ -3312,7 +4110,7 @@ func (m *MsgUpdateChainParamsResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgRemoveChainParams) Unmarshal(dAtA []byte) error { +func (m *MsgAddBlameVote) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3335,10 +4133,10 @@ func (m *MsgRemoveChainParams) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgRemoveChainParams: wiretype end group for non-group") + return fmt.Errorf("proto: MsgAddBlameVote: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgRemoveChainParams: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgAddBlameVote: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -3392,6 +4190,39 @@ func (m *MsgRemoveChainParams) Unmarshal(dAtA []byte) error { break } } + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field BlameInfo", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + 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.BlameInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -3413,7 +4244,7 @@ func (m *MsgRemoveChainParams) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgRemoveChainParamsResponse) Unmarshal(dAtA []byte) error { +func (m *MsgAddBlameVoteResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3436,10 +4267,10 @@ func (m *MsgRemoveChainParamsResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgRemoveChainParamsResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgAddBlameVoteResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgRemoveChainParamsResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgAddBlameVoteResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { default: @@ -3463,7 +4294,7 @@ func (m *MsgRemoveChainParamsResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgAddObserver) Unmarshal(dAtA []byte) error { +func (m *MsgUpdateKeygen) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3486,10 +4317,10 @@ func (m *MsgAddObserver) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgAddObserver: wiretype end group for non-group") + return fmt.Errorf("proto: MsgUpdateKeygen: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgAddObserver: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgUpdateKeygen: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -3525,74 +4356,10 @@ func (m *MsgAddObserver) Unmarshal(dAtA []byte) error { m.Creator = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ObserverAddress", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - 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 ErrInvalidLengthTx - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthTx - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ObserverAddress = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ZetaclientGranteePubkey", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - 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 ErrInvalidLengthTx - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthTx - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ZetaclientGranteePubkey = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field AddNodeAccountOnly", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field Block", wireType) } - var v int + m.Block = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -3602,12 +4369,11 @@ func (m *MsgAddObserver) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - v |= int(b&0x7F) << shift + m.Block |= int64(b&0x7F) << shift if b < 0x80 { break } } - m.AddNodeAccountOnly = bool(v != 0) default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -3629,7 +4395,7 @@ func (m *MsgAddObserver) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgAddObserverResponse) Unmarshal(dAtA []byte) error { +func (m *MsgUpdateKeygenResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3652,10 +4418,10 @@ func (m *MsgAddObserverResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgAddObserverResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgUpdateKeygenResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgAddObserverResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgUpdateKeygenResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { default: @@ -3679,7 +4445,7 @@ func (m *MsgAddObserverResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgAddBlameVote) Unmarshal(dAtA []byte) error { +func (m *MsgResetChainNonces) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3702,10 +4468,10 @@ func (m *MsgAddBlameVote) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgAddBlameVote: wiretype end group for non-group") + return fmt.Errorf("proto: MsgResetChainNonces: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgAddBlameVote: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgResetChainNonces: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -3760,10 +4526,10 @@ func (m *MsgAddBlameVote) Unmarshal(dAtA []byte) error { } } case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field BlameInfo", wireType) + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ChainNonceLow", wireType) } - var msglen int + m.ChainNonceLow = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -3773,25 +4539,30 @@ func (m *MsgAddBlameVote) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + m.ChainNonceLow |= int64(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 + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field ChainNonceHigh", wireType) } - if err := m.BlameInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + m.ChainNonceHigh = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.ChainNonceHigh |= int64(b&0x7F) << shift + if b < 0x80 { + break + } } - iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -3813,7 +4584,7 @@ func (m *MsgAddBlameVote) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgAddBlameVoteResponse) Unmarshal(dAtA []byte) error { +func (m *MsgResetChainNoncesResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3836,10 +4607,10 @@ func (m *MsgAddBlameVoteResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgAddBlameVoteResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgResetChainNoncesResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgAddBlameVoteResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgResetChainNoncesResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { default: @@ -3863,7 +4634,7 @@ func (m *MsgAddBlameVoteResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateCrosschainFlags) Unmarshal(dAtA []byte) error { +func (m *MsgVoteTSS) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -3886,10 +4657,10 @@ func (m *MsgUpdateCrosschainFlags) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateCrosschainFlags: wiretype end group for non-group") + return fmt.Errorf("proto: MsgVoteTSS: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateCrosschainFlags: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgVoteTSS: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -3924,11 +4695,11 @@ func (m *MsgUpdateCrosschainFlags) Unmarshal(dAtA []byte) error { } m.Creator = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex - case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field IsInboundEnabled", wireType) + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field TssPubkey", wireType) } - var v int + var stringLen uint64 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -3938,17 +4709,29 @@ func (m *MsgUpdateCrosschainFlags) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - v |= int(b&0x7F) << shift + stringLen |= uint64(b&0x7F) << shift if b < 0x80 { break } } - m.IsInboundEnabled = bool(v != 0) - case 4: + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.TssPubkey = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field IsOutboundEnabled", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field KeygenZetaHeight", wireType) } - var v int + m.KeygenZetaHeight = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -3958,48 +4741,30 @@ func (m *MsgUpdateCrosschainFlags) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - v |= int(b&0x7F) << shift + m.KeygenZetaHeight |= int64(b&0x7F) << shift if b < 0x80 { break } } - m.IsOutboundEnabled = bool(v != 0) - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field GasPriceIncreaseFlags", wireType) + case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) } - var msglen int + m.Status = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - 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 m.GasPriceIncreaseFlags == nil { - m.GasPriceIncreaseFlags = &GasPriceIncreaseFlags{} - } - if err := m.GasPriceIncreaseFlags.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Status |= chains.ReceiveStatus(b&0x7F) << shift + if b < 0x80 { + break + } } - iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -4021,7 +4786,7 @@ func (m *MsgUpdateCrosschainFlags) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateCrosschainFlagsResponse) Unmarshal(dAtA []byte) error { +func (m *MsgVoteTSSResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -4044,12 +4809,72 @@ func (m *MsgUpdateCrosschainFlagsResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateCrosschainFlagsResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgVoteTSSResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateCrosschainFlagsResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgVoteTSSResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field BallotCreated", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.BallotCreated = bool(v != 0) + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field VoteFinalized", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.VoteFinalized = bool(v != 0) + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field KeygenSuccess", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.KeygenSuccess = bool(v != 0) default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -4071,7 +4896,7 @@ func (m *MsgUpdateCrosschainFlagsResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateKeygen) Unmarshal(dAtA []byte) error { +func (m *MsgEnableCCTX) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -4094,10 +4919,10 @@ func (m *MsgUpdateKeygen) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateKeygen: wiretype end group for non-group") + return fmt.Errorf("proto: MsgEnableCCTX: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateKeygen: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgEnableCCTX: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -4134,9 +4959,9 @@ func (m *MsgUpdateKeygen) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 2: if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Block", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field EnableInbound", wireType) } - m.Block = 0 + var v int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -4146,11 +4971,32 @@ func (m *MsgUpdateKeygen) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.Block |= int64(b&0x7F) << shift + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.EnableInbound = bool(v != 0) + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field EnableOutbound", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift if b < 0x80 { break } } + m.EnableOutbound = bool(v != 0) default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -4172,7 +5018,7 @@ func (m *MsgUpdateKeygen) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgUpdateKeygenResponse) Unmarshal(dAtA []byte) error { +func (m *MsgEnableCCTXResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -4195,10 +5041,10 @@ func (m *MsgUpdateKeygenResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateKeygenResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgEnableCCTXResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateKeygenResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgEnableCCTXResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { default: @@ -4222,7 +5068,7 @@ func (m *MsgUpdateKeygenResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgResetChainNonces) Unmarshal(dAtA []byte) error { +func (m *MsgDisableCCTX) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -4245,10 +5091,10 @@ func (m *MsgResetChainNonces) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgResetChainNonces: wiretype end group for non-group") + return fmt.Errorf("proto: MsgDisableCCTX: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgResetChainNonces: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgDisableCCTX: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -4285,9 +5131,9 @@ func (m *MsgResetChainNonces) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 2: if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field DisableInbound", wireType) } - m.ChainId = 0 + var v int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -4297,35 +5143,17 @@ func (m *MsgResetChainNonces) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.ChainId |= int64(b&0x7F) << shift + v |= int(b&0x7F) << shift if b < 0x80 { break } } + m.DisableInbound = bool(v != 0) case 3: if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field ChainNonceLow", wireType) - } - m.ChainNonceLow = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.ChainNonceLow |= int64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field ChainNonceHigh", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field DisableOutbound", wireType) } - m.ChainNonceHigh = 0 + var v int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -4335,11 +5163,12 @@ func (m *MsgResetChainNonces) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.ChainNonceHigh |= int64(b&0x7F) << shift + v |= int(b&0x7F) << shift if b < 0x80 { break } } + m.DisableOutbound = bool(v != 0) default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -4361,7 +5190,7 @@ func (m *MsgResetChainNonces) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgResetChainNoncesResponse) Unmarshal(dAtA []byte) error { +func (m *MsgDisableCCTXResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -4384,10 +5213,10 @@ func (m *MsgResetChainNoncesResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgResetChainNoncesResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgDisableCCTXResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgResetChainNoncesResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgDisableCCTXResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { default: @@ -4411,7 +5240,7 @@ func (m *MsgResetChainNoncesResponse) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgVoteTSS) Unmarshal(dAtA []byte) error { +func (m *MsgUpdateGasPriceIncreaseFlags) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -4434,10 +5263,10 @@ func (m *MsgVoteTSS) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgVoteTSS: wiretype end group for non-group") + return fmt.Errorf("proto: MsgUpdateGasPriceIncreaseFlags: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgVoteTSS: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgUpdateGasPriceIncreaseFlags: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: @@ -4474,9 +5303,9 @@ func (m *MsgVoteTSS) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field TssPubkey", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field GasPriceIncreaseFlags", wireType) } - var stringLen uint64 + var msglen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -4486,62 +5315,25 @@ func (m *MsgVoteTSS) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - stringLen |= uint64(b&0x7F) << shift + msglen |= int(b&0x7F) << shift if b < 0x80 { break } } - intStringLen := int(stringLen) - if intStringLen < 0 { + if msglen < 0 { return ErrInvalidLengthTx } - postIndex := iNdEx + intStringLen + postIndex := iNdEx + msglen if postIndex < 0 { return ErrInvalidLengthTx } if postIndex > l { return io.ErrUnexpectedEOF } - m.TssPubkey = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field KeygenZetaHeight", wireType) - } - m.KeygenZetaHeight = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.KeygenZetaHeight |= int64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) - } - m.Status = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Status |= chains.ReceiveStatus(b&0x7F) << shift - if b < 0x80 { - break - } + if err := m.GasPriceIncreaseFlags.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -4563,7 +5355,7 @@ func (m *MsgVoteTSS) Unmarshal(dAtA []byte) error { } return nil } -func (m *MsgVoteTSSResponse) Unmarshal(dAtA []byte) error { +func (m *MsgUpdateGasPriceIncreaseFlagsResponse) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -4586,72 +5378,12 @@ func (m *MsgVoteTSSResponse) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: MsgVoteTSSResponse: wiretype end group for non-group") + return fmt.Errorf("proto: MsgUpdateGasPriceIncreaseFlagsResponse: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: MsgVoteTSSResponse: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: MsgUpdateGasPriceIncreaseFlagsResponse: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field BallotCreated", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.BallotCreated = bool(v != 0) - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field VoteFinalized", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.VoteFinalized = bool(v != 0) - case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field KeygenSuccess", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.KeygenSuccess = bool(v != 0) default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:])