소스 검색

sdk/wormchain: regen and initial release

Evan Gray 2 년 전
부모
커밋
4ac2e094d9
40개의 변경된 파일14795개의 추가작업 그리고 116개의 파일을 삭제
  1. 3 0
      wormchain/ts-sdk/package.json
  2. 3 3
      wormchain/ts-sdk/src/modules/cosmos.bank.v1beta1/index.ts
  3. 6 6
      wormchain/ts-sdk/src/modules/cosmos.distribution.v1beta1/index.ts
  4. 3 3
      wormchain/ts-sdk/src/modules/cosmos.feegrant.v1beta1/index.ts
  5. 6 6
      wormchain/ts-sdk/src/modules/cosmos.gov.v1beta1/index.ts
  6. 9 9
      wormchain/ts-sdk/src/modules/cosmos.staking.v1beta1/index.ts
  7. 15 12
      wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/index.ts
  8. 100 19
      wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/rest.ts
  9. 1 29
      wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmos/base/query/v1beta1/pagination.ts
  10. 796 0
      wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/authz.ts
  11. 44 0
      wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/genesis.ts
  12. 439 0
      wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/proposal.ts
  13. 356 0
      wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/query.ts
  14. 368 3
      wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/tx.ts
  15. 42 7
      wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/types.ts
  16. 76 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/index.ts
  17. 400 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/rest.ts
  18. 738 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/cosmos/bank/v1beta1/bank.ts
  19. 301 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/cosmos/base/query/v1beta1/pagination.ts
  20. 302 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/cosmos/base/v1beta1/coin.ts
  21. 3 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/cosmos_proto/cosmos.ts
  22. 3 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/gogoproto/gogo.ts
  23. 3 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/google/api/annotations.ts
  24. 707 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/google/api/http.ts
  25. 5315 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/google/protobuf/descriptor.ts
  26. 86 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/osmosis/tokenfactory/v1beta1/authorityMetadata.ts
  27. 210 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/osmosis/tokenfactory/v1beta1/genesis.ts
  28. 149 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/osmosis/tokenfactory/v1beta1/params.ts
  29. 533 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/osmosis/tokenfactory/v1beta1/query.ts
  30. 1040 0
      wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/osmosis/tokenfactory/v1beta1/tx.ts
  31. 24 6
      wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/index.ts
  32. 171 0
      wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/rest.ts
  33. 122 3
      wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/genesis.ts
  34. 1 1
      wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/governance.ts
  35. 621 0
      wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/guardian.ts
  36. 1 0
      wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/guardian_key.ts
  37. 1 0
      wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/guardian_set.ts
  38. 1 0
      wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/guardian_validator.ts
  39. 821 2
      wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/query.ts
  40. 975 7
      wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/tx.ts

+ 3 - 0
wormchain/ts-sdk/package.json

@@ -3,6 +3,9 @@
   "version": "0.0.1",
   "description": "Typescript SDK for interating with the Wormhole chain",
   "main": "lib/index.js",
+  "files": [
+    "lib/"
+  ],
   "scripts": {
     "test": "jest --config jestconfig.json --verbose",
     "build": "npm run genTypes && tsc",

+ 3 - 3
wormchain/ts-sdk/src/modules/cosmos.bank.v1beta1/index.ts

@@ -5,13 +5,13 @@ import { StdFee } from "@cosmjs/launchpad";
 import { SigningStargateClient } from "@cosmjs/stargate";
 import { Registry, OfflineSigner, EncodeObject, DirectSecp256k1HdWallet } from "@cosmjs/proto-signing";
 import { Api } from "./rest";
-import { MsgSend } from "./types/cosmos/bank/v1beta1/tx";
 import { MsgMultiSend } from "./types/cosmos/bank/v1beta1/tx";
+import { MsgSend } from "./types/cosmos/bank/v1beta1/tx";
 
 
 const types = [
-  ["/cosmos.bank.v1beta1.MsgSend", MsgSend],
   ["/cosmos.bank.v1beta1.MsgMultiSend", MsgMultiSend],
+  ["/cosmos.bank.v1beta1.MsgSend", MsgSend],
   
 ];
 export const MissingWalletError = new Error("wallet is required");
@@ -44,8 +44,8 @@ const txClient = async (wallet: OfflineSigner, { addr: addr }: TxClientOptions =
 
   return {
     signAndBroadcast: (msgs: EncodeObject[], { fee, memo }: SignAndBroadcastOptions = {fee: defaultFee, memo: ""}) => client.signAndBroadcast(address, msgs, fee,memo),
-    msgSend: (data: MsgSend): EncodeObject => ({ typeUrl: "/cosmos.bank.v1beta1.MsgSend", value: MsgSend.fromPartial( data ) }),
     msgMultiSend: (data: MsgMultiSend): EncodeObject => ({ typeUrl: "/cosmos.bank.v1beta1.MsgMultiSend", value: MsgMultiSend.fromPartial( data ) }),
+    msgSend: (data: MsgSend): EncodeObject => ({ typeUrl: "/cosmos.bank.v1beta1.MsgSend", value: MsgSend.fromPartial( data ) }),
     
   };
 };

+ 6 - 6
wormchain/ts-sdk/src/modules/cosmos.distribution.v1beta1/index.ts

@@ -5,17 +5,17 @@ import { StdFee } from "@cosmjs/launchpad";
 import { SigningStargateClient } from "@cosmjs/stargate";
 import { Registry, OfflineSigner, EncodeObject, DirectSecp256k1HdWallet } from "@cosmjs/proto-signing";
 import { Api } from "./rest";
+import { MsgWithdrawValidatorCommission } from "./types/cosmos/distribution/v1beta1/tx";
 import { MsgSetWithdrawAddress } from "./types/cosmos/distribution/v1beta1/tx";
-import { MsgFundCommunityPool } from "./types/cosmos/distribution/v1beta1/tx";
 import { MsgWithdrawDelegatorReward } from "./types/cosmos/distribution/v1beta1/tx";
-import { MsgWithdrawValidatorCommission } from "./types/cosmos/distribution/v1beta1/tx";
+import { MsgFundCommunityPool } from "./types/cosmos/distribution/v1beta1/tx";
 
 
 const types = [
+  ["/cosmos.distribution.v1beta1.MsgWithdrawValidatorCommission", MsgWithdrawValidatorCommission],
   ["/cosmos.distribution.v1beta1.MsgSetWithdrawAddress", MsgSetWithdrawAddress],
-  ["/cosmos.distribution.v1beta1.MsgFundCommunityPool", MsgFundCommunityPool],
   ["/cosmos.distribution.v1beta1.MsgWithdrawDelegatorReward", MsgWithdrawDelegatorReward],
-  ["/cosmos.distribution.v1beta1.MsgWithdrawValidatorCommission", MsgWithdrawValidatorCommission],
+  ["/cosmos.distribution.v1beta1.MsgFundCommunityPool", MsgFundCommunityPool],
   
 ];
 export const MissingWalletError = new Error("wallet is required");
@@ -48,10 +48,10 @@ const txClient = async (wallet: OfflineSigner, { addr: addr }: TxClientOptions =
 
   return {
     signAndBroadcast: (msgs: EncodeObject[], { fee, memo }: SignAndBroadcastOptions = {fee: defaultFee, memo: ""}) => client.signAndBroadcast(address, msgs, fee,memo),
+    msgWithdrawValidatorCommission: (data: MsgWithdrawValidatorCommission): EncodeObject => ({ typeUrl: "/cosmos.distribution.v1beta1.MsgWithdrawValidatorCommission", value: MsgWithdrawValidatorCommission.fromPartial( data ) }),
     msgSetWithdrawAddress: (data: MsgSetWithdrawAddress): EncodeObject => ({ typeUrl: "/cosmos.distribution.v1beta1.MsgSetWithdrawAddress", value: MsgSetWithdrawAddress.fromPartial( data ) }),
-    msgFundCommunityPool: (data: MsgFundCommunityPool): EncodeObject => ({ typeUrl: "/cosmos.distribution.v1beta1.MsgFundCommunityPool", value: MsgFundCommunityPool.fromPartial( data ) }),
     msgWithdrawDelegatorReward: (data: MsgWithdrawDelegatorReward): EncodeObject => ({ typeUrl: "/cosmos.distribution.v1beta1.MsgWithdrawDelegatorReward", value: MsgWithdrawDelegatorReward.fromPartial( data ) }),
-    msgWithdrawValidatorCommission: (data: MsgWithdrawValidatorCommission): EncodeObject => ({ typeUrl: "/cosmos.distribution.v1beta1.MsgWithdrawValidatorCommission", value: MsgWithdrawValidatorCommission.fromPartial( data ) }),
+    msgFundCommunityPool: (data: MsgFundCommunityPool): EncodeObject => ({ typeUrl: "/cosmos.distribution.v1beta1.MsgFundCommunityPool", value: MsgFundCommunityPool.fromPartial( data ) }),
     
   };
 };

+ 3 - 3
wormchain/ts-sdk/src/modules/cosmos.feegrant.v1beta1/index.ts

@@ -5,13 +5,13 @@ import { StdFee } from "@cosmjs/launchpad";
 import { SigningStargateClient } from "@cosmjs/stargate";
 import { Registry, OfflineSigner, EncodeObject, DirectSecp256k1HdWallet } from "@cosmjs/proto-signing";
 import { Api } from "./rest";
-import { MsgRevokeAllowance } from "./types/cosmos/feegrant/v1beta1/tx";
 import { MsgGrantAllowance } from "./types/cosmos/feegrant/v1beta1/tx";
+import { MsgRevokeAllowance } from "./types/cosmos/feegrant/v1beta1/tx";
 
 
 const types = [
-  ["/cosmos.feegrant.v1beta1.MsgRevokeAllowance", MsgRevokeAllowance],
   ["/cosmos.feegrant.v1beta1.MsgGrantAllowance", MsgGrantAllowance],
+  ["/cosmos.feegrant.v1beta1.MsgRevokeAllowance", MsgRevokeAllowance],
   
 ];
 export const MissingWalletError = new Error("wallet is required");
@@ -44,8 +44,8 @@ const txClient = async (wallet: OfflineSigner, { addr: addr }: TxClientOptions =
 
   return {
     signAndBroadcast: (msgs: EncodeObject[], { fee, memo }: SignAndBroadcastOptions = {fee: defaultFee, memo: ""}) => client.signAndBroadcast(address, msgs, fee,memo),
-    msgRevokeAllowance: (data: MsgRevokeAllowance): EncodeObject => ({ typeUrl: "/cosmos.feegrant.v1beta1.MsgRevokeAllowance", value: MsgRevokeAllowance.fromPartial( data ) }),
     msgGrantAllowance: (data: MsgGrantAllowance): EncodeObject => ({ typeUrl: "/cosmos.feegrant.v1beta1.MsgGrantAllowance", value: MsgGrantAllowance.fromPartial( data ) }),
+    msgRevokeAllowance: (data: MsgRevokeAllowance): EncodeObject => ({ typeUrl: "/cosmos.feegrant.v1beta1.MsgRevokeAllowance", value: MsgRevokeAllowance.fromPartial( data ) }),
     
   };
 };

+ 6 - 6
wormchain/ts-sdk/src/modules/cosmos.gov.v1beta1/index.ts

@@ -5,17 +5,17 @@ import { StdFee } from "@cosmjs/launchpad";
 import { SigningStargateClient } from "@cosmjs/stargate";
 import { Registry, OfflineSigner, EncodeObject, DirectSecp256k1HdWallet } from "@cosmjs/proto-signing";
 import { Api } from "./rest";
-import { MsgSubmitProposal } from "./types/cosmos/gov/v1beta1/tx";
 import { MsgDeposit } from "./types/cosmos/gov/v1beta1/tx";
-import { MsgVoteWeighted } from "./types/cosmos/gov/v1beta1/tx";
 import { MsgVote } from "./types/cosmos/gov/v1beta1/tx";
+import { MsgVoteWeighted } from "./types/cosmos/gov/v1beta1/tx";
+import { MsgSubmitProposal } from "./types/cosmos/gov/v1beta1/tx";
 
 
 const types = [
-  ["/cosmos.gov.v1beta1.MsgSubmitProposal", MsgSubmitProposal],
   ["/cosmos.gov.v1beta1.MsgDeposit", MsgDeposit],
-  ["/cosmos.gov.v1beta1.MsgVoteWeighted", MsgVoteWeighted],
   ["/cosmos.gov.v1beta1.MsgVote", MsgVote],
+  ["/cosmos.gov.v1beta1.MsgVoteWeighted", MsgVoteWeighted],
+  ["/cosmos.gov.v1beta1.MsgSubmitProposal", MsgSubmitProposal],
   
 ];
 export const MissingWalletError = new Error("wallet is required");
@@ -48,10 +48,10 @@ const txClient = async (wallet: OfflineSigner, { addr: addr }: TxClientOptions =
 
   return {
     signAndBroadcast: (msgs: EncodeObject[], { fee, memo }: SignAndBroadcastOptions = {fee: defaultFee, memo: ""}) => client.signAndBroadcast(address, msgs, fee,memo),
-    msgSubmitProposal: (data: MsgSubmitProposal): EncodeObject => ({ typeUrl: "/cosmos.gov.v1beta1.MsgSubmitProposal", value: MsgSubmitProposal.fromPartial( data ) }),
     msgDeposit: (data: MsgDeposit): EncodeObject => ({ typeUrl: "/cosmos.gov.v1beta1.MsgDeposit", value: MsgDeposit.fromPartial( data ) }),
-    msgVoteWeighted: (data: MsgVoteWeighted): EncodeObject => ({ typeUrl: "/cosmos.gov.v1beta1.MsgVoteWeighted", value: MsgVoteWeighted.fromPartial( data ) }),
     msgVote: (data: MsgVote): EncodeObject => ({ typeUrl: "/cosmos.gov.v1beta1.MsgVote", value: MsgVote.fromPartial( data ) }),
+    msgVoteWeighted: (data: MsgVoteWeighted): EncodeObject => ({ typeUrl: "/cosmos.gov.v1beta1.MsgVoteWeighted", value: MsgVoteWeighted.fromPartial( data ) }),
+    msgSubmitProposal: (data: MsgSubmitProposal): EncodeObject => ({ typeUrl: "/cosmos.gov.v1beta1.MsgSubmitProposal", value: MsgSubmitProposal.fromPartial( data ) }),
     
   };
 };

+ 9 - 9
wormchain/ts-sdk/src/modules/cosmos.staking.v1beta1/index.ts

@@ -6,18 +6,18 @@ import { SigningStargateClient } from "@cosmjs/stargate";
 import { Registry, OfflineSigner, EncodeObject, DirectSecp256k1HdWallet } from "@cosmjs/proto-signing";
 import { Api } from "./rest";
 import { MsgCreateValidator } from "./types/cosmos/staking/v1beta1/tx";
-import { MsgBeginRedelegate } from "./types/cosmos/staking/v1beta1/tx";
-import { MsgUndelegate } from "./types/cosmos/staking/v1beta1/tx";
-import { MsgEditValidator } from "./types/cosmos/staking/v1beta1/tx";
 import { MsgDelegate } from "./types/cosmos/staking/v1beta1/tx";
+import { MsgEditValidator } from "./types/cosmos/staking/v1beta1/tx";
+import { MsgUndelegate } from "./types/cosmos/staking/v1beta1/tx";
+import { MsgBeginRedelegate } from "./types/cosmos/staking/v1beta1/tx";
 
 
 const types = [
   ["/cosmos.staking.v1beta1.MsgCreateValidator", MsgCreateValidator],
-  ["/cosmos.staking.v1beta1.MsgBeginRedelegate", MsgBeginRedelegate],
-  ["/cosmos.staking.v1beta1.MsgUndelegate", MsgUndelegate],
-  ["/cosmos.staking.v1beta1.MsgEditValidator", MsgEditValidator],
   ["/cosmos.staking.v1beta1.MsgDelegate", MsgDelegate],
+  ["/cosmos.staking.v1beta1.MsgEditValidator", MsgEditValidator],
+  ["/cosmos.staking.v1beta1.MsgUndelegate", MsgUndelegate],
+  ["/cosmos.staking.v1beta1.MsgBeginRedelegate", MsgBeginRedelegate],
   
 ];
 export const MissingWalletError = new Error("wallet is required");
@@ -51,10 +51,10 @@ const txClient = async (wallet: OfflineSigner, { addr: addr }: TxClientOptions =
   return {
     signAndBroadcast: (msgs: EncodeObject[], { fee, memo }: SignAndBroadcastOptions = {fee: defaultFee, memo: ""}) => client.signAndBroadcast(address, msgs, fee,memo),
     msgCreateValidator: (data: MsgCreateValidator): EncodeObject => ({ typeUrl: "/cosmos.staking.v1beta1.MsgCreateValidator", value: MsgCreateValidator.fromPartial( data ) }),
-    msgBeginRedelegate: (data: MsgBeginRedelegate): EncodeObject => ({ typeUrl: "/cosmos.staking.v1beta1.MsgBeginRedelegate", value: MsgBeginRedelegate.fromPartial( data ) }),
-    msgUndelegate: (data: MsgUndelegate): EncodeObject => ({ typeUrl: "/cosmos.staking.v1beta1.MsgUndelegate", value: MsgUndelegate.fromPartial( data ) }),
-    msgEditValidator: (data: MsgEditValidator): EncodeObject => ({ typeUrl: "/cosmos.staking.v1beta1.MsgEditValidator", value: MsgEditValidator.fromPartial( data ) }),
     msgDelegate: (data: MsgDelegate): EncodeObject => ({ typeUrl: "/cosmos.staking.v1beta1.MsgDelegate", value: MsgDelegate.fromPartial( data ) }),
+    msgEditValidator: (data: MsgEditValidator): EncodeObject => ({ typeUrl: "/cosmos.staking.v1beta1.MsgEditValidator", value: MsgEditValidator.fromPartial( data ) }),
+    msgUndelegate: (data: MsgUndelegate): EncodeObject => ({ typeUrl: "/cosmos.staking.v1beta1.MsgUndelegate", value: MsgUndelegate.fromPartial( data ) }),
+    msgBeginRedelegate: (data: MsgBeginRedelegate): EncodeObject => ({ typeUrl: "/cosmos.staking.v1beta1.MsgBeginRedelegate", value: MsgBeginRedelegate.fromPartial( data ) }),
     
   };
 };

+ 15 - 12
wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/index.ts

@@ -5,25 +5,27 @@ import { StdFee } from "@cosmjs/launchpad";
 import { SigningStargateClient } from "@cosmjs/stargate";
 import { Registry, OfflineSigner, EncodeObject, DirectSecp256k1HdWallet } from "@cosmjs/proto-signing";
 import { Api } from "./rest";
+import { MsgInstantiateContract } from "./types/cosmwasm/wasm/v1/tx";
+import { MsgUpdateAdmin } from "./types/cosmwasm/wasm/v1/tx";
+import { MsgInstantiateContract2 } from "./types/cosmwasm/wasm/v1/tx";
 import { MsgIBCCloseChannel } from "./types/cosmwasm/wasm/v1/ibc";
-import { MsgIBCSend } from "./types/cosmwasm/wasm/v1/ibc";
-import { MsgExecuteContract } from "./types/cosmwasm/wasm/v1/tx";
 import { MsgMigrateContract } from "./types/cosmwasm/wasm/v1/tx";
 import { MsgStoreCode } from "./types/cosmwasm/wasm/v1/tx";
-import { MsgInstantiateContract } from "./types/cosmwasm/wasm/v1/tx";
+import { MsgExecuteContract } from "./types/cosmwasm/wasm/v1/tx";
 import { MsgClearAdmin } from "./types/cosmwasm/wasm/v1/tx";
-import { MsgUpdateAdmin } from "./types/cosmwasm/wasm/v1/tx";
+import { MsgIBCSend } from "./types/cosmwasm/wasm/v1/ibc";
 
 
 const types = [
+  ["/cosmwasm.wasm.v1.MsgInstantiateContract", MsgInstantiateContract],
+  ["/cosmwasm.wasm.v1.MsgUpdateAdmin", MsgUpdateAdmin],
+  ["/cosmwasm.wasm.v1.MsgInstantiateContract2", MsgInstantiateContract2],
   ["/cosmwasm.wasm.v1.MsgIBCCloseChannel", MsgIBCCloseChannel],
-  ["/cosmwasm.wasm.v1.MsgIBCSend", MsgIBCSend],
-  ["/cosmwasm.wasm.v1.MsgExecuteContract", MsgExecuteContract],
   ["/cosmwasm.wasm.v1.MsgMigrateContract", MsgMigrateContract],
   ["/cosmwasm.wasm.v1.MsgStoreCode", MsgStoreCode],
-  ["/cosmwasm.wasm.v1.MsgInstantiateContract", MsgInstantiateContract],
+  ["/cosmwasm.wasm.v1.MsgExecuteContract", MsgExecuteContract],
   ["/cosmwasm.wasm.v1.MsgClearAdmin", MsgClearAdmin],
-  ["/cosmwasm.wasm.v1.MsgUpdateAdmin", MsgUpdateAdmin],
+  ["/cosmwasm.wasm.v1.MsgIBCSend", MsgIBCSend],
   
 ];
 export const MissingWalletError = new Error("wallet is required");
@@ -56,14 +58,15 @@ const txClient = async (wallet: OfflineSigner, { addr: addr }: TxClientOptions =
 
   return {
     signAndBroadcast: (msgs: EncodeObject[], { fee, memo }: SignAndBroadcastOptions = {fee: defaultFee, memo: ""}) => client.signAndBroadcast(address, msgs, fee,memo),
+    msgInstantiateContract: (data: MsgInstantiateContract): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgInstantiateContract", value: MsgInstantiateContract.fromPartial( data ) }),
+    msgUpdateAdmin: (data: MsgUpdateAdmin): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgUpdateAdmin", value: MsgUpdateAdmin.fromPartial( data ) }),
+    msgInstantiateContract2: (data: MsgInstantiateContract2): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgInstantiateContract2", value: MsgInstantiateContract2.fromPartial( data ) }),
     msgIBCCloseChannel: (data: MsgIBCCloseChannel): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgIBCCloseChannel", value: MsgIBCCloseChannel.fromPartial( data ) }),
-    msgIBCSend: (data: MsgIBCSend): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgIBCSend", value: MsgIBCSend.fromPartial( data ) }),
-    msgExecuteContract: (data: MsgExecuteContract): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgExecuteContract", value: MsgExecuteContract.fromPartial( data ) }),
     msgMigrateContract: (data: MsgMigrateContract): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgMigrateContract", value: MsgMigrateContract.fromPartial( data ) }),
     msgStoreCode: (data: MsgStoreCode): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgStoreCode", value: MsgStoreCode.fromPartial( data ) }),
-    msgInstantiateContract: (data: MsgInstantiateContract): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgInstantiateContract", value: MsgInstantiateContract.fromPartial( data ) }),
+    msgExecuteContract: (data: MsgExecuteContract): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgExecuteContract", value: MsgExecuteContract.fromPartial( data ) }),
     msgClearAdmin: (data: MsgClearAdmin): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgClearAdmin", value: MsgClearAdmin.fromPartial( data ) }),
-    msgUpdateAdmin: (data: MsgUpdateAdmin): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgUpdateAdmin", value: MsgUpdateAdmin.fromPartial( data ) }),
+    msgIBCSend: (data: MsgIBCSend): EncodeObject => ({ typeUrl: "/cosmwasm.wasm.v1.MsgIBCSend", value: MsgIBCSend.fromPartial( data ) }),
     
   };
 };

+ 100 - 19
wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/rest.ts

@@ -153,24 +153,30 @@ export interface V1AccessConfig {
   /**
    * - ACCESS_TYPE_UNSPECIFIED: AccessTypeUnspecified placeholder for empty value
    *  - ACCESS_TYPE_NOBODY: AccessTypeNobody forbidden
-   *  - ACCESS_TYPE_ONLY_ADDRESS: AccessTypeOnlyAddress restricted to an address
+   *  - ACCESS_TYPE_ONLY_ADDRESS: AccessTypeOnlyAddress restricted to a single address
+   * Deprecated: use AccessTypeAnyOfAddresses instead
    *  - ACCESS_TYPE_EVERYBODY: AccessTypeEverybody unrestricted
+   *  - ACCESS_TYPE_ANY_OF_ADDRESSES: AccessTypeAnyOfAddresses allow any of the addresses
    */
   permission?: V1AccessType;
   address?: string;
+  addresses?: string[];
 }
 
 /**
 * - ACCESS_TYPE_UNSPECIFIED: AccessTypeUnspecified placeholder for empty value
  - ACCESS_TYPE_NOBODY: AccessTypeNobody forbidden
- - ACCESS_TYPE_ONLY_ADDRESS: AccessTypeOnlyAddress restricted to an address
+ - ACCESS_TYPE_ONLY_ADDRESS: AccessTypeOnlyAddress restricted to a single address
+Deprecated: use AccessTypeAnyOfAddresses instead
  - ACCESS_TYPE_EVERYBODY: AccessTypeEverybody unrestricted
+ - ACCESS_TYPE_ANY_OF_ADDRESSES: AccessTypeAnyOfAddresses allow any of the addresses
 */
 export enum V1AccessType {
   ACCESS_TYPE_UNSPECIFIED = "ACCESS_TYPE_UNSPECIFIED",
   ACCESS_TYPE_NOBODY = "ACCESS_TYPE_NOBODY",
   ACCESS_TYPE_ONLY_ADDRESS = "ACCESS_TYPE_ONLY_ADDRESS",
   ACCESS_TYPE_EVERYBODY = "ACCESS_TYPE_EVERYBODY",
+  ACCESS_TYPE_ANY_OF_ADDRESSES = "ACCESS_TYPE_ANY_OF_ADDRESSES",
 }
 
 export interface V1CodeInfoResponse {
@@ -229,10 +235,7 @@ export interface V1ContractInfo {
   /** Label is optional metadata to be stored with a contract instance. */
   label?: string;
 
-  /**
-   * AbsoluteTxPosition is a unique transaction position that allows for global
-   * ordering of transactions.
-   */
+  /** Created Tx position when the contract was instantiated. */
   created?: V1AbsoluteTxPosition;
   ibc_port_id?: string;
 
@@ -261,6 +264,14 @@ export interface V1MsgExecuteContractResponse {
   data?: string;
 }
 
+export interface V1MsgInstantiateContract2Response {
+  /** Address is the bech32 address of the new contract instance. */
+  address?: string;
+
+  /** @format byte */
+  data?: string;
+}
+
 export interface V1MsgInstantiateContractResponse {
   /** Address is the bech32 address of the new contract instance. */
   address?: string;
@@ -283,10 +294,31 @@ export interface V1MsgMigrateContractResponse {
 export interface V1MsgStoreCodeResponse {
   /** @format uint64 */
   code_id?: string;
+
+  /** @format byte */
+  checksum?: string;
 }
 
 export type V1MsgUpdateAdminResponse = object;
 
+/**
+ * Params defines the set of wasm parameters.
+ */
+export interface V1Params {
+  /** AccessConfig access control type. */
+  code_upload_access?: V1AccessConfig;
+
+  /**
+   * - ACCESS_TYPE_UNSPECIFIED: AccessTypeUnspecified placeholder for empty value
+   *  - ACCESS_TYPE_NOBODY: AccessTypeNobody forbidden
+   *  - ACCESS_TYPE_ONLY_ADDRESS: AccessTypeOnlyAddress restricted to a single address
+   * Deprecated: use AccessTypeAnyOfAddresses instead
+   *  - ACCESS_TYPE_EVERYBODY: AccessTypeEverybody unrestricted
+   *  - ACCESS_TYPE_ANY_OF_ADDRESSES: AccessTypeAnyOfAddresses allow any of the addresses
+   */
+  instantiate_default_permission?: V1AccessType;
+}
+
 export interface V1QueryAllContractStateResponse {
   models?: V1Model[];
 
@@ -327,6 +359,25 @@ export interface V1QueryContractsByCodeResponse {
   pagination?: V1Beta1PageResponse;
 }
 
+/**
+* QueryContractsByCreatorResponse is the response type for the
+Query/ContractsByCreator RPC method.
+*/
+export interface V1QueryContractsByCreatorResponse {
+  contract_addresses?: string[];
+
+  /** Pagination defines the pagination in the response. */
+  pagination?: V1Beta1PageResponse;
+}
+
+/**
+ * QueryParamsResponse is the response type for the Query/Params RPC method.
+ */
+export interface V1QueryParamsResponse {
+  /** params defines the parameters of the module. */
+  params?: V1Params;
+}
+
 export interface V1QueryPinnedCodesResponse {
   code_ids?: string[];
 
@@ -392,13 +443,6 @@ export interface V1Beta1PageRequest {
    * is set.
    */
   count_total?: boolean;
-
-  /**
-   * reverse is set to true if results are to be returned in the descending order.
-   *
-   * Since: cosmos-sdk 0.43
-   */
-  reverse?: boolean;
 }
 
 /**
@@ -610,7 +654,7 @@ export class HttpClient<SecurityDataType = unknown> {
 }
 
 /**
- * @title cosmwasm/wasm/v1/genesis.proto
+ * @title cosmwasm/wasm/v1/authz.proto
  * @version version not set
  */
 export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDataType> {
@@ -628,7 +672,6 @@ export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDa
       "pagination.offset"?: string;
       "pagination.limit"?: string;
       "pagination.count_total"?: boolean;
-      "pagination.reverse"?: boolean;
     },
     params: RequestParams = {},
   ) =>
@@ -671,7 +714,6 @@ export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDa
       "pagination.offset"?: string;
       "pagination.limit"?: string;
       "pagination.count_total"?: boolean;
-      "pagination.reverse"?: boolean;
     },
     params: RequestParams = {},
   ) =>
@@ -683,6 +725,22 @@ export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDa
       ...params,
     });
 
+  /**
+   * No description
+   *
+   * @tags Query
+   * @name QueryParams
+   * @summary Params gets the module params
+   * @request GET:/cosmwasm/wasm/v1/codes/params
+   */
+  queryParams = (params: RequestParams = {}) =>
+    this.request<V1QueryParamsResponse, RpcStatus>({
+      path: `/cosmwasm/wasm/v1/codes/params`,
+      method: "GET",
+      format: "json",
+      ...params,
+    });
+
   /**
    * No description
    *
@@ -697,7 +755,6 @@ export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDa
       "pagination.offset"?: string;
       "pagination.limit"?: string;
       "pagination.count_total"?: boolean;
-      "pagination.reverse"?: boolean;
     },
     params: RequestParams = {},
   ) =>
@@ -740,7 +797,6 @@ export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDa
       "pagination.offset"?: string;
       "pagination.limit"?: string;
       "pagination.count_total"?: boolean;
-      "pagination.reverse"?: boolean;
     },
     params: RequestParams = {},
   ) =>
@@ -799,7 +855,6 @@ export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDa
       "pagination.offset"?: string;
       "pagination.limit"?: string;
       "pagination.count_total"?: boolean;
-      "pagination.reverse"?: boolean;
     },
     params: RequestParams = {},
   ) =>
@@ -810,4 +865,30 @@ export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDa
       format: "json",
       ...params,
     });
+
+  /**
+   * No description
+   *
+   * @tags Query
+   * @name QueryContractsByCreator
+   * @summary ContractsByCreator gets the contracts by creator
+   * @request GET:/cosmwasm/wasm/v1/contracts/creator/{creator_address}
+   */
+  queryContractsByCreator = (
+    creator_address: string,
+    query?: {
+      "pagination.key"?: string;
+      "pagination.offset"?: string;
+      "pagination.limit"?: string;
+      "pagination.count_total"?: boolean;
+    },
+    params: RequestParams = {},
+  ) =>
+    this.request<V1QueryContractsByCreatorResponse, RpcStatus>({
+      path: `/cosmwasm/wasm/v1/contracts/creator/${creator_address}`,
+      method: "GET",
+      query: query,
+      format: "json",
+      ...params,
+    });
 }

+ 1 - 29
wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmos/base/query/v1beta1/pagination.ts

@@ -39,12 +39,6 @@ export interface PageRequest {
    * is set.
    */
   count_total: boolean;
-  /**
-   * reverse is set to true if results are to be returned in the descending order.
-   *
-   * Since: cosmos-sdk 0.43
-   */
-  reverse: boolean;
 }
 
 /**
@@ -69,12 +63,7 @@ export interface PageResponse {
   total: number;
 }
 
-const basePageRequest: object = {
-  offset: 0,
-  limit: 0,
-  count_total: false,
-  reverse: false,
-};
+const basePageRequest: object = { offset: 0, limit: 0, count_total: false };
 
 export const PageRequest = {
   encode(message: PageRequest, writer: Writer = Writer.create()): Writer {
@@ -90,9 +79,6 @@ export const PageRequest = {
     if (message.count_total === true) {
       writer.uint32(32).bool(message.count_total);
     }
-    if (message.reverse === true) {
-      writer.uint32(40).bool(message.reverse);
-    }
     return writer;
   },
 
@@ -115,9 +101,6 @@ export const PageRequest = {
         case 4:
           message.count_total = reader.bool();
           break;
-        case 5:
-          message.reverse = reader.bool();
-          break;
         default:
           reader.skipType(tag & 7);
           break;
@@ -146,11 +129,6 @@ export const PageRequest = {
     } else {
       message.count_total = false;
     }
-    if (object.reverse !== undefined && object.reverse !== null) {
-      message.reverse = Boolean(object.reverse);
-    } else {
-      message.reverse = false;
-    }
     return message;
   },
 
@@ -164,7 +142,6 @@ export const PageRequest = {
     message.limit !== undefined && (obj.limit = message.limit);
     message.count_total !== undefined &&
       (obj.count_total = message.count_total);
-    message.reverse !== undefined && (obj.reverse = message.reverse);
     return obj;
   },
 
@@ -190,11 +167,6 @@ export const PageRequest = {
     } else {
       message.count_total = false;
     }
-    if (object.reverse !== undefined && object.reverse !== null) {
-      message.reverse = object.reverse;
-    } else {
-      message.reverse = false;
-    }
     return message;
   },
 };

+ 796 - 0
wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/authz.ts

@@ -0,0 +1,796 @@
+//@ts-nocheck
+/* eslint-disable */
+import * as Long from "long";
+import { util, configure, Writer, Reader } from "protobufjs/minimal";
+import { Any } from "../../../google/protobuf/any";
+import { Coin } from "../../../cosmos/base/v1beta1/coin";
+
+export const protobufPackage = "cosmwasm.wasm.v1";
+
+/**
+ * ContractExecutionAuthorization defines authorization for wasm execute.
+ * Since: wasmd 0.30
+ */
+export interface ContractExecutionAuthorization {
+  /** Grants for contract executions */
+  grants: ContractGrant[];
+}
+
+/**
+ * ContractMigrationAuthorization defines authorization for wasm contract
+ * migration. Since: wasmd 0.30
+ */
+export interface ContractMigrationAuthorization {
+  /** Grants for contract migrations */
+  grants: ContractGrant[];
+}
+
+/**
+ * ContractGrant a granted permission for a single contract
+ * Since: wasmd 0.30
+ */
+export interface ContractGrant {
+  /** Contract is the bech32 address of the smart contract */
+  contract: string;
+  /**
+   * Limit defines execution limits that are enforced and updated when the grant
+   * is applied. When the limit lapsed the grant is removed.
+   */
+  limit: Any | undefined;
+  /**
+   * Filter define more fine-grained control on the message payload passed
+   * to the contract in the operation. When no filter applies on execution, the
+   * operation is prohibited.
+   */
+  filter: Any | undefined;
+}
+
+/**
+ * MaxCallsLimit limited number of calls to the contract. No funds transferable.
+ * Since: wasmd 0.30
+ */
+export interface MaxCallsLimit {
+  /** Remaining number that is decremented on each execution */
+  remaining: number;
+}
+
+/**
+ * MaxFundsLimit defines the maximal amounts that can be sent to the contract.
+ * Since: wasmd 0.30
+ */
+export interface MaxFundsLimit {
+  /** Amounts is the maximal amount of tokens transferable to the contract. */
+  amounts: Coin[];
+}
+
+/**
+ * CombinedLimit defines the maximal amounts that can be sent to a contract and
+ * the maximal number of calls executable. Both need to remain >0 to be valid.
+ * Since: wasmd 0.30
+ */
+export interface CombinedLimit {
+  /** Remaining number that is decremented on each execution */
+  calls_remaining: number;
+  /** Amounts is the maximal amount of tokens transferable to the contract. */
+  amounts: Coin[];
+}
+
+/**
+ * AllowAllMessagesFilter is a wildcard to allow any type of contract payload
+ * message.
+ * Since: wasmd 0.30
+ */
+export interface AllowAllMessagesFilter {}
+
+/**
+ * AcceptedMessageKeysFilter accept only the specific contract message keys in
+ * the json object to be executed.
+ * Since: wasmd 0.30
+ */
+export interface AcceptedMessageKeysFilter {
+  /** Messages is the list of unique keys */
+  keys: string[];
+}
+
+/**
+ * AcceptedMessagesFilter accept only the specific raw contract messages to be
+ * executed.
+ * Since: wasmd 0.30
+ */
+export interface AcceptedMessagesFilter {
+  /** Messages is the list of raw contract messages */
+  messages: Uint8Array[];
+}
+
+const baseContractExecutionAuthorization: object = {};
+
+export const ContractExecutionAuthorization = {
+  encode(
+    message: ContractExecutionAuthorization,
+    writer: Writer = Writer.create()
+  ): Writer {
+    for (const v of message.grants) {
+      ContractGrant.encode(v!, writer.uint32(10).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): ContractExecutionAuthorization {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseContractExecutionAuthorization,
+    } as ContractExecutionAuthorization;
+    message.grants = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.grants.push(ContractGrant.decode(reader, reader.uint32()));
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): ContractExecutionAuthorization {
+    const message = {
+      ...baseContractExecutionAuthorization,
+    } as ContractExecutionAuthorization;
+    message.grants = [];
+    if (object.grants !== undefined && object.grants !== null) {
+      for (const e of object.grants) {
+        message.grants.push(ContractGrant.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: ContractExecutionAuthorization): unknown {
+    const obj: any = {};
+    if (message.grants) {
+      obj.grants = message.grants.map((e) =>
+        e ? ContractGrant.toJSON(e) : undefined
+      );
+    } else {
+      obj.grants = [];
+    }
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<ContractExecutionAuthorization>
+  ): ContractExecutionAuthorization {
+    const message = {
+      ...baseContractExecutionAuthorization,
+    } as ContractExecutionAuthorization;
+    message.grants = [];
+    if (object.grants !== undefined && object.grants !== null) {
+      for (const e of object.grants) {
+        message.grants.push(ContractGrant.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseContractMigrationAuthorization: object = {};
+
+export const ContractMigrationAuthorization = {
+  encode(
+    message: ContractMigrationAuthorization,
+    writer: Writer = Writer.create()
+  ): Writer {
+    for (const v of message.grants) {
+      ContractGrant.encode(v!, writer.uint32(10).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): ContractMigrationAuthorization {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseContractMigrationAuthorization,
+    } as ContractMigrationAuthorization;
+    message.grants = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.grants.push(ContractGrant.decode(reader, reader.uint32()));
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): ContractMigrationAuthorization {
+    const message = {
+      ...baseContractMigrationAuthorization,
+    } as ContractMigrationAuthorization;
+    message.grants = [];
+    if (object.grants !== undefined && object.grants !== null) {
+      for (const e of object.grants) {
+        message.grants.push(ContractGrant.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: ContractMigrationAuthorization): unknown {
+    const obj: any = {};
+    if (message.grants) {
+      obj.grants = message.grants.map((e) =>
+        e ? ContractGrant.toJSON(e) : undefined
+      );
+    } else {
+      obj.grants = [];
+    }
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<ContractMigrationAuthorization>
+  ): ContractMigrationAuthorization {
+    const message = {
+      ...baseContractMigrationAuthorization,
+    } as ContractMigrationAuthorization;
+    message.grants = [];
+    if (object.grants !== undefined && object.grants !== null) {
+      for (const e of object.grants) {
+        message.grants.push(ContractGrant.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseContractGrant: object = { contract: "" };
+
+export const ContractGrant = {
+  encode(message: ContractGrant, writer: Writer = Writer.create()): Writer {
+    if (message.contract !== "") {
+      writer.uint32(10).string(message.contract);
+    }
+    if (message.limit !== undefined) {
+      Any.encode(message.limit, writer.uint32(18).fork()).ldelim();
+    }
+    if (message.filter !== undefined) {
+      Any.encode(message.filter, writer.uint32(26).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): ContractGrant {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseContractGrant } as ContractGrant;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.contract = reader.string();
+          break;
+        case 2:
+          message.limit = Any.decode(reader, reader.uint32());
+          break;
+        case 3:
+          message.filter = Any.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): ContractGrant {
+    const message = { ...baseContractGrant } as ContractGrant;
+    if (object.contract !== undefined && object.contract !== null) {
+      message.contract = String(object.contract);
+    } else {
+      message.contract = "";
+    }
+    if (object.limit !== undefined && object.limit !== null) {
+      message.limit = Any.fromJSON(object.limit);
+    } else {
+      message.limit = undefined;
+    }
+    if (object.filter !== undefined && object.filter !== null) {
+      message.filter = Any.fromJSON(object.filter);
+    } else {
+      message.filter = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: ContractGrant): unknown {
+    const obj: any = {};
+    message.contract !== undefined && (obj.contract = message.contract);
+    message.limit !== undefined &&
+      (obj.limit = message.limit ? Any.toJSON(message.limit) : undefined);
+    message.filter !== undefined &&
+      (obj.filter = message.filter ? Any.toJSON(message.filter) : undefined);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<ContractGrant>): ContractGrant {
+    const message = { ...baseContractGrant } as ContractGrant;
+    if (object.contract !== undefined && object.contract !== null) {
+      message.contract = object.contract;
+    } else {
+      message.contract = "";
+    }
+    if (object.limit !== undefined && object.limit !== null) {
+      message.limit = Any.fromPartial(object.limit);
+    } else {
+      message.limit = undefined;
+    }
+    if (object.filter !== undefined && object.filter !== null) {
+      message.filter = Any.fromPartial(object.filter);
+    } else {
+      message.filter = undefined;
+    }
+    return message;
+  },
+};
+
+const baseMaxCallsLimit: object = { remaining: 0 };
+
+export const MaxCallsLimit = {
+  encode(message: MaxCallsLimit, writer: Writer = Writer.create()): Writer {
+    if (message.remaining !== 0) {
+      writer.uint32(8).uint64(message.remaining);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MaxCallsLimit {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMaxCallsLimit } as MaxCallsLimit;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.remaining = longToNumber(reader.uint64() as Long);
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MaxCallsLimit {
+    const message = { ...baseMaxCallsLimit } as MaxCallsLimit;
+    if (object.remaining !== undefined && object.remaining !== null) {
+      message.remaining = Number(object.remaining);
+    } else {
+      message.remaining = 0;
+    }
+    return message;
+  },
+
+  toJSON(message: MaxCallsLimit): unknown {
+    const obj: any = {};
+    message.remaining !== undefined && (obj.remaining = message.remaining);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<MaxCallsLimit>): MaxCallsLimit {
+    const message = { ...baseMaxCallsLimit } as MaxCallsLimit;
+    if (object.remaining !== undefined && object.remaining !== null) {
+      message.remaining = object.remaining;
+    } else {
+      message.remaining = 0;
+    }
+    return message;
+  },
+};
+
+const baseMaxFundsLimit: object = {};
+
+export const MaxFundsLimit = {
+  encode(message: MaxFundsLimit, writer: Writer = Writer.create()): Writer {
+    for (const v of message.amounts) {
+      Coin.encode(v!, writer.uint32(10).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MaxFundsLimit {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMaxFundsLimit } as MaxFundsLimit;
+    message.amounts = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.amounts.push(Coin.decode(reader, reader.uint32()));
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MaxFundsLimit {
+    const message = { ...baseMaxFundsLimit } as MaxFundsLimit;
+    message.amounts = [];
+    if (object.amounts !== undefined && object.amounts !== null) {
+      for (const e of object.amounts) {
+        message.amounts.push(Coin.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: MaxFundsLimit): unknown {
+    const obj: any = {};
+    if (message.amounts) {
+      obj.amounts = message.amounts.map((e) =>
+        e ? Coin.toJSON(e) : undefined
+      );
+    } else {
+      obj.amounts = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<MaxFundsLimit>): MaxFundsLimit {
+    const message = { ...baseMaxFundsLimit } as MaxFundsLimit;
+    message.amounts = [];
+    if (object.amounts !== undefined && object.amounts !== null) {
+      for (const e of object.amounts) {
+        message.amounts.push(Coin.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseCombinedLimit: object = { calls_remaining: 0 };
+
+export const CombinedLimit = {
+  encode(message: CombinedLimit, writer: Writer = Writer.create()): Writer {
+    if (message.calls_remaining !== 0) {
+      writer.uint32(8).uint64(message.calls_remaining);
+    }
+    for (const v of message.amounts) {
+      Coin.encode(v!, writer.uint32(18).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): CombinedLimit {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseCombinedLimit } as CombinedLimit;
+    message.amounts = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.calls_remaining = longToNumber(reader.uint64() as Long);
+          break;
+        case 2:
+          message.amounts.push(Coin.decode(reader, reader.uint32()));
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): CombinedLimit {
+    const message = { ...baseCombinedLimit } as CombinedLimit;
+    message.amounts = [];
+    if (
+      object.calls_remaining !== undefined &&
+      object.calls_remaining !== null
+    ) {
+      message.calls_remaining = Number(object.calls_remaining);
+    } else {
+      message.calls_remaining = 0;
+    }
+    if (object.amounts !== undefined && object.amounts !== null) {
+      for (const e of object.amounts) {
+        message.amounts.push(Coin.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: CombinedLimit): unknown {
+    const obj: any = {};
+    message.calls_remaining !== undefined &&
+      (obj.calls_remaining = message.calls_remaining);
+    if (message.amounts) {
+      obj.amounts = message.amounts.map((e) =>
+        e ? Coin.toJSON(e) : undefined
+      );
+    } else {
+      obj.amounts = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<CombinedLimit>): CombinedLimit {
+    const message = { ...baseCombinedLimit } as CombinedLimit;
+    message.amounts = [];
+    if (
+      object.calls_remaining !== undefined &&
+      object.calls_remaining !== null
+    ) {
+      message.calls_remaining = object.calls_remaining;
+    } else {
+      message.calls_remaining = 0;
+    }
+    if (object.amounts !== undefined && object.amounts !== null) {
+      for (const e of object.amounts) {
+        message.amounts.push(Coin.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseAllowAllMessagesFilter: object = {};
+
+export const AllowAllMessagesFilter = {
+  encode(_: AllowAllMessagesFilter, writer: Writer = Writer.create()): Writer {
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): AllowAllMessagesFilter {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseAllowAllMessagesFilter } as AllowAllMessagesFilter;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(_: any): AllowAllMessagesFilter {
+    const message = { ...baseAllowAllMessagesFilter } as AllowAllMessagesFilter;
+    return message;
+  },
+
+  toJSON(_: AllowAllMessagesFilter): unknown {
+    const obj: any = {};
+    return obj;
+  },
+
+  fromPartial(_: DeepPartial<AllowAllMessagesFilter>): AllowAllMessagesFilter {
+    const message = { ...baseAllowAllMessagesFilter } as AllowAllMessagesFilter;
+    return message;
+  },
+};
+
+const baseAcceptedMessageKeysFilter: object = { keys: "" };
+
+export const AcceptedMessageKeysFilter = {
+  encode(
+    message: AcceptedMessageKeysFilter,
+    writer: Writer = Writer.create()
+  ): Writer {
+    for (const v of message.keys) {
+      writer.uint32(10).string(v!);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): AcceptedMessageKeysFilter {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseAcceptedMessageKeysFilter,
+    } as AcceptedMessageKeysFilter;
+    message.keys = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.keys.push(reader.string());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): AcceptedMessageKeysFilter {
+    const message = {
+      ...baseAcceptedMessageKeysFilter,
+    } as AcceptedMessageKeysFilter;
+    message.keys = [];
+    if (object.keys !== undefined && object.keys !== null) {
+      for (const e of object.keys) {
+        message.keys.push(String(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: AcceptedMessageKeysFilter): unknown {
+    const obj: any = {};
+    if (message.keys) {
+      obj.keys = message.keys.map((e) => e);
+    } else {
+      obj.keys = [];
+    }
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<AcceptedMessageKeysFilter>
+  ): AcceptedMessageKeysFilter {
+    const message = {
+      ...baseAcceptedMessageKeysFilter,
+    } as AcceptedMessageKeysFilter;
+    message.keys = [];
+    if (object.keys !== undefined && object.keys !== null) {
+      for (const e of object.keys) {
+        message.keys.push(e);
+      }
+    }
+    return message;
+  },
+};
+
+const baseAcceptedMessagesFilter: object = {};
+
+export const AcceptedMessagesFilter = {
+  encode(
+    message: AcceptedMessagesFilter,
+    writer: Writer = Writer.create()
+  ): Writer {
+    for (const v of message.messages) {
+      writer.uint32(10).bytes(v!);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): AcceptedMessagesFilter {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseAcceptedMessagesFilter } as AcceptedMessagesFilter;
+    message.messages = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.messages.push(reader.bytes());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): AcceptedMessagesFilter {
+    const message = { ...baseAcceptedMessagesFilter } as AcceptedMessagesFilter;
+    message.messages = [];
+    if (object.messages !== undefined && object.messages !== null) {
+      for (const e of object.messages) {
+        message.messages.push(bytesFromBase64(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: AcceptedMessagesFilter): unknown {
+    const obj: any = {};
+    if (message.messages) {
+      obj.messages = message.messages.map((e) =>
+        base64FromBytes(e !== undefined ? e : new Uint8Array())
+      );
+    } else {
+      obj.messages = [];
+    }
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<AcceptedMessagesFilter>
+  ): AcceptedMessagesFilter {
+    const message = { ...baseAcceptedMessagesFilter } as AcceptedMessagesFilter;
+    message.messages = [];
+    if (object.messages !== undefined && object.messages !== null) {
+      for (const e of object.messages) {
+        message.messages.push(e);
+      }
+    }
+    return message;
+  },
+};
+
+declare var self: any | undefined;
+declare var window: any | undefined;
+var globalThis: any = (() => {
+  if (typeof globalThis !== "undefined") return globalThis;
+  if (typeof self !== "undefined") return self;
+  if (typeof window !== "undefined") return window;
+  if (typeof global !== "undefined") return global;
+  throw "Unable to locate global object";
+})();
+
+const atob: (b64: string) => string =
+  globalThis.atob ||
+  ((b64) => globalThis.Buffer.from(b64, "base64").toString("binary"));
+function bytesFromBase64(b64: string): Uint8Array {
+  const bin = atob(b64);
+  const arr = new Uint8Array(bin.length);
+  for (let i = 0; i < bin.length; ++i) {
+    arr[i] = bin.charCodeAt(i);
+  }
+  return arr;
+}
+
+const btoa: (bin: string) => string =
+  globalThis.btoa ||
+  ((bin) => globalThis.Buffer.from(bin, "binary").toString("base64"));
+function base64FromBytes(arr: Uint8Array): string {
+  const bin: string[] = [];
+  for (let i = 0; i < arr.byteLength; ++i) {
+    bin.push(String.fromCharCode(arr[i]));
+  }
+  return btoa(bin.join(""));
+}
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;
+
+function longToNumber(long: Long): number {
+  if (long.gt(Number.MAX_SAFE_INTEGER)) {
+    throw new globalThis.Error("Value is larger than Number.MAX_SAFE_INTEGER");
+  }
+  return long.toNumber();
+}
+
+if (util.Long !== Long) {
+  util.Long = Long as any;
+  configure();
+}

+ 44 - 0
wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/genesis.ts

@@ -7,6 +7,7 @@ import {
   CodeInfo,
   ContractInfo,
   Model,
+  ContractCodeHistoryEntry,
 } from "../../../cosmwasm/wasm/v1/types";
 import {
   MsgStoreCode,
@@ -32,6 +33,10 @@ export interface GenesisState {
 export interface GenesisState_GenMsgs {
   store_code: MsgStoreCode | undefined;
   instantiate_contract: MsgInstantiateContract | undefined;
+  /**
+   * MsgInstantiateContract2 intentionally not supported
+   * see https://github.com/CosmWasm/wasmd/issues/987
+   */
   execute_contract: MsgExecuteContract | undefined;
 }
 
@@ -49,6 +54,7 @@ export interface Contract {
   contract_address: string;
   contract_info: ContractInfo | undefined;
   contract_state: Model[];
+  contract_code_history: ContractCodeHistoryEntry[];
 }
 
 /** Sequence key and value of an id generation counter */
@@ -479,6 +485,9 @@ export const Contract = {
     for (const v of message.contract_state) {
       Model.encode(v!, writer.uint32(26).fork()).ldelim();
     }
+    for (const v of message.contract_code_history) {
+      ContractCodeHistoryEntry.encode(v!, writer.uint32(34).fork()).ldelim();
+    }
     return writer;
   },
 
@@ -487,6 +496,7 @@ export const Contract = {
     let end = length === undefined ? reader.len : reader.pos + length;
     const message = { ...baseContract } as Contract;
     message.contract_state = [];
+    message.contract_code_history = [];
     while (reader.pos < end) {
       const tag = reader.uint32();
       switch (tag >>> 3) {
@@ -499,6 +509,11 @@ export const Contract = {
         case 3:
           message.contract_state.push(Model.decode(reader, reader.uint32()));
           break;
+        case 4:
+          message.contract_code_history.push(
+            ContractCodeHistoryEntry.decode(reader, reader.uint32())
+          );
+          break;
         default:
           reader.skipType(tag & 7);
           break;
@@ -510,6 +525,7 @@ export const Contract = {
   fromJSON(object: any): Contract {
     const message = { ...baseContract } as Contract;
     message.contract_state = [];
+    message.contract_code_history = [];
     if (
       object.contract_address !== undefined &&
       object.contract_address !== null
@@ -528,6 +544,16 @@ export const Contract = {
         message.contract_state.push(Model.fromJSON(e));
       }
     }
+    if (
+      object.contract_code_history !== undefined &&
+      object.contract_code_history !== null
+    ) {
+      for (const e of object.contract_code_history) {
+        message.contract_code_history.push(
+          ContractCodeHistoryEntry.fromJSON(e)
+        );
+      }
+    }
     return message;
   },
 
@@ -546,12 +572,20 @@ export const Contract = {
     } else {
       obj.contract_state = [];
     }
+    if (message.contract_code_history) {
+      obj.contract_code_history = message.contract_code_history.map((e) =>
+        e ? ContractCodeHistoryEntry.toJSON(e) : undefined
+      );
+    } else {
+      obj.contract_code_history = [];
+    }
     return obj;
   },
 
   fromPartial(object: DeepPartial<Contract>): Contract {
     const message = { ...baseContract } as Contract;
     message.contract_state = [];
+    message.contract_code_history = [];
     if (
       object.contract_address !== undefined &&
       object.contract_address !== null
@@ -570,6 +604,16 @@ export const Contract = {
         message.contract_state.push(Model.fromPartial(e));
       }
     }
+    if (
+      object.contract_code_history !== undefined &&
+      object.contract_code_history !== null
+    ) {
+      for (const e of object.contract_code_history) {
+        message.contract_code_history.push(
+          ContractCodeHistoryEntry.fromPartial(e)
+        );
+      }
+    }
     return message;
   },
 };

+ 439 - 0
wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/proposal.ts

@@ -19,6 +19,20 @@ export interface StoreCodeProposal {
   wasm_byte_code: Uint8Array;
   /** InstantiatePermission to apply on contract creation, optional */
   instantiate_permission: AccessConfig | undefined;
+  /** UnpinCode code on upload, optional */
+  unpin_code: boolean;
+  /** Source is the URL where the code is hosted */
+  source: string;
+  /**
+   * Builder is the docker image used to build the code deterministically, used
+   * for smart contract verification
+   */
+  builder: string;
+  /**
+   * CodeHash is the SHA256 sum of the code outputted by builder, used for smart
+   * contract verification
+   */
+  code_hash: Uint8Array;
 }
 
 /**
@@ -167,10 +181,52 @@ export interface UpdateInstantiateConfigProposal {
   access_config_updates: AccessConfigUpdate[];
 }
 
+/**
+ * StoreAndInstantiateContractProposal gov proposal content type to store
+ * and instantiate the contract.
+ */
+export interface StoreAndInstantiateContractProposal {
+  /** Title is a short summary */
+  title: string;
+  /** Description is a human readable text */
+  description: string;
+  /** RunAs is the address that is passed to the contract's environment as sender */
+  run_as: string;
+  /** WASMByteCode can be raw or gzip compressed */
+  wasm_byte_code: Uint8Array;
+  /** InstantiatePermission to apply on contract creation, optional */
+  instantiate_permission: AccessConfig | undefined;
+  /** UnpinCode code on upload, optional */
+  unpin_code: boolean;
+  /** Admin is an optional address that can execute migrations */
+  admin: string;
+  /** Label is optional metadata to be stored with a constract instance. */
+  label: string;
+  /** Msg json encoded message to be passed to the contract on instantiation */
+  msg: Uint8Array;
+  /** Funds coins that are transferred to the contract on instantiation */
+  funds: Coin[];
+  /** Source is the URL where the code is hosted */
+  source: string;
+  /**
+   * Builder is the docker image used to build the code deterministically, used
+   * for smart contract verification
+   */
+  builder: string;
+  /**
+   * CodeHash is the SHA256 sum of the code outputted by builder, used for smart
+   * contract verification
+   */
+  code_hash: Uint8Array;
+}
+
 const baseStoreCodeProposal: object = {
   title: "",
   description: "",
   run_as: "",
+  unpin_code: false,
+  source: "",
+  builder: "",
 };
 
 export const StoreCodeProposal = {
@@ -193,6 +249,18 @@ export const StoreCodeProposal = {
         writer.uint32(58).fork()
       ).ldelim();
     }
+    if (message.unpin_code === true) {
+      writer.uint32(64).bool(message.unpin_code);
+    }
+    if (message.source !== "") {
+      writer.uint32(74).string(message.source);
+    }
+    if (message.builder !== "") {
+      writer.uint32(82).string(message.builder);
+    }
+    if (message.code_hash.length !== 0) {
+      writer.uint32(90).bytes(message.code_hash);
+    }
     return writer;
   },
 
@@ -221,6 +289,18 @@ export const StoreCodeProposal = {
             reader.uint32()
           );
           break;
+        case 8:
+          message.unpin_code = reader.bool();
+          break;
+        case 9:
+          message.source = reader.string();
+          break;
+        case 10:
+          message.builder = reader.string();
+          break;
+        case 11:
+          message.code_hash = reader.bytes();
+          break;
         default:
           reader.skipType(tag & 7);
           break;
@@ -259,6 +339,24 @@ export const StoreCodeProposal = {
     } else {
       message.instantiate_permission = undefined;
     }
+    if (object.unpin_code !== undefined && object.unpin_code !== null) {
+      message.unpin_code = Boolean(object.unpin_code);
+    } else {
+      message.unpin_code = false;
+    }
+    if (object.source !== undefined && object.source !== null) {
+      message.source = String(object.source);
+    } else {
+      message.source = "";
+    }
+    if (object.builder !== undefined && object.builder !== null) {
+      message.builder = String(object.builder);
+    } else {
+      message.builder = "";
+    }
+    if (object.code_hash !== undefined && object.code_hash !== null) {
+      message.code_hash = bytesFromBase64(object.code_hash);
+    }
     return message;
   },
 
@@ -278,6 +376,13 @@ export const StoreCodeProposal = {
       (obj.instantiate_permission = message.instantiate_permission
         ? AccessConfig.toJSON(message.instantiate_permission)
         : undefined);
+    message.unpin_code !== undefined && (obj.unpin_code = message.unpin_code);
+    message.source !== undefined && (obj.source = message.source);
+    message.builder !== undefined && (obj.builder = message.builder);
+    message.code_hash !== undefined &&
+      (obj.code_hash = base64FromBytes(
+        message.code_hash !== undefined ? message.code_hash : new Uint8Array()
+      ));
     return obj;
   },
 
@@ -313,6 +418,26 @@ export const StoreCodeProposal = {
     } else {
       message.instantiate_permission = undefined;
     }
+    if (object.unpin_code !== undefined && object.unpin_code !== null) {
+      message.unpin_code = object.unpin_code;
+    } else {
+      message.unpin_code = false;
+    }
+    if (object.source !== undefined && object.source !== null) {
+      message.source = object.source;
+    } else {
+      message.source = "";
+    }
+    if (object.builder !== undefined && object.builder !== null) {
+      message.builder = object.builder;
+    } else {
+      message.builder = "";
+    }
+    if (object.code_hash !== undefined && object.code_hash !== null) {
+      message.code_hash = object.code_hash;
+    } else {
+      message.code_hash = new Uint8Array();
+    }
     return message;
   },
 };
@@ -1595,6 +1720,320 @@ export const UpdateInstantiateConfigProposal = {
   },
 };
 
+const baseStoreAndInstantiateContractProposal: object = {
+  title: "",
+  description: "",
+  run_as: "",
+  unpin_code: false,
+  admin: "",
+  label: "",
+  source: "",
+  builder: "",
+};
+
+export const StoreAndInstantiateContractProposal = {
+  encode(
+    message: StoreAndInstantiateContractProposal,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.title !== "") {
+      writer.uint32(10).string(message.title);
+    }
+    if (message.description !== "") {
+      writer.uint32(18).string(message.description);
+    }
+    if (message.run_as !== "") {
+      writer.uint32(26).string(message.run_as);
+    }
+    if (message.wasm_byte_code.length !== 0) {
+      writer.uint32(34).bytes(message.wasm_byte_code);
+    }
+    if (message.instantiate_permission !== undefined) {
+      AccessConfig.encode(
+        message.instantiate_permission,
+        writer.uint32(42).fork()
+      ).ldelim();
+    }
+    if (message.unpin_code === true) {
+      writer.uint32(48).bool(message.unpin_code);
+    }
+    if (message.admin !== "") {
+      writer.uint32(58).string(message.admin);
+    }
+    if (message.label !== "") {
+      writer.uint32(66).string(message.label);
+    }
+    if (message.msg.length !== 0) {
+      writer.uint32(74).bytes(message.msg);
+    }
+    for (const v of message.funds) {
+      Coin.encode(v!, writer.uint32(82).fork()).ldelim();
+    }
+    if (message.source !== "") {
+      writer.uint32(90).string(message.source);
+    }
+    if (message.builder !== "") {
+      writer.uint32(98).string(message.builder);
+    }
+    if (message.code_hash.length !== 0) {
+      writer.uint32(106).bytes(message.code_hash);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): StoreAndInstantiateContractProposal {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseStoreAndInstantiateContractProposal,
+    } as StoreAndInstantiateContractProposal;
+    message.funds = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.title = reader.string();
+          break;
+        case 2:
+          message.description = reader.string();
+          break;
+        case 3:
+          message.run_as = reader.string();
+          break;
+        case 4:
+          message.wasm_byte_code = reader.bytes();
+          break;
+        case 5:
+          message.instantiate_permission = AccessConfig.decode(
+            reader,
+            reader.uint32()
+          );
+          break;
+        case 6:
+          message.unpin_code = reader.bool();
+          break;
+        case 7:
+          message.admin = reader.string();
+          break;
+        case 8:
+          message.label = reader.string();
+          break;
+        case 9:
+          message.msg = reader.bytes();
+          break;
+        case 10:
+          message.funds.push(Coin.decode(reader, reader.uint32()));
+          break;
+        case 11:
+          message.source = reader.string();
+          break;
+        case 12:
+          message.builder = reader.string();
+          break;
+        case 13:
+          message.code_hash = reader.bytes();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): StoreAndInstantiateContractProposal {
+    const message = {
+      ...baseStoreAndInstantiateContractProposal,
+    } as StoreAndInstantiateContractProposal;
+    message.funds = [];
+    if (object.title !== undefined && object.title !== null) {
+      message.title = String(object.title);
+    } else {
+      message.title = "";
+    }
+    if (object.description !== undefined && object.description !== null) {
+      message.description = String(object.description);
+    } else {
+      message.description = "";
+    }
+    if (object.run_as !== undefined && object.run_as !== null) {
+      message.run_as = String(object.run_as);
+    } else {
+      message.run_as = "";
+    }
+    if (object.wasm_byte_code !== undefined && object.wasm_byte_code !== null) {
+      message.wasm_byte_code = bytesFromBase64(object.wasm_byte_code);
+    }
+    if (
+      object.instantiate_permission !== undefined &&
+      object.instantiate_permission !== null
+    ) {
+      message.instantiate_permission = AccessConfig.fromJSON(
+        object.instantiate_permission
+      );
+    } else {
+      message.instantiate_permission = undefined;
+    }
+    if (object.unpin_code !== undefined && object.unpin_code !== null) {
+      message.unpin_code = Boolean(object.unpin_code);
+    } else {
+      message.unpin_code = false;
+    }
+    if (object.admin !== undefined && object.admin !== null) {
+      message.admin = String(object.admin);
+    } else {
+      message.admin = "";
+    }
+    if (object.label !== undefined && object.label !== null) {
+      message.label = String(object.label);
+    } else {
+      message.label = "";
+    }
+    if (object.msg !== undefined && object.msg !== null) {
+      message.msg = bytesFromBase64(object.msg);
+    }
+    if (object.funds !== undefined && object.funds !== null) {
+      for (const e of object.funds) {
+        message.funds.push(Coin.fromJSON(e));
+      }
+    }
+    if (object.source !== undefined && object.source !== null) {
+      message.source = String(object.source);
+    } else {
+      message.source = "";
+    }
+    if (object.builder !== undefined && object.builder !== null) {
+      message.builder = String(object.builder);
+    } else {
+      message.builder = "";
+    }
+    if (object.code_hash !== undefined && object.code_hash !== null) {
+      message.code_hash = bytesFromBase64(object.code_hash);
+    }
+    return message;
+  },
+
+  toJSON(message: StoreAndInstantiateContractProposal): unknown {
+    const obj: any = {};
+    message.title !== undefined && (obj.title = message.title);
+    message.description !== undefined &&
+      (obj.description = message.description);
+    message.run_as !== undefined && (obj.run_as = message.run_as);
+    message.wasm_byte_code !== undefined &&
+      (obj.wasm_byte_code = base64FromBytes(
+        message.wasm_byte_code !== undefined
+          ? message.wasm_byte_code
+          : new Uint8Array()
+      ));
+    message.instantiate_permission !== undefined &&
+      (obj.instantiate_permission = message.instantiate_permission
+        ? AccessConfig.toJSON(message.instantiate_permission)
+        : undefined);
+    message.unpin_code !== undefined && (obj.unpin_code = message.unpin_code);
+    message.admin !== undefined && (obj.admin = message.admin);
+    message.label !== undefined && (obj.label = message.label);
+    message.msg !== undefined &&
+      (obj.msg = base64FromBytes(
+        message.msg !== undefined ? message.msg : new Uint8Array()
+      ));
+    if (message.funds) {
+      obj.funds = message.funds.map((e) => (e ? Coin.toJSON(e) : undefined));
+    } else {
+      obj.funds = [];
+    }
+    message.source !== undefined && (obj.source = message.source);
+    message.builder !== undefined && (obj.builder = message.builder);
+    message.code_hash !== undefined &&
+      (obj.code_hash = base64FromBytes(
+        message.code_hash !== undefined ? message.code_hash : new Uint8Array()
+      ));
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<StoreAndInstantiateContractProposal>
+  ): StoreAndInstantiateContractProposal {
+    const message = {
+      ...baseStoreAndInstantiateContractProposal,
+    } as StoreAndInstantiateContractProposal;
+    message.funds = [];
+    if (object.title !== undefined && object.title !== null) {
+      message.title = object.title;
+    } else {
+      message.title = "";
+    }
+    if (object.description !== undefined && object.description !== null) {
+      message.description = object.description;
+    } else {
+      message.description = "";
+    }
+    if (object.run_as !== undefined && object.run_as !== null) {
+      message.run_as = object.run_as;
+    } else {
+      message.run_as = "";
+    }
+    if (object.wasm_byte_code !== undefined && object.wasm_byte_code !== null) {
+      message.wasm_byte_code = object.wasm_byte_code;
+    } else {
+      message.wasm_byte_code = new Uint8Array();
+    }
+    if (
+      object.instantiate_permission !== undefined &&
+      object.instantiate_permission !== null
+    ) {
+      message.instantiate_permission = AccessConfig.fromPartial(
+        object.instantiate_permission
+      );
+    } else {
+      message.instantiate_permission = undefined;
+    }
+    if (object.unpin_code !== undefined && object.unpin_code !== null) {
+      message.unpin_code = object.unpin_code;
+    } else {
+      message.unpin_code = false;
+    }
+    if (object.admin !== undefined && object.admin !== null) {
+      message.admin = object.admin;
+    } else {
+      message.admin = "";
+    }
+    if (object.label !== undefined && object.label !== null) {
+      message.label = object.label;
+    } else {
+      message.label = "";
+    }
+    if (object.msg !== undefined && object.msg !== null) {
+      message.msg = object.msg;
+    } else {
+      message.msg = new Uint8Array();
+    }
+    if (object.funds !== undefined && object.funds !== null) {
+      for (const e of object.funds) {
+        message.funds.push(Coin.fromPartial(e));
+      }
+    }
+    if (object.source !== undefined && object.source !== null) {
+      message.source = object.source;
+    } else {
+      message.source = "";
+    }
+    if (object.builder !== undefined && object.builder !== null) {
+      message.builder = object.builder;
+    } else {
+      message.builder = "";
+    }
+    if (object.code_hash !== undefined && object.code_hash !== null) {
+      message.code_hash = object.code_hash;
+    } else {
+      message.code_hash = new Uint8Array();
+    }
+    return message;
+  },
+};
+
 declare var self: any | undefined;
 declare var window: any | undefined;
 var globalThis: any = (() => {

+ 356 - 0
wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/query.ts

@@ -7,6 +7,7 @@ import {
   ContractCodeHistoryEntry,
   Model,
   AccessConfig,
+  Params,
 } from "../../../cosmwasm/wasm/v1/types";
 import {
   PageRequest,
@@ -190,6 +191,37 @@ export interface QueryPinnedCodesResponse {
   pagination: PageResponse | undefined;
 }
 
+/** QueryParamsRequest is the request type for the Query/Params RPC method. */
+export interface QueryParamsRequest {}
+
+/** QueryParamsResponse is the response type for the Query/Params RPC method. */
+export interface QueryParamsResponse {
+  /** params defines the parameters of the module. */
+  params: Params | undefined;
+}
+
+/**
+ * QueryContractsByCreatorRequest is the request type for the
+ * Query/ContractsByCreator RPC method.
+ */
+export interface QueryContractsByCreatorRequest {
+  /** CreatorAddress is the address of contract creator */
+  creator_address: string;
+  /** Pagination defines an optional pagination for the request. */
+  pagination: PageRequest | undefined;
+}
+
+/**
+ * QueryContractsByCreatorResponse is the response type for the
+ * Query/ContractsByCreator RPC method.
+ */
+export interface QueryContractsByCreatorResponse {
+  /** ContractAddresses result set */
+  contract_addresses: string[];
+  /** Pagination defines the pagination in the response. */
+  pagination: PageResponse | undefined;
+}
+
 const baseQueryContractInfoRequest: object = { address: "" };
 
 export const QueryContractInfoRequest = {
@@ -1820,6 +1852,304 @@ export const QueryPinnedCodesResponse = {
   },
 };
 
+const baseQueryParamsRequest: object = {};
+
+export const QueryParamsRequest = {
+  encode(_: QueryParamsRequest, writer: Writer = Writer.create()): Writer {
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): QueryParamsRequest {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseQueryParamsRequest } as QueryParamsRequest;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(_: any): QueryParamsRequest {
+    const message = { ...baseQueryParamsRequest } as QueryParamsRequest;
+    return message;
+  },
+
+  toJSON(_: QueryParamsRequest): unknown {
+    const obj: any = {};
+    return obj;
+  },
+
+  fromPartial(_: DeepPartial<QueryParamsRequest>): QueryParamsRequest {
+    const message = { ...baseQueryParamsRequest } as QueryParamsRequest;
+    return message;
+  },
+};
+
+const baseQueryParamsResponse: object = {};
+
+export const QueryParamsResponse = {
+  encode(
+    message: QueryParamsResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.params !== undefined) {
+      Params.encode(message.params, writer.uint32(10).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): QueryParamsResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseQueryParamsResponse } as QueryParamsResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.params = Params.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryParamsResponse {
+    const message = { ...baseQueryParamsResponse } as QueryParamsResponse;
+    if (object.params !== undefined && object.params !== null) {
+      message.params = Params.fromJSON(object.params);
+    } else {
+      message.params = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryParamsResponse): unknown {
+    const obj: any = {};
+    message.params !== undefined &&
+      (obj.params = message.params ? Params.toJSON(message.params) : undefined);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<QueryParamsResponse>): QueryParamsResponse {
+    const message = { ...baseQueryParamsResponse } as QueryParamsResponse;
+    if (object.params !== undefined && object.params !== null) {
+      message.params = Params.fromPartial(object.params);
+    } else {
+      message.params = undefined;
+    }
+    return message;
+  },
+};
+
+const baseQueryContractsByCreatorRequest: object = { creator_address: "" };
+
+export const QueryContractsByCreatorRequest = {
+  encode(
+    message: QueryContractsByCreatorRequest,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.creator_address !== "") {
+      writer.uint32(10).string(message.creator_address);
+    }
+    if (message.pagination !== undefined) {
+      PageRequest.encode(message.pagination, writer.uint32(18).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryContractsByCreatorRequest {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryContractsByCreatorRequest,
+    } as QueryContractsByCreatorRequest;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.creator_address = reader.string();
+          break;
+        case 2:
+          message.pagination = PageRequest.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryContractsByCreatorRequest {
+    const message = {
+      ...baseQueryContractsByCreatorRequest,
+    } as QueryContractsByCreatorRequest;
+    if (
+      object.creator_address !== undefined &&
+      object.creator_address !== null
+    ) {
+      message.creator_address = String(object.creator_address);
+    } else {
+      message.creator_address = "";
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageRequest.fromJSON(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryContractsByCreatorRequest): unknown {
+    const obj: any = {};
+    message.creator_address !== undefined &&
+      (obj.creator_address = message.creator_address);
+    message.pagination !== undefined &&
+      (obj.pagination = message.pagination
+        ? PageRequest.toJSON(message.pagination)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryContractsByCreatorRequest>
+  ): QueryContractsByCreatorRequest {
+    const message = {
+      ...baseQueryContractsByCreatorRequest,
+    } as QueryContractsByCreatorRequest;
+    if (
+      object.creator_address !== undefined &&
+      object.creator_address !== null
+    ) {
+      message.creator_address = object.creator_address;
+    } else {
+      message.creator_address = "";
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageRequest.fromPartial(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+};
+
+const baseQueryContractsByCreatorResponse: object = { contract_addresses: "" };
+
+export const QueryContractsByCreatorResponse = {
+  encode(
+    message: QueryContractsByCreatorResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    for (const v of message.contract_addresses) {
+      writer.uint32(10).string(v!);
+    }
+    if (message.pagination !== undefined) {
+      PageResponse.encode(
+        message.pagination,
+        writer.uint32(18).fork()
+      ).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryContractsByCreatorResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryContractsByCreatorResponse,
+    } as QueryContractsByCreatorResponse;
+    message.contract_addresses = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.contract_addresses.push(reader.string());
+          break;
+        case 2:
+          message.pagination = PageResponse.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryContractsByCreatorResponse {
+    const message = {
+      ...baseQueryContractsByCreatorResponse,
+    } as QueryContractsByCreatorResponse;
+    message.contract_addresses = [];
+    if (
+      object.contract_addresses !== undefined &&
+      object.contract_addresses !== null
+    ) {
+      for (const e of object.contract_addresses) {
+        message.contract_addresses.push(String(e));
+      }
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageResponse.fromJSON(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryContractsByCreatorResponse): unknown {
+    const obj: any = {};
+    if (message.contract_addresses) {
+      obj.contract_addresses = message.contract_addresses.map((e) => e);
+    } else {
+      obj.contract_addresses = [];
+    }
+    message.pagination !== undefined &&
+      (obj.pagination = message.pagination
+        ? PageResponse.toJSON(message.pagination)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryContractsByCreatorResponse>
+  ): QueryContractsByCreatorResponse {
+    const message = {
+      ...baseQueryContractsByCreatorResponse,
+    } as QueryContractsByCreatorResponse;
+    message.contract_addresses = [];
+    if (
+      object.contract_addresses !== undefined &&
+      object.contract_addresses !== null
+    ) {
+      for (const e of object.contract_addresses) {
+        message.contract_addresses.push(e);
+      }
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageResponse.fromPartial(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+};
+
 /** Query provides defines the gRPC querier service */
 export interface Query {
   /** ContractInfo gets the contract meta data */
@@ -1854,6 +2184,12 @@ export interface Query {
   PinnedCodes(
     request: QueryPinnedCodesRequest
   ): Promise<QueryPinnedCodesResponse>;
+  /** Params gets the module params */
+  Params(request: QueryParamsRequest): Promise<QueryParamsResponse>;
+  /** ContractsByCreator gets the contracts by creator */
+  ContractsByCreator(
+    request: QueryContractsByCreatorRequest
+  ): Promise<QueryContractsByCreatorResponse>;
 }
 
 export class QueryClientImpl implements Query {
@@ -1970,6 +2306,26 @@ export class QueryClientImpl implements Query {
       QueryPinnedCodesResponse.decode(new Reader(data))
     );
   }
+
+  Params(request: QueryParamsRequest): Promise<QueryParamsResponse> {
+    const data = QueryParamsRequest.encode(request).finish();
+    const promise = this.rpc.request("cosmwasm.wasm.v1.Query", "Params", data);
+    return promise.then((data) => QueryParamsResponse.decode(new Reader(data)));
+  }
+
+  ContractsByCreator(
+    request: QueryContractsByCreatorRequest
+  ): Promise<QueryContractsByCreatorResponse> {
+    const data = QueryContractsByCreatorRequest.encode(request).finish();
+    const promise = this.rpc.request(
+      "cosmwasm.wasm.v1.Query",
+      "ContractsByCreator",
+      data
+    );
+    return promise.then((data) =>
+      QueryContractsByCreatorResponse.decode(new Reader(data))
+    );
+  }
 }
 
 interface Rpc {

+ 368 - 3
wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/tx.ts

@@ -24,6 +24,8 @@ export interface MsgStoreCode {
 export interface MsgStoreCodeResponse {
   /** CodeID is the reference to the stored WASM code */
   code_id: number;
+  /** Checksum is the sha256 hash of the stored code */
+  checksum: Uint8Array;
 }
 
 /**
@@ -45,11 +47,45 @@ export interface MsgInstantiateContract {
   funds: Coin[];
 }
 
+/**
+ * MsgInstantiateContract2 create a new smart contract instance for the given
+ * code id with a predicable address.
+ */
+export interface MsgInstantiateContract2 {
+  /** Sender is the that actor that signed the messages */
+  sender: string;
+  /** Admin is an optional address that can execute migrations */
+  admin: string;
+  /** CodeID is the reference to the stored WASM code */
+  code_id: number;
+  /** Label is optional metadata to be stored with a contract instance. */
+  label: string;
+  /** Msg json encoded message to be passed to the contract on instantiation */
+  msg: Uint8Array;
+  /** Funds coins that are transferred to the contract on instantiation */
+  funds: Coin[];
+  /** Salt is an arbitrary value provided by the sender. Size can be 1 to 64. */
+  salt: Uint8Array;
+  /**
+   * FixMsg include the msg value into the hash for the predictable address.
+   * Default is false
+   */
+  fix_msg: boolean;
+}
+
 /** MsgInstantiateContractResponse return instantiation result data */
 export interface MsgInstantiateContractResponse {
   /** Address is the bech32 address of the new contract instance. */
   address: string;
-  /** Data contains base64-encoded bytes to returned from the contract */
+  /** Data contains bytes to returned from the contract */
+  data: Uint8Array;
+}
+
+/** MsgInstantiateContract2Response return instantiation result data */
+export interface MsgInstantiateContract2Response {
+  /** Address is the bech32 address of the new contract instance. */
+  address: string;
+  /** Data contains bytes to returned from the contract */
   data: Uint8Array;
 }
 
@@ -67,7 +103,7 @@ export interface MsgExecuteContract {
 
 /** MsgExecuteContractResponse returns execution result data. */
 export interface MsgExecuteContractResponse {
-  /** Data contains base64-encoded bytes to returned from the contract */
+  /** Data contains bytes to returned from the contract */
   data: Uint8Array;
 }
 
@@ -237,6 +273,9 @@ export const MsgStoreCodeResponse = {
     if (message.code_id !== 0) {
       writer.uint32(8).uint64(message.code_id);
     }
+    if (message.checksum.length !== 0) {
+      writer.uint32(18).bytes(message.checksum);
+    }
     return writer;
   },
 
@@ -250,6 +289,9 @@ export const MsgStoreCodeResponse = {
         case 1:
           message.code_id = longToNumber(reader.uint64() as Long);
           break;
+        case 2:
+          message.checksum = reader.bytes();
+          break;
         default:
           reader.skipType(tag & 7);
           break;
@@ -265,12 +307,19 @@ export const MsgStoreCodeResponse = {
     } else {
       message.code_id = 0;
     }
+    if (object.checksum !== undefined && object.checksum !== null) {
+      message.checksum = bytesFromBase64(object.checksum);
+    }
     return message;
   },
 
   toJSON(message: MsgStoreCodeResponse): unknown {
     const obj: any = {};
     message.code_id !== undefined && (obj.code_id = message.code_id);
+    message.checksum !== undefined &&
+      (obj.checksum = base64FromBytes(
+        message.checksum !== undefined ? message.checksum : new Uint8Array()
+      ));
     return obj;
   },
 
@@ -281,6 +330,11 @@ export const MsgStoreCodeResponse = {
     } else {
       message.code_id = 0;
     }
+    if (object.checksum !== undefined && object.checksum !== null) {
+      message.checksum = object.checksum;
+    } else {
+      message.checksum = new Uint8Array();
+    }
     return message;
   },
 };
@@ -443,6 +497,206 @@ export const MsgInstantiateContract = {
   },
 };
 
+const baseMsgInstantiateContract2: object = {
+  sender: "",
+  admin: "",
+  code_id: 0,
+  label: "",
+  fix_msg: false,
+};
+
+export const MsgInstantiateContract2 = {
+  encode(
+    message: MsgInstantiateContract2,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.sender !== "") {
+      writer.uint32(10).string(message.sender);
+    }
+    if (message.admin !== "") {
+      writer.uint32(18).string(message.admin);
+    }
+    if (message.code_id !== 0) {
+      writer.uint32(24).uint64(message.code_id);
+    }
+    if (message.label !== "") {
+      writer.uint32(34).string(message.label);
+    }
+    if (message.msg.length !== 0) {
+      writer.uint32(42).bytes(message.msg);
+    }
+    for (const v of message.funds) {
+      Coin.encode(v!, writer.uint32(50).fork()).ldelim();
+    }
+    if (message.salt.length !== 0) {
+      writer.uint32(58).bytes(message.salt);
+    }
+    if (message.fix_msg === true) {
+      writer.uint32(64).bool(message.fix_msg);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgInstantiateContract2 {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseMsgInstantiateContract2,
+    } as MsgInstantiateContract2;
+    message.funds = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.sender = reader.string();
+          break;
+        case 2:
+          message.admin = reader.string();
+          break;
+        case 3:
+          message.code_id = longToNumber(reader.uint64() as Long);
+          break;
+        case 4:
+          message.label = reader.string();
+          break;
+        case 5:
+          message.msg = reader.bytes();
+          break;
+        case 6:
+          message.funds.push(Coin.decode(reader, reader.uint32()));
+          break;
+        case 7:
+          message.salt = reader.bytes();
+          break;
+        case 8:
+          message.fix_msg = reader.bool();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MsgInstantiateContract2 {
+    const message = {
+      ...baseMsgInstantiateContract2,
+    } as MsgInstantiateContract2;
+    message.funds = [];
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = String(object.sender);
+    } else {
+      message.sender = "";
+    }
+    if (object.admin !== undefined && object.admin !== null) {
+      message.admin = String(object.admin);
+    } else {
+      message.admin = "";
+    }
+    if (object.code_id !== undefined && object.code_id !== null) {
+      message.code_id = Number(object.code_id);
+    } else {
+      message.code_id = 0;
+    }
+    if (object.label !== undefined && object.label !== null) {
+      message.label = String(object.label);
+    } else {
+      message.label = "";
+    }
+    if (object.msg !== undefined && object.msg !== null) {
+      message.msg = bytesFromBase64(object.msg);
+    }
+    if (object.funds !== undefined && object.funds !== null) {
+      for (const e of object.funds) {
+        message.funds.push(Coin.fromJSON(e));
+      }
+    }
+    if (object.salt !== undefined && object.salt !== null) {
+      message.salt = bytesFromBase64(object.salt);
+    }
+    if (object.fix_msg !== undefined && object.fix_msg !== null) {
+      message.fix_msg = Boolean(object.fix_msg);
+    } else {
+      message.fix_msg = false;
+    }
+    return message;
+  },
+
+  toJSON(message: MsgInstantiateContract2): unknown {
+    const obj: any = {};
+    message.sender !== undefined && (obj.sender = message.sender);
+    message.admin !== undefined && (obj.admin = message.admin);
+    message.code_id !== undefined && (obj.code_id = message.code_id);
+    message.label !== undefined && (obj.label = message.label);
+    message.msg !== undefined &&
+      (obj.msg = base64FromBytes(
+        message.msg !== undefined ? message.msg : new Uint8Array()
+      ));
+    if (message.funds) {
+      obj.funds = message.funds.map((e) => (e ? Coin.toJSON(e) : undefined));
+    } else {
+      obj.funds = [];
+    }
+    message.salt !== undefined &&
+      (obj.salt = base64FromBytes(
+        message.salt !== undefined ? message.salt : new Uint8Array()
+      ));
+    message.fix_msg !== undefined && (obj.fix_msg = message.fix_msg);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<MsgInstantiateContract2>
+  ): MsgInstantiateContract2 {
+    const message = {
+      ...baseMsgInstantiateContract2,
+    } as MsgInstantiateContract2;
+    message.funds = [];
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = object.sender;
+    } else {
+      message.sender = "";
+    }
+    if (object.admin !== undefined && object.admin !== null) {
+      message.admin = object.admin;
+    } else {
+      message.admin = "";
+    }
+    if (object.code_id !== undefined && object.code_id !== null) {
+      message.code_id = object.code_id;
+    } else {
+      message.code_id = 0;
+    }
+    if (object.label !== undefined && object.label !== null) {
+      message.label = object.label;
+    } else {
+      message.label = "";
+    }
+    if (object.msg !== undefined && object.msg !== null) {
+      message.msg = object.msg;
+    } else {
+      message.msg = new Uint8Array();
+    }
+    if (object.funds !== undefined && object.funds !== null) {
+      for (const e of object.funds) {
+        message.funds.push(Coin.fromPartial(e));
+      }
+    }
+    if (object.salt !== undefined && object.salt !== null) {
+      message.salt = object.salt;
+    } else {
+      message.salt = new Uint8Array();
+    }
+    if (object.fix_msg !== undefined && object.fix_msg !== null) {
+      message.fix_msg = object.fix_msg;
+    } else {
+      message.fix_msg = false;
+    }
+    return message;
+  },
+};
+
 const baseMsgInstantiateContractResponse: object = { address: "" };
 
 export const MsgInstantiateContractResponse = {
@@ -530,6 +784,93 @@ export const MsgInstantiateContractResponse = {
   },
 };
 
+const baseMsgInstantiateContract2Response: object = { address: "" };
+
+export const MsgInstantiateContract2Response = {
+  encode(
+    message: MsgInstantiateContract2Response,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.address !== "") {
+      writer.uint32(10).string(message.address);
+    }
+    if (message.data.length !== 0) {
+      writer.uint32(18).bytes(message.data);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): MsgInstantiateContract2Response {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseMsgInstantiateContract2Response,
+    } as MsgInstantiateContract2Response;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.address = reader.string();
+          break;
+        case 2:
+          message.data = reader.bytes();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MsgInstantiateContract2Response {
+    const message = {
+      ...baseMsgInstantiateContract2Response,
+    } as MsgInstantiateContract2Response;
+    if (object.address !== undefined && object.address !== null) {
+      message.address = String(object.address);
+    } else {
+      message.address = "";
+    }
+    if (object.data !== undefined && object.data !== null) {
+      message.data = bytesFromBase64(object.data);
+    }
+    return message;
+  },
+
+  toJSON(message: MsgInstantiateContract2Response): unknown {
+    const obj: any = {};
+    message.address !== undefined && (obj.address = message.address);
+    message.data !== undefined &&
+      (obj.data = base64FromBytes(
+        message.data !== undefined ? message.data : new Uint8Array()
+      ));
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<MsgInstantiateContract2Response>
+  ): MsgInstantiateContract2Response {
+    const message = {
+      ...baseMsgInstantiateContract2Response,
+    } as MsgInstantiateContract2Response;
+    if (object.address !== undefined && object.address !== null) {
+      message.address = object.address;
+    } else {
+      message.address = "";
+    }
+    if (object.data !== undefined && object.data !== null) {
+      message.data = object.data;
+    } else {
+      message.data = new Uint8Array();
+    }
+    return message;
+  },
+};
+
 const baseMsgExecuteContract: object = { sender: "", contract: "" };
 
 export const MsgExecuteContract = {
@@ -1138,10 +1479,20 @@ export const MsgClearAdminResponse = {
 export interface Msg {
   /** StoreCode to submit Wasm code to the system */
   StoreCode(request: MsgStoreCode): Promise<MsgStoreCodeResponse>;
-  /** Instantiate creates a new smart contract instance for the given code id. */
+  /**
+   * InstantiateContract creates a new smart contract instance for the given
+   *  code id.
+   */
   InstantiateContract(
     request: MsgInstantiateContract
   ): Promise<MsgInstantiateContractResponse>;
+  /**
+   * InstantiateContract2 creates a new smart contract instance for the given
+   *  code id with a predictable address
+   */
+  InstantiateContract2(
+    request: MsgInstantiateContract2
+  ): Promise<MsgInstantiateContract2Response>;
   /** Execute submits the given message data to a smart contract */
   ExecuteContract(
     request: MsgExecuteContract
@@ -1183,6 +1534,20 @@ export class MsgClientImpl implements Msg {
     );
   }
 
+  InstantiateContract2(
+    request: MsgInstantiateContract2
+  ): Promise<MsgInstantiateContract2Response> {
+    const data = MsgInstantiateContract2.encode(request).finish();
+    const promise = this.rpc.request(
+      "cosmwasm.wasm.v1.Msg",
+      "InstantiateContract2",
+      data
+    );
+    return promise.then((data) =>
+      MsgInstantiateContract2Response.decode(new Reader(data))
+    );
+  }
+
   ExecuteContract(
     request: MsgExecuteContract
   ): Promise<MsgExecuteContractResponse> {

+ 42 - 7
wormchain/ts-sdk/src/modules/cosmwasm.wasm.v1/types/cosmwasm/wasm/v1/types.ts

@@ -12,10 +12,15 @@ export enum AccessType {
   ACCESS_TYPE_UNSPECIFIED = 0,
   /** ACCESS_TYPE_NOBODY - AccessTypeNobody forbidden */
   ACCESS_TYPE_NOBODY = 1,
-  /** ACCESS_TYPE_ONLY_ADDRESS - AccessTypeOnlyAddress restricted to an address */
+  /**
+   * ACCESS_TYPE_ONLY_ADDRESS - AccessTypeOnlyAddress restricted to a single address
+   * Deprecated: use AccessTypeAnyOfAddresses instead
+   */
   ACCESS_TYPE_ONLY_ADDRESS = 2,
   /** ACCESS_TYPE_EVERYBODY - AccessTypeEverybody unrestricted */
   ACCESS_TYPE_EVERYBODY = 3,
+  /** ACCESS_TYPE_ANY_OF_ADDRESSES - AccessTypeAnyOfAddresses allow any of the addresses */
+  ACCESS_TYPE_ANY_OF_ADDRESSES = 4,
   UNRECOGNIZED = -1,
 }
 
@@ -33,6 +38,9 @@ export function accessTypeFromJSON(object: any): AccessType {
     case 3:
     case "ACCESS_TYPE_EVERYBODY":
       return AccessType.ACCESS_TYPE_EVERYBODY;
+    case 4:
+    case "ACCESS_TYPE_ANY_OF_ADDRESSES":
+      return AccessType.ACCESS_TYPE_ANY_OF_ADDRESSES;
     case -1:
     case "UNRECOGNIZED":
     default:
@@ -50,6 +58,8 @@ export function accessTypeToJSON(object: AccessType): string {
       return "ACCESS_TYPE_ONLY_ADDRESS";
     case AccessType.ACCESS_TYPE_EVERYBODY:
       return "ACCESS_TYPE_EVERYBODY";
+    case AccessType.ACCESS_TYPE_ANY_OF_ADDRESSES:
+      return "ACCESS_TYPE_ANY_OF_ADDRESSES";
     default:
       return "UNKNOWN";
   }
@@ -116,7 +126,12 @@ export interface AccessTypeParam {
 /** AccessConfig access control type. */
 export interface AccessConfig {
   permission: AccessType;
+  /**
+   * Address
+   * Deprecated: replaced by addresses
+   */
   address: string;
+  addresses: string[];
 }
 
 /** Params defines the set of wasm parameters. */
@@ -145,11 +160,7 @@ export interface ContractInfo {
   admin: string;
   /** Label is optional metadata to be stored with a contract instance. */
   label: string;
-  /**
-   * Created Tx position when the contract was instantiated.
-   * This data should kept internal and not be exposed via query results. Just
-   * use for sorting
-   */
+  /** Created Tx position when the contract was instantiated. */
   created: AbsoluteTxPosition | undefined;
   ibc_port_id: string;
   /**
@@ -247,7 +258,7 @@ export const AccessTypeParam = {
   },
 };
 
-const baseAccessConfig: object = { permission: 0, address: "" };
+const baseAccessConfig: object = { permission: 0, address: "", addresses: "" };
 
 export const AccessConfig = {
   encode(message: AccessConfig, writer: Writer = Writer.create()): Writer {
@@ -257,6 +268,9 @@ export const AccessConfig = {
     if (message.address !== "") {
       writer.uint32(18).string(message.address);
     }
+    for (const v of message.addresses) {
+      writer.uint32(26).string(v!);
+    }
     return writer;
   },
 
@@ -264,6 +278,7 @@ export const AccessConfig = {
     const reader = input instanceof Uint8Array ? new Reader(input) : input;
     let end = length === undefined ? reader.len : reader.pos + length;
     const message = { ...baseAccessConfig } as AccessConfig;
+    message.addresses = [];
     while (reader.pos < end) {
       const tag = reader.uint32();
       switch (tag >>> 3) {
@@ -273,6 +288,9 @@ export const AccessConfig = {
         case 2:
           message.address = reader.string();
           break;
+        case 3:
+          message.addresses.push(reader.string());
+          break;
         default:
           reader.skipType(tag & 7);
           break;
@@ -283,6 +301,7 @@ export const AccessConfig = {
 
   fromJSON(object: any): AccessConfig {
     const message = { ...baseAccessConfig } as AccessConfig;
+    message.addresses = [];
     if (object.permission !== undefined && object.permission !== null) {
       message.permission = accessTypeFromJSON(object.permission);
     } else {
@@ -293,6 +312,11 @@ export const AccessConfig = {
     } else {
       message.address = "";
     }
+    if (object.addresses !== undefined && object.addresses !== null) {
+      for (const e of object.addresses) {
+        message.addresses.push(String(e));
+      }
+    }
     return message;
   },
 
@@ -301,11 +325,17 @@ export const AccessConfig = {
     message.permission !== undefined &&
       (obj.permission = accessTypeToJSON(message.permission));
     message.address !== undefined && (obj.address = message.address);
+    if (message.addresses) {
+      obj.addresses = message.addresses.map((e) => e);
+    } else {
+      obj.addresses = [];
+    }
     return obj;
   },
 
   fromPartial(object: DeepPartial<AccessConfig>): AccessConfig {
     const message = { ...baseAccessConfig } as AccessConfig;
+    message.addresses = [];
     if (object.permission !== undefined && object.permission !== null) {
       message.permission = object.permission;
     } else {
@@ -316,6 +346,11 @@ export const AccessConfig = {
     } else {
       message.address = "";
     }
+    if (object.addresses !== undefined && object.addresses !== null) {
+      for (const e of object.addresses) {
+        message.addresses.push(e);
+      }
+    }
     return message;
   },
 };

+ 76 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/index.ts

@@ -0,0 +1,76 @@
+//@ts-nocheck
+// THIS FILE IS GENERATED AUTOMATICALLY. DO NOT MODIFY.
+
+import { StdFee } from "@cosmjs/launchpad";
+import { SigningStargateClient } from "@cosmjs/stargate";
+import { Registry, OfflineSigner, EncodeObject, DirectSecp256k1HdWallet } from "@cosmjs/proto-signing";
+import { Api } from "./rest";
+import { MsgCreateDenom } from "./types/osmosis/tokenfactory/v1beta1/tx";
+import { MsgMint } from "./types/osmosis/tokenfactory/v1beta1/tx";
+import { MsgForceTransfer } from "./types/osmosis/tokenfactory/v1beta1/tx";
+import { MsgSetDenomMetadata } from "./types/osmosis/tokenfactory/v1beta1/tx";
+import { MsgBurn } from "./types/osmosis/tokenfactory/v1beta1/tx";
+import { MsgChangeAdmin } from "./types/osmosis/tokenfactory/v1beta1/tx";
+
+
+const types = [
+  ["/osmosis.tokenfactory.v1beta1.MsgCreateDenom", MsgCreateDenom],
+  ["/osmosis.tokenfactory.v1beta1.MsgMint", MsgMint],
+  ["/osmosis.tokenfactory.v1beta1.MsgForceTransfer", MsgForceTransfer],
+  ["/osmosis.tokenfactory.v1beta1.MsgSetDenomMetadata", MsgSetDenomMetadata],
+  ["/osmosis.tokenfactory.v1beta1.MsgBurn", MsgBurn],
+  ["/osmosis.tokenfactory.v1beta1.MsgChangeAdmin", MsgChangeAdmin],
+  
+];
+export const MissingWalletError = new Error("wallet is required");
+
+export const registry = new Registry(<any>types);
+
+const defaultFee = {
+  amount: [],
+  gas: "200000",
+};
+
+interface TxClientOptions {
+  addr: string
+}
+
+interface SignAndBroadcastOptions {
+  fee: StdFee,
+  memo?: string
+}
+
+const txClient = async (wallet: OfflineSigner, { addr: addr }: TxClientOptions = { addr: "http://localhost:26657" }) => {
+  if (!wallet) throw MissingWalletError;
+  let client;
+  if (addr) {
+    client = await SigningStargateClient.connectWithSigner(addr, wallet, { registry });
+  }else{
+    client = await SigningStargateClient.offline( wallet, { registry });
+  }
+  const { address } = (await wallet.getAccounts())[0];
+
+  return {
+    signAndBroadcast: (msgs: EncodeObject[], { fee, memo }: SignAndBroadcastOptions = {fee: defaultFee, memo: ""}) => client.signAndBroadcast(address, msgs, fee,memo),
+    msgCreateDenom: (data: MsgCreateDenom): EncodeObject => ({ typeUrl: "/osmosis.tokenfactory.v1beta1.MsgCreateDenom", value: MsgCreateDenom.fromPartial( data ) }),
+    msgMint: (data: MsgMint): EncodeObject => ({ typeUrl: "/osmosis.tokenfactory.v1beta1.MsgMint", value: MsgMint.fromPartial( data ) }),
+    msgForceTransfer: (data: MsgForceTransfer): EncodeObject => ({ typeUrl: "/osmosis.tokenfactory.v1beta1.MsgForceTransfer", value: MsgForceTransfer.fromPartial( data ) }),
+    msgSetDenomMetadata: (data: MsgSetDenomMetadata): EncodeObject => ({ typeUrl: "/osmosis.tokenfactory.v1beta1.MsgSetDenomMetadata", value: MsgSetDenomMetadata.fromPartial( data ) }),
+    msgBurn: (data: MsgBurn): EncodeObject => ({ typeUrl: "/osmosis.tokenfactory.v1beta1.MsgBurn", value: MsgBurn.fromPartial( data ) }),
+    msgChangeAdmin: (data: MsgChangeAdmin): EncodeObject => ({ typeUrl: "/osmosis.tokenfactory.v1beta1.MsgChangeAdmin", value: MsgChangeAdmin.fromPartial( data ) }),
+    
+  };
+};
+
+interface QueryClientOptions {
+  addr: string
+}
+
+const queryClient = async ({ addr: addr }: QueryClientOptions = { addr: "http://localhost:1317" }) => {
+  return new Api({ baseUrl: addr });
+};
+
+export {
+  txClient,
+  queryClient,
+};

+ 400 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/rest.ts

@@ -0,0 +1,400 @@
+//@ts-nocheck
+/* eslint-disable */
+/* tslint:disable */
+/*
+ * ---------------------------------------------------------------
+ * ## THIS FILE WAS GENERATED VIA SWAGGER-TYPESCRIPT-API        ##
+ * ##                                                           ##
+ * ## AUTHOR: acacode                                           ##
+ * ## SOURCE: https://github.com/acacode/swagger-typescript-api ##
+ * ---------------------------------------------------------------
+ */
+
+/**
+ * Params defines the parameters for the tokenfactory module.
+ */
+export interface Osmosistokenfactoryv1Beta1Params {
+  denom_creation_fee?: V1Beta1Coin[];
+
+  /** @format uint64 */
+  denom_creation_gas_consume?: string;
+}
+
+export interface ProtobufAny {
+  "@type"?: string;
+}
+
+export interface RpcStatus {
+  /** @format int32 */
+  code?: number;
+  message?: string;
+  details?: ProtobufAny[];
+}
+
+/**
+* Coin defines a token with a denomination and an amount.
+
+NOTE: The amount field is an Int which implements the custom method
+signatures required by gogoproto.
+*/
+export interface V1Beta1Coin {
+  denom?: string;
+  amount?: string;
+}
+
+/**
+* DenomAuthorityMetadata specifies metadata for addresses that have specific
+capabilities over a token factory denom. Right now there is only one Admin
+permission, but is planned to be extended to the future.
+*/
+export interface V1Beta1DenomAuthorityMetadata {
+  admin?: string;
+}
+
+/**
+* DenomUnit represents a struct that describes a given
+denomination unit of the basic token.
+*/
+export interface V1Beta1DenomUnit {
+  /** denom represents the string name of the given denom unit (e.g uatom). */
+  denom?: string;
+
+  /**
+   * exponent represents power of 10 exponent that one must
+   * raise the base_denom to in order to equal the given DenomUnit's denom
+   * 1 denom = 1^exponent base_denom
+   * (e.g. with a base_denom of uatom, one can create a DenomUnit of 'atom' with
+   * exponent = 6, thus: 1 atom = 10^6 uatom).
+   * @format int64
+   */
+  exponent?: number;
+  aliases?: string[];
+}
+
+/**
+* Metadata represents a struct that describes
+a basic token.
+*/
+export interface V1Beta1Metadata {
+  description?: string;
+  denom_units?: V1Beta1DenomUnit[];
+
+  /** base represents the base denom (should be the DenomUnit with exponent = 0). */
+  base?: string;
+
+  /**
+   * display indicates the suggested denom that should be
+   * displayed in clients.
+   */
+  display?: string;
+
+  /** Since: cosmos-sdk 0.43 */
+  name?: string;
+
+  /**
+   * symbol is the token symbol usually shown on exchanges (eg: ATOM). This can
+   * be the same as the display.
+   *
+   * Since: cosmos-sdk 0.43
+   */
+  symbol?: string;
+}
+
+export type V1Beta1MsgBurnResponse = object;
+
+/**
+* MsgChangeAdminResponse defines the response structure for an executed
+MsgChangeAdmin message.
+*/
+export type V1Beta1MsgChangeAdminResponse = object;
+
+export interface V1Beta1MsgCreateDenomResponse {
+  new_token_denom?: string;
+}
+
+export type V1Beta1MsgForceTransferResponse = object;
+
+export type V1Beta1MsgMintResponse = object;
+
+/**
+* MsgSetDenomMetadataResponse defines the response structure for an executed
+MsgSetDenomMetadata message.
+*/
+export type V1Beta1MsgSetDenomMetadataResponse = object;
+
+/**
+* QueryDenomAuthorityMetadataResponse defines the response structure for the
+DenomAuthorityMetadata gRPC query.
+*/
+export interface V1Beta1QueryDenomAuthorityMetadataResponse {
+  /**
+   * DenomAuthorityMetadata specifies metadata for addresses that have specific
+   * capabilities over a token factory denom. Right now there is only one Admin
+   * permission, but is planned to be extended to the future.
+   */
+  authority_metadata?: V1Beta1DenomAuthorityMetadata;
+}
+
+/**
+* QueryDenomsFromCreatorRequest defines the response structure for the
+DenomsFromCreator gRPC query.
+*/
+export interface V1Beta1QueryDenomsFromCreatorResponse {
+  denoms?: string[];
+}
+
+/**
+ * QueryParamsResponse is the response type for the Query/Params RPC method.
+ */
+export interface V1Beta1QueryParamsResponse {
+  /** params defines the parameters of the module. */
+  params?: Osmosistokenfactoryv1Beta1Params;
+}
+
+export type QueryParamsType = Record<string | number, any>;
+export type ResponseFormat = keyof Omit<Body, "body" | "bodyUsed">;
+
+export interface FullRequestParams extends Omit<RequestInit, "body"> {
+  /** set parameter to `true` for call `securityWorker` for this request */
+  secure?: boolean;
+  /** request path */
+  path: string;
+  /** content type of request body */
+  type?: ContentType;
+  /** query params */
+  query?: QueryParamsType;
+  /** format of response (i.e. response.json() -> format: "json") */
+  format?: keyof Omit<Body, "body" | "bodyUsed">;
+  /** request body */
+  body?: unknown;
+  /** base url */
+  baseUrl?: string;
+  /** request cancellation token */
+  cancelToken?: CancelToken;
+}
+
+export type RequestParams = Omit<FullRequestParams, "body" | "method" | "query" | "path">;
+
+export interface ApiConfig<SecurityDataType = unknown> {
+  baseUrl?: string;
+  baseApiParams?: Omit<RequestParams, "baseUrl" | "cancelToken" | "signal">;
+  securityWorker?: (securityData: SecurityDataType) => RequestParams | void;
+}
+
+export interface HttpResponse<D extends unknown, E extends unknown = unknown> extends Response {
+  data: D;
+  error: E;
+}
+
+type CancelToken = Symbol | string | number;
+
+export enum ContentType {
+  Json = "application/json",
+  FormData = "multipart/form-data",
+  UrlEncoded = "application/x-www-form-urlencoded",
+}
+
+export class HttpClient<SecurityDataType = unknown> {
+  public baseUrl: string = "";
+  private securityData: SecurityDataType = null as any;
+  private securityWorker: null | ApiConfig<SecurityDataType>["securityWorker"] = null;
+  private abortControllers = new Map<CancelToken, AbortController>();
+
+  private baseApiParams: RequestParams = {
+    credentials: "same-origin",
+    headers: {},
+    redirect: "follow",
+    referrerPolicy: "no-referrer",
+  };
+
+  constructor(apiConfig: ApiConfig<SecurityDataType> = {}) {
+    Object.assign(this, apiConfig);
+  }
+
+  public setSecurityData = (data: SecurityDataType) => {
+    this.securityData = data;
+  };
+
+  private addQueryParam(query: QueryParamsType, key: string) {
+    const value = query[key];
+
+    return (
+      encodeURIComponent(key) +
+      "=" +
+      encodeURIComponent(Array.isArray(value) ? value.join(",") : typeof value === "number" ? value : `${value}`)
+    );
+  }
+
+  protected toQueryString(rawQuery?: QueryParamsType): string {
+    const query = rawQuery || {};
+    const keys = Object.keys(query).filter((key) => "undefined" !== typeof query[key]);
+    return keys
+      .map((key) =>
+        typeof query[key] === "object" && !Array.isArray(query[key])
+          ? this.toQueryString(query[key] as QueryParamsType)
+          : this.addQueryParam(query, key),
+      )
+      .join("&");
+  }
+
+  protected addQueryParams(rawQuery?: QueryParamsType): string {
+    const queryString = this.toQueryString(rawQuery);
+    return queryString ? `?${queryString}` : "";
+  }
+
+  private contentFormatters: Record<ContentType, (input: any) => any> = {
+    [ContentType.Json]: (input: any) =>
+      input !== null && (typeof input === "object" || typeof input === "string") ? JSON.stringify(input) : input,
+    [ContentType.FormData]: (input: any) =>
+      Object.keys(input || {}).reduce((data, key) => {
+        data.append(key, input[key]);
+        return data;
+      }, new FormData()),
+    [ContentType.UrlEncoded]: (input: any) => this.toQueryString(input),
+  };
+
+  private mergeRequestParams(params1: RequestParams, params2?: RequestParams): RequestParams {
+    return {
+      ...this.baseApiParams,
+      ...params1,
+      ...(params2 || {}),
+      headers: {
+        ...(this.baseApiParams.headers || {}),
+        ...(params1.headers || {}),
+        ...((params2 && params2.headers) || {}),
+      },
+    };
+  }
+
+  private createAbortSignal = (cancelToken: CancelToken): AbortSignal | undefined => {
+    if (this.abortControllers.has(cancelToken)) {
+      const abortController = this.abortControllers.get(cancelToken);
+      if (abortController) {
+        return abortController.signal;
+      }
+      return void 0;
+    }
+
+    const abortController = new AbortController();
+    this.abortControllers.set(cancelToken, abortController);
+    return abortController.signal;
+  };
+
+  public abortRequest = (cancelToken: CancelToken) => {
+    const abortController = this.abortControllers.get(cancelToken);
+
+    if (abortController) {
+      abortController.abort();
+      this.abortControllers.delete(cancelToken);
+    }
+  };
+
+  public request = <T = any, E = any>({
+    body,
+    secure,
+    path,
+    type,
+    query,
+    format = "json",
+    baseUrl,
+    cancelToken,
+    ...params
+  }: FullRequestParams): Promise<HttpResponse<T, E>> => {
+    const secureParams = (secure && this.securityWorker && this.securityWorker(this.securityData)) || {};
+    const requestParams = this.mergeRequestParams(params, secureParams);
+    const queryString = query && this.toQueryString(query);
+    const payloadFormatter = this.contentFormatters[type || ContentType.Json];
+
+    return fetch(`${baseUrl || this.baseUrl || ""}${path}${queryString ? `?${queryString}` : ""}`, {
+      ...requestParams,
+      headers: {
+        ...(type && type !== ContentType.FormData ? { "Content-Type": type } : {}),
+        ...(requestParams.headers || {}),
+      },
+      signal: cancelToken ? this.createAbortSignal(cancelToken) : void 0,
+      body: typeof body === "undefined" || body === null ? null : payloadFormatter(body),
+    }).then(async (response) => {
+      const r = response as HttpResponse<T, E>;
+      r.data = (null as unknown) as T;
+      r.error = (null as unknown) as E;
+
+      const data = await response[format]()
+        .then((data) => {
+          if (r.ok) {
+            r.data = data;
+          } else {
+            r.error = data;
+          }
+          return r;
+        })
+        .catch((e) => {
+          r.error = e;
+          return r;
+        });
+
+      if (cancelToken) {
+        this.abortControllers.delete(cancelToken);
+      }
+
+      if (!response.ok) throw data;
+      return data;
+    });
+  };
+}
+
+/**
+ * @title osmosis/tokenfactory/v1beta1/authorityMetadata.proto
+ * @version version not set
+ */
+export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDataType> {
+  /**
+ * No description
+ * 
+ * @tags Query
+ * @name QueryDenomAuthorityMetadata
+ * @summary DenomAuthorityMetadata defines a gRPC query method for fetching
+DenomAuthorityMetadata for a particular denom.
+ * @request GET:/osmosis/tokenfactory/v1beta1/denoms/{denom}/authority_metadata
+ */
+  queryDenomAuthorityMetadata = (denom: string, params: RequestParams = {}) =>
+    this.request<V1Beta1QueryDenomAuthorityMetadataResponse, RpcStatus>({
+      path: `/osmosis/tokenfactory/v1beta1/denoms/${denom}/authority_metadata`,
+      method: "GET",
+      format: "json",
+      ...params,
+    });
+
+  /**
+ * No description
+ * 
+ * @tags Query
+ * @name QueryDenomsFromCreator
+ * @summary DenomsFromCreator defines a gRPC query method for fetching all
+denominations created by a specific admin/creator.
+ * @request GET:/osmosis/tokenfactory/v1beta1/denoms_from_creator/{creator}
+ */
+  queryDenomsFromCreator = (creator: string, params: RequestParams = {}) =>
+    this.request<V1Beta1QueryDenomsFromCreatorResponse, RpcStatus>({
+      path: `/osmosis/tokenfactory/v1beta1/denoms_from_creator/${creator}`,
+      method: "GET",
+      format: "json",
+      ...params,
+    });
+
+  /**
+ * No description
+ * 
+ * @tags Query
+ * @name QueryParams
+ * @summary Params defines a gRPC query method that returns the tokenfactory module's
+parameters.
+ * @request GET:/osmosis/tokenfactory/v1beta1/params
+ */
+  queryParams = (params: RequestParams = {}) =>
+    this.request<V1Beta1QueryParamsResponse, RpcStatus>({
+      path: `/osmosis/tokenfactory/v1beta1/params`,
+      method: "GET",
+      format: "json",
+      ...params,
+    });
+}

+ 738 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/cosmos/bank/v1beta1/bank.ts

@@ -0,0 +1,738 @@
+//@ts-nocheck
+/* eslint-disable */
+import { Coin } from "../../../cosmos/base/v1beta1/coin";
+import { Writer, Reader } from "protobufjs/minimal";
+
+export const protobufPackage = "cosmos.bank.v1beta1";
+
+/** Params defines the parameters for the bank module. */
+export interface Params {
+  send_enabled: SendEnabled[];
+  default_send_enabled: boolean;
+}
+
+/**
+ * SendEnabled maps coin denom to a send_enabled status (whether a denom is
+ * sendable).
+ */
+export interface SendEnabled {
+  denom: string;
+  enabled: boolean;
+}
+
+/** Input models transaction input. */
+export interface Input {
+  address: string;
+  coins: Coin[];
+}
+
+/** Output models transaction outputs. */
+export interface Output {
+  address: string;
+  coins: Coin[];
+}
+
+/**
+ * Supply represents a struct that passively keeps track of the total supply
+ * amounts in the network.
+ * This message is deprecated now that supply is indexed by denom.
+ *
+ * @deprecated
+ */
+export interface Supply {
+  total: Coin[];
+}
+
+/**
+ * DenomUnit represents a struct that describes a given
+ * denomination unit of the basic token.
+ */
+export interface DenomUnit {
+  /** denom represents the string name of the given denom unit (e.g uatom). */
+  denom: string;
+  /**
+   * exponent represents power of 10 exponent that one must
+   * raise the base_denom to in order to equal the given DenomUnit's denom
+   * 1 denom = 1^exponent base_denom
+   * (e.g. with a base_denom of uatom, one can create a DenomUnit of 'atom' with
+   * exponent = 6, thus: 1 atom = 10^6 uatom).
+   */
+  exponent: number;
+  /** aliases is a list of string aliases for the given denom */
+  aliases: string[];
+}
+
+/**
+ * Metadata represents a struct that describes
+ * a basic token.
+ */
+export interface Metadata {
+  description: string;
+  /** denom_units represents the list of DenomUnit's for a given coin */
+  denom_units: DenomUnit[];
+  /** base represents the base denom (should be the DenomUnit with exponent = 0). */
+  base: string;
+  /**
+   * display indicates the suggested denom that should be
+   * displayed in clients.
+   */
+  display: string;
+  /**
+   * name defines the name of the token (eg: Cosmos Atom)
+   *
+   * Since: cosmos-sdk 0.43
+   */
+  name: string;
+  /**
+   * symbol is the token symbol usually shown on exchanges (eg: ATOM). This can
+   * be the same as the display.
+   *
+   * Since: cosmos-sdk 0.43
+   */
+  symbol: string;
+}
+
+const baseParams: object = { default_send_enabled: false };
+
+export const Params = {
+  encode(message: Params, writer: Writer = Writer.create()): Writer {
+    for (const v of message.send_enabled) {
+      SendEnabled.encode(v!, writer.uint32(10).fork()).ldelim();
+    }
+    if (message.default_send_enabled === true) {
+      writer.uint32(16).bool(message.default_send_enabled);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): Params {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseParams } as Params;
+    message.send_enabled = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.send_enabled.push(
+            SendEnabled.decode(reader, reader.uint32())
+          );
+          break;
+        case 2:
+          message.default_send_enabled = reader.bool();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): Params {
+    const message = { ...baseParams } as Params;
+    message.send_enabled = [];
+    if (object.send_enabled !== undefined && object.send_enabled !== null) {
+      for (const e of object.send_enabled) {
+        message.send_enabled.push(SendEnabled.fromJSON(e));
+      }
+    }
+    if (
+      object.default_send_enabled !== undefined &&
+      object.default_send_enabled !== null
+    ) {
+      message.default_send_enabled = Boolean(object.default_send_enabled);
+    } else {
+      message.default_send_enabled = false;
+    }
+    return message;
+  },
+
+  toJSON(message: Params): unknown {
+    const obj: any = {};
+    if (message.send_enabled) {
+      obj.send_enabled = message.send_enabled.map((e) =>
+        e ? SendEnabled.toJSON(e) : undefined
+      );
+    } else {
+      obj.send_enabled = [];
+    }
+    message.default_send_enabled !== undefined &&
+      (obj.default_send_enabled = message.default_send_enabled);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<Params>): Params {
+    const message = { ...baseParams } as Params;
+    message.send_enabled = [];
+    if (object.send_enabled !== undefined && object.send_enabled !== null) {
+      for (const e of object.send_enabled) {
+        message.send_enabled.push(SendEnabled.fromPartial(e));
+      }
+    }
+    if (
+      object.default_send_enabled !== undefined &&
+      object.default_send_enabled !== null
+    ) {
+      message.default_send_enabled = object.default_send_enabled;
+    } else {
+      message.default_send_enabled = false;
+    }
+    return message;
+  },
+};
+
+const baseSendEnabled: object = { denom: "", enabled: false };
+
+export const SendEnabled = {
+  encode(message: SendEnabled, writer: Writer = Writer.create()): Writer {
+    if (message.denom !== "") {
+      writer.uint32(10).string(message.denom);
+    }
+    if (message.enabled === true) {
+      writer.uint32(16).bool(message.enabled);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): SendEnabled {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseSendEnabled } as SendEnabled;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.denom = reader.string();
+          break;
+        case 2:
+          message.enabled = reader.bool();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): SendEnabled {
+    const message = { ...baseSendEnabled } as SendEnabled;
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = String(object.denom);
+    } else {
+      message.denom = "";
+    }
+    if (object.enabled !== undefined && object.enabled !== null) {
+      message.enabled = Boolean(object.enabled);
+    } else {
+      message.enabled = false;
+    }
+    return message;
+  },
+
+  toJSON(message: SendEnabled): unknown {
+    const obj: any = {};
+    message.denom !== undefined && (obj.denom = message.denom);
+    message.enabled !== undefined && (obj.enabled = message.enabled);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<SendEnabled>): SendEnabled {
+    const message = { ...baseSendEnabled } as SendEnabled;
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = object.denom;
+    } else {
+      message.denom = "";
+    }
+    if (object.enabled !== undefined && object.enabled !== null) {
+      message.enabled = object.enabled;
+    } else {
+      message.enabled = false;
+    }
+    return message;
+  },
+};
+
+const baseInput: object = { address: "" };
+
+export const Input = {
+  encode(message: Input, writer: Writer = Writer.create()): Writer {
+    if (message.address !== "") {
+      writer.uint32(10).string(message.address);
+    }
+    for (const v of message.coins) {
+      Coin.encode(v!, writer.uint32(18).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): Input {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseInput } as Input;
+    message.coins = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.address = reader.string();
+          break;
+        case 2:
+          message.coins.push(Coin.decode(reader, reader.uint32()));
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): Input {
+    const message = { ...baseInput } as Input;
+    message.coins = [];
+    if (object.address !== undefined && object.address !== null) {
+      message.address = String(object.address);
+    } else {
+      message.address = "";
+    }
+    if (object.coins !== undefined && object.coins !== null) {
+      for (const e of object.coins) {
+        message.coins.push(Coin.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: Input): unknown {
+    const obj: any = {};
+    message.address !== undefined && (obj.address = message.address);
+    if (message.coins) {
+      obj.coins = message.coins.map((e) => (e ? Coin.toJSON(e) : undefined));
+    } else {
+      obj.coins = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<Input>): Input {
+    const message = { ...baseInput } as Input;
+    message.coins = [];
+    if (object.address !== undefined && object.address !== null) {
+      message.address = object.address;
+    } else {
+      message.address = "";
+    }
+    if (object.coins !== undefined && object.coins !== null) {
+      for (const e of object.coins) {
+        message.coins.push(Coin.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseOutput: object = { address: "" };
+
+export const Output = {
+  encode(message: Output, writer: Writer = Writer.create()): Writer {
+    if (message.address !== "") {
+      writer.uint32(10).string(message.address);
+    }
+    for (const v of message.coins) {
+      Coin.encode(v!, writer.uint32(18).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): Output {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseOutput } as Output;
+    message.coins = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.address = reader.string();
+          break;
+        case 2:
+          message.coins.push(Coin.decode(reader, reader.uint32()));
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): Output {
+    const message = { ...baseOutput } as Output;
+    message.coins = [];
+    if (object.address !== undefined && object.address !== null) {
+      message.address = String(object.address);
+    } else {
+      message.address = "";
+    }
+    if (object.coins !== undefined && object.coins !== null) {
+      for (const e of object.coins) {
+        message.coins.push(Coin.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: Output): unknown {
+    const obj: any = {};
+    message.address !== undefined && (obj.address = message.address);
+    if (message.coins) {
+      obj.coins = message.coins.map((e) => (e ? Coin.toJSON(e) : undefined));
+    } else {
+      obj.coins = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<Output>): Output {
+    const message = { ...baseOutput } as Output;
+    message.coins = [];
+    if (object.address !== undefined && object.address !== null) {
+      message.address = object.address;
+    } else {
+      message.address = "";
+    }
+    if (object.coins !== undefined && object.coins !== null) {
+      for (const e of object.coins) {
+        message.coins.push(Coin.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseSupply: object = {};
+
+export const Supply = {
+  encode(message: Supply, writer: Writer = Writer.create()): Writer {
+    for (const v of message.total) {
+      Coin.encode(v!, writer.uint32(10).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): Supply {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseSupply } as Supply;
+    message.total = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.total.push(Coin.decode(reader, reader.uint32()));
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): Supply {
+    const message = { ...baseSupply } as Supply;
+    message.total = [];
+    if (object.total !== undefined && object.total !== null) {
+      for (const e of object.total) {
+        message.total.push(Coin.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: Supply): unknown {
+    const obj: any = {};
+    if (message.total) {
+      obj.total = message.total.map((e) => (e ? Coin.toJSON(e) : undefined));
+    } else {
+      obj.total = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<Supply>): Supply {
+    const message = { ...baseSupply } as Supply;
+    message.total = [];
+    if (object.total !== undefined && object.total !== null) {
+      for (const e of object.total) {
+        message.total.push(Coin.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseDenomUnit: object = { denom: "", exponent: 0, aliases: "" };
+
+export const DenomUnit = {
+  encode(message: DenomUnit, writer: Writer = Writer.create()): Writer {
+    if (message.denom !== "") {
+      writer.uint32(10).string(message.denom);
+    }
+    if (message.exponent !== 0) {
+      writer.uint32(16).uint32(message.exponent);
+    }
+    for (const v of message.aliases) {
+      writer.uint32(26).string(v!);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): DenomUnit {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseDenomUnit } as DenomUnit;
+    message.aliases = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.denom = reader.string();
+          break;
+        case 2:
+          message.exponent = reader.uint32();
+          break;
+        case 3:
+          message.aliases.push(reader.string());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): DenomUnit {
+    const message = { ...baseDenomUnit } as DenomUnit;
+    message.aliases = [];
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = String(object.denom);
+    } else {
+      message.denom = "";
+    }
+    if (object.exponent !== undefined && object.exponent !== null) {
+      message.exponent = Number(object.exponent);
+    } else {
+      message.exponent = 0;
+    }
+    if (object.aliases !== undefined && object.aliases !== null) {
+      for (const e of object.aliases) {
+        message.aliases.push(String(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: DenomUnit): unknown {
+    const obj: any = {};
+    message.denom !== undefined && (obj.denom = message.denom);
+    message.exponent !== undefined && (obj.exponent = message.exponent);
+    if (message.aliases) {
+      obj.aliases = message.aliases.map((e) => e);
+    } else {
+      obj.aliases = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<DenomUnit>): DenomUnit {
+    const message = { ...baseDenomUnit } as DenomUnit;
+    message.aliases = [];
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = object.denom;
+    } else {
+      message.denom = "";
+    }
+    if (object.exponent !== undefined && object.exponent !== null) {
+      message.exponent = object.exponent;
+    } else {
+      message.exponent = 0;
+    }
+    if (object.aliases !== undefined && object.aliases !== null) {
+      for (const e of object.aliases) {
+        message.aliases.push(e);
+      }
+    }
+    return message;
+  },
+};
+
+const baseMetadata: object = {
+  description: "",
+  base: "",
+  display: "",
+  name: "",
+  symbol: "",
+};
+
+export const Metadata = {
+  encode(message: Metadata, writer: Writer = Writer.create()): Writer {
+    if (message.description !== "") {
+      writer.uint32(10).string(message.description);
+    }
+    for (const v of message.denom_units) {
+      DenomUnit.encode(v!, writer.uint32(18).fork()).ldelim();
+    }
+    if (message.base !== "") {
+      writer.uint32(26).string(message.base);
+    }
+    if (message.display !== "") {
+      writer.uint32(34).string(message.display);
+    }
+    if (message.name !== "") {
+      writer.uint32(42).string(message.name);
+    }
+    if (message.symbol !== "") {
+      writer.uint32(50).string(message.symbol);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): Metadata {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMetadata } as Metadata;
+    message.denom_units = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.description = reader.string();
+          break;
+        case 2:
+          message.denom_units.push(DenomUnit.decode(reader, reader.uint32()));
+          break;
+        case 3:
+          message.base = reader.string();
+          break;
+        case 4:
+          message.display = reader.string();
+          break;
+        case 5:
+          message.name = reader.string();
+          break;
+        case 6:
+          message.symbol = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): Metadata {
+    const message = { ...baseMetadata } as Metadata;
+    message.denom_units = [];
+    if (object.description !== undefined && object.description !== null) {
+      message.description = String(object.description);
+    } else {
+      message.description = "";
+    }
+    if (object.denom_units !== undefined && object.denom_units !== null) {
+      for (const e of object.denom_units) {
+        message.denom_units.push(DenomUnit.fromJSON(e));
+      }
+    }
+    if (object.base !== undefined && object.base !== null) {
+      message.base = String(object.base);
+    } else {
+      message.base = "";
+    }
+    if (object.display !== undefined && object.display !== null) {
+      message.display = String(object.display);
+    } else {
+      message.display = "";
+    }
+    if (object.name !== undefined && object.name !== null) {
+      message.name = String(object.name);
+    } else {
+      message.name = "";
+    }
+    if (object.symbol !== undefined && object.symbol !== null) {
+      message.symbol = String(object.symbol);
+    } else {
+      message.symbol = "";
+    }
+    return message;
+  },
+
+  toJSON(message: Metadata): unknown {
+    const obj: any = {};
+    message.description !== undefined &&
+      (obj.description = message.description);
+    if (message.denom_units) {
+      obj.denom_units = message.denom_units.map((e) =>
+        e ? DenomUnit.toJSON(e) : undefined
+      );
+    } else {
+      obj.denom_units = [];
+    }
+    message.base !== undefined && (obj.base = message.base);
+    message.display !== undefined && (obj.display = message.display);
+    message.name !== undefined && (obj.name = message.name);
+    message.symbol !== undefined && (obj.symbol = message.symbol);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<Metadata>): Metadata {
+    const message = { ...baseMetadata } as Metadata;
+    message.denom_units = [];
+    if (object.description !== undefined && object.description !== null) {
+      message.description = object.description;
+    } else {
+      message.description = "";
+    }
+    if (object.denom_units !== undefined && object.denom_units !== null) {
+      for (const e of object.denom_units) {
+        message.denom_units.push(DenomUnit.fromPartial(e));
+      }
+    }
+    if (object.base !== undefined && object.base !== null) {
+      message.base = object.base;
+    } else {
+      message.base = "";
+    }
+    if (object.display !== undefined && object.display !== null) {
+      message.display = object.display;
+    } else {
+      message.display = "";
+    }
+    if (object.name !== undefined && object.name !== null) {
+      message.name = object.name;
+    } else {
+      message.name = "";
+    }
+    if (object.symbol !== undefined && object.symbol !== null) {
+      message.symbol = object.symbol;
+    } else {
+      message.symbol = "";
+    }
+    return message;
+  },
+};
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;

+ 301 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/cosmos/base/query/v1beta1/pagination.ts

@@ -0,0 +1,301 @@
+//@ts-nocheck
+/* eslint-disable */
+import * as Long from "long";
+import { util, configure, Writer, Reader } from "protobufjs/minimal";
+
+export const protobufPackage = "cosmos.base.query.v1beta1";
+
+/**
+ * PageRequest is to be embedded in gRPC request messages for efficient
+ * pagination. Ex:
+ *
+ *  message SomeRequest {
+ *          Foo some_parameter = 1;
+ *          PageRequest pagination = 2;
+ *  }
+ */
+export interface PageRequest {
+  /**
+   * key is a value returned in PageResponse.next_key to begin
+   * querying the next page most efficiently. Only one of offset or key
+   * should be set.
+   */
+  key: Uint8Array;
+  /**
+   * offset is a numeric offset that can be used when key is unavailable.
+   * It is less efficient than using key. Only one of offset or key should
+   * be set.
+   */
+  offset: number;
+  /**
+   * limit is the total number of results to be returned in the result page.
+   * If left empty it will default to a value to be set by each app.
+   */
+  limit: number;
+  /**
+   * count_total is set to true  to indicate that the result set should include
+   * a count of the total number of items available for pagination in UIs.
+   * count_total is only respected when offset is used. It is ignored when key
+   * is set.
+   */
+  count_total: boolean;
+}
+
+/**
+ * PageResponse is to be embedded in gRPC response messages where the
+ * corresponding request message has used PageRequest.
+ *
+ *  message SomeResponse {
+ *          repeated Bar results = 1;
+ *          PageResponse page = 2;
+ *  }
+ */
+export interface PageResponse {
+  /**
+   * next_key is the key to be passed to PageRequest.key to
+   * query the next page most efficiently
+   */
+  next_key: Uint8Array;
+  /**
+   * total is total number of results available if PageRequest.count_total
+   * was set, its value is undefined otherwise
+   */
+  total: number;
+}
+
+const basePageRequest: object = { offset: 0, limit: 0, count_total: false };
+
+export const PageRequest = {
+  encode(message: PageRequest, writer: Writer = Writer.create()): Writer {
+    if (message.key.length !== 0) {
+      writer.uint32(10).bytes(message.key);
+    }
+    if (message.offset !== 0) {
+      writer.uint32(16).uint64(message.offset);
+    }
+    if (message.limit !== 0) {
+      writer.uint32(24).uint64(message.limit);
+    }
+    if (message.count_total === true) {
+      writer.uint32(32).bool(message.count_total);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): PageRequest {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...basePageRequest } as PageRequest;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.key = reader.bytes();
+          break;
+        case 2:
+          message.offset = longToNumber(reader.uint64() as Long);
+          break;
+        case 3:
+          message.limit = longToNumber(reader.uint64() as Long);
+          break;
+        case 4:
+          message.count_total = reader.bool();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): PageRequest {
+    const message = { ...basePageRequest } as PageRequest;
+    if (object.key !== undefined && object.key !== null) {
+      message.key = bytesFromBase64(object.key);
+    }
+    if (object.offset !== undefined && object.offset !== null) {
+      message.offset = Number(object.offset);
+    } else {
+      message.offset = 0;
+    }
+    if (object.limit !== undefined && object.limit !== null) {
+      message.limit = Number(object.limit);
+    } else {
+      message.limit = 0;
+    }
+    if (object.count_total !== undefined && object.count_total !== null) {
+      message.count_total = Boolean(object.count_total);
+    } else {
+      message.count_total = false;
+    }
+    return message;
+  },
+
+  toJSON(message: PageRequest): unknown {
+    const obj: any = {};
+    message.key !== undefined &&
+      (obj.key = base64FromBytes(
+        message.key !== undefined ? message.key : new Uint8Array()
+      ));
+    message.offset !== undefined && (obj.offset = message.offset);
+    message.limit !== undefined && (obj.limit = message.limit);
+    message.count_total !== undefined &&
+      (obj.count_total = message.count_total);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<PageRequest>): PageRequest {
+    const message = { ...basePageRequest } as PageRequest;
+    if (object.key !== undefined && object.key !== null) {
+      message.key = object.key;
+    } else {
+      message.key = new Uint8Array();
+    }
+    if (object.offset !== undefined && object.offset !== null) {
+      message.offset = object.offset;
+    } else {
+      message.offset = 0;
+    }
+    if (object.limit !== undefined && object.limit !== null) {
+      message.limit = object.limit;
+    } else {
+      message.limit = 0;
+    }
+    if (object.count_total !== undefined && object.count_total !== null) {
+      message.count_total = object.count_total;
+    } else {
+      message.count_total = false;
+    }
+    return message;
+  },
+};
+
+const basePageResponse: object = { total: 0 };
+
+export const PageResponse = {
+  encode(message: PageResponse, writer: Writer = Writer.create()): Writer {
+    if (message.next_key.length !== 0) {
+      writer.uint32(10).bytes(message.next_key);
+    }
+    if (message.total !== 0) {
+      writer.uint32(16).uint64(message.total);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): PageResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...basePageResponse } as PageResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.next_key = reader.bytes();
+          break;
+        case 2:
+          message.total = longToNumber(reader.uint64() as Long);
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): PageResponse {
+    const message = { ...basePageResponse } as PageResponse;
+    if (object.next_key !== undefined && object.next_key !== null) {
+      message.next_key = bytesFromBase64(object.next_key);
+    }
+    if (object.total !== undefined && object.total !== null) {
+      message.total = Number(object.total);
+    } else {
+      message.total = 0;
+    }
+    return message;
+  },
+
+  toJSON(message: PageResponse): unknown {
+    const obj: any = {};
+    message.next_key !== undefined &&
+      (obj.next_key = base64FromBytes(
+        message.next_key !== undefined ? message.next_key : new Uint8Array()
+      ));
+    message.total !== undefined && (obj.total = message.total);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<PageResponse>): PageResponse {
+    const message = { ...basePageResponse } as PageResponse;
+    if (object.next_key !== undefined && object.next_key !== null) {
+      message.next_key = object.next_key;
+    } else {
+      message.next_key = new Uint8Array();
+    }
+    if (object.total !== undefined && object.total !== null) {
+      message.total = object.total;
+    } else {
+      message.total = 0;
+    }
+    return message;
+  },
+};
+
+declare var self: any | undefined;
+declare var window: any | undefined;
+var globalThis: any = (() => {
+  if (typeof globalThis !== "undefined") return globalThis;
+  if (typeof self !== "undefined") return self;
+  if (typeof window !== "undefined") return window;
+  if (typeof global !== "undefined") return global;
+  throw "Unable to locate global object";
+})();
+
+const atob: (b64: string) => string =
+  globalThis.atob ||
+  ((b64) => globalThis.Buffer.from(b64, "base64").toString("binary"));
+function bytesFromBase64(b64: string): Uint8Array {
+  const bin = atob(b64);
+  const arr = new Uint8Array(bin.length);
+  for (let i = 0; i < bin.length; ++i) {
+    arr[i] = bin.charCodeAt(i);
+  }
+  return arr;
+}
+
+const btoa: (bin: string) => string =
+  globalThis.btoa ||
+  ((bin) => globalThis.Buffer.from(bin, "binary").toString("base64"));
+function base64FromBytes(arr: Uint8Array): string {
+  const bin: string[] = [];
+  for (let i = 0; i < arr.byteLength; ++i) {
+    bin.push(String.fromCharCode(arr[i]));
+  }
+  return btoa(bin.join(""));
+}
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;
+
+function longToNumber(long: Long): number {
+  if (long.gt(Number.MAX_SAFE_INTEGER)) {
+    throw new globalThis.Error("Value is larger than Number.MAX_SAFE_INTEGER");
+  }
+  return long.toNumber();
+}
+
+if (util.Long !== Long) {
+  util.Long = Long as any;
+  configure();
+}

+ 302 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/cosmos/base/v1beta1/coin.ts

@@ -0,0 +1,302 @@
+//@ts-nocheck
+/* eslint-disable */
+import { Writer, Reader } from "protobufjs/minimal";
+
+export const protobufPackage = "cosmos.base.v1beta1";
+
+/**
+ * Coin defines a token with a denomination and an amount.
+ *
+ * NOTE: The amount field is an Int which implements the custom method
+ * signatures required by gogoproto.
+ */
+export interface Coin {
+  denom: string;
+  amount: string;
+}
+
+/**
+ * DecCoin defines a token with a denomination and a decimal amount.
+ *
+ * NOTE: The amount field is an Dec which implements the custom method
+ * signatures required by gogoproto.
+ */
+export interface DecCoin {
+  denom: string;
+  amount: string;
+}
+
+/** IntProto defines a Protobuf wrapper around an Int object. */
+export interface IntProto {
+  int: string;
+}
+
+/** DecProto defines a Protobuf wrapper around a Dec object. */
+export interface DecProto {
+  dec: string;
+}
+
+const baseCoin: object = { denom: "", amount: "" };
+
+export const Coin = {
+  encode(message: Coin, writer: Writer = Writer.create()): Writer {
+    if (message.denom !== "") {
+      writer.uint32(10).string(message.denom);
+    }
+    if (message.amount !== "") {
+      writer.uint32(18).string(message.amount);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): Coin {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseCoin } as Coin;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.denom = reader.string();
+          break;
+        case 2:
+          message.amount = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): Coin {
+    const message = { ...baseCoin } as Coin;
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = String(object.denom);
+    } else {
+      message.denom = "";
+    }
+    if (object.amount !== undefined && object.amount !== null) {
+      message.amount = String(object.amount);
+    } else {
+      message.amount = "";
+    }
+    return message;
+  },
+
+  toJSON(message: Coin): unknown {
+    const obj: any = {};
+    message.denom !== undefined && (obj.denom = message.denom);
+    message.amount !== undefined && (obj.amount = message.amount);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<Coin>): Coin {
+    const message = { ...baseCoin } as Coin;
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = object.denom;
+    } else {
+      message.denom = "";
+    }
+    if (object.amount !== undefined && object.amount !== null) {
+      message.amount = object.amount;
+    } else {
+      message.amount = "";
+    }
+    return message;
+  },
+};
+
+const baseDecCoin: object = { denom: "", amount: "" };
+
+export const DecCoin = {
+  encode(message: DecCoin, writer: Writer = Writer.create()): Writer {
+    if (message.denom !== "") {
+      writer.uint32(10).string(message.denom);
+    }
+    if (message.amount !== "") {
+      writer.uint32(18).string(message.amount);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): DecCoin {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseDecCoin } as DecCoin;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.denom = reader.string();
+          break;
+        case 2:
+          message.amount = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): DecCoin {
+    const message = { ...baseDecCoin } as DecCoin;
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = String(object.denom);
+    } else {
+      message.denom = "";
+    }
+    if (object.amount !== undefined && object.amount !== null) {
+      message.amount = String(object.amount);
+    } else {
+      message.amount = "";
+    }
+    return message;
+  },
+
+  toJSON(message: DecCoin): unknown {
+    const obj: any = {};
+    message.denom !== undefined && (obj.denom = message.denom);
+    message.amount !== undefined && (obj.amount = message.amount);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<DecCoin>): DecCoin {
+    const message = { ...baseDecCoin } as DecCoin;
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = object.denom;
+    } else {
+      message.denom = "";
+    }
+    if (object.amount !== undefined && object.amount !== null) {
+      message.amount = object.amount;
+    } else {
+      message.amount = "";
+    }
+    return message;
+  },
+};
+
+const baseIntProto: object = { int: "" };
+
+export const IntProto = {
+  encode(message: IntProto, writer: Writer = Writer.create()): Writer {
+    if (message.int !== "") {
+      writer.uint32(10).string(message.int);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): IntProto {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseIntProto } as IntProto;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.int = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): IntProto {
+    const message = { ...baseIntProto } as IntProto;
+    if (object.int !== undefined && object.int !== null) {
+      message.int = String(object.int);
+    } else {
+      message.int = "";
+    }
+    return message;
+  },
+
+  toJSON(message: IntProto): unknown {
+    const obj: any = {};
+    message.int !== undefined && (obj.int = message.int);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<IntProto>): IntProto {
+    const message = { ...baseIntProto } as IntProto;
+    if (object.int !== undefined && object.int !== null) {
+      message.int = object.int;
+    } else {
+      message.int = "";
+    }
+    return message;
+  },
+};
+
+const baseDecProto: object = { dec: "" };
+
+export const DecProto = {
+  encode(message: DecProto, writer: Writer = Writer.create()): Writer {
+    if (message.dec !== "") {
+      writer.uint32(10).string(message.dec);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): DecProto {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseDecProto } as DecProto;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.dec = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): DecProto {
+    const message = { ...baseDecProto } as DecProto;
+    if (object.dec !== undefined && object.dec !== null) {
+      message.dec = String(object.dec);
+    } else {
+      message.dec = "";
+    }
+    return message;
+  },
+
+  toJSON(message: DecProto): unknown {
+    const obj: any = {};
+    message.dec !== undefined && (obj.dec = message.dec);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<DecProto>): DecProto {
+    const message = { ...baseDecProto } as DecProto;
+    if (object.dec !== undefined && object.dec !== null) {
+      message.dec = object.dec;
+    } else {
+      message.dec = "";
+    }
+    return message;
+  },
+};
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;

+ 3 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/cosmos_proto/cosmos.ts

@@ -0,0 +1,3 @@
+//@ts-nocheck
+/* eslint-disable */
+export const protobufPackage = "cosmos_proto";

+ 3 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/gogoproto/gogo.ts

@@ -0,0 +1,3 @@
+//@ts-nocheck
+/* eslint-disable */
+export const protobufPackage = "gogoproto";

+ 3 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/google/api/annotations.ts

@@ -0,0 +1,3 @@
+//@ts-nocheck
+/* eslint-disable */
+export const protobufPackage = "google.api";

+ 707 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/google/api/http.ts

@@ -0,0 +1,707 @@
+//@ts-nocheck
+/* eslint-disable */
+import { Writer, Reader } from "protobufjs/minimal";
+
+export const protobufPackage = "google.api";
+
+/**
+ * Defines the HTTP configuration for an API service. It contains a list of
+ * [HttpRule][google.api.HttpRule], each specifying the mapping of an RPC method
+ * to one or more HTTP REST API methods.
+ */
+export interface Http {
+  /**
+   * A list of HTTP configuration rules that apply to individual API methods.
+   *
+   * **NOTE:** All service configuration rules follow "last one wins" order.
+   */
+  rules: HttpRule[];
+  /**
+   * When set to true, URL path parmeters will be fully URI-decoded except in
+   * cases of single segment matches in reserved expansion, where "%2F" will be
+   * left encoded.
+   *
+   * The default behavior is to not decode RFC 6570 reserved characters in multi
+   * segment matches.
+   */
+  fully_decode_reserved_expansion: boolean;
+}
+
+/**
+ * `HttpRule` defines the mapping of an RPC method to one or more HTTP
+ * REST API methods. The mapping specifies how different portions of the RPC
+ * request message are mapped to URL path, URL query parameters, and
+ * HTTP request body. The mapping is typically specified as an
+ * `google.api.http` annotation on the RPC method,
+ * see "google/api/annotations.proto" for details.
+ *
+ * The mapping consists of a field specifying the path template and
+ * method kind.  The path template can refer to fields in the request
+ * message, as in the example below which describes a REST GET
+ * operation on a resource collection of messages:
+ *
+ *
+ *     service Messaging {
+ *       rpc GetMessage(GetMessageRequest) returns (Message) {
+ *         option (google.api.http).get = "/v1/messages/{message_id}/{sub.subfield}";
+ *       }
+ *     }
+ *     message GetMessageRequest {
+ *       message SubMessage {
+ *         string subfield = 1;
+ *       }
+ *       string message_id = 1; // mapped to the URL
+ *       SubMessage sub = 2;    // `sub.subfield` is url-mapped
+ *     }
+ *     message Message {
+ *       string text = 1; // content of the resource
+ *     }
+ *
+ * The same http annotation can alternatively be expressed inside the
+ * `GRPC API Configuration` YAML file.
+ *
+ *     http:
+ *       rules:
+ *         - selector: <proto_package_name>.Messaging.GetMessage
+ *           get: /v1/messages/{message_id}/{sub.subfield}
+ *
+ * This definition enables an automatic, bidrectional mapping of HTTP
+ * JSON to RPC. Example:
+ *
+ * HTTP | RPC
+ * -----|-----
+ * `GET /v1/messages/123456/foo`  | `GetMessage(message_id: "123456" sub: SubMessage(subfield: "foo"))`
+ *
+ * In general, not only fields but also field paths can be referenced
+ * from a path pattern. Fields mapped to the path pattern cannot be
+ * repeated and must have a primitive (non-message) type.
+ *
+ * Any fields in the request message which are not bound by the path
+ * pattern automatically become (optional) HTTP query
+ * parameters. Assume the following definition of the request message:
+ *
+ *
+ *     service Messaging {
+ *       rpc GetMessage(GetMessageRequest) returns (Message) {
+ *         option (google.api.http).get = "/v1/messages/{message_id}";
+ *       }
+ *     }
+ *     message GetMessageRequest {
+ *       message SubMessage {
+ *         string subfield = 1;
+ *       }
+ *       string message_id = 1; // mapped to the URL
+ *       int64 revision = 2;    // becomes a parameter
+ *       SubMessage sub = 3;    // `sub.subfield` becomes a parameter
+ *     }
+ *
+ *
+ * This enables a HTTP JSON to RPC mapping as below:
+ *
+ * HTTP | RPC
+ * -----|-----
+ * `GET /v1/messages/123456?revision=2&sub.subfield=foo` | `GetMessage(message_id: "123456" revision: 2 sub: SubMessage(subfield: "foo"))`
+ *
+ * Note that fields which are mapped to HTTP parameters must have a
+ * primitive type or a repeated primitive type. Message types are not
+ * allowed. In the case of a repeated type, the parameter can be
+ * repeated in the URL, as in `...?param=A&param=B`.
+ *
+ * For HTTP method kinds which allow a request body, the `body` field
+ * specifies the mapping. Consider a REST update method on the
+ * message resource collection:
+ *
+ *
+ *     service Messaging {
+ *       rpc UpdateMessage(UpdateMessageRequest) returns (Message) {
+ *         option (google.api.http) = {
+ *           put: "/v1/messages/{message_id}"
+ *           body: "message"
+ *         };
+ *       }
+ *     }
+ *     message UpdateMessageRequest {
+ *       string message_id = 1; // mapped to the URL
+ *       Message message = 2;   // mapped to the body
+ *     }
+ *
+ *
+ * The following HTTP JSON to RPC mapping is enabled, where the
+ * representation of the JSON in the request body is determined by
+ * protos JSON encoding:
+ *
+ * HTTP | RPC
+ * -----|-----
+ * `PUT /v1/messages/123456 { "text": "Hi!" }` | `UpdateMessage(message_id: "123456" message { text: "Hi!" })`
+ *
+ * The special name `*` can be used in the body mapping to define that
+ * every field not bound by the path template should be mapped to the
+ * request body.  This enables the following alternative definition of
+ * the update method:
+ *
+ *     service Messaging {
+ *       rpc UpdateMessage(Message) returns (Message) {
+ *         option (google.api.http) = {
+ *           put: "/v1/messages/{message_id}"
+ *           body: "*"
+ *         };
+ *       }
+ *     }
+ *     message Message {
+ *       string message_id = 1;
+ *       string text = 2;
+ *     }
+ *
+ *
+ * The following HTTP JSON to RPC mapping is enabled:
+ *
+ * HTTP | RPC
+ * -----|-----
+ * `PUT /v1/messages/123456 { "text": "Hi!" }` | `UpdateMessage(message_id: "123456" text: "Hi!")`
+ *
+ * Note that when using `*` in the body mapping, it is not possible to
+ * have HTTP parameters, as all fields not bound by the path end in
+ * the body. This makes this option more rarely used in practice of
+ * defining REST APIs. The common usage of `*` is in custom methods
+ * which don't use the URL at all for transferring data.
+ *
+ * It is possible to define multiple HTTP methods for one RPC by using
+ * the `additional_bindings` option. Example:
+ *
+ *     service Messaging {
+ *       rpc GetMessage(GetMessageRequest) returns (Message) {
+ *         option (google.api.http) = {
+ *           get: "/v1/messages/{message_id}"
+ *           additional_bindings {
+ *             get: "/v1/users/{user_id}/messages/{message_id}"
+ *           }
+ *         };
+ *       }
+ *     }
+ *     message GetMessageRequest {
+ *       string message_id = 1;
+ *       string user_id = 2;
+ *     }
+ *
+ *
+ * This enables the following two alternative HTTP JSON to RPC
+ * mappings:
+ *
+ * HTTP | RPC
+ * -----|-----
+ * `GET /v1/messages/123456` | `GetMessage(message_id: "123456")`
+ * `GET /v1/users/me/messages/123456` | `GetMessage(user_id: "me" message_id: "123456")`
+ *
+ * # Rules for HTTP mapping
+ *
+ * The rules for mapping HTTP path, query parameters, and body fields
+ * to the request message are as follows:
+ *
+ * 1. The `body` field specifies either `*` or a field path, or is
+ *    omitted. If omitted, it indicates there is no HTTP request body.
+ * 2. Leaf fields (recursive expansion of nested messages in the
+ *    request) can be classified into three types:
+ *     (a) Matched in the URL template.
+ *     (b) Covered by body (if body is `*`, everything except (a) fields;
+ *         else everything under the body field)
+ *     (c) All other fields.
+ * 3. URL query parameters found in the HTTP request are mapped to (c) fields.
+ * 4. Any body sent with an HTTP request can contain only (b) fields.
+ *
+ * The syntax of the path template is as follows:
+ *
+ *     Template = "/" Segments [ Verb ] ;
+ *     Segments = Segment { "/" Segment } ;
+ *     Segment  = "*" | "**" | LITERAL | Variable ;
+ *     Variable = "{" FieldPath [ "=" Segments ] "}" ;
+ *     FieldPath = IDENT { "." IDENT } ;
+ *     Verb     = ":" LITERAL ;
+ *
+ * The syntax `*` matches a single path segment. The syntax `**` matches zero
+ * or more path segments, which must be the last part of the path except the
+ * `Verb`. The syntax `LITERAL` matches literal text in the path.
+ *
+ * The syntax `Variable` matches part of the URL path as specified by its
+ * template. A variable template must not contain other variables. If a variable
+ * matches a single path segment, its template may be omitted, e.g. `{var}`
+ * is equivalent to `{var=*}`.
+ *
+ * If a variable contains exactly one path segment, such as `"{var}"` or
+ * `"{var=*}"`, when such a variable is expanded into a URL path, all characters
+ * except `[-_.~0-9a-zA-Z]` are percent-encoded. Such variables show up in the
+ * Discovery Document as `{var}`.
+ *
+ * If a variable contains one or more path segments, such as `"{var=foo/*}"`
+ * or `"{var=**}"`, when such a variable is expanded into a URL path, all
+ * characters except `[-_.~/0-9a-zA-Z]` are percent-encoded. Such variables
+ * show up in the Discovery Document as `{+var}`.
+ *
+ * NOTE: While the single segment variable matches the semantics of
+ * [RFC 6570](https://tools.ietf.org/html/rfc6570) Section 3.2.2
+ * Simple String Expansion, the multi segment variable **does not** match
+ * RFC 6570 Reserved Expansion. The reason is that the Reserved Expansion
+ * does not expand special characters like `?` and `#`, which would lead
+ * to invalid URLs.
+ *
+ * NOTE: the field paths in variables and in the `body` must not refer to
+ * repeated fields or map fields.
+ */
+export interface HttpRule {
+  /**
+   * Selects methods to which this rule applies.
+   *
+   * Refer to [selector][google.api.DocumentationRule.selector] for syntax details.
+   */
+  selector: string;
+  /** Used for listing and getting information about resources. */
+  get: string | undefined;
+  /** Used for updating a resource. */
+  put: string | undefined;
+  /** Used for creating a resource. */
+  post: string | undefined;
+  /** Used for deleting a resource. */
+  delete: string | undefined;
+  /** Used for updating a resource. */
+  patch: string | undefined;
+  /**
+   * The custom pattern is used for specifying an HTTP method that is not
+   * included in the `pattern` field, such as HEAD, or "*" to leave the
+   * HTTP method unspecified for this rule. The wild-card rule is useful
+   * for services that provide content to Web (HTML) clients.
+   */
+  custom: CustomHttpPattern | undefined;
+  /**
+   * The name of the request field whose value is mapped to the HTTP body, or
+   * `*` for mapping all fields not captured by the path pattern to the HTTP
+   * body. NOTE: the referred field must not be a repeated field and must be
+   * present at the top-level of request message type.
+   */
+  body: string;
+  /**
+   * Optional. The name of the response field whose value is mapped to the HTTP
+   * body of response. Other response fields are ignored. When
+   * not set, the response message will be used as HTTP body of response.
+   */
+  response_body: string;
+  /**
+   * Additional HTTP bindings for the selector. Nested bindings must
+   * not contain an `additional_bindings` field themselves (that is,
+   * the nesting may only be one level deep).
+   */
+  additional_bindings: HttpRule[];
+}
+
+/** A custom pattern is used for defining custom HTTP verb. */
+export interface CustomHttpPattern {
+  /** The name of this custom HTTP verb. */
+  kind: string;
+  /** The path matched by this custom verb. */
+  path: string;
+}
+
+const baseHttp: object = { fully_decode_reserved_expansion: false };
+
+export const Http = {
+  encode(message: Http, writer: Writer = Writer.create()): Writer {
+    for (const v of message.rules) {
+      HttpRule.encode(v!, writer.uint32(10).fork()).ldelim();
+    }
+    if (message.fully_decode_reserved_expansion === true) {
+      writer.uint32(16).bool(message.fully_decode_reserved_expansion);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): Http {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseHttp } as Http;
+    message.rules = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.rules.push(HttpRule.decode(reader, reader.uint32()));
+          break;
+        case 2:
+          message.fully_decode_reserved_expansion = reader.bool();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): Http {
+    const message = { ...baseHttp } as Http;
+    message.rules = [];
+    if (object.rules !== undefined && object.rules !== null) {
+      for (const e of object.rules) {
+        message.rules.push(HttpRule.fromJSON(e));
+      }
+    }
+    if (
+      object.fully_decode_reserved_expansion !== undefined &&
+      object.fully_decode_reserved_expansion !== null
+    ) {
+      message.fully_decode_reserved_expansion = Boolean(
+        object.fully_decode_reserved_expansion
+      );
+    } else {
+      message.fully_decode_reserved_expansion = false;
+    }
+    return message;
+  },
+
+  toJSON(message: Http): unknown {
+    const obj: any = {};
+    if (message.rules) {
+      obj.rules = message.rules.map((e) =>
+        e ? HttpRule.toJSON(e) : undefined
+      );
+    } else {
+      obj.rules = [];
+    }
+    message.fully_decode_reserved_expansion !== undefined &&
+      (obj.fully_decode_reserved_expansion =
+        message.fully_decode_reserved_expansion);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<Http>): Http {
+    const message = { ...baseHttp } as Http;
+    message.rules = [];
+    if (object.rules !== undefined && object.rules !== null) {
+      for (const e of object.rules) {
+        message.rules.push(HttpRule.fromPartial(e));
+      }
+    }
+    if (
+      object.fully_decode_reserved_expansion !== undefined &&
+      object.fully_decode_reserved_expansion !== null
+    ) {
+      message.fully_decode_reserved_expansion =
+        object.fully_decode_reserved_expansion;
+    } else {
+      message.fully_decode_reserved_expansion = false;
+    }
+    return message;
+  },
+};
+
+const baseHttpRule: object = { selector: "", body: "", response_body: "" };
+
+export const HttpRule = {
+  encode(message: HttpRule, writer: Writer = Writer.create()): Writer {
+    if (message.selector !== "") {
+      writer.uint32(10).string(message.selector);
+    }
+    if (message.get !== undefined) {
+      writer.uint32(18).string(message.get);
+    }
+    if (message.put !== undefined) {
+      writer.uint32(26).string(message.put);
+    }
+    if (message.post !== undefined) {
+      writer.uint32(34).string(message.post);
+    }
+    if (message.delete !== undefined) {
+      writer.uint32(42).string(message.delete);
+    }
+    if (message.patch !== undefined) {
+      writer.uint32(50).string(message.patch);
+    }
+    if (message.custom !== undefined) {
+      CustomHttpPattern.encode(
+        message.custom,
+        writer.uint32(66).fork()
+      ).ldelim();
+    }
+    if (message.body !== "") {
+      writer.uint32(58).string(message.body);
+    }
+    if (message.response_body !== "") {
+      writer.uint32(98).string(message.response_body);
+    }
+    for (const v of message.additional_bindings) {
+      HttpRule.encode(v!, writer.uint32(90).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): HttpRule {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseHttpRule } as HttpRule;
+    message.additional_bindings = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.selector = reader.string();
+          break;
+        case 2:
+          message.get = reader.string();
+          break;
+        case 3:
+          message.put = reader.string();
+          break;
+        case 4:
+          message.post = reader.string();
+          break;
+        case 5:
+          message.delete = reader.string();
+          break;
+        case 6:
+          message.patch = reader.string();
+          break;
+        case 8:
+          message.custom = CustomHttpPattern.decode(reader, reader.uint32());
+          break;
+        case 7:
+          message.body = reader.string();
+          break;
+        case 12:
+          message.response_body = reader.string();
+          break;
+        case 11:
+          message.additional_bindings.push(
+            HttpRule.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): HttpRule {
+    const message = { ...baseHttpRule } as HttpRule;
+    message.additional_bindings = [];
+    if (object.selector !== undefined && object.selector !== null) {
+      message.selector = String(object.selector);
+    } else {
+      message.selector = "";
+    }
+    if (object.get !== undefined && object.get !== null) {
+      message.get = String(object.get);
+    } else {
+      message.get = undefined;
+    }
+    if (object.put !== undefined && object.put !== null) {
+      message.put = String(object.put);
+    } else {
+      message.put = undefined;
+    }
+    if (object.post !== undefined && object.post !== null) {
+      message.post = String(object.post);
+    } else {
+      message.post = undefined;
+    }
+    if (object.delete !== undefined && object.delete !== null) {
+      message.delete = String(object.delete);
+    } else {
+      message.delete = undefined;
+    }
+    if (object.patch !== undefined && object.patch !== null) {
+      message.patch = String(object.patch);
+    } else {
+      message.patch = undefined;
+    }
+    if (object.custom !== undefined && object.custom !== null) {
+      message.custom = CustomHttpPattern.fromJSON(object.custom);
+    } else {
+      message.custom = undefined;
+    }
+    if (object.body !== undefined && object.body !== null) {
+      message.body = String(object.body);
+    } else {
+      message.body = "";
+    }
+    if (object.response_body !== undefined && object.response_body !== null) {
+      message.response_body = String(object.response_body);
+    } else {
+      message.response_body = "";
+    }
+    if (
+      object.additional_bindings !== undefined &&
+      object.additional_bindings !== null
+    ) {
+      for (const e of object.additional_bindings) {
+        message.additional_bindings.push(HttpRule.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: HttpRule): unknown {
+    const obj: any = {};
+    message.selector !== undefined && (obj.selector = message.selector);
+    message.get !== undefined && (obj.get = message.get);
+    message.put !== undefined && (obj.put = message.put);
+    message.post !== undefined && (obj.post = message.post);
+    message.delete !== undefined && (obj.delete = message.delete);
+    message.patch !== undefined && (obj.patch = message.patch);
+    message.custom !== undefined &&
+      (obj.custom = message.custom
+        ? CustomHttpPattern.toJSON(message.custom)
+        : undefined);
+    message.body !== undefined && (obj.body = message.body);
+    message.response_body !== undefined &&
+      (obj.response_body = message.response_body);
+    if (message.additional_bindings) {
+      obj.additional_bindings = message.additional_bindings.map((e) =>
+        e ? HttpRule.toJSON(e) : undefined
+      );
+    } else {
+      obj.additional_bindings = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<HttpRule>): HttpRule {
+    const message = { ...baseHttpRule } as HttpRule;
+    message.additional_bindings = [];
+    if (object.selector !== undefined && object.selector !== null) {
+      message.selector = object.selector;
+    } else {
+      message.selector = "";
+    }
+    if (object.get !== undefined && object.get !== null) {
+      message.get = object.get;
+    } else {
+      message.get = undefined;
+    }
+    if (object.put !== undefined && object.put !== null) {
+      message.put = object.put;
+    } else {
+      message.put = undefined;
+    }
+    if (object.post !== undefined && object.post !== null) {
+      message.post = object.post;
+    } else {
+      message.post = undefined;
+    }
+    if (object.delete !== undefined && object.delete !== null) {
+      message.delete = object.delete;
+    } else {
+      message.delete = undefined;
+    }
+    if (object.patch !== undefined && object.patch !== null) {
+      message.patch = object.patch;
+    } else {
+      message.patch = undefined;
+    }
+    if (object.custom !== undefined && object.custom !== null) {
+      message.custom = CustomHttpPattern.fromPartial(object.custom);
+    } else {
+      message.custom = undefined;
+    }
+    if (object.body !== undefined && object.body !== null) {
+      message.body = object.body;
+    } else {
+      message.body = "";
+    }
+    if (object.response_body !== undefined && object.response_body !== null) {
+      message.response_body = object.response_body;
+    } else {
+      message.response_body = "";
+    }
+    if (
+      object.additional_bindings !== undefined &&
+      object.additional_bindings !== null
+    ) {
+      for (const e of object.additional_bindings) {
+        message.additional_bindings.push(HttpRule.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseCustomHttpPattern: object = { kind: "", path: "" };
+
+export const CustomHttpPattern = {
+  encode(message: CustomHttpPattern, writer: Writer = Writer.create()): Writer {
+    if (message.kind !== "") {
+      writer.uint32(10).string(message.kind);
+    }
+    if (message.path !== "") {
+      writer.uint32(18).string(message.path);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): CustomHttpPattern {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseCustomHttpPattern } as CustomHttpPattern;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.kind = reader.string();
+          break;
+        case 2:
+          message.path = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): CustomHttpPattern {
+    const message = { ...baseCustomHttpPattern } as CustomHttpPattern;
+    if (object.kind !== undefined && object.kind !== null) {
+      message.kind = String(object.kind);
+    } else {
+      message.kind = "";
+    }
+    if (object.path !== undefined && object.path !== null) {
+      message.path = String(object.path);
+    } else {
+      message.path = "";
+    }
+    return message;
+  },
+
+  toJSON(message: CustomHttpPattern): unknown {
+    const obj: any = {};
+    message.kind !== undefined && (obj.kind = message.kind);
+    message.path !== undefined && (obj.path = message.path);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<CustomHttpPattern>): CustomHttpPattern {
+    const message = { ...baseCustomHttpPattern } as CustomHttpPattern;
+    if (object.kind !== undefined && object.kind !== null) {
+      message.kind = object.kind;
+    } else {
+      message.kind = "";
+    }
+    if (object.path !== undefined && object.path !== null) {
+      message.path = object.path;
+    } else {
+      message.path = "";
+    }
+    return message;
+  },
+};
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;

+ 5315 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/google/protobuf/descriptor.ts

@@ -0,0 +1,5315 @@
+//@ts-nocheck
+/* eslint-disable */
+import * as Long from "long";
+import { util, configure, Writer, Reader } from "protobufjs/minimal";
+
+export const protobufPackage = "google.protobuf";
+
+/**
+ * The protocol compiler can output a FileDescriptorSet containing the .proto
+ * files it parses.
+ */
+export interface FileDescriptorSet {
+  file: FileDescriptorProto[];
+}
+
+/** Describes a complete .proto file. */
+export interface FileDescriptorProto {
+  /** file name, relative to root of source tree */
+  name: string;
+  /** e.g. "foo", "foo.bar", etc. */
+  package: string;
+  /** Names of files imported by this file. */
+  dependency: string[];
+  /** Indexes of the public imported files in the dependency list above. */
+  public_dependency: number[];
+  /**
+   * Indexes of the weak imported files in the dependency list.
+   * For Google-internal migration only. Do not use.
+   */
+  weak_dependency: number[];
+  /** All top-level definitions in this file. */
+  message_type: DescriptorProto[];
+  enum_type: EnumDescriptorProto[];
+  service: ServiceDescriptorProto[];
+  extension: FieldDescriptorProto[];
+  options: FileOptions | undefined;
+  /**
+   * This field contains optional information about the original source code.
+   * You may safely remove this entire field without harming runtime
+   * functionality of the descriptors -- the information is needed only by
+   * development tools.
+   */
+  source_code_info: SourceCodeInfo | undefined;
+  /**
+   * The syntax of the proto file.
+   * The supported values are "proto2" and "proto3".
+   */
+  syntax: string;
+}
+
+/** Describes a message type. */
+export interface DescriptorProto {
+  name: string;
+  field: FieldDescriptorProto[];
+  extension: FieldDescriptorProto[];
+  nested_type: DescriptorProto[];
+  enum_type: EnumDescriptorProto[];
+  extension_range: DescriptorProto_ExtensionRange[];
+  oneof_decl: OneofDescriptorProto[];
+  options: MessageOptions | undefined;
+  reserved_range: DescriptorProto_ReservedRange[];
+  /**
+   * Reserved field names, which may not be used by fields in the same message.
+   * A given name may only be reserved once.
+   */
+  reserved_name: string[];
+}
+
+export interface DescriptorProto_ExtensionRange {
+  /** Inclusive. */
+  start: number;
+  /** Exclusive. */
+  end: number;
+  options: ExtensionRangeOptions | undefined;
+}
+
+/**
+ * Range of reserved tag numbers. Reserved tag numbers may not be used by
+ * fields or extension ranges in the same message. Reserved ranges may
+ * not overlap.
+ */
+export interface DescriptorProto_ReservedRange {
+  /** Inclusive. */
+  start: number;
+  /** Exclusive. */
+  end: number;
+}
+
+export interface ExtensionRangeOptions {
+  /** The parser stores options it doesn't recognize here. See above. */
+  uninterpreted_option: UninterpretedOption[];
+}
+
+/** Describes a field within a message. */
+export interface FieldDescriptorProto {
+  name: string;
+  number: number;
+  label: FieldDescriptorProto_Label;
+  /**
+   * If type_name is set, this need not be set.  If both this and type_name
+   * are set, this must be one of TYPE_ENUM, TYPE_MESSAGE or TYPE_GROUP.
+   */
+  type: FieldDescriptorProto_Type;
+  /**
+   * For message and enum types, this is the name of the type.  If the name
+   * starts with a '.', it is fully-qualified.  Otherwise, C++-like scoping
+   * rules are used to find the type (i.e. first the nested types within this
+   * message are searched, then within the parent, on up to the root
+   * namespace).
+   */
+  type_name: string;
+  /**
+   * For extensions, this is the name of the type being extended.  It is
+   * resolved in the same manner as type_name.
+   */
+  extendee: string;
+  /**
+   * For numeric types, contains the original text representation of the value.
+   * For booleans, "true" or "false".
+   * For strings, contains the default text contents (not escaped in any way).
+   * For bytes, contains the C escaped value.  All bytes >= 128 are escaped.
+   * TODO(kenton):  Base-64 encode?
+   */
+  default_value: string;
+  /**
+   * If set, gives the index of a oneof in the containing type's oneof_decl
+   * list.  This field is a member of that oneof.
+   */
+  oneof_index: number;
+  /**
+   * JSON name of this field. The value is set by protocol compiler. If the
+   * user has set a "json_name" option on this field, that option's value
+   * will be used. Otherwise, it's deduced from the field's name by converting
+   * it to camelCase.
+   */
+  json_name: string;
+  options: FieldOptions | undefined;
+  /**
+   * If true, this is a proto3 "optional". When a proto3 field is optional, it
+   * tracks presence regardless of field type.
+   *
+   * When proto3_optional is true, this field must be belong to a oneof to
+   * signal to old proto3 clients that presence is tracked for this field. This
+   * oneof is known as a "synthetic" oneof, and this field must be its sole
+   * member (each proto3 optional field gets its own synthetic oneof). Synthetic
+   * oneofs exist in the descriptor only, and do not generate any API. Synthetic
+   * oneofs must be ordered after all "real" oneofs.
+   *
+   * For message fields, proto3_optional doesn't create any semantic change,
+   * since non-repeated message fields always track presence. However it still
+   * indicates the semantic detail of whether the user wrote "optional" or not.
+   * This can be useful for round-tripping the .proto file. For consistency we
+   * give message fields a synthetic oneof also, even though it is not required
+   * to track presence. This is especially important because the parser can't
+   * tell if a field is a message or an enum, so it must always create a
+   * synthetic oneof.
+   *
+   * Proto2 optional fields do not set this flag, because they already indicate
+   * optional with `LABEL_OPTIONAL`.
+   */
+  proto3_optional: boolean;
+}
+
+export enum FieldDescriptorProto_Type {
+  /**
+   * TYPE_DOUBLE - 0 is reserved for errors.
+   * Order is weird for historical reasons.
+   */
+  TYPE_DOUBLE = 1,
+  TYPE_FLOAT = 2,
+  /**
+   * TYPE_INT64 - Not ZigZag encoded.  Negative numbers take 10 bytes.  Use TYPE_SINT64 if
+   * negative values are likely.
+   */
+  TYPE_INT64 = 3,
+  TYPE_UINT64 = 4,
+  /**
+   * TYPE_INT32 - Not ZigZag encoded.  Negative numbers take 10 bytes.  Use TYPE_SINT32 if
+   * negative values are likely.
+   */
+  TYPE_INT32 = 5,
+  TYPE_FIXED64 = 6,
+  TYPE_FIXED32 = 7,
+  TYPE_BOOL = 8,
+  TYPE_STRING = 9,
+  /**
+   * TYPE_GROUP - Tag-delimited aggregate.
+   * Group type is deprecated and not supported in proto3. However, Proto3
+   * implementations should still be able to parse the group wire format and
+   * treat group fields as unknown fields.
+   */
+  TYPE_GROUP = 10,
+  /** TYPE_MESSAGE - Length-delimited aggregate. */
+  TYPE_MESSAGE = 11,
+  /** TYPE_BYTES - New in version 2. */
+  TYPE_BYTES = 12,
+  TYPE_UINT32 = 13,
+  TYPE_ENUM = 14,
+  TYPE_SFIXED32 = 15,
+  TYPE_SFIXED64 = 16,
+  /** TYPE_SINT32 - Uses ZigZag encoding. */
+  TYPE_SINT32 = 17,
+  /** TYPE_SINT64 - Uses ZigZag encoding. */
+  TYPE_SINT64 = 18,
+  UNRECOGNIZED = -1,
+}
+
+export function fieldDescriptorProto_TypeFromJSON(
+  object: any
+): FieldDescriptorProto_Type {
+  switch (object) {
+    case 1:
+    case "TYPE_DOUBLE":
+      return FieldDescriptorProto_Type.TYPE_DOUBLE;
+    case 2:
+    case "TYPE_FLOAT":
+      return FieldDescriptorProto_Type.TYPE_FLOAT;
+    case 3:
+    case "TYPE_INT64":
+      return FieldDescriptorProto_Type.TYPE_INT64;
+    case 4:
+    case "TYPE_UINT64":
+      return FieldDescriptorProto_Type.TYPE_UINT64;
+    case 5:
+    case "TYPE_INT32":
+      return FieldDescriptorProto_Type.TYPE_INT32;
+    case 6:
+    case "TYPE_FIXED64":
+      return FieldDescriptorProto_Type.TYPE_FIXED64;
+    case 7:
+    case "TYPE_FIXED32":
+      return FieldDescriptorProto_Type.TYPE_FIXED32;
+    case 8:
+    case "TYPE_BOOL":
+      return FieldDescriptorProto_Type.TYPE_BOOL;
+    case 9:
+    case "TYPE_STRING":
+      return FieldDescriptorProto_Type.TYPE_STRING;
+    case 10:
+    case "TYPE_GROUP":
+      return FieldDescriptorProto_Type.TYPE_GROUP;
+    case 11:
+    case "TYPE_MESSAGE":
+      return FieldDescriptorProto_Type.TYPE_MESSAGE;
+    case 12:
+    case "TYPE_BYTES":
+      return FieldDescriptorProto_Type.TYPE_BYTES;
+    case 13:
+    case "TYPE_UINT32":
+      return FieldDescriptorProto_Type.TYPE_UINT32;
+    case 14:
+    case "TYPE_ENUM":
+      return FieldDescriptorProto_Type.TYPE_ENUM;
+    case 15:
+    case "TYPE_SFIXED32":
+      return FieldDescriptorProto_Type.TYPE_SFIXED32;
+    case 16:
+    case "TYPE_SFIXED64":
+      return FieldDescriptorProto_Type.TYPE_SFIXED64;
+    case 17:
+    case "TYPE_SINT32":
+      return FieldDescriptorProto_Type.TYPE_SINT32;
+    case 18:
+    case "TYPE_SINT64":
+      return FieldDescriptorProto_Type.TYPE_SINT64;
+    case -1:
+    case "UNRECOGNIZED":
+    default:
+      return FieldDescriptorProto_Type.UNRECOGNIZED;
+  }
+}
+
+export function fieldDescriptorProto_TypeToJSON(
+  object: FieldDescriptorProto_Type
+): string {
+  switch (object) {
+    case FieldDescriptorProto_Type.TYPE_DOUBLE:
+      return "TYPE_DOUBLE";
+    case FieldDescriptorProto_Type.TYPE_FLOAT:
+      return "TYPE_FLOAT";
+    case FieldDescriptorProto_Type.TYPE_INT64:
+      return "TYPE_INT64";
+    case FieldDescriptorProto_Type.TYPE_UINT64:
+      return "TYPE_UINT64";
+    case FieldDescriptorProto_Type.TYPE_INT32:
+      return "TYPE_INT32";
+    case FieldDescriptorProto_Type.TYPE_FIXED64:
+      return "TYPE_FIXED64";
+    case FieldDescriptorProto_Type.TYPE_FIXED32:
+      return "TYPE_FIXED32";
+    case FieldDescriptorProto_Type.TYPE_BOOL:
+      return "TYPE_BOOL";
+    case FieldDescriptorProto_Type.TYPE_STRING:
+      return "TYPE_STRING";
+    case FieldDescriptorProto_Type.TYPE_GROUP:
+      return "TYPE_GROUP";
+    case FieldDescriptorProto_Type.TYPE_MESSAGE:
+      return "TYPE_MESSAGE";
+    case FieldDescriptorProto_Type.TYPE_BYTES:
+      return "TYPE_BYTES";
+    case FieldDescriptorProto_Type.TYPE_UINT32:
+      return "TYPE_UINT32";
+    case FieldDescriptorProto_Type.TYPE_ENUM:
+      return "TYPE_ENUM";
+    case FieldDescriptorProto_Type.TYPE_SFIXED32:
+      return "TYPE_SFIXED32";
+    case FieldDescriptorProto_Type.TYPE_SFIXED64:
+      return "TYPE_SFIXED64";
+    case FieldDescriptorProto_Type.TYPE_SINT32:
+      return "TYPE_SINT32";
+    case FieldDescriptorProto_Type.TYPE_SINT64:
+      return "TYPE_SINT64";
+    default:
+      return "UNKNOWN";
+  }
+}
+
+export enum FieldDescriptorProto_Label {
+  /** LABEL_OPTIONAL - 0 is reserved for errors */
+  LABEL_OPTIONAL = 1,
+  LABEL_REQUIRED = 2,
+  LABEL_REPEATED = 3,
+  UNRECOGNIZED = -1,
+}
+
+export function fieldDescriptorProto_LabelFromJSON(
+  object: any
+): FieldDescriptorProto_Label {
+  switch (object) {
+    case 1:
+    case "LABEL_OPTIONAL":
+      return FieldDescriptorProto_Label.LABEL_OPTIONAL;
+    case 2:
+    case "LABEL_REQUIRED":
+      return FieldDescriptorProto_Label.LABEL_REQUIRED;
+    case 3:
+    case "LABEL_REPEATED":
+      return FieldDescriptorProto_Label.LABEL_REPEATED;
+    case -1:
+    case "UNRECOGNIZED":
+    default:
+      return FieldDescriptorProto_Label.UNRECOGNIZED;
+  }
+}
+
+export function fieldDescriptorProto_LabelToJSON(
+  object: FieldDescriptorProto_Label
+): string {
+  switch (object) {
+    case FieldDescriptorProto_Label.LABEL_OPTIONAL:
+      return "LABEL_OPTIONAL";
+    case FieldDescriptorProto_Label.LABEL_REQUIRED:
+      return "LABEL_REQUIRED";
+    case FieldDescriptorProto_Label.LABEL_REPEATED:
+      return "LABEL_REPEATED";
+    default:
+      return "UNKNOWN";
+  }
+}
+
+/** Describes a oneof. */
+export interface OneofDescriptorProto {
+  name: string;
+  options: OneofOptions | undefined;
+}
+
+/** Describes an enum type. */
+export interface EnumDescriptorProto {
+  name: string;
+  value: EnumValueDescriptorProto[];
+  options: EnumOptions | undefined;
+  /**
+   * Range of reserved numeric values. Reserved numeric values may not be used
+   * by enum values in the same enum declaration. Reserved ranges may not
+   * overlap.
+   */
+  reserved_range: EnumDescriptorProto_EnumReservedRange[];
+  /**
+   * Reserved enum value names, which may not be reused. A given name may only
+   * be reserved once.
+   */
+  reserved_name: string[];
+}
+
+/**
+ * Range of reserved numeric values. Reserved values may not be used by
+ * entries in the same enum. Reserved ranges may not overlap.
+ *
+ * Note that this is distinct from DescriptorProto.ReservedRange in that it
+ * is inclusive such that it can appropriately represent the entire int32
+ * domain.
+ */
+export interface EnumDescriptorProto_EnumReservedRange {
+  /** Inclusive. */
+  start: number;
+  /** Inclusive. */
+  end: number;
+}
+
+/** Describes a value within an enum. */
+export interface EnumValueDescriptorProto {
+  name: string;
+  number: number;
+  options: EnumValueOptions | undefined;
+}
+
+/** Describes a service. */
+export interface ServiceDescriptorProto {
+  name: string;
+  method: MethodDescriptorProto[];
+  options: ServiceOptions | undefined;
+}
+
+/** Describes a method of a service. */
+export interface MethodDescriptorProto {
+  name: string;
+  /**
+   * Input and output type names.  These are resolved in the same way as
+   * FieldDescriptorProto.type_name, but must refer to a message type.
+   */
+  input_type: string;
+  output_type: string;
+  options: MethodOptions | undefined;
+  /** Identifies if client streams multiple client messages */
+  client_streaming: boolean;
+  /** Identifies if server streams multiple server messages */
+  server_streaming: boolean;
+}
+
+export interface FileOptions {
+  /**
+   * Sets the Java package where classes generated from this .proto will be
+   * placed.  By default, the proto package is used, but this is often
+   * inappropriate because proto packages do not normally start with backwards
+   * domain names.
+   */
+  java_package: string;
+  /**
+   * Controls the name of the wrapper Java class generated for the .proto file.
+   * That class will always contain the .proto file's getDescriptor() method as
+   * well as any top-level extensions defined in the .proto file.
+   * If java_multiple_files is disabled, then all the other classes from the
+   * .proto file will be nested inside the single wrapper outer class.
+   */
+  java_outer_classname: string;
+  /**
+   * If enabled, then the Java code generator will generate a separate .java
+   * file for each top-level message, enum, and service defined in the .proto
+   * file.  Thus, these types will *not* be nested inside the wrapper class
+   * named by java_outer_classname.  However, the wrapper class will still be
+   * generated to contain the file's getDescriptor() method as well as any
+   * top-level extensions defined in the file.
+   */
+  java_multiple_files: boolean;
+  /**
+   * This option does nothing.
+   *
+   * @deprecated
+   */
+  java_generate_equals_and_hash: boolean;
+  /**
+   * If set true, then the Java2 code generator will generate code that
+   * throws an exception whenever an attempt is made to assign a non-UTF-8
+   * byte sequence to a string field.
+   * Message reflection will do the same.
+   * However, an extension field still accepts non-UTF-8 byte sequences.
+   * This option has no effect on when used with the lite runtime.
+   */
+  java_string_check_utf8: boolean;
+  optimize_for: FileOptions_OptimizeMode;
+  /**
+   * Sets the Go package where structs generated from this .proto will be
+   * placed. If omitted, the Go package will be derived from the following:
+   *   - The basename of the package import path, if provided.
+   *   - Otherwise, the package statement in the .proto file, if present.
+   *   - Otherwise, the basename of the .proto file, without extension.
+   */
+  go_package: string;
+  /**
+   * Should generic services be generated in each language?  "Generic" services
+   * are not specific to any particular RPC system.  They are generated by the
+   * main code generators in each language (without additional plugins).
+   * Generic services were the only kind of service generation supported by
+   * early versions of google.protobuf.
+   *
+   * Generic services are now considered deprecated in favor of using plugins
+   * that generate code specific to your particular RPC system.  Therefore,
+   * these default to false.  Old code which depends on generic services should
+   * explicitly set them to true.
+   */
+  cc_generic_services: boolean;
+  java_generic_services: boolean;
+  py_generic_services: boolean;
+  php_generic_services: boolean;
+  /**
+   * Is this file deprecated?
+   * Depending on the target platform, this can emit Deprecated annotations
+   * for everything in the file, or it will be completely ignored; in the very
+   * least, this is a formalization for deprecating files.
+   */
+  deprecated: boolean;
+  /**
+   * Enables the use of arenas for the proto messages in this file. This applies
+   * only to generated classes for C++.
+   */
+  cc_enable_arenas: boolean;
+  /**
+   * Sets the objective c class prefix which is prepended to all objective c
+   * generated classes from this .proto. There is no default.
+   */
+  objc_class_prefix: string;
+  /** Namespace for generated classes; defaults to the package. */
+  csharp_namespace: string;
+  /**
+   * By default Swift generators will take the proto package and CamelCase it
+   * replacing '.' with underscore and use that to prefix the types/symbols
+   * defined. When this options is provided, they will use this value instead
+   * to prefix the types/symbols defined.
+   */
+  swift_prefix: string;
+  /**
+   * Sets the php class prefix which is prepended to all php generated classes
+   * from this .proto. Default is empty.
+   */
+  php_class_prefix: string;
+  /**
+   * Use this option to change the namespace of php generated classes. Default
+   * is empty. When this option is empty, the package name will be used for
+   * determining the namespace.
+   */
+  php_namespace: string;
+  /**
+   * Use this option to change the namespace of php generated metadata classes.
+   * Default is empty. When this option is empty, the proto file name will be
+   * used for determining the namespace.
+   */
+  php_metadata_namespace: string;
+  /**
+   * Use this option to change the package of ruby generated classes. Default
+   * is empty. When this option is not set, the package name will be used for
+   * determining the ruby package.
+   */
+  ruby_package: string;
+  /**
+   * The parser stores options it doesn't recognize here.
+   * See the documentation for the "Options" section above.
+   */
+  uninterpreted_option: UninterpretedOption[];
+}
+
+/** Generated classes can be optimized for speed or code size. */
+export enum FileOptions_OptimizeMode {
+  /** SPEED - Generate complete code for parsing, serialization, */
+  SPEED = 1,
+  /** CODE_SIZE - etc. */
+  CODE_SIZE = 2,
+  /** LITE_RUNTIME - Generate code using MessageLite and the lite runtime. */
+  LITE_RUNTIME = 3,
+  UNRECOGNIZED = -1,
+}
+
+export function fileOptions_OptimizeModeFromJSON(
+  object: any
+): FileOptions_OptimizeMode {
+  switch (object) {
+    case 1:
+    case "SPEED":
+      return FileOptions_OptimizeMode.SPEED;
+    case 2:
+    case "CODE_SIZE":
+      return FileOptions_OptimizeMode.CODE_SIZE;
+    case 3:
+    case "LITE_RUNTIME":
+      return FileOptions_OptimizeMode.LITE_RUNTIME;
+    case -1:
+    case "UNRECOGNIZED":
+    default:
+      return FileOptions_OptimizeMode.UNRECOGNIZED;
+  }
+}
+
+export function fileOptions_OptimizeModeToJSON(
+  object: FileOptions_OptimizeMode
+): string {
+  switch (object) {
+    case FileOptions_OptimizeMode.SPEED:
+      return "SPEED";
+    case FileOptions_OptimizeMode.CODE_SIZE:
+      return "CODE_SIZE";
+    case FileOptions_OptimizeMode.LITE_RUNTIME:
+      return "LITE_RUNTIME";
+    default:
+      return "UNKNOWN";
+  }
+}
+
+export interface MessageOptions {
+  /**
+   * Set true to use the old proto1 MessageSet wire format for extensions.
+   * This is provided for backwards-compatibility with the MessageSet wire
+   * format.  You should not use this for any other reason:  It's less
+   * efficient, has fewer features, and is more complicated.
+   *
+   * The message must be defined exactly as follows:
+   *   message Foo {
+   *     option message_set_wire_format = true;
+   *     extensions 4 to max;
+   *   }
+   * Note that the message cannot have any defined fields; MessageSets only
+   * have extensions.
+   *
+   * All extensions of your type must be singular messages; e.g. they cannot
+   * be int32s, enums, or repeated messages.
+   *
+   * Because this is an option, the above two restrictions are not enforced by
+   * the protocol compiler.
+   */
+  message_set_wire_format: boolean;
+  /**
+   * Disables the generation of the standard "descriptor()" accessor, which can
+   * conflict with a field of the same name.  This is meant to make migration
+   * from proto1 easier; new code should avoid fields named "descriptor".
+   */
+  no_standard_descriptor_accessor: boolean;
+  /**
+   * Is this message deprecated?
+   * Depending on the target platform, this can emit Deprecated annotations
+   * for the message, or it will be completely ignored; in the very least,
+   * this is a formalization for deprecating messages.
+   */
+  deprecated: boolean;
+  /**
+   * Whether the message is an automatically generated map entry type for the
+   * maps field.
+   *
+   * For maps fields:
+   *     map<KeyType, ValueType> map_field = 1;
+   * The parsed descriptor looks like:
+   *     message MapFieldEntry {
+   *         option map_entry = true;
+   *         optional KeyType key = 1;
+   *         optional ValueType value = 2;
+   *     }
+   *     repeated MapFieldEntry map_field = 1;
+   *
+   * Implementations may choose not to generate the map_entry=true message, but
+   * use a native map in the target language to hold the keys and values.
+   * The reflection APIs in such implementations still need to work as
+   * if the field is a repeated message field.
+   *
+   * NOTE: Do not set the option in .proto files. Always use the maps syntax
+   * instead. The option should only be implicitly set by the proto compiler
+   * parser.
+   */
+  map_entry: boolean;
+  /** The parser stores options it doesn't recognize here. See above. */
+  uninterpreted_option: UninterpretedOption[];
+}
+
+export interface FieldOptions {
+  /**
+   * The ctype option instructs the C++ code generator to use a different
+   * representation of the field than it normally would.  See the specific
+   * options below.  This option is not yet implemented in the open source
+   * release -- sorry, we'll try to include it in a future version!
+   */
+  ctype: FieldOptions_CType;
+  /**
+   * The packed option can be enabled for repeated primitive fields to enable
+   * a more efficient representation on the wire. Rather than repeatedly
+   * writing the tag and type for each element, the entire array is encoded as
+   * a single length-delimited blob. In proto3, only explicit setting it to
+   * false will avoid using packed encoding.
+   */
+  packed: boolean;
+  /**
+   * The jstype option determines the JavaScript type used for values of the
+   * field.  The option is permitted only for 64 bit integral and fixed types
+   * (int64, uint64, sint64, fixed64, sfixed64).  A field with jstype JS_STRING
+   * is represented as JavaScript string, which avoids loss of precision that
+   * can happen when a large value is converted to a floating point JavaScript.
+   * Specifying JS_NUMBER for the jstype causes the generated JavaScript code to
+   * use the JavaScript "number" type.  The behavior of the default option
+   * JS_NORMAL is implementation dependent.
+   *
+   * This option is an enum to permit additional types to be added, e.g.
+   * goog.math.Integer.
+   */
+  jstype: FieldOptions_JSType;
+  /**
+   * Should this field be parsed lazily?  Lazy applies only to message-type
+   * fields.  It means that when the outer message is initially parsed, the
+   * inner message's contents will not be parsed but instead stored in encoded
+   * form.  The inner message will actually be parsed when it is first accessed.
+   *
+   * This is only a hint.  Implementations are free to choose whether to use
+   * eager or lazy parsing regardless of the value of this option.  However,
+   * setting this option true suggests that the protocol author believes that
+   * using lazy parsing on this field is worth the additional bookkeeping
+   * overhead typically needed to implement it.
+   *
+   * This option does not affect the public interface of any generated code;
+   * all method signatures remain the same.  Furthermore, thread-safety of the
+   * interface is not affected by this option; const methods remain safe to
+   * call from multiple threads concurrently, while non-const methods continue
+   * to require exclusive access.
+   *
+   *
+   * Note that implementations may choose not to check required fields within
+   * a lazy sub-message.  That is, calling IsInitialized() on the outer message
+   * may return true even if the inner message has missing required fields.
+   * This is necessary because otherwise the inner message would have to be
+   * parsed in order to perform the check, defeating the purpose of lazy
+   * parsing.  An implementation which chooses not to check required fields
+   * must be consistent about it.  That is, for any particular sub-message, the
+   * implementation must either *always* check its required fields, or *never*
+   * check its required fields, regardless of whether or not the message has
+   * been parsed.
+   */
+  lazy: boolean;
+  /**
+   * Is this field deprecated?
+   * Depending on the target platform, this can emit Deprecated annotations
+   * for accessors, or it will be completely ignored; in the very least, this
+   * is a formalization for deprecating fields.
+   */
+  deprecated: boolean;
+  /** For Google-internal migration only. Do not use. */
+  weak: boolean;
+  /** The parser stores options it doesn't recognize here. See above. */
+  uninterpreted_option: UninterpretedOption[];
+}
+
+export enum FieldOptions_CType {
+  /** STRING - Default mode. */
+  STRING = 0,
+  CORD = 1,
+  STRING_PIECE = 2,
+  UNRECOGNIZED = -1,
+}
+
+export function fieldOptions_CTypeFromJSON(object: any): FieldOptions_CType {
+  switch (object) {
+    case 0:
+    case "STRING":
+      return FieldOptions_CType.STRING;
+    case 1:
+    case "CORD":
+      return FieldOptions_CType.CORD;
+    case 2:
+    case "STRING_PIECE":
+      return FieldOptions_CType.STRING_PIECE;
+    case -1:
+    case "UNRECOGNIZED":
+    default:
+      return FieldOptions_CType.UNRECOGNIZED;
+  }
+}
+
+export function fieldOptions_CTypeToJSON(object: FieldOptions_CType): string {
+  switch (object) {
+    case FieldOptions_CType.STRING:
+      return "STRING";
+    case FieldOptions_CType.CORD:
+      return "CORD";
+    case FieldOptions_CType.STRING_PIECE:
+      return "STRING_PIECE";
+    default:
+      return "UNKNOWN";
+  }
+}
+
+export enum FieldOptions_JSType {
+  /** JS_NORMAL - Use the default type. */
+  JS_NORMAL = 0,
+  /** JS_STRING - Use JavaScript strings. */
+  JS_STRING = 1,
+  /** JS_NUMBER - Use JavaScript numbers. */
+  JS_NUMBER = 2,
+  UNRECOGNIZED = -1,
+}
+
+export function fieldOptions_JSTypeFromJSON(object: any): FieldOptions_JSType {
+  switch (object) {
+    case 0:
+    case "JS_NORMAL":
+      return FieldOptions_JSType.JS_NORMAL;
+    case 1:
+    case "JS_STRING":
+      return FieldOptions_JSType.JS_STRING;
+    case 2:
+    case "JS_NUMBER":
+      return FieldOptions_JSType.JS_NUMBER;
+    case -1:
+    case "UNRECOGNIZED":
+    default:
+      return FieldOptions_JSType.UNRECOGNIZED;
+  }
+}
+
+export function fieldOptions_JSTypeToJSON(object: FieldOptions_JSType): string {
+  switch (object) {
+    case FieldOptions_JSType.JS_NORMAL:
+      return "JS_NORMAL";
+    case FieldOptions_JSType.JS_STRING:
+      return "JS_STRING";
+    case FieldOptions_JSType.JS_NUMBER:
+      return "JS_NUMBER";
+    default:
+      return "UNKNOWN";
+  }
+}
+
+export interface OneofOptions {
+  /** The parser stores options it doesn't recognize here. See above. */
+  uninterpreted_option: UninterpretedOption[];
+}
+
+export interface EnumOptions {
+  /**
+   * Set this option to true to allow mapping different tag names to the same
+   * value.
+   */
+  allow_alias: boolean;
+  /**
+   * Is this enum deprecated?
+   * Depending on the target platform, this can emit Deprecated annotations
+   * for the enum, or it will be completely ignored; in the very least, this
+   * is a formalization for deprecating enums.
+   */
+  deprecated: boolean;
+  /** The parser stores options it doesn't recognize here. See above. */
+  uninterpreted_option: UninterpretedOption[];
+}
+
+export interface EnumValueOptions {
+  /**
+   * Is this enum value deprecated?
+   * Depending on the target platform, this can emit Deprecated annotations
+   * for the enum value, or it will be completely ignored; in the very least,
+   * this is a formalization for deprecating enum values.
+   */
+  deprecated: boolean;
+  /** The parser stores options it doesn't recognize here. See above. */
+  uninterpreted_option: UninterpretedOption[];
+}
+
+export interface ServiceOptions {
+  /**
+   * Is this service deprecated?
+   * Depending on the target platform, this can emit Deprecated annotations
+   * for the service, or it will be completely ignored; in the very least,
+   * this is a formalization for deprecating services.
+   */
+  deprecated: boolean;
+  /** The parser stores options it doesn't recognize here. See above. */
+  uninterpreted_option: UninterpretedOption[];
+}
+
+export interface MethodOptions {
+  /**
+   * Is this method deprecated?
+   * Depending on the target platform, this can emit Deprecated annotations
+   * for the method, or it will be completely ignored; in the very least,
+   * this is a formalization for deprecating methods.
+   */
+  deprecated: boolean;
+  idempotency_level: MethodOptions_IdempotencyLevel;
+  /** The parser stores options it doesn't recognize here. See above. */
+  uninterpreted_option: UninterpretedOption[];
+}
+
+/**
+ * Is this method side-effect-free (or safe in HTTP parlance), or idempotent,
+ * or neither? HTTP based RPC implementation may choose GET verb for safe
+ * methods, and PUT verb for idempotent methods instead of the default POST.
+ */
+export enum MethodOptions_IdempotencyLevel {
+  IDEMPOTENCY_UNKNOWN = 0,
+  /** NO_SIDE_EFFECTS - implies idempotent */
+  NO_SIDE_EFFECTS = 1,
+  /** IDEMPOTENT - idempotent, but may have side effects */
+  IDEMPOTENT = 2,
+  UNRECOGNIZED = -1,
+}
+
+export function methodOptions_IdempotencyLevelFromJSON(
+  object: any
+): MethodOptions_IdempotencyLevel {
+  switch (object) {
+    case 0:
+    case "IDEMPOTENCY_UNKNOWN":
+      return MethodOptions_IdempotencyLevel.IDEMPOTENCY_UNKNOWN;
+    case 1:
+    case "NO_SIDE_EFFECTS":
+      return MethodOptions_IdempotencyLevel.NO_SIDE_EFFECTS;
+    case 2:
+    case "IDEMPOTENT":
+      return MethodOptions_IdempotencyLevel.IDEMPOTENT;
+    case -1:
+    case "UNRECOGNIZED":
+    default:
+      return MethodOptions_IdempotencyLevel.UNRECOGNIZED;
+  }
+}
+
+export function methodOptions_IdempotencyLevelToJSON(
+  object: MethodOptions_IdempotencyLevel
+): string {
+  switch (object) {
+    case MethodOptions_IdempotencyLevel.IDEMPOTENCY_UNKNOWN:
+      return "IDEMPOTENCY_UNKNOWN";
+    case MethodOptions_IdempotencyLevel.NO_SIDE_EFFECTS:
+      return "NO_SIDE_EFFECTS";
+    case MethodOptions_IdempotencyLevel.IDEMPOTENT:
+      return "IDEMPOTENT";
+    default:
+      return "UNKNOWN";
+  }
+}
+
+/**
+ * A message representing a option the parser does not recognize. This only
+ * appears in options protos created by the compiler::Parser class.
+ * DescriptorPool resolves these when building Descriptor objects. Therefore,
+ * options protos in descriptor objects (e.g. returned by Descriptor::options(),
+ * or produced by Descriptor::CopyTo()) will never have UninterpretedOptions
+ * in them.
+ */
+export interface UninterpretedOption {
+  name: UninterpretedOption_NamePart[];
+  /**
+   * The value of the uninterpreted option, in whatever type the tokenizer
+   * identified it as during parsing. Exactly one of these should be set.
+   */
+  identifier_value: string;
+  positive_int_value: number;
+  negative_int_value: number;
+  double_value: number;
+  string_value: Uint8Array;
+  aggregate_value: string;
+}
+
+/**
+ * The name of the uninterpreted option.  Each string represents a segment in
+ * a dot-separated name.  is_extension is true iff a segment represents an
+ * extension (denoted with parentheses in options specs in .proto files).
+ * E.g.,{ ["foo", false], ["bar.baz", true], ["qux", false] } represents
+ * "foo.(bar.baz).qux".
+ */
+export interface UninterpretedOption_NamePart {
+  name_part: string;
+  is_extension: boolean;
+}
+
+/**
+ * Encapsulates information about the original source file from which a
+ * FileDescriptorProto was generated.
+ */
+export interface SourceCodeInfo {
+  /**
+   * A Location identifies a piece of source code in a .proto file which
+   * corresponds to a particular definition.  This information is intended
+   * to be useful to IDEs, code indexers, documentation generators, and similar
+   * tools.
+   *
+   * For example, say we have a file like:
+   *   message Foo {
+   *     optional string foo = 1;
+   *   }
+   * Let's look at just the field definition:
+   *   optional string foo = 1;
+   *   ^       ^^     ^^  ^  ^^^
+   *   a       bc     de  f  ghi
+   * We have the following locations:
+   *   span   path               represents
+   *   [a,i)  [ 4, 0, 2, 0 ]     The whole field definition.
+   *   [a,b)  [ 4, 0, 2, 0, 4 ]  The label (optional).
+   *   [c,d)  [ 4, 0, 2, 0, 5 ]  The type (string).
+   *   [e,f)  [ 4, 0, 2, 0, 1 ]  The name (foo).
+   *   [g,h)  [ 4, 0, 2, 0, 3 ]  The number (1).
+   *
+   * Notes:
+   * - A location may refer to a repeated field itself (i.e. not to any
+   *   particular index within it).  This is used whenever a set of elements are
+   *   logically enclosed in a single code segment.  For example, an entire
+   *   extend block (possibly containing multiple extension definitions) will
+   *   have an outer location whose path refers to the "extensions" repeated
+   *   field without an index.
+   * - Multiple locations may have the same path.  This happens when a single
+   *   logical declaration is spread out across multiple places.  The most
+   *   obvious example is the "extend" block again -- there may be multiple
+   *   extend blocks in the same scope, each of which will have the same path.
+   * - A location's span is not always a subset of its parent's span.  For
+   *   example, the "extendee" of an extension declaration appears at the
+   *   beginning of the "extend" block and is shared by all extensions within
+   *   the block.
+   * - Just because a location's span is a subset of some other location's span
+   *   does not mean that it is a descendant.  For example, a "group" defines
+   *   both a type and a field in a single declaration.  Thus, the locations
+   *   corresponding to the type and field and their components will overlap.
+   * - Code which tries to interpret locations should probably be designed to
+   *   ignore those that it doesn't understand, as more types of locations could
+   *   be recorded in the future.
+   */
+  location: SourceCodeInfo_Location[];
+}
+
+export interface SourceCodeInfo_Location {
+  /**
+   * Identifies which part of the FileDescriptorProto was defined at this
+   * location.
+   *
+   * Each element is a field number or an index.  They form a path from
+   * the root FileDescriptorProto to the place where the definition.  For
+   * example, this path:
+   *   [ 4, 3, 2, 7, 1 ]
+   * refers to:
+   *   file.message_type(3)  // 4, 3
+   *       .field(7)         // 2, 7
+   *       .name()           // 1
+   * This is because FileDescriptorProto.message_type has field number 4:
+   *   repeated DescriptorProto message_type = 4;
+   * and DescriptorProto.field has field number 2:
+   *   repeated FieldDescriptorProto field = 2;
+   * and FieldDescriptorProto.name has field number 1:
+   *   optional string name = 1;
+   *
+   * Thus, the above path gives the location of a field name.  If we removed
+   * the last element:
+   *   [ 4, 3, 2, 7 ]
+   * this path refers to the whole field declaration (from the beginning
+   * of the label to the terminating semicolon).
+   */
+  path: number[];
+  /**
+   * Always has exactly three or four elements: start line, start column,
+   * end line (optional, otherwise assumed same as start line), end column.
+   * These are packed into a single field for efficiency.  Note that line
+   * and column numbers are zero-based -- typically you will want to add
+   * 1 to each before displaying to a user.
+   */
+  span: number[];
+  /**
+   * If this SourceCodeInfo represents a complete declaration, these are any
+   * comments appearing before and after the declaration which appear to be
+   * attached to the declaration.
+   *
+   * A series of line comments appearing on consecutive lines, with no other
+   * tokens appearing on those lines, will be treated as a single comment.
+   *
+   * leading_detached_comments will keep paragraphs of comments that appear
+   * before (but not connected to) the current element. Each paragraph,
+   * separated by empty lines, will be one comment element in the repeated
+   * field.
+   *
+   * Only the comment content is provided; comment markers (e.g. //) are
+   * stripped out.  For block comments, leading whitespace and an asterisk
+   * will be stripped from the beginning of each line other than the first.
+   * Newlines are included in the output.
+   *
+   * Examples:
+   *
+   *   optional int32 foo = 1;  // Comment attached to foo.
+   *   // Comment attached to bar.
+   *   optional int32 bar = 2;
+   *
+   *   optional string baz = 3;
+   *   // Comment attached to baz.
+   *   // Another line attached to baz.
+   *
+   *   // Comment attached to qux.
+   *   //
+   *   // Another line attached to qux.
+   *   optional double qux = 4;
+   *
+   *   // Detached comment for corge. This is not leading or trailing comments
+   *   // to qux or corge because there are blank lines separating it from
+   *   // both.
+   *
+   *   // Detached comment for corge paragraph 2.
+   *
+   *   optional string corge = 5;
+   *   /* Block comment attached
+   *    * to corge.  Leading asterisks
+   *    * will be removed. * /
+   *   /* Block comment attached to
+   *    * grault. * /
+   *   optional int32 grault = 6;
+   *
+   *   // ignored detached comments.
+   */
+  leading_comments: string;
+  trailing_comments: string;
+  leading_detached_comments: string[];
+}
+
+/**
+ * Describes the relationship between generated code and its original source
+ * file. A GeneratedCodeInfo message is associated with only one generated
+ * source file, but may contain references to different source .proto files.
+ */
+export interface GeneratedCodeInfo {
+  /**
+   * An Annotation connects some span of text in generated code to an element
+   * of its generating .proto file.
+   */
+  annotation: GeneratedCodeInfo_Annotation[];
+}
+
+export interface GeneratedCodeInfo_Annotation {
+  /**
+   * Identifies the element in the original source .proto file. This field
+   * is formatted the same as SourceCodeInfo.Location.path.
+   */
+  path: number[];
+  /** Identifies the filesystem path to the original source .proto. */
+  source_file: string;
+  /**
+   * Identifies the starting offset in bytes in the generated code
+   * that relates to the identified object.
+   */
+  begin: number;
+  /**
+   * Identifies the ending offset in bytes in the generated code that
+   * relates to the identified offset. The end offset should be one past
+   * the last relevant byte (so the length of the text = end - begin).
+   */
+  end: number;
+}
+
+const baseFileDescriptorSet: object = {};
+
+export const FileDescriptorSet = {
+  encode(message: FileDescriptorSet, writer: Writer = Writer.create()): Writer {
+    for (const v of message.file) {
+      FileDescriptorProto.encode(v!, writer.uint32(10).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): FileDescriptorSet {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseFileDescriptorSet } as FileDescriptorSet;
+    message.file = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.file.push(
+            FileDescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): FileDescriptorSet {
+    const message = { ...baseFileDescriptorSet } as FileDescriptorSet;
+    message.file = [];
+    if (object.file !== undefined && object.file !== null) {
+      for (const e of object.file) {
+        message.file.push(FileDescriptorProto.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: FileDescriptorSet): unknown {
+    const obj: any = {};
+    if (message.file) {
+      obj.file = message.file.map((e) =>
+        e ? FileDescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.file = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<FileDescriptorSet>): FileDescriptorSet {
+    const message = { ...baseFileDescriptorSet } as FileDescriptorSet;
+    message.file = [];
+    if (object.file !== undefined && object.file !== null) {
+      for (const e of object.file) {
+        message.file.push(FileDescriptorProto.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseFileDescriptorProto: object = {
+  name: "",
+  package: "",
+  dependency: "",
+  public_dependency: 0,
+  weak_dependency: 0,
+  syntax: "",
+};
+
+export const FileDescriptorProto = {
+  encode(
+    message: FileDescriptorProto,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.name !== "") {
+      writer.uint32(10).string(message.name);
+    }
+    if (message.package !== "") {
+      writer.uint32(18).string(message.package);
+    }
+    for (const v of message.dependency) {
+      writer.uint32(26).string(v!);
+    }
+    writer.uint32(82).fork();
+    for (const v of message.public_dependency) {
+      writer.int32(v);
+    }
+    writer.ldelim();
+    writer.uint32(90).fork();
+    for (const v of message.weak_dependency) {
+      writer.int32(v);
+    }
+    writer.ldelim();
+    for (const v of message.message_type) {
+      DescriptorProto.encode(v!, writer.uint32(34).fork()).ldelim();
+    }
+    for (const v of message.enum_type) {
+      EnumDescriptorProto.encode(v!, writer.uint32(42).fork()).ldelim();
+    }
+    for (const v of message.service) {
+      ServiceDescriptorProto.encode(v!, writer.uint32(50).fork()).ldelim();
+    }
+    for (const v of message.extension) {
+      FieldDescriptorProto.encode(v!, writer.uint32(58).fork()).ldelim();
+    }
+    if (message.options !== undefined) {
+      FileOptions.encode(message.options, writer.uint32(66).fork()).ldelim();
+    }
+    if (message.source_code_info !== undefined) {
+      SourceCodeInfo.encode(
+        message.source_code_info,
+        writer.uint32(74).fork()
+      ).ldelim();
+    }
+    if (message.syntax !== "") {
+      writer.uint32(98).string(message.syntax);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): FileDescriptorProto {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseFileDescriptorProto } as FileDescriptorProto;
+    message.dependency = [];
+    message.public_dependency = [];
+    message.weak_dependency = [];
+    message.message_type = [];
+    message.enum_type = [];
+    message.service = [];
+    message.extension = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.name = reader.string();
+          break;
+        case 2:
+          message.package = reader.string();
+          break;
+        case 3:
+          message.dependency.push(reader.string());
+          break;
+        case 10:
+          if ((tag & 7) === 2) {
+            const end2 = reader.uint32() + reader.pos;
+            while (reader.pos < end2) {
+              message.public_dependency.push(reader.int32());
+            }
+          } else {
+            message.public_dependency.push(reader.int32());
+          }
+          break;
+        case 11:
+          if ((tag & 7) === 2) {
+            const end2 = reader.uint32() + reader.pos;
+            while (reader.pos < end2) {
+              message.weak_dependency.push(reader.int32());
+            }
+          } else {
+            message.weak_dependency.push(reader.int32());
+          }
+          break;
+        case 4:
+          message.message_type.push(
+            DescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 5:
+          message.enum_type.push(
+            EnumDescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 6:
+          message.service.push(
+            ServiceDescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 7:
+          message.extension.push(
+            FieldDescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 8:
+          message.options = FileOptions.decode(reader, reader.uint32());
+          break;
+        case 9:
+          message.source_code_info = SourceCodeInfo.decode(
+            reader,
+            reader.uint32()
+          );
+          break;
+        case 12:
+          message.syntax = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): FileDescriptorProto {
+    const message = { ...baseFileDescriptorProto } as FileDescriptorProto;
+    message.dependency = [];
+    message.public_dependency = [];
+    message.weak_dependency = [];
+    message.message_type = [];
+    message.enum_type = [];
+    message.service = [];
+    message.extension = [];
+    if (object.name !== undefined && object.name !== null) {
+      message.name = String(object.name);
+    } else {
+      message.name = "";
+    }
+    if (object.package !== undefined && object.package !== null) {
+      message.package = String(object.package);
+    } else {
+      message.package = "";
+    }
+    if (object.dependency !== undefined && object.dependency !== null) {
+      for (const e of object.dependency) {
+        message.dependency.push(String(e));
+      }
+    }
+    if (
+      object.public_dependency !== undefined &&
+      object.public_dependency !== null
+    ) {
+      for (const e of object.public_dependency) {
+        message.public_dependency.push(Number(e));
+      }
+    }
+    if (
+      object.weak_dependency !== undefined &&
+      object.weak_dependency !== null
+    ) {
+      for (const e of object.weak_dependency) {
+        message.weak_dependency.push(Number(e));
+      }
+    }
+    if (object.message_type !== undefined && object.message_type !== null) {
+      for (const e of object.message_type) {
+        message.message_type.push(DescriptorProto.fromJSON(e));
+      }
+    }
+    if (object.enum_type !== undefined && object.enum_type !== null) {
+      for (const e of object.enum_type) {
+        message.enum_type.push(EnumDescriptorProto.fromJSON(e));
+      }
+    }
+    if (object.service !== undefined && object.service !== null) {
+      for (const e of object.service) {
+        message.service.push(ServiceDescriptorProto.fromJSON(e));
+      }
+    }
+    if (object.extension !== undefined && object.extension !== null) {
+      for (const e of object.extension) {
+        message.extension.push(FieldDescriptorProto.fromJSON(e));
+      }
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = FileOptions.fromJSON(object.options);
+    } else {
+      message.options = undefined;
+    }
+    if (
+      object.source_code_info !== undefined &&
+      object.source_code_info !== null
+    ) {
+      message.source_code_info = SourceCodeInfo.fromJSON(
+        object.source_code_info
+      );
+    } else {
+      message.source_code_info = undefined;
+    }
+    if (object.syntax !== undefined && object.syntax !== null) {
+      message.syntax = String(object.syntax);
+    } else {
+      message.syntax = "";
+    }
+    return message;
+  },
+
+  toJSON(message: FileDescriptorProto): unknown {
+    const obj: any = {};
+    message.name !== undefined && (obj.name = message.name);
+    message.package !== undefined && (obj.package = message.package);
+    if (message.dependency) {
+      obj.dependency = message.dependency.map((e) => e);
+    } else {
+      obj.dependency = [];
+    }
+    if (message.public_dependency) {
+      obj.public_dependency = message.public_dependency.map((e) => e);
+    } else {
+      obj.public_dependency = [];
+    }
+    if (message.weak_dependency) {
+      obj.weak_dependency = message.weak_dependency.map((e) => e);
+    } else {
+      obj.weak_dependency = [];
+    }
+    if (message.message_type) {
+      obj.message_type = message.message_type.map((e) =>
+        e ? DescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.message_type = [];
+    }
+    if (message.enum_type) {
+      obj.enum_type = message.enum_type.map((e) =>
+        e ? EnumDescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.enum_type = [];
+    }
+    if (message.service) {
+      obj.service = message.service.map((e) =>
+        e ? ServiceDescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.service = [];
+    }
+    if (message.extension) {
+      obj.extension = message.extension.map((e) =>
+        e ? FieldDescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.extension = [];
+    }
+    message.options !== undefined &&
+      (obj.options = message.options
+        ? FileOptions.toJSON(message.options)
+        : undefined);
+    message.source_code_info !== undefined &&
+      (obj.source_code_info = message.source_code_info
+        ? SourceCodeInfo.toJSON(message.source_code_info)
+        : undefined);
+    message.syntax !== undefined && (obj.syntax = message.syntax);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<FileDescriptorProto>): FileDescriptorProto {
+    const message = { ...baseFileDescriptorProto } as FileDescriptorProto;
+    message.dependency = [];
+    message.public_dependency = [];
+    message.weak_dependency = [];
+    message.message_type = [];
+    message.enum_type = [];
+    message.service = [];
+    message.extension = [];
+    if (object.name !== undefined && object.name !== null) {
+      message.name = object.name;
+    } else {
+      message.name = "";
+    }
+    if (object.package !== undefined && object.package !== null) {
+      message.package = object.package;
+    } else {
+      message.package = "";
+    }
+    if (object.dependency !== undefined && object.dependency !== null) {
+      for (const e of object.dependency) {
+        message.dependency.push(e);
+      }
+    }
+    if (
+      object.public_dependency !== undefined &&
+      object.public_dependency !== null
+    ) {
+      for (const e of object.public_dependency) {
+        message.public_dependency.push(e);
+      }
+    }
+    if (
+      object.weak_dependency !== undefined &&
+      object.weak_dependency !== null
+    ) {
+      for (const e of object.weak_dependency) {
+        message.weak_dependency.push(e);
+      }
+    }
+    if (object.message_type !== undefined && object.message_type !== null) {
+      for (const e of object.message_type) {
+        message.message_type.push(DescriptorProto.fromPartial(e));
+      }
+    }
+    if (object.enum_type !== undefined && object.enum_type !== null) {
+      for (const e of object.enum_type) {
+        message.enum_type.push(EnumDescriptorProto.fromPartial(e));
+      }
+    }
+    if (object.service !== undefined && object.service !== null) {
+      for (const e of object.service) {
+        message.service.push(ServiceDescriptorProto.fromPartial(e));
+      }
+    }
+    if (object.extension !== undefined && object.extension !== null) {
+      for (const e of object.extension) {
+        message.extension.push(FieldDescriptorProto.fromPartial(e));
+      }
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = FileOptions.fromPartial(object.options);
+    } else {
+      message.options = undefined;
+    }
+    if (
+      object.source_code_info !== undefined &&
+      object.source_code_info !== null
+    ) {
+      message.source_code_info = SourceCodeInfo.fromPartial(
+        object.source_code_info
+      );
+    } else {
+      message.source_code_info = undefined;
+    }
+    if (object.syntax !== undefined && object.syntax !== null) {
+      message.syntax = object.syntax;
+    } else {
+      message.syntax = "";
+    }
+    return message;
+  },
+};
+
+const baseDescriptorProto: object = { name: "", reserved_name: "" };
+
+export const DescriptorProto = {
+  encode(message: DescriptorProto, writer: Writer = Writer.create()): Writer {
+    if (message.name !== "") {
+      writer.uint32(10).string(message.name);
+    }
+    for (const v of message.field) {
+      FieldDescriptorProto.encode(v!, writer.uint32(18).fork()).ldelim();
+    }
+    for (const v of message.extension) {
+      FieldDescriptorProto.encode(v!, writer.uint32(50).fork()).ldelim();
+    }
+    for (const v of message.nested_type) {
+      DescriptorProto.encode(v!, writer.uint32(26).fork()).ldelim();
+    }
+    for (const v of message.enum_type) {
+      EnumDescriptorProto.encode(v!, writer.uint32(34).fork()).ldelim();
+    }
+    for (const v of message.extension_range) {
+      DescriptorProto_ExtensionRange.encode(
+        v!,
+        writer.uint32(42).fork()
+      ).ldelim();
+    }
+    for (const v of message.oneof_decl) {
+      OneofDescriptorProto.encode(v!, writer.uint32(66).fork()).ldelim();
+    }
+    if (message.options !== undefined) {
+      MessageOptions.encode(message.options, writer.uint32(58).fork()).ldelim();
+    }
+    for (const v of message.reserved_range) {
+      DescriptorProto_ReservedRange.encode(
+        v!,
+        writer.uint32(74).fork()
+      ).ldelim();
+    }
+    for (const v of message.reserved_name) {
+      writer.uint32(82).string(v!);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): DescriptorProto {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseDescriptorProto } as DescriptorProto;
+    message.field = [];
+    message.extension = [];
+    message.nested_type = [];
+    message.enum_type = [];
+    message.extension_range = [];
+    message.oneof_decl = [];
+    message.reserved_range = [];
+    message.reserved_name = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.name = reader.string();
+          break;
+        case 2:
+          message.field.push(
+            FieldDescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 6:
+          message.extension.push(
+            FieldDescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 3:
+          message.nested_type.push(
+            DescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 4:
+          message.enum_type.push(
+            EnumDescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 5:
+          message.extension_range.push(
+            DescriptorProto_ExtensionRange.decode(reader, reader.uint32())
+          );
+          break;
+        case 8:
+          message.oneof_decl.push(
+            OneofDescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 7:
+          message.options = MessageOptions.decode(reader, reader.uint32());
+          break;
+        case 9:
+          message.reserved_range.push(
+            DescriptorProto_ReservedRange.decode(reader, reader.uint32())
+          );
+          break;
+        case 10:
+          message.reserved_name.push(reader.string());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): DescriptorProto {
+    const message = { ...baseDescriptorProto } as DescriptorProto;
+    message.field = [];
+    message.extension = [];
+    message.nested_type = [];
+    message.enum_type = [];
+    message.extension_range = [];
+    message.oneof_decl = [];
+    message.reserved_range = [];
+    message.reserved_name = [];
+    if (object.name !== undefined && object.name !== null) {
+      message.name = String(object.name);
+    } else {
+      message.name = "";
+    }
+    if (object.field !== undefined && object.field !== null) {
+      for (const e of object.field) {
+        message.field.push(FieldDescriptorProto.fromJSON(e));
+      }
+    }
+    if (object.extension !== undefined && object.extension !== null) {
+      for (const e of object.extension) {
+        message.extension.push(FieldDescriptorProto.fromJSON(e));
+      }
+    }
+    if (object.nested_type !== undefined && object.nested_type !== null) {
+      for (const e of object.nested_type) {
+        message.nested_type.push(DescriptorProto.fromJSON(e));
+      }
+    }
+    if (object.enum_type !== undefined && object.enum_type !== null) {
+      for (const e of object.enum_type) {
+        message.enum_type.push(EnumDescriptorProto.fromJSON(e));
+      }
+    }
+    if (
+      object.extension_range !== undefined &&
+      object.extension_range !== null
+    ) {
+      for (const e of object.extension_range) {
+        message.extension_range.push(
+          DescriptorProto_ExtensionRange.fromJSON(e)
+        );
+      }
+    }
+    if (object.oneof_decl !== undefined && object.oneof_decl !== null) {
+      for (const e of object.oneof_decl) {
+        message.oneof_decl.push(OneofDescriptorProto.fromJSON(e));
+      }
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = MessageOptions.fromJSON(object.options);
+    } else {
+      message.options = undefined;
+    }
+    if (object.reserved_range !== undefined && object.reserved_range !== null) {
+      for (const e of object.reserved_range) {
+        message.reserved_range.push(DescriptorProto_ReservedRange.fromJSON(e));
+      }
+    }
+    if (object.reserved_name !== undefined && object.reserved_name !== null) {
+      for (const e of object.reserved_name) {
+        message.reserved_name.push(String(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: DescriptorProto): unknown {
+    const obj: any = {};
+    message.name !== undefined && (obj.name = message.name);
+    if (message.field) {
+      obj.field = message.field.map((e) =>
+        e ? FieldDescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.field = [];
+    }
+    if (message.extension) {
+      obj.extension = message.extension.map((e) =>
+        e ? FieldDescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.extension = [];
+    }
+    if (message.nested_type) {
+      obj.nested_type = message.nested_type.map((e) =>
+        e ? DescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.nested_type = [];
+    }
+    if (message.enum_type) {
+      obj.enum_type = message.enum_type.map((e) =>
+        e ? EnumDescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.enum_type = [];
+    }
+    if (message.extension_range) {
+      obj.extension_range = message.extension_range.map((e) =>
+        e ? DescriptorProto_ExtensionRange.toJSON(e) : undefined
+      );
+    } else {
+      obj.extension_range = [];
+    }
+    if (message.oneof_decl) {
+      obj.oneof_decl = message.oneof_decl.map((e) =>
+        e ? OneofDescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.oneof_decl = [];
+    }
+    message.options !== undefined &&
+      (obj.options = message.options
+        ? MessageOptions.toJSON(message.options)
+        : undefined);
+    if (message.reserved_range) {
+      obj.reserved_range = message.reserved_range.map((e) =>
+        e ? DescriptorProto_ReservedRange.toJSON(e) : undefined
+      );
+    } else {
+      obj.reserved_range = [];
+    }
+    if (message.reserved_name) {
+      obj.reserved_name = message.reserved_name.map((e) => e);
+    } else {
+      obj.reserved_name = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<DescriptorProto>): DescriptorProto {
+    const message = { ...baseDescriptorProto } as DescriptorProto;
+    message.field = [];
+    message.extension = [];
+    message.nested_type = [];
+    message.enum_type = [];
+    message.extension_range = [];
+    message.oneof_decl = [];
+    message.reserved_range = [];
+    message.reserved_name = [];
+    if (object.name !== undefined && object.name !== null) {
+      message.name = object.name;
+    } else {
+      message.name = "";
+    }
+    if (object.field !== undefined && object.field !== null) {
+      for (const e of object.field) {
+        message.field.push(FieldDescriptorProto.fromPartial(e));
+      }
+    }
+    if (object.extension !== undefined && object.extension !== null) {
+      for (const e of object.extension) {
+        message.extension.push(FieldDescriptorProto.fromPartial(e));
+      }
+    }
+    if (object.nested_type !== undefined && object.nested_type !== null) {
+      for (const e of object.nested_type) {
+        message.nested_type.push(DescriptorProto.fromPartial(e));
+      }
+    }
+    if (object.enum_type !== undefined && object.enum_type !== null) {
+      for (const e of object.enum_type) {
+        message.enum_type.push(EnumDescriptorProto.fromPartial(e));
+      }
+    }
+    if (
+      object.extension_range !== undefined &&
+      object.extension_range !== null
+    ) {
+      for (const e of object.extension_range) {
+        message.extension_range.push(
+          DescriptorProto_ExtensionRange.fromPartial(e)
+        );
+      }
+    }
+    if (object.oneof_decl !== undefined && object.oneof_decl !== null) {
+      for (const e of object.oneof_decl) {
+        message.oneof_decl.push(OneofDescriptorProto.fromPartial(e));
+      }
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = MessageOptions.fromPartial(object.options);
+    } else {
+      message.options = undefined;
+    }
+    if (object.reserved_range !== undefined && object.reserved_range !== null) {
+      for (const e of object.reserved_range) {
+        message.reserved_range.push(
+          DescriptorProto_ReservedRange.fromPartial(e)
+        );
+      }
+    }
+    if (object.reserved_name !== undefined && object.reserved_name !== null) {
+      for (const e of object.reserved_name) {
+        message.reserved_name.push(e);
+      }
+    }
+    return message;
+  },
+};
+
+const baseDescriptorProto_ExtensionRange: object = { start: 0, end: 0 };
+
+export const DescriptorProto_ExtensionRange = {
+  encode(
+    message: DescriptorProto_ExtensionRange,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.start !== 0) {
+      writer.uint32(8).int32(message.start);
+    }
+    if (message.end !== 0) {
+      writer.uint32(16).int32(message.end);
+    }
+    if (message.options !== undefined) {
+      ExtensionRangeOptions.encode(
+        message.options,
+        writer.uint32(26).fork()
+      ).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): DescriptorProto_ExtensionRange {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseDescriptorProto_ExtensionRange,
+    } as DescriptorProto_ExtensionRange;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.start = reader.int32();
+          break;
+        case 2:
+          message.end = reader.int32();
+          break;
+        case 3:
+          message.options = ExtensionRangeOptions.decode(
+            reader,
+            reader.uint32()
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): DescriptorProto_ExtensionRange {
+    const message = {
+      ...baseDescriptorProto_ExtensionRange,
+    } as DescriptorProto_ExtensionRange;
+    if (object.start !== undefined && object.start !== null) {
+      message.start = Number(object.start);
+    } else {
+      message.start = 0;
+    }
+    if (object.end !== undefined && object.end !== null) {
+      message.end = Number(object.end);
+    } else {
+      message.end = 0;
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = ExtensionRangeOptions.fromJSON(object.options);
+    } else {
+      message.options = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: DescriptorProto_ExtensionRange): unknown {
+    const obj: any = {};
+    message.start !== undefined && (obj.start = message.start);
+    message.end !== undefined && (obj.end = message.end);
+    message.options !== undefined &&
+      (obj.options = message.options
+        ? ExtensionRangeOptions.toJSON(message.options)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<DescriptorProto_ExtensionRange>
+  ): DescriptorProto_ExtensionRange {
+    const message = {
+      ...baseDescriptorProto_ExtensionRange,
+    } as DescriptorProto_ExtensionRange;
+    if (object.start !== undefined && object.start !== null) {
+      message.start = object.start;
+    } else {
+      message.start = 0;
+    }
+    if (object.end !== undefined && object.end !== null) {
+      message.end = object.end;
+    } else {
+      message.end = 0;
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = ExtensionRangeOptions.fromPartial(object.options);
+    } else {
+      message.options = undefined;
+    }
+    return message;
+  },
+};
+
+const baseDescriptorProto_ReservedRange: object = { start: 0, end: 0 };
+
+export const DescriptorProto_ReservedRange = {
+  encode(
+    message: DescriptorProto_ReservedRange,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.start !== 0) {
+      writer.uint32(8).int32(message.start);
+    }
+    if (message.end !== 0) {
+      writer.uint32(16).int32(message.end);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): DescriptorProto_ReservedRange {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseDescriptorProto_ReservedRange,
+    } as DescriptorProto_ReservedRange;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.start = reader.int32();
+          break;
+        case 2:
+          message.end = reader.int32();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): DescriptorProto_ReservedRange {
+    const message = {
+      ...baseDescriptorProto_ReservedRange,
+    } as DescriptorProto_ReservedRange;
+    if (object.start !== undefined && object.start !== null) {
+      message.start = Number(object.start);
+    } else {
+      message.start = 0;
+    }
+    if (object.end !== undefined && object.end !== null) {
+      message.end = Number(object.end);
+    } else {
+      message.end = 0;
+    }
+    return message;
+  },
+
+  toJSON(message: DescriptorProto_ReservedRange): unknown {
+    const obj: any = {};
+    message.start !== undefined && (obj.start = message.start);
+    message.end !== undefined && (obj.end = message.end);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<DescriptorProto_ReservedRange>
+  ): DescriptorProto_ReservedRange {
+    const message = {
+      ...baseDescriptorProto_ReservedRange,
+    } as DescriptorProto_ReservedRange;
+    if (object.start !== undefined && object.start !== null) {
+      message.start = object.start;
+    } else {
+      message.start = 0;
+    }
+    if (object.end !== undefined && object.end !== null) {
+      message.end = object.end;
+    } else {
+      message.end = 0;
+    }
+    return message;
+  },
+};
+
+const baseExtensionRangeOptions: object = {};
+
+export const ExtensionRangeOptions = {
+  encode(
+    message: ExtensionRangeOptions,
+    writer: Writer = Writer.create()
+  ): Writer {
+    for (const v of message.uninterpreted_option) {
+      UninterpretedOption.encode(v!, writer.uint32(7994).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): ExtensionRangeOptions {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseExtensionRangeOptions } as ExtensionRangeOptions;
+    message.uninterpreted_option = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 999:
+          message.uninterpreted_option.push(
+            UninterpretedOption.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): ExtensionRangeOptions {
+    const message = { ...baseExtensionRangeOptions } as ExtensionRangeOptions;
+    message.uninterpreted_option = [];
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: ExtensionRangeOptions): unknown {
+    const obj: any = {};
+    if (message.uninterpreted_option) {
+      obj.uninterpreted_option = message.uninterpreted_option.map((e) =>
+        e ? UninterpretedOption.toJSON(e) : undefined
+      );
+    } else {
+      obj.uninterpreted_option = [];
+    }
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<ExtensionRangeOptions>
+  ): ExtensionRangeOptions {
+    const message = { ...baseExtensionRangeOptions } as ExtensionRangeOptions;
+    message.uninterpreted_option = [];
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseFieldDescriptorProto: object = {
+  name: "",
+  number: 0,
+  label: 1,
+  type: 1,
+  type_name: "",
+  extendee: "",
+  default_value: "",
+  oneof_index: 0,
+  json_name: "",
+  proto3_optional: false,
+};
+
+export const FieldDescriptorProto = {
+  encode(
+    message: FieldDescriptorProto,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.name !== "") {
+      writer.uint32(10).string(message.name);
+    }
+    if (message.number !== 0) {
+      writer.uint32(24).int32(message.number);
+    }
+    if (message.label !== 1) {
+      writer.uint32(32).int32(message.label);
+    }
+    if (message.type !== 1) {
+      writer.uint32(40).int32(message.type);
+    }
+    if (message.type_name !== "") {
+      writer.uint32(50).string(message.type_name);
+    }
+    if (message.extendee !== "") {
+      writer.uint32(18).string(message.extendee);
+    }
+    if (message.default_value !== "") {
+      writer.uint32(58).string(message.default_value);
+    }
+    if (message.oneof_index !== 0) {
+      writer.uint32(72).int32(message.oneof_index);
+    }
+    if (message.json_name !== "") {
+      writer.uint32(82).string(message.json_name);
+    }
+    if (message.options !== undefined) {
+      FieldOptions.encode(message.options, writer.uint32(66).fork()).ldelim();
+    }
+    if (message.proto3_optional === true) {
+      writer.uint32(136).bool(message.proto3_optional);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): FieldDescriptorProto {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseFieldDescriptorProto } as FieldDescriptorProto;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.name = reader.string();
+          break;
+        case 3:
+          message.number = reader.int32();
+          break;
+        case 4:
+          message.label = reader.int32() as any;
+          break;
+        case 5:
+          message.type = reader.int32() as any;
+          break;
+        case 6:
+          message.type_name = reader.string();
+          break;
+        case 2:
+          message.extendee = reader.string();
+          break;
+        case 7:
+          message.default_value = reader.string();
+          break;
+        case 9:
+          message.oneof_index = reader.int32();
+          break;
+        case 10:
+          message.json_name = reader.string();
+          break;
+        case 8:
+          message.options = FieldOptions.decode(reader, reader.uint32());
+          break;
+        case 17:
+          message.proto3_optional = reader.bool();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): FieldDescriptorProto {
+    const message = { ...baseFieldDescriptorProto } as FieldDescriptorProto;
+    if (object.name !== undefined && object.name !== null) {
+      message.name = String(object.name);
+    } else {
+      message.name = "";
+    }
+    if (object.number !== undefined && object.number !== null) {
+      message.number = Number(object.number);
+    } else {
+      message.number = 0;
+    }
+    if (object.label !== undefined && object.label !== null) {
+      message.label = fieldDescriptorProto_LabelFromJSON(object.label);
+    } else {
+      message.label = 1;
+    }
+    if (object.type !== undefined && object.type !== null) {
+      message.type = fieldDescriptorProto_TypeFromJSON(object.type);
+    } else {
+      message.type = 1;
+    }
+    if (object.type_name !== undefined && object.type_name !== null) {
+      message.type_name = String(object.type_name);
+    } else {
+      message.type_name = "";
+    }
+    if (object.extendee !== undefined && object.extendee !== null) {
+      message.extendee = String(object.extendee);
+    } else {
+      message.extendee = "";
+    }
+    if (object.default_value !== undefined && object.default_value !== null) {
+      message.default_value = String(object.default_value);
+    } else {
+      message.default_value = "";
+    }
+    if (object.oneof_index !== undefined && object.oneof_index !== null) {
+      message.oneof_index = Number(object.oneof_index);
+    } else {
+      message.oneof_index = 0;
+    }
+    if (object.json_name !== undefined && object.json_name !== null) {
+      message.json_name = String(object.json_name);
+    } else {
+      message.json_name = "";
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = FieldOptions.fromJSON(object.options);
+    } else {
+      message.options = undefined;
+    }
+    if (
+      object.proto3_optional !== undefined &&
+      object.proto3_optional !== null
+    ) {
+      message.proto3_optional = Boolean(object.proto3_optional);
+    } else {
+      message.proto3_optional = false;
+    }
+    return message;
+  },
+
+  toJSON(message: FieldDescriptorProto): unknown {
+    const obj: any = {};
+    message.name !== undefined && (obj.name = message.name);
+    message.number !== undefined && (obj.number = message.number);
+    message.label !== undefined &&
+      (obj.label = fieldDescriptorProto_LabelToJSON(message.label));
+    message.type !== undefined &&
+      (obj.type = fieldDescriptorProto_TypeToJSON(message.type));
+    message.type_name !== undefined && (obj.type_name = message.type_name);
+    message.extendee !== undefined && (obj.extendee = message.extendee);
+    message.default_value !== undefined &&
+      (obj.default_value = message.default_value);
+    message.oneof_index !== undefined &&
+      (obj.oneof_index = message.oneof_index);
+    message.json_name !== undefined && (obj.json_name = message.json_name);
+    message.options !== undefined &&
+      (obj.options = message.options
+        ? FieldOptions.toJSON(message.options)
+        : undefined);
+    message.proto3_optional !== undefined &&
+      (obj.proto3_optional = message.proto3_optional);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<FieldDescriptorProto>): FieldDescriptorProto {
+    const message = { ...baseFieldDescriptorProto } as FieldDescriptorProto;
+    if (object.name !== undefined && object.name !== null) {
+      message.name = object.name;
+    } else {
+      message.name = "";
+    }
+    if (object.number !== undefined && object.number !== null) {
+      message.number = object.number;
+    } else {
+      message.number = 0;
+    }
+    if (object.label !== undefined && object.label !== null) {
+      message.label = object.label;
+    } else {
+      message.label = 1;
+    }
+    if (object.type !== undefined && object.type !== null) {
+      message.type = object.type;
+    } else {
+      message.type = 1;
+    }
+    if (object.type_name !== undefined && object.type_name !== null) {
+      message.type_name = object.type_name;
+    } else {
+      message.type_name = "";
+    }
+    if (object.extendee !== undefined && object.extendee !== null) {
+      message.extendee = object.extendee;
+    } else {
+      message.extendee = "";
+    }
+    if (object.default_value !== undefined && object.default_value !== null) {
+      message.default_value = object.default_value;
+    } else {
+      message.default_value = "";
+    }
+    if (object.oneof_index !== undefined && object.oneof_index !== null) {
+      message.oneof_index = object.oneof_index;
+    } else {
+      message.oneof_index = 0;
+    }
+    if (object.json_name !== undefined && object.json_name !== null) {
+      message.json_name = object.json_name;
+    } else {
+      message.json_name = "";
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = FieldOptions.fromPartial(object.options);
+    } else {
+      message.options = undefined;
+    }
+    if (
+      object.proto3_optional !== undefined &&
+      object.proto3_optional !== null
+    ) {
+      message.proto3_optional = object.proto3_optional;
+    } else {
+      message.proto3_optional = false;
+    }
+    return message;
+  },
+};
+
+const baseOneofDescriptorProto: object = { name: "" };
+
+export const OneofDescriptorProto = {
+  encode(
+    message: OneofDescriptorProto,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.name !== "") {
+      writer.uint32(10).string(message.name);
+    }
+    if (message.options !== undefined) {
+      OneofOptions.encode(message.options, writer.uint32(18).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): OneofDescriptorProto {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseOneofDescriptorProto } as OneofDescriptorProto;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.name = reader.string();
+          break;
+        case 2:
+          message.options = OneofOptions.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): OneofDescriptorProto {
+    const message = { ...baseOneofDescriptorProto } as OneofDescriptorProto;
+    if (object.name !== undefined && object.name !== null) {
+      message.name = String(object.name);
+    } else {
+      message.name = "";
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = OneofOptions.fromJSON(object.options);
+    } else {
+      message.options = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: OneofDescriptorProto): unknown {
+    const obj: any = {};
+    message.name !== undefined && (obj.name = message.name);
+    message.options !== undefined &&
+      (obj.options = message.options
+        ? OneofOptions.toJSON(message.options)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<OneofDescriptorProto>): OneofDescriptorProto {
+    const message = { ...baseOneofDescriptorProto } as OneofDescriptorProto;
+    if (object.name !== undefined && object.name !== null) {
+      message.name = object.name;
+    } else {
+      message.name = "";
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = OneofOptions.fromPartial(object.options);
+    } else {
+      message.options = undefined;
+    }
+    return message;
+  },
+};
+
+const baseEnumDescriptorProto: object = { name: "", reserved_name: "" };
+
+export const EnumDescriptorProto = {
+  encode(
+    message: EnumDescriptorProto,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.name !== "") {
+      writer.uint32(10).string(message.name);
+    }
+    for (const v of message.value) {
+      EnumValueDescriptorProto.encode(v!, writer.uint32(18).fork()).ldelim();
+    }
+    if (message.options !== undefined) {
+      EnumOptions.encode(message.options, writer.uint32(26).fork()).ldelim();
+    }
+    for (const v of message.reserved_range) {
+      EnumDescriptorProto_EnumReservedRange.encode(
+        v!,
+        writer.uint32(34).fork()
+      ).ldelim();
+    }
+    for (const v of message.reserved_name) {
+      writer.uint32(42).string(v!);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): EnumDescriptorProto {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseEnumDescriptorProto } as EnumDescriptorProto;
+    message.value = [];
+    message.reserved_range = [];
+    message.reserved_name = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.name = reader.string();
+          break;
+        case 2:
+          message.value.push(
+            EnumValueDescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 3:
+          message.options = EnumOptions.decode(reader, reader.uint32());
+          break;
+        case 4:
+          message.reserved_range.push(
+            EnumDescriptorProto_EnumReservedRange.decode(
+              reader,
+              reader.uint32()
+            )
+          );
+          break;
+        case 5:
+          message.reserved_name.push(reader.string());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): EnumDescriptorProto {
+    const message = { ...baseEnumDescriptorProto } as EnumDescriptorProto;
+    message.value = [];
+    message.reserved_range = [];
+    message.reserved_name = [];
+    if (object.name !== undefined && object.name !== null) {
+      message.name = String(object.name);
+    } else {
+      message.name = "";
+    }
+    if (object.value !== undefined && object.value !== null) {
+      for (const e of object.value) {
+        message.value.push(EnumValueDescriptorProto.fromJSON(e));
+      }
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = EnumOptions.fromJSON(object.options);
+    } else {
+      message.options = undefined;
+    }
+    if (object.reserved_range !== undefined && object.reserved_range !== null) {
+      for (const e of object.reserved_range) {
+        message.reserved_range.push(
+          EnumDescriptorProto_EnumReservedRange.fromJSON(e)
+        );
+      }
+    }
+    if (object.reserved_name !== undefined && object.reserved_name !== null) {
+      for (const e of object.reserved_name) {
+        message.reserved_name.push(String(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: EnumDescriptorProto): unknown {
+    const obj: any = {};
+    message.name !== undefined && (obj.name = message.name);
+    if (message.value) {
+      obj.value = message.value.map((e) =>
+        e ? EnumValueDescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.value = [];
+    }
+    message.options !== undefined &&
+      (obj.options = message.options
+        ? EnumOptions.toJSON(message.options)
+        : undefined);
+    if (message.reserved_range) {
+      obj.reserved_range = message.reserved_range.map((e) =>
+        e ? EnumDescriptorProto_EnumReservedRange.toJSON(e) : undefined
+      );
+    } else {
+      obj.reserved_range = [];
+    }
+    if (message.reserved_name) {
+      obj.reserved_name = message.reserved_name.map((e) => e);
+    } else {
+      obj.reserved_name = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<EnumDescriptorProto>): EnumDescriptorProto {
+    const message = { ...baseEnumDescriptorProto } as EnumDescriptorProto;
+    message.value = [];
+    message.reserved_range = [];
+    message.reserved_name = [];
+    if (object.name !== undefined && object.name !== null) {
+      message.name = object.name;
+    } else {
+      message.name = "";
+    }
+    if (object.value !== undefined && object.value !== null) {
+      for (const e of object.value) {
+        message.value.push(EnumValueDescriptorProto.fromPartial(e));
+      }
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = EnumOptions.fromPartial(object.options);
+    } else {
+      message.options = undefined;
+    }
+    if (object.reserved_range !== undefined && object.reserved_range !== null) {
+      for (const e of object.reserved_range) {
+        message.reserved_range.push(
+          EnumDescriptorProto_EnumReservedRange.fromPartial(e)
+        );
+      }
+    }
+    if (object.reserved_name !== undefined && object.reserved_name !== null) {
+      for (const e of object.reserved_name) {
+        message.reserved_name.push(e);
+      }
+    }
+    return message;
+  },
+};
+
+const baseEnumDescriptorProto_EnumReservedRange: object = { start: 0, end: 0 };
+
+export const EnumDescriptorProto_EnumReservedRange = {
+  encode(
+    message: EnumDescriptorProto_EnumReservedRange,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.start !== 0) {
+      writer.uint32(8).int32(message.start);
+    }
+    if (message.end !== 0) {
+      writer.uint32(16).int32(message.end);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): EnumDescriptorProto_EnumReservedRange {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseEnumDescriptorProto_EnumReservedRange,
+    } as EnumDescriptorProto_EnumReservedRange;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.start = reader.int32();
+          break;
+        case 2:
+          message.end = reader.int32();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): EnumDescriptorProto_EnumReservedRange {
+    const message = {
+      ...baseEnumDescriptorProto_EnumReservedRange,
+    } as EnumDescriptorProto_EnumReservedRange;
+    if (object.start !== undefined && object.start !== null) {
+      message.start = Number(object.start);
+    } else {
+      message.start = 0;
+    }
+    if (object.end !== undefined && object.end !== null) {
+      message.end = Number(object.end);
+    } else {
+      message.end = 0;
+    }
+    return message;
+  },
+
+  toJSON(message: EnumDescriptorProto_EnumReservedRange): unknown {
+    const obj: any = {};
+    message.start !== undefined && (obj.start = message.start);
+    message.end !== undefined && (obj.end = message.end);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<EnumDescriptorProto_EnumReservedRange>
+  ): EnumDescriptorProto_EnumReservedRange {
+    const message = {
+      ...baseEnumDescriptorProto_EnumReservedRange,
+    } as EnumDescriptorProto_EnumReservedRange;
+    if (object.start !== undefined && object.start !== null) {
+      message.start = object.start;
+    } else {
+      message.start = 0;
+    }
+    if (object.end !== undefined && object.end !== null) {
+      message.end = object.end;
+    } else {
+      message.end = 0;
+    }
+    return message;
+  },
+};
+
+const baseEnumValueDescriptorProto: object = { name: "", number: 0 };
+
+export const EnumValueDescriptorProto = {
+  encode(
+    message: EnumValueDescriptorProto,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.name !== "") {
+      writer.uint32(10).string(message.name);
+    }
+    if (message.number !== 0) {
+      writer.uint32(16).int32(message.number);
+    }
+    if (message.options !== undefined) {
+      EnumValueOptions.encode(
+        message.options,
+        writer.uint32(26).fork()
+      ).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): EnumValueDescriptorProto {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseEnumValueDescriptorProto,
+    } as EnumValueDescriptorProto;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.name = reader.string();
+          break;
+        case 2:
+          message.number = reader.int32();
+          break;
+        case 3:
+          message.options = EnumValueOptions.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): EnumValueDescriptorProto {
+    const message = {
+      ...baseEnumValueDescriptorProto,
+    } as EnumValueDescriptorProto;
+    if (object.name !== undefined && object.name !== null) {
+      message.name = String(object.name);
+    } else {
+      message.name = "";
+    }
+    if (object.number !== undefined && object.number !== null) {
+      message.number = Number(object.number);
+    } else {
+      message.number = 0;
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = EnumValueOptions.fromJSON(object.options);
+    } else {
+      message.options = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: EnumValueDescriptorProto): unknown {
+    const obj: any = {};
+    message.name !== undefined && (obj.name = message.name);
+    message.number !== undefined && (obj.number = message.number);
+    message.options !== undefined &&
+      (obj.options = message.options
+        ? EnumValueOptions.toJSON(message.options)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<EnumValueDescriptorProto>
+  ): EnumValueDescriptorProto {
+    const message = {
+      ...baseEnumValueDescriptorProto,
+    } as EnumValueDescriptorProto;
+    if (object.name !== undefined && object.name !== null) {
+      message.name = object.name;
+    } else {
+      message.name = "";
+    }
+    if (object.number !== undefined && object.number !== null) {
+      message.number = object.number;
+    } else {
+      message.number = 0;
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = EnumValueOptions.fromPartial(object.options);
+    } else {
+      message.options = undefined;
+    }
+    return message;
+  },
+};
+
+const baseServiceDescriptorProto: object = { name: "" };
+
+export const ServiceDescriptorProto = {
+  encode(
+    message: ServiceDescriptorProto,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.name !== "") {
+      writer.uint32(10).string(message.name);
+    }
+    for (const v of message.method) {
+      MethodDescriptorProto.encode(v!, writer.uint32(18).fork()).ldelim();
+    }
+    if (message.options !== undefined) {
+      ServiceOptions.encode(message.options, writer.uint32(26).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): ServiceDescriptorProto {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseServiceDescriptorProto } as ServiceDescriptorProto;
+    message.method = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.name = reader.string();
+          break;
+        case 2:
+          message.method.push(
+            MethodDescriptorProto.decode(reader, reader.uint32())
+          );
+          break;
+        case 3:
+          message.options = ServiceOptions.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): ServiceDescriptorProto {
+    const message = { ...baseServiceDescriptorProto } as ServiceDescriptorProto;
+    message.method = [];
+    if (object.name !== undefined && object.name !== null) {
+      message.name = String(object.name);
+    } else {
+      message.name = "";
+    }
+    if (object.method !== undefined && object.method !== null) {
+      for (const e of object.method) {
+        message.method.push(MethodDescriptorProto.fromJSON(e));
+      }
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = ServiceOptions.fromJSON(object.options);
+    } else {
+      message.options = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: ServiceDescriptorProto): unknown {
+    const obj: any = {};
+    message.name !== undefined && (obj.name = message.name);
+    if (message.method) {
+      obj.method = message.method.map((e) =>
+        e ? MethodDescriptorProto.toJSON(e) : undefined
+      );
+    } else {
+      obj.method = [];
+    }
+    message.options !== undefined &&
+      (obj.options = message.options
+        ? ServiceOptions.toJSON(message.options)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<ServiceDescriptorProto>
+  ): ServiceDescriptorProto {
+    const message = { ...baseServiceDescriptorProto } as ServiceDescriptorProto;
+    message.method = [];
+    if (object.name !== undefined && object.name !== null) {
+      message.name = object.name;
+    } else {
+      message.name = "";
+    }
+    if (object.method !== undefined && object.method !== null) {
+      for (const e of object.method) {
+        message.method.push(MethodDescriptorProto.fromPartial(e));
+      }
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = ServiceOptions.fromPartial(object.options);
+    } else {
+      message.options = undefined;
+    }
+    return message;
+  },
+};
+
+const baseMethodDescriptorProto: object = {
+  name: "",
+  input_type: "",
+  output_type: "",
+  client_streaming: false,
+  server_streaming: false,
+};
+
+export const MethodDescriptorProto = {
+  encode(
+    message: MethodDescriptorProto,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.name !== "") {
+      writer.uint32(10).string(message.name);
+    }
+    if (message.input_type !== "") {
+      writer.uint32(18).string(message.input_type);
+    }
+    if (message.output_type !== "") {
+      writer.uint32(26).string(message.output_type);
+    }
+    if (message.options !== undefined) {
+      MethodOptions.encode(message.options, writer.uint32(34).fork()).ldelim();
+    }
+    if (message.client_streaming === true) {
+      writer.uint32(40).bool(message.client_streaming);
+    }
+    if (message.server_streaming === true) {
+      writer.uint32(48).bool(message.server_streaming);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MethodDescriptorProto {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMethodDescriptorProto } as MethodDescriptorProto;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.name = reader.string();
+          break;
+        case 2:
+          message.input_type = reader.string();
+          break;
+        case 3:
+          message.output_type = reader.string();
+          break;
+        case 4:
+          message.options = MethodOptions.decode(reader, reader.uint32());
+          break;
+        case 5:
+          message.client_streaming = reader.bool();
+          break;
+        case 6:
+          message.server_streaming = reader.bool();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MethodDescriptorProto {
+    const message = { ...baseMethodDescriptorProto } as MethodDescriptorProto;
+    if (object.name !== undefined && object.name !== null) {
+      message.name = String(object.name);
+    } else {
+      message.name = "";
+    }
+    if (object.input_type !== undefined && object.input_type !== null) {
+      message.input_type = String(object.input_type);
+    } else {
+      message.input_type = "";
+    }
+    if (object.output_type !== undefined && object.output_type !== null) {
+      message.output_type = String(object.output_type);
+    } else {
+      message.output_type = "";
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = MethodOptions.fromJSON(object.options);
+    } else {
+      message.options = undefined;
+    }
+    if (
+      object.client_streaming !== undefined &&
+      object.client_streaming !== null
+    ) {
+      message.client_streaming = Boolean(object.client_streaming);
+    } else {
+      message.client_streaming = false;
+    }
+    if (
+      object.server_streaming !== undefined &&
+      object.server_streaming !== null
+    ) {
+      message.server_streaming = Boolean(object.server_streaming);
+    } else {
+      message.server_streaming = false;
+    }
+    return message;
+  },
+
+  toJSON(message: MethodDescriptorProto): unknown {
+    const obj: any = {};
+    message.name !== undefined && (obj.name = message.name);
+    message.input_type !== undefined && (obj.input_type = message.input_type);
+    message.output_type !== undefined &&
+      (obj.output_type = message.output_type);
+    message.options !== undefined &&
+      (obj.options = message.options
+        ? MethodOptions.toJSON(message.options)
+        : undefined);
+    message.client_streaming !== undefined &&
+      (obj.client_streaming = message.client_streaming);
+    message.server_streaming !== undefined &&
+      (obj.server_streaming = message.server_streaming);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<MethodDescriptorProto>
+  ): MethodDescriptorProto {
+    const message = { ...baseMethodDescriptorProto } as MethodDescriptorProto;
+    if (object.name !== undefined && object.name !== null) {
+      message.name = object.name;
+    } else {
+      message.name = "";
+    }
+    if (object.input_type !== undefined && object.input_type !== null) {
+      message.input_type = object.input_type;
+    } else {
+      message.input_type = "";
+    }
+    if (object.output_type !== undefined && object.output_type !== null) {
+      message.output_type = object.output_type;
+    } else {
+      message.output_type = "";
+    }
+    if (object.options !== undefined && object.options !== null) {
+      message.options = MethodOptions.fromPartial(object.options);
+    } else {
+      message.options = undefined;
+    }
+    if (
+      object.client_streaming !== undefined &&
+      object.client_streaming !== null
+    ) {
+      message.client_streaming = object.client_streaming;
+    } else {
+      message.client_streaming = false;
+    }
+    if (
+      object.server_streaming !== undefined &&
+      object.server_streaming !== null
+    ) {
+      message.server_streaming = object.server_streaming;
+    } else {
+      message.server_streaming = false;
+    }
+    return message;
+  },
+};
+
+const baseFileOptions: object = {
+  java_package: "",
+  java_outer_classname: "",
+  java_multiple_files: false,
+  java_generate_equals_and_hash: false,
+  java_string_check_utf8: false,
+  optimize_for: 1,
+  go_package: "",
+  cc_generic_services: false,
+  java_generic_services: false,
+  py_generic_services: false,
+  php_generic_services: false,
+  deprecated: false,
+  cc_enable_arenas: false,
+  objc_class_prefix: "",
+  csharp_namespace: "",
+  swift_prefix: "",
+  php_class_prefix: "",
+  php_namespace: "",
+  php_metadata_namespace: "",
+  ruby_package: "",
+};
+
+export const FileOptions = {
+  encode(message: FileOptions, writer: Writer = Writer.create()): Writer {
+    if (message.java_package !== "") {
+      writer.uint32(10).string(message.java_package);
+    }
+    if (message.java_outer_classname !== "") {
+      writer.uint32(66).string(message.java_outer_classname);
+    }
+    if (message.java_multiple_files === true) {
+      writer.uint32(80).bool(message.java_multiple_files);
+    }
+    if (message.java_generate_equals_and_hash === true) {
+      writer.uint32(160).bool(message.java_generate_equals_and_hash);
+    }
+    if (message.java_string_check_utf8 === true) {
+      writer.uint32(216).bool(message.java_string_check_utf8);
+    }
+    if (message.optimize_for !== 1) {
+      writer.uint32(72).int32(message.optimize_for);
+    }
+    if (message.go_package !== "") {
+      writer.uint32(90).string(message.go_package);
+    }
+    if (message.cc_generic_services === true) {
+      writer.uint32(128).bool(message.cc_generic_services);
+    }
+    if (message.java_generic_services === true) {
+      writer.uint32(136).bool(message.java_generic_services);
+    }
+    if (message.py_generic_services === true) {
+      writer.uint32(144).bool(message.py_generic_services);
+    }
+    if (message.php_generic_services === true) {
+      writer.uint32(336).bool(message.php_generic_services);
+    }
+    if (message.deprecated === true) {
+      writer.uint32(184).bool(message.deprecated);
+    }
+    if (message.cc_enable_arenas === true) {
+      writer.uint32(248).bool(message.cc_enable_arenas);
+    }
+    if (message.objc_class_prefix !== "") {
+      writer.uint32(290).string(message.objc_class_prefix);
+    }
+    if (message.csharp_namespace !== "") {
+      writer.uint32(298).string(message.csharp_namespace);
+    }
+    if (message.swift_prefix !== "") {
+      writer.uint32(314).string(message.swift_prefix);
+    }
+    if (message.php_class_prefix !== "") {
+      writer.uint32(322).string(message.php_class_prefix);
+    }
+    if (message.php_namespace !== "") {
+      writer.uint32(330).string(message.php_namespace);
+    }
+    if (message.php_metadata_namespace !== "") {
+      writer.uint32(354).string(message.php_metadata_namespace);
+    }
+    if (message.ruby_package !== "") {
+      writer.uint32(362).string(message.ruby_package);
+    }
+    for (const v of message.uninterpreted_option) {
+      UninterpretedOption.encode(v!, writer.uint32(7994).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): FileOptions {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseFileOptions } as FileOptions;
+    message.uninterpreted_option = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.java_package = reader.string();
+          break;
+        case 8:
+          message.java_outer_classname = reader.string();
+          break;
+        case 10:
+          message.java_multiple_files = reader.bool();
+          break;
+        case 20:
+          message.java_generate_equals_and_hash = reader.bool();
+          break;
+        case 27:
+          message.java_string_check_utf8 = reader.bool();
+          break;
+        case 9:
+          message.optimize_for = reader.int32() as any;
+          break;
+        case 11:
+          message.go_package = reader.string();
+          break;
+        case 16:
+          message.cc_generic_services = reader.bool();
+          break;
+        case 17:
+          message.java_generic_services = reader.bool();
+          break;
+        case 18:
+          message.py_generic_services = reader.bool();
+          break;
+        case 42:
+          message.php_generic_services = reader.bool();
+          break;
+        case 23:
+          message.deprecated = reader.bool();
+          break;
+        case 31:
+          message.cc_enable_arenas = reader.bool();
+          break;
+        case 36:
+          message.objc_class_prefix = reader.string();
+          break;
+        case 37:
+          message.csharp_namespace = reader.string();
+          break;
+        case 39:
+          message.swift_prefix = reader.string();
+          break;
+        case 40:
+          message.php_class_prefix = reader.string();
+          break;
+        case 41:
+          message.php_namespace = reader.string();
+          break;
+        case 44:
+          message.php_metadata_namespace = reader.string();
+          break;
+        case 45:
+          message.ruby_package = reader.string();
+          break;
+        case 999:
+          message.uninterpreted_option.push(
+            UninterpretedOption.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): FileOptions {
+    const message = { ...baseFileOptions } as FileOptions;
+    message.uninterpreted_option = [];
+    if (object.java_package !== undefined && object.java_package !== null) {
+      message.java_package = String(object.java_package);
+    } else {
+      message.java_package = "";
+    }
+    if (
+      object.java_outer_classname !== undefined &&
+      object.java_outer_classname !== null
+    ) {
+      message.java_outer_classname = String(object.java_outer_classname);
+    } else {
+      message.java_outer_classname = "";
+    }
+    if (
+      object.java_multiple_files !== undefined &&
+      object.java_multiple_files !== null
+    ) {
+      message.java_multiple_files = Boolean(object.java_multiple_files);
+    } else {
+      message.java_multiple_files = false;
+    }
+    if (
+      object.java_generate_equals_and_hash !== undefined &&
+      object.java_generate_equals_and_hash !== null
+    ) {
+      message.java_generate_equals_and_hash = Boolean(
+        object.java_generate_equals_and_hash
+      );
+    } else {
+      message.java_generate_equals_and_hash = false;
+    }
+    if (
+      object.java_string_check_utf8 !== undefined &&
+      object.java_string_check_utf8 !== null
+    ) {
+      message.java_string_check_utf8 = Boolean(object.java_string_check_utf8);
+    } else {
+      message.java_string_check_utf8 = false;
+    }
+    if (object.optimize_for !== undefined && object.optimize_for !== null) {
+      message.optimize_for = fileOptions_OptimizeModeFromJSON(
+        object.optimize_for
+      );
+    } else {
+      message.optimize_for = 1;
+    }
+    if (object.go_package !== undefined && object.go_package !== null) {
+      message.go_package = String(object.go_package);
+    } else {
+      message.go_package = "";
+    }
+    if (
+      object.cc_generic_services !== undefined &&
+      object.cc_generic_services !== null
+    ) {
+      message.cc_generic_services = Boolean(object.cc_generic_services);
+    } else {
+      message.cc_generic_services = false;
+    }
+    if (
+      object.java_generic_services !== undefined &&
+      object.java_generic_services !== null
+    ) {
+      message.java_generic_services = Boolean(object.java_generic_services);
+    } else {
+      message.java_generic_services = false;
+    }
+    if (
+      object.py_generic_services !== undefined &&
+      object.py_generic_services !== null
+    ) {
+      message.py_generic_services = Boolean(object.py_generic_services);
+    } else {
+      message.py_generic_services = false;
+    }
+    if (
+      object.php_generic_services !== undefined &&
+      object.php_generic_services !== null
+    ) {
+      message.php_generic_services = Boolean(object.php_generic_services);
+    } else {
+      message.php_generic_services = false;
+    }
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = Boolean(object.deprecated);
+    } else {
+      message.deprecated = false;
+    }
+    if (
+      object.cc_enable_arenas !== undefined &&
+      object.cc_enable_arenas !== null
+    ) {
+      message.cc_enable_arenas = Boolean(object.cc_enable_arenas);
+    } else {
+      message.cc_enable_arenas = false;
+    }
+    if (
+      object.objc_class_prefix !== undefined &&
+      object.objc_class_prefix !== null
+    ) {
+      message.objc_class_prefix = String(object.objc_class_prefix);
+    } else {
+      message.objc_class_prefix = "";
+    }
+    if (
+      object.csharp_namespace !== undefined &&
+      object.csharp_namespace !== null
+    ) {
+      message.csharp_namespace = String(object.csharp_namespace);
+    } else {
+      message.csharp_namespace = "";
+    }
+    if (object.swift_prefix !== undefined && object.swift_prefix !== null) {
+      message.swift_prefix = String(object.swift_prefix);
+    } else {
+      message.swift_prefix = "";
+    }
+    if (
+      object.php_class_prefix !== undefined &&
+      object.php_class_prefix !== null
+    ) {
+      message.php_class_prefix = String(object.php_class_prefix);
+    } else {
+      message.php_class_prefix = "";
+    }
+    if (object.php_namespace !== undefined && object.php_namespace !== null) {
+      message.php_namespace = String(object.php_namespace);
+    } else {
+      message.php_namespace = "";
+    }
+    if (
+      object.php_metadata_namespace !== undefined &&
+      object.php_metadata_namespace !== null
+    ) {
+      message.php_metadata_namespace = String(object.php_metadata_namespace);
+    } else {
+      message.php_metadata_namespace = "";
+    }
+    if (object.ruby_package !== undefined && object.ruby_package !== null) {
+      message.ruby_package = String(object.ruby_package);
+    } else {
+      message.ruby_package = "";
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: FileOptions): unknown {
+    const obj: any = {};
+    message.java_package !== undefined &&
+      (obj.java_package = message.java_package);
+    message.java_outer_classname !== undefined &&
+      (obj.java_outer_classname = message.java_outer_classname);
+    message.java_multiple_files !== undefined &&
+      (obj.java_multiple_files = message.java_multiple_files);
+    message.java_generate_equals_and_hash !== undefined &&
+      (obj.java_generate_equals_and_hash =
+        message.java_generate_equals_and_hash);
+    message.java_string_check_utf8 !== undefined &&
+      (obj.java_string_check_utf8 = message.java_string_check_utf8);
+    message.optimize_for !== undefined &&
+      (obj.optimize_for = fileOptions_OptimizeModeToJSON(message.optimize_for));
+    message.go_package !== undefined && (obj.go_package = message.go_package);
+    message.cc_generic_services !== undefined &&
+      (obj.cc_generic_services = message.cc_generic_services);
+    message.java_generic_services !== undefined &&
+      (obj.java_generic_services = message.java_generic_services);
+    message.py_generic_services !== undefined &&
+      (obj.py_generic_services = message.py_generic_services);
+    message.php_generic_services !== undefined &&
+      (obj.php_generic_services = message.php_generic_services);
+    message.deprecated !== undefined && (obj.deprecated = message.deprecated);
+    message.cc_enable_arenas !== undefined &&
+      (obj.cc_enable_arenas = message.cc_enable_arenas);
+    message.objc_class_prefix !== undefined &&
+      (obj.objc_class_prefix = message.objc_class_prefix);
+    message.csharp_namespace !== undefined &&
+      (obj.csharp_namespace = message.csharp_namespace);
+    message.swift_prefix !== undefined &&
+      (obj.swift_prefix = message.swift_prefix);
+    message.php_class_prefix !== undefined &&
+      (obj.php_class_prefix = message.php_class_prefix);
+    message.php_namespace !== undefined &&
+      (obj.php_namespace = message.php_namespace);
+    message.php_metadata_namespace !== undefined &&
+      (obj.php_metadata_namespace = message.php_metadata_namespace);
+    message.ruby_package !== undefined &&
+      (obj.ruby_package = message.ruby_package);
+    if (message.uninterpreted_option) {
+      obj.uninterpreted_option = message.uninterpreted_option.map((e) =>
+        e ? UninterpretedOption.toJSON(e) : undefined
+      );
+    } else {
+      obj.uninterpreted_option = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<FileOptions>): FileOptions {
+    const message = { ...baseFileOptions } as FileOptions;
+    message.uninterpreted_option = [];
+    if (object.java_package !== undefined && object.java_package !== null) {
+      message.java_package = object.java_package;
+    } else {
+      message.java_package = "";
+    }
+    if (
+      object.java_outer_classname !== undefined &&
+      object.java_outer_classname !== null
+    ) {
+      message.java_outer_classname = object.java_outer_classname;
+    } else {
+      message.java_outer_classname = "";
+    }
+    if (
+      object.java_multiple_files !== undefined &&
+      object.java_multiple_files !== null
+    ) {
+      message.java_multiple_files = object.java_multiple_files;
+    } else {
+      message.java_multiple_files = false;
+    }
+    if (
+      object.java_generate_equals_and_hash !== undefined &&
+      object.java_generate_equals_and_hash !== null
+    ) {
+      message.java_generate_equals_and_hash =
+        object.java_generate_equals_and_hash;
+    } else {
+      message.java_generate_equals_and_hash = false;
+    }
+    if (
+      object.java_string_check_utf8 !== undefined &&
+      object.java_string_check_utf8 !== null
+    ) {
+      message.java_string_check_utf8 = object.java_string_check_utf8;
+    } else {
+      message.java_string_check_utf8 = false;
+    }
+    if (object.optimize_for !== undefined && object.optimize_for !== null) {
+      message.optimize_for = object.optimize_for;
+    } else {
+      message.optimize_for = 1;
+    }
+    if (object.go_package !== undefined && object.go_package !== null) {
+      message.go_package = object.go_package;
+    } else {
+      message.go_package = "";
+    }
+    if (
+      object.cc_generic_services !== undefined &&
+      object.cc_generic_services !== null
+    ) {
+      message.cc_generic_services = object.cc_generic_services;
+    } else {
+      message.cc_generic_services = false;
+    }
+    if (
+      object.java_generic_services !== undefined &&
+      object.java_generic_services !== null
+    ) {
+      message.java_generic_services = object.java_generic_services;
+    } else {
+      message.java_generic_services = false;
+    }
+    if (
+      object.py_generic_services !== undefined &&
+      object.py_generic_services !== null
+    ) {
+      message.py_generic_services = object.py_generic_services;
+    } else {
+      message.py_generic_services = false;
+    }
+    if (
+      object.php_generic_services !== undefined &&
+      object.php_generic_services !== null
+    ) {
+      message.php_generic_services = object.php_generic_services;
+    } else {
+      message.php_generic_services = false;
+    }
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = object.deprecated;
+    } else {
+      message.deprecated = false;
+    }
+    if (
+      object.cc_enable_arenas !== undefined &&
+      object.cc_enable_arenas !== null
+    ) {
+      message.cc_enable_arenas = object.cc_enable_arenas;
+    } else {
+      message.cc_enable_arenas = false;
+    }
+    if (
+      object.objc_class_prefix !== undefined &&
+      object.objc_class_prefix !== null
+    ) {
+      message.objc_class_prefix = object.objc_class_prefix;
+    } else {
+      message.objc_class_prefix = "";
+    }
+    if (
+      object.csharp_namespace !== undefined &&
+      object.csharp_namespace !== null
+    ) {
+      message.csharp_namespace = object.csharp_namespace;
+    } else {
+      message.csharp_namespace = "";
+    }
+    if (object.swift_prefix !== undefined && object.swift_prefix !== null) {
+      message.swift_prefix = object.swift_prefix;
+    } else {
+      message.swift_prefix = "";
+    }
+    if (
+      object.php_class_prefix !== undefined &&
+      object.php_class_prefix !== null
+    ) {
+      message.php_class_prefix = object.php_class_prefix;
+    } else {
+      message.php_class_prefix = "";
+    }
+    if (object.php_namespace !== undefined && object.php_namespace !== null) {
+      message.php_namespace = object.php_namespace;
+    } else {
+      message.php_namespace = "";
+    }
+    if (
+      object.php_metadata_namespace !== undefined &&
+      object.php_metadata_namespace !== null
+    ) {
+      message.php_metadata_namespace = object.php_metadata_namespace;
+    } else {
+      message.php_metadata_namespace = "";
+    }
+    if (object.ruby_package !== undefined && object.ruby_package !== null) {
+      message.ruby_package = object.ruby_package;
+    } else {
+      message.ruby_package = "";
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseMessageOptions: object = {
+  message_set_wire_format: false,
+  no_standard_descriptor_accessor: false,
+  deprecated: false,
+  map_entry: false,
+};
+
+export const MessageOptions = {
+  encode(message: MessageOptions, writer: Writer = Writer.create()): Writer {
+    if (message.message_set_wire_format === true) {
+      writer.uint32(8).bool(message.message_set_wire_format);
+    }
+    if (message.no_standard_descriptor_accessor === true) {
+      writer.uint32(16).bool(message.no_standard_descriptor_accessor);
+    }
+    if (message.deprecated === true) {
+      writer.uint32(24).bool(message.deprecated);
+    }
+    if (message.map_entry === true) {
+      writer.uint32(56).bool(message.map_entry);
+    }
+    for (const v of message.uninterpreted_option) {
+      UninterpretedOption.encode(v!, writer.uint32(7994).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MessageOptions {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMessageOptions } as MessageOptions;
+    message.uninterpreted_option = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.message_set_wire_format = reader.bool();
+          break;
+        case 2:
+          message.no_standard_descriptor_accessor = reader.bool();
+          break;
+        case 3:
+          message.deprecated = reader.bool();
+          break;
+        case 7:
+          message.map_entry = reader.bool();
+          break;
+        case 999:
+          message.uninterpreted_option.push(
+            UninterpretedOption.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MessageOptions {
+    const message = { ...baseMessageOptions } as MessageOptions;
+    message.uninterpreted_option = [];
+    if (
+      object.message_set_wire_format !== undefined &&
+      object.message_set_wire_format !== null
+    ) {
+      message.message_set_wire_format = Boolean(object.message_set_wire_format);
+    } else {
+      message.message_set_wire_format = false;
+    }
+    if (
+      object.no_standard_descriptor_accessor !== undefined &&
+      object.no_standard_descriptor_accessor !== null
+    ) {
+      message.no_standard_descriptor_accessor = Boolean(
+        object.no_standard_descriptor_accessor
+      );
+    } else {
+      message.no_standard_descriptor_accessor = false;
+    }
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = Boolean(object.deprecated);
+    } else {
+      message.deprecated = false;
+    }
+    if (object.map_entry !== undefined && object.map_entry !== null) {
+      message.map_entry = Boolean(object.map_entry);
+    } else {
+      message.map_entry = false;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: MessageOptions): unknown {
+    const obj: any = {};
+    message.message_set_wire_format !== undefined &&
+      (obj.message_set_wire_format = message.message_set_wire_format);
+    message.no_standard_descriptor_accessor !== undefined &&
+      (obj.no_standard_descriptor_accessor =
+        message.no_standard_descriptor_accessor);
+    message.deprecated !== undefined && (obj.deprecated = message.deprecated);
+    message.map_entry !== undefined && (obj.map_entry = message.map_entry);
+    if (message.uninterpreted_option) {
+      obj.uninterpreted_option = message.uninterpreted_option.map((e) =>
+        e ? UninterpretedOption.toJSON(e) : undefined
+      );
+    } else {
+      obj.uninterpreted_option = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<MessageOptions>): MessageOptions {
+    const message = { ...baseMessageOptions } as MessageOptions;
+    message.uninterpreted_option = [];
+    if (
+      object.message_set_wire_format !== undefined &&
+      object.message_set_wire_format !== null
+    ) {
+      message.message_set_wire_format = object.message_set_wire_format;
+    } else {
+      message.message_set_wire_format = false;
+    }
+    if (
+      object.no_standard_descriptor_accessor !== undefined &&
+      object.no_standard_descriptor_accessor !== null
+    ) {
+      message.no_standard_descriptor_accessor =
+        object.no_standard_descriptor_accessor;
+    } else {
+      message.no_standard_descriptor_accessor = false;
+    }
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = object.deprecated;
+    } else {
+      message.deprecated = false;
+    }
+    if (object.map_entry !== undefined && object.map_entry !== null) {
+      message.map_entry = object.map_entry;
+    } else {
+      message.map_entry = false;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseFieldOptions: object = {
+  ctype: 0,
+  packed: false,
+  jstype: 0,
+  lazy: false,
+  deprecated: false,
+  weak: false,
+};
+
+export const FieldOptions = {
+  encode(message: FieldOptions, writer: Writer = Writer.create()): Writer {
+    if (message.ctype !== 0) {
+      writer.uint32(8).int32(message.ctype);
+    }
+    if (message.packed === true) {
+      writer.uint32(16).bool(message.packed);
+    }
+    if (message.jstype !== 0) {
+      writer.uint32(48).int32(message.jstype);
+    }
+    if (message.lazy === true) {
+      writer.uint32(40).bool(message.lazy);
+    }
+    if (message.deprecated === true) {
+      writer.uint32(24).bool(message.deprecated);
+    }
+    if (message.weak === true) {
+      writer.uint32(80).bool(message.weak);
+    }
+    for (const v of message.uninterpreted_option) {
+      UninterpretedOption.encode(v!, writer.uint32(7994).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): FieldOptions {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseFieldOptions } as FieldOptions;
+    message.uninterpreted_option = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.ctype = reader.int32() as any;
+          break;
+        case 2:
+          message.packed = reader.bool();
+          break;
+        case 6:
+          message.jstype = reader.int32() as any;
+          break;
+        case 5:
+          message.lazy = reader.bool();
+          break;
+        case 3:
+          message.deprecated = reader.bool();
+          break;
+        case 10:
+          message.weak = reader.bool();
+          break;
+        case 999:
+          message.uninterpreted_option.push(
+            UninterpretedOption.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): FieldOptions {
+    const message = { ...baseFieldOptions } as FieldOptions;
+    message.uninterpreted_option = [];
+    if (object.ctype !== undefined && object.ctype !== null) {
+      message.ctype = fieldOptions_CTypeFromJSON(object.ctype);
+    } else {
+      message.ctype = 0;
+    }
+    if (object.packed !== undefined && object.packed !== null) {
+      message.packed = Boolean(object.packed);
+    } else {
+      message.packed = false;
+    }
+    if (object.jstype !== undefined && object.jstype !== null) {
+      message.jstype = fieldOptions_JSTypeFromJSON(object.jstype);
+    } else {
+      message.jstype = 0;
+    }
+    if (object.lazy !== undefined && object.lazy !== null) {
+      message.lazy = Boolean(object.lazy);
+    } else {
+      message.lazy = false;
+    }
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = Boolean(object.deprecated);
+    } else {
+      message.deprecated = false;
+    }
+    if (object.weak !== undefined && object.weak !== null) {
+      message.weak = Boolean(object.weak);
+    } else {
+      message.weak = false;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: FieldOptions): unknown {
+    const obj: any = {};
+    message.ctype !== undefined &&
+      (obj.ctype = fieldOptions_CTypeToJSON(message.ctype));
+    message.packed !== undefined && (obj.packed = message.packed);
+    message.jstype !== undefined &&
+      (obj.jstype = fieldOptions_JSTypeToJSON(message.jstype));
+    message.lazy !== undefined && (obj.lazy = message.lazy);
+    message.deprecated !== undefined && (obj.deprecated = message.deprecated);
+    message.weak !== undefined && (obj.weak = message.weak);
+    if (message.uninterpreted_option) {
+      obj.uninterpreted_option = message.uninterpreted_option.map((e) =>
+        e ? UninterpretedOption.toJSON(e) : undefined
+      );
+    } else {
+      obj.uninterpreted_option = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<FieldOptions>): FieldOptions {
+    const message = { ...baseFieldOptions } as FieldOptions;
+    message.uninterpreted_option = [];
+    if (object.ctype !== undefined && object.ctype !== null) {
+      message.ctype = object.ctype;
+    } else {
+      message.ctype = 0;
+    }
+    if (object.packed !== undefined && object.packed !== null) {
+      message.packed = object.packed;
+    } else {
+      message.packed = false;
+    }
+    if (object.jstype !== undefined && object.jstype !== null) {
+      message.jstype = object.jstype;
+    } else {
+      message.jstype = 0;
+    }
+    if (object.lazy !== undefined && object.lazy !== null) {
+      message.lazy = object.lazy;
+    } else {
+      message.lazy = false;
+    }
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = object.deprecated;
+    } else {
+      message.deprecated = false;
+    }
+    if (object.weak !== undefined && object.weak !== null) {
+      message.weak = object.weak;
+    } else {
+      message.weak = false;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseOneofOptions: object = {};
+
+export const OneofOptions = {
+  encode(message: OneofOptions, writer: Writer = Writer.create()): Writer {
+    for (const v of message.uninterpreted_option) {
+      UninterpretedOption.encode(v!, writer.uint32(7994).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): OneofOptions {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseOneofOptions } as OneofOptions;
+    message.uninterpreted_option = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 999:
+          message.uninterpreted_option.push(
+            UninterpretedOption.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): OneofOptions {
+    const message = { ...baseOneofOptions } as OneofOptions;
+    message.uninterpreted_option = [];
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: OneofOptions): unknown {
+    const obj: any = {};
+    if (message.uninterpreted_option) {
+      obj.uninterpreted_option = message.uninterpreted_option.map((e) =>
+        e ? UninterpretedOption.toJSON(e) : undefined
+      );
+    } else {
+      obj.uninterpreted_option = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<OneofOptions>): OneofOptions {
+    const message = { ...baseOneofOptions } as OneofOptions;
+    message.uninterpreted_option = [];
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseEnumOptions: object = { allow_alias: false, deprecated: false };
+
+export const EnumOptions = {
+  encode(message: EnumOptions, writer: Writer = Writer.create()): Writer {
+    if (message.allow_alias === true) {
+      writer.uint32(16).bool(message.allow_alias);
+    }
+    if (message.deprecated === true) {
+      writer.uint32(24).bool(message.deprecated);
+    }
+    for (const v of message.uninterpreted_option) {
+      UninterpretedOption.encode(v!, writer.uint32(7994).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): EnumOptions {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseEnumOptions } as EnumOptions;
+    message.uninterpreted_option = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 2:
+          message.allow_alias = reader.bool();
+          break;
+        case 3:
+          message.deprecated = reader.bool();
+          break;
+        case 999:
+          message.uninterpreted_option.push(
+            UninterpretedOption.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): EnumOptions {
+    const message = { ...baseEnumOptions } as EnumOptions;
+    message.uninterpreted_option = [];
+    if (object.allow_alias !== undefined && object.allow_alias !== null) {
+      message.allow_alias = Boolean(object.allow_alias);
+    } else {
+      message.allow_alias = false;
+    }
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = Boolean(object.deprecated);
+    } else {
+      message.deprecated = false;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: EnumOptions): unknown {
+    const obj: any = {};
+    message.allow_alias !== undefined &&
+      (obj.allow_alias = message.allow_alias);
+    message.deprecated !== undefined && (obj.deprecated = message.deprecated);
+    if (message.uninterpreted_option) {
+      obj.uninterpreted_option = message.uninterpreted_option.map((e) =>
+        e ? UninterpretedOption.toJSON(e) : undefined
+      );
+    } else {
+      obj.uninterpreted_option = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<EnumOptions>): EnumOptions {
+    const message = { ...baseEnumOptions } as EnumOptions;
+    message.uninterpreted_option = [];
+    if (object.allow_alias !== undefined && object.allow_alias !== null) {
+      message.allow_alias = object.allow_alias;
+    } else {
+      message.allow_alias = false;
+    }
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = object.deprecated;
+    } else {
+      message.deprecated = false;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseEnumValueOptions: object = { deprecated: false };
+
+export const EnumValueOptions = {
+  encode(message: EnumValueOptions, writer: Writer = Writer.create()): Writer {
+    if (message.deprecated === true) {
+      writer.uint32(8).bool(message.deprecated);
+    }
+    for (const v of message.uninterpreted_option) {
+      UninterpretedOption.encode(v!, writer.uint32(7994).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): EnumValueOptions {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseEnumValueOptions } as EnumValueOptions;
+    message.uninterpreted_option = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.deprecated = reader.bool();
+          break;
+        case 999:
+          message.uninterpreted_option.push(
+            UninterpretedOption.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): EnumValueOptions {
+    const message = { ...baseEnumValueOptions } as EnumValueOptions;
+    message.uninterpreted_option = [];
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = Boolean(object.deprecated);
+    } else {
+      message.deprecated = false;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: EnumValueOptions): unknown {
+    const obj: any = {};
+    message.deprecated !== undefined && (obj.deprecated = message.deprecated);
+    if (message.uninterpreted_option) {
+      obj.uninterpreted_option = message.uninterpreted_option.map((e) =>
+        e ? UninterpretedOption.toJSON(e) : undefined
+      );
+    } else {
+      obj.uninterpreted_option = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<EnumValueOptions>): EnumValueOptions {
+    const message = { ...baseEnumValueOptions } as EnumValueOptions;
+    message.uninterpreted_option = [];
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = object.deprecated;
+    } else {
+      message.deprecated = false;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseServiceOptions: object = { deprecated: false };
+
+export const ServiceOptions = {
+  encode(message: ServiceOptions, writer: Writer = Writer.create()): Writer {
+    if (message.deprecated === true) {
+      writer.uint32(264).bool(message.deprecated);
+    }
+    for (const v of message.uninterpreted_option) {
+      UninterpretedOption.encode(v!, writer.uint32(7994).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): ServiceOptions {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseServiceOptions } as ServiceOptions;
+    message.uninterpreted_option = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 33:
+          message.deprecated = reader.bool();
+          break;
+        case 999:
+          message.uninterpreted_option.push(
+            UninterpretedOption.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): ServiceOptions {
+    const message = { ...baseServiceOptions } as ServiceOptions;
+    message.uninterpreted_option = [];
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = Boolean(object.deprecated);
+    } else {
+      message.deprecated = false;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: ServiceOptions): unknown {
+    const obj: any = {};
+    message.deprecated !== undefined && (obj.deprecated = message.deprecated);
+    if (message.uninterpreted_option) {
+      obj.uninterpreted_option = message.uninterpreted_option.map((e) =>
+        e ? UninterpretedOption.toJSON(e) : undefined
+      );
+    } else {
+      obj.uninterpreted_option = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<ServiceOptions>): ServiceOptions {
+    const message = { ...baseServiceOptions } as ServiceOptions;
+    message.uninterpreted_option = [];
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = object.deprecated;
+    } else {
+      message.deprecated = false;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseMethodOptions: object = { deprecated: false, idempotency_level: 0 };
+
+export const MethodOptions = {
+  encode(message: MethodOptions, writer: Writer = Writer.create()): Writer {
+    if (message.deprecated === true) {
+      writer.uint32(264).bool(message.deprecated);
+    }
+    if (message.idempotency_level !== 0) {
+      writer.uint32(272).int32(message.idempotency_level);
+    }
+    for (const v of message.uninterpreted_option) {
+      UninterpretedOption.encode(v!, writer.uint32(7994).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MethodOptions {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMethodOptions } as MethodOptions;
+    message.uninterpreted_option = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 33:
+          message.deprecated = reader.bool();
+          break;
+        case 34:
+          message.idempotency_level = reader.int32() as any;
+          break;
+        case 999:
+          message.uninterpreted_option.push(
+            UninterpretedOption.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MethodOptions {
+    const message = { ...baseMethodOptions } as MethodOptions;
+    message.uninterpreted_option = [];
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = Boolean(object.deprecated);
+    } else {
+      message.deprecated = false;
+    }
+    if (
+      object.idempotency_level !== undefined &&
+      object.idempotency_level !== null
+    ) {
+      message.idempotency_level = methodOptions_IdempotencyLevelFromJSON(
+        object.idempotency_level
+      );
+    } else {
+      message.idempotency_level = 0;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: MethodOptions): unknown {
+    const obj: any = {};
+    message.deprecated !== undefined && (obj.deprecated = message.deprecated);
+    message.idempotency_level !== undefined &&
+      (obj.idempotency_level = methodOptions_IdempotencyLevelToJSON(
+        message.idempotency_level
+      ));
+    if (message.uninterpreted_option) {
+      obj.uninterpreted_option = message.uninterpreted_option.map((e) =>
+        e ? UninterpretedOption.toJSON(e) : undefined
+      );
+    } else {
+      obj.uninterpreted_option = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<MethodOptions>): MethodOptions {
+    const message = { ...baseMethodOptions } as MethodOptions;
+    message.uninterpreted_option = [];
+    if (object.deprecated !== undefined && object.deprecated !== null) {
+      message.deprecated = object.deprecated;
+    } else {
+      message.deprecated = false;
+    }
+    if (
+      object.idempotency_level !== undefined &&
+      object.idempotency_level !== null
+    ) {
+      message.idempotency_level = object.idempotency_level;
+    } else {
+      message.idempotency_level = 0;
+    }
+    if (
+      object.uninterpreted_option !== undefined &&
+      object.uninterpreted_option !== null
+    ) {
+      for (const e of object.uninterpreted_option) {
+        message.uninterpreted_option.push(UninterpretedOption.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseUninterpretedOption: object = {
+  identifier_value: "",
+  positive_int_value: 0,
+  negative_int_value: 0,
+  double_value: 0,
+  aggregate_value: "",
+};
+
+export const UninterpretedOption = {
+  encode(
+    message: UninterpretedOption,
+    writer: Writer = Writer.create()
+  ): Writer {
+    for (const v of message.name) {
+      UninterpretedOption_NamePart.encode(
+        v!,
+        writer.uint32(18).fork()
+      ).ldelim();
+    }
+    if (message.identifier_value !== "") {
+      writer.uint32(26).string(message.identifier_value);
+    }
+    if (message.positive_int_value !== 0) {
+      writer.uint32(32).uint64(message.positive_int_value);
+    }
+    if (message.negative_int_value !== 0) {
+      writer.uint32(40).int64(message.negative_int_value);
+    }
+    if (message.double_value !== 0) {
+      writer.uint32(49).double(message.double_value);
+    }
+    if (message.string_value.length !== 0) {
+      writer.uint32(58).bytes(message.string_value);
+    }
+    if (message.aggregate_value !== "") {
+      writer.uint32(66).string(message.aggregate_value);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): UninterpretedOption {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseUninterpretedOption } as UninterpretedOption;
+    message.name = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 2:
+          message.name.push(
+            UninterpretedOption_NamePart.decode(reader, reader.uint32())
+          );
+          break;
+        case 3:
+          message.identifier_value = reader.string();
+          break;
+        case 4:
+          message.positive_int_value = longToNumber(reader.uint64() as Long);
+          break;
+        case 5:
+          message.negative_int_value = longToNumber(reader.int64() as Long);
+          break;
+        case 6:
+          message.double_value = reader.double();
+          break;
+        case 7:
+          message.string_value = reader.bytes();
+          break;
+        case 8:
+          message.aggregate_value = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): UninterpretedOption {
+    const message = { ...baseUninterpretedOption } as UninterpretedOption;
+    message.name = [];
+    if (object.name !== undefined && object.name !== null) {
+      for (const e of object.name) {
+        message.name.push(UninterpretedOption_NamePart.fromJSON(e));
+      }
+    }
+    if (
+      object.identifier_value !== undefined &&
+      object.identifier_value !== null
+    ) {
+      message.identifier_value = String(object.identifier_value);
+    } else {
+      message.identifier_value = "";
+    }
+    if (
+      object.positive_int_value !== undefined &&
+      object.positive_int_value !== null
+    ) {
+      message.positive_int_value = Number(object.positive_int_value);
+    } else {
+      message.positive_int_value = 0;
+    }
+    if (
+      object.negative_int_value !== undefined &&
+      object.negative_int_value !== null
+    ) {
+      message.negative_int_value = Number(object.negative_int_value);
+    } else {
+      message.negative_int_value = 0;
+    }
+    if (object.double_value !== undefined && object.double_value !== null) {
+      message.double_value = Number(object.double_value);
+    } else {
+      message.double_value = 0;
+    }
+    if (object.string_value !== undefined && object.string_value !== null) {
+      message.string_value = bytesFromBase64(object.string_value);
+    }
+    if (
+      object.aggregate_value !== undefined &&
+      object.aggregate_value !== null
+    ) {
+      message.aggregate_value = String(object.aggregate_value);
+    } else {
+      message.aggregate_value = "";
+    }
+    return message;
+  },
+
+  toJSON(message: UninterpretedOption): unknown {
+    const obj: any = {};
+    if (message.name) {
+      obj.name = message.name.map((e) =>
+        e ? UninterpretedOption_NamePart.toJSON(e) : undefined
+      );
+    } else {
+      obj.name = [];
+    }
+    message.identifier_value !== undefined &&
+      (obj.identifier_value = message.identifier_value);
+    message.positive_int_value !== undefined &&
+      (obj.positive_int_value = message.positive_int_value);
+    message.negative_int_value !== undefined &&
+      (obj.negative_int_value = message.negative_int_value);
+    message.double_value !== undefined &&
+      (obj.double_value = message.double_value);
+    message.string_value !== undefined &&
+      (obj.string_value = base64FromBytes(
+        message.string_value !== undefined
+          ? message.string_value
+          : new Uint8Array()
+      ));
+    message.aggregate_value !== undefined &&
+      (obj.aggregate_value = message.aggregate_value);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<UninterpretedOption>): UninterpretedOption {
+    const message = { ...baseUninterpretedOption } as UninterpretedOption;
+    message.name = [];
+    if (object.name !== undefined && object.name !== null) {
+      for (const e of object.name) {
+        message.name.push(UninterpretedOption_NamePart.fromPartial(e));
+      }
+    }
+    if (
+      object.identifier_value !== undefined &&
+      object.identifier_value !== null
+    ) {
+      message.identifier_value = object.identifier_value;
+    } else {
+      message.identifier_value = "";
+    }
+    if (
+      object.positive_int_value !== undefined &&
+      object.positive_int_value !== null
+    ) {
+      message.positive_int_value = object.positive_int_value;
+    } else {
+      message.positive_int_value = 0;
+    }
+    if (
+      object.negative_int_value !== undefined &&
+      object.negative_int_value !== null
+    ) {
+      message.negative_int_value = object.negative_int_value;
+    } else {
+      message.negative_int_value = 0;
+    }
+    if (object.double_value !== undefined && object.double_value !== null) {
+      message.double_value = object.double_value;
+    } else {
+      message.double_value = 0;
+    }
+    if (object.string_value !== undefined && object.string_value !== null) {
+      message.string_value = object.string_value;
+    } else {
+      message.string_value = new Uint8Array();
+    }
+    if (
+      object.aggregate_value !== undefined &&
+      object.aggregate_value !== null
+    ) {
+      message.aggregate_value = object.aggregate_value;
+    } else {
+      message.aggregate_value = "";
+    }
+    return message;
+  },
+};
+
+const baseUninterpretedOption_NamePart: object = {
+  name_part: "",
+  is_extension: false,
+};
+
+export const UninterpretedOption_NamePart = {
+  encode(
+    message: UninterpretedOption_NamePart,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.name_part !== "") {
+      writer.uint32(10).string(message.name_part);
+    }
+    if (message.is_extension === true) {
+      writer.uint32(16).bool(message.is_extension);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): UninterpretedOption_NamePart {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseUninterpretedOption_NamePart,
+    } as UninterpretedOption_NamePart;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.name_part = reader.string();
+          break;
+        case 2:
+          message.is_extension = reader.bool();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): UninterpretedOption_NamePart {
+    const message = {
+      ...baseUninterpretedOption_NamePart,
+    } as UninterpretedOption_NamePart;
+    if (object.name_part !== undefined && object.name_part !== null) {
+      message.name_part = String(object.name_part);
+    } else {
+      message.name_part = "";
+    }
+    if (object.is_extension !== undefined && object.is_extension !== null) {
+      message.is_extension = Boolean(object.is_extension);
+    } else {
+      message.is_extension = false;
+    }
+    return message;
+  },
+
+  toJSON(message: UninterpretedOption_NamePart): unknown {
+    const obj: any = {};
+    message.name_part !== undefined && (obj.name_part = message.name_part);
+    message.is_extension !== undefined &&
+      (obj.is_extension = message.is_extension);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<UninterpretedOption_NamePart>
+  ): UninterpretedOption_NamePart {
+    const message = {
+      ...baseUninterpretedOption_NamePart,
+    } as UninterpretedOption_NamePart;
+    if (object.name_part !== undefined && object.name_part !== null) {
+      message.name_part = object.name_part;
+    } else {
+      message.name_part = "";
+    }
+    if (object.is_extension !== undefined && object.is_extension !== null) {
+      message.is_extension = object.is_extension;
+    } else {
+      message.is_extension = false;
+    }
+    return message;
+  },
+};
+
+const baseSourceCodeInfo: object = {};
+
+export const SourceCodeInfo = {
+  encode(message: SourceCodeInfo, writer: Writer = Writer.create()): Writer {
+    for (const v of message.location) {
+      SourceCodeInfo_Location.encode(v!, writer.uint32(10).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): SourceCodeInfo {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseSourceCodeInfo } as SourceCodeInfo;
+    message.location = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.location.push(
+            SourceCodeInfo_Location.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): SourceCodeInfo {
+    const message = { ...baseSourceCodeInfo } as SourceCodeInfo;
+    message.location = [];
+    if (object.location !== undefined && object.location !== null) {
+      for (const e of object.location) {
+        message.location.push(SourceCodeInfo_Location.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: SourceCodeInfo): unknown {
+    const obj: any = {};
+    if (message.location) {
+      obj.location = message.location.map((e) =>
+        e ? SourceCodeInfo_Location.toJSON(e) : undefined
+      );
+    } else {
+      obj.location = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<SourceCodeInfo>): SourceCodeInfo {
+    const message = { ...baseSourceCodeInfo } as SourceCodeInfo;
+    message.location = [];
+    if (object.location !== undefined && object.location !== null) {
+      for (const e of object.location) {
+        message.location.push(SourceCodeInfo_Location.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseSourceCodeInfo_Location: object = {
+  path: 0,
+  span: 0,
+  leading_comments: "",
+  trailing_comments: "",
+  leading_detached_comments: "",
+};
+
+export const SourceCodeInfo_Location = {
+  encode(
+    message: SourceCodeInfo_Location,
+    writer: Writer = Writer.create()
+  ): Writer {
+    writer.uint32(10).fork();
+    for (const v of message.path) {
+      writer.int32(v);
+    }
+    writer.ldelim();
+    writer.uint32(18).fork();
+    for (const v of message.span) {
+      writer.int32(v);
+    }
+    writer.ldelim();
+    if (message.leading_comments !== "") {
+      writer.uint32(26).string(message.leading_comments);
+    }
+    if (message.trailing_comments !== "") {
+      writer.uint32(34).string(message.trailing_comments);
+    }
+    for (const v of message.leading_detached_comments) {
+      writer.uint32(50).string(v!);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): SourceCodeInfo_Location {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseSourceCodeInfo_Location,
+    } as SourceCodeInfo_Location;
+    message.path = [];
+    message.span = [];
+    message.leading_detached_comments = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          if ((tag & 7) === 2) {
+            const end2 = reader.uint32() + reader.pos;
+            while (reader.pos < end2) {
+              message.path.push(reader.int32());
+            }
+          } else {
+            message.path.push(reader.int32());
+          }
+          break;
+        case 2:
+          if ((tag & 7) === 2) {
+            const end2 = reader.uint32() + reader.pos;
+            while (reader.pos < end2) {
+              message.span.push(reader.int32());
+            }
+          } else {
+            message.span.push(reader.int32());
+          }
+          break;
+        case 3:
+          message.leading_comments = reader.string();
+          break;
+        case 4:
+          message.trailing_comments = reader.string();
+          break;
+        case 6:
+          message.leading_detached_comments.push(reader.string());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): SourceCodeInfo_Location {
+    const message = {
+      ...baseSourceCodeInfo_Location,
+    } as SourceCodeInfo_Location;
+    message.path = [];
+    message.span = [];
+    message.leading_detached_comments = [];
+    if (object.path !== undefined && object.path !== null) {
+      for (const e of object.path) {
+        message.path.push(Number(e));
+      }
+    }
+    if (object.span !== undefined && object.span !== null) {
+      for (const e of object.span) {
+        message.span.push(Number(e));
+      }
+    }
+    if (
+      object.leading_comments !== undefined &&
+      object.leading_comments !== null
+    ) {
+      message.leading_comments = String(object.leading_comments);
+    } else {
+      message.leading_comments = "";
+    }
+    if (
+      object.trailing_comments !== undefined &&
+      object.trailing_comments !== null
+    ) {
+      message.trailing_comments = String(object.trailing_comments);
+    } else {
+      message.trailing_comments = "";
+    }
+    if (
+      object.leading_detached_comments !== undefined &&
+      object.leading_detached_comments !== null
+    ) {
+      for (const e of object.leading_detached_comments) {
+        message.leading_detached_comments.push(String(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: SourceCodeInfo_Location): unknown {
+    const obj: any = {};
+    if (message.path) {
+      obj.path = message.path.map((e) => e);
+    } else {
+      obj.path = [];
+    }
+    if (message.span) {
+      obj.span = message.span.map((e) => e);
+    } else {
+      obj.span = [];
+    }
+    message.leading_comments !== undefined &&
+      (obj.leading_comments = message.leading_comments);
+    message.trailing_comments !== undefined &&
+      (obj.trailing_comments = message.trailing_comments);
+    if (message.leading_detached_comments) {
+      obj.leading_detached_comments = message.leading_detached_comments.map(
+        (e) => e
+      );
+    } else {
+      obj.leading_detached_comments = [];
+    }
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<SourceCodeInfo_Location>
+  ): SourceCodeInfo_Location {
+    const message = {
+      ...baseSourceCodeInfo_Location,
+    } as SourceCodeInfo_Location;
+    message.path = [];
+    message.span = [];
+    message.leading_detached_comments = [];
+    if (object.path !== undefined && object.path !== null) {
+      for (const e of object.path) {
+        message.path.push(e);
+      }
+    }
+    if (object.span !== undefined && object.span !== null) {
+      for (const e of object.span) {
+        message.span.push(e);
+      }
+    }
+    if (
+      object.leading_comments !== undefined &&
+      object.leading_comments !== null
+    ) {
+      message.leading_comments = object.leading_comments;
+    } else {
+      message.leading_comments = "";
+    }
+    if (
+      object.trailing_comments !== undefined &&
+      object.trailing_comments !== null
+    ) {
+      message.trailing_comments = object.trailing_comments;
+    } else {
+      message.trailing_comments = "";
+    }
+    if (
+      object.leading_detached_comments !== undefined &&
+      object.leading_detached_comments !== null
+    ) {
+      for (const e of object.leading_detached_comments) {
+        message.leading_detached_comments.push(e);
+      }
+    }
+    return message;
+  },
+};
+
+const baseGeneratedCodeInfo: object = {};
+
+export const GeneratedCodeInfo = {
+  encode(message: GeneratedCodeInfo, writer: Writer = Writer.create()): Writer {
+    for (const v of message.annotation) {
+      GeneratedCodeInfo_Annotation.encode(
+        v!,
+        writer.uint32(10).fork()
+      ).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): GeneratedCodeInfo {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseGeneratedCodeInfo } as GeneratedCodeInfo;
+    message.annotation = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.annotation.push(
+            GeneratedCodeInfo_Annotation.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): GeneratedCodeInfo {
+    const message = { ...baseGeneratedCodeInfo } as GeneratedCodeInfo;
+    message.annotation = [];
+    if (object.annotation !== undefined && object.annotation !== null) {
+      for (const e of object.annotation) {
+        message.annotation.push(GeneratedCodeInfo_Annotation.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: GeneratedCodeInfo): unknown {
+    const obj: any = {};
+    if (message.annotation) {
+      obj.annotation = message.annotation.map((e) =>
+        e ? GeneratedCodeInfo_Annotation.toJSON(e) : undefined
+      );
+    } else {
+      obj.annotation = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<GeneratedCodeInfo>): GeneratedCodeInfo {
+    const message = { ...baseGeneratedCodeInfo } as GeneratedCodeInfo;
+    message.annotation = [];
+    if (object.annotation !== undefined && object.annotation !== null) {
+      for (const e of object.annotation) {
+        message.annotation.push(GeneratedCodeInfo_Annotation.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseGeneratedCodeInfo_Annotation: object = {
+  path: 0,
+  source_file: "",
+  begin: 0,
+  end: 0,
+};
+
+export const GeneratedCodeInfo_Annotation = {
+  encode(
+    message: GeneratedCodeInfo_Annotation,
+    writer: Writer = Writer.create()
+  ): Writer {
+    writer.uint32(10).fork();
+    for (const v of message.path) {
+      writer.int32(v);
+    }
+    writer.ldelim();
+    if (message.source_file !== "") {
+      writer.uint32(18).string(message.source_file);
+    }
+    if (message.begin !== 0) {
+      writer.uint32(24).int32(message.begin);
+    }
+    if (message.end !== 0) {
+      writer.uint32(32).int32(message.end);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): GeneratedCodeInfo_Annotation {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseGeneratedCodeInfo_Annotation,
+    } as GeneratedCodeInfo_Annotation;
+    message.path = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          if ((tag & 7) === 2) {
+            const end2 = reader.uint32() + reader.pos;
+            while (reader.pos < end2) {
+              message.path.push(reader.int32());
+            }
+          } else {
+            message.path.push(reader.int32());
+          }
+          break;
+        case 2:
+          message.source_file = reader.string();
+          break;
+        case 3:
+          message.begin = reader.int32();
+          break;
+        case 4:
+          message.end = reader.int32();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): GeneratedCodeInfo_Annotation {
+    const message = {
+      ...baseGeneratedCodeInfo_Annotation,
+    } as GeneratedCodeInfo_Annotation;
+    message.path = [];
+    if (object.path !== undefined && object.path !== null) {
+      for (const e of object.path) {
+        message.path.push(Number(e));
+      }
+    }
+    if (object.source_file !== undefined && object.source_file !== null) {
+      message.source_file = String(object.source_file);
+    } else {
+      message.source_file = "";
+    }
+    if (object.begin !== undefined && object.begin !== null) {
+      message.begin = Number(object.begin);
+    } else {
+      message.begin = 0;
+    }
+    if (object.end !== undefined && object.end !== null) {
+      message.end = Number(object.end);
+    } else {
+      message.end = 0;
+    }
+    return message;
+  },
+
+  toJSON(message: GeneratedCodeInfo_Annotation): unknown {
+    const obj: any = {};
+    if (message.path) {
+      obj.path = message.path.map((e) => e);
+    } else {
+      obj.path = [];
+    }
+    message.source_file !== undefined &&
+      (obj.source_file = message.source_file);
+    message.begin !== undefined && (obj.begin = message.begin);
+    message.end !== undefined && (obj.end = message.end);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<GeneratedCodeInfo_Annotation>
+  ): GeneratedCodeInfo_Annotation {
+    const message = {
+      ...baseGeneratedCodeInfo_Annotation,
+    } as GeneratedCodeInfo_Annotation;
+    message.path = [];
+    if (object.path !== undefined && object.path !== null) {
+      for (const e of object.path) {
+        message.path.push(e);
+      }
+    }
+    if (object.source_file !== undefined && object.source_file !== null) {
+      message.source_file = object.source_file;
+    } else {
+      message.source_file = "";
+    }
+    if (object.begin !== undefined && object.begin !== null) {
+      message.begin = object.begin;
+    } else {
+      message.begin = 0;
+    }
+    if (object.end !== undefined && object.end !== null) {
+      message.end = object.end;
+    } else {
+      message.end = 0;
+    }
+    return message;
+  },
+};
+
+declare var self: any | undefined;
+declare var window: any | undefined;
+var globalThis: any = (() => {
+  if (typeof globalThis !== "undefined") return globalThis;
+  if (typeof self !== "undefined") return self;
+  if (typeof window !== "undefined") return window;
+  if (typeof global !== "undefined") return global;
+  throw "Unable to locate global object";
+})();
+
+const atob: (b64: string) => string =
+  globalThis.atob ||
+  ((b64) => globalThis.Buffer.from(b64, "base64").toString("binary"));
+function bytesFromBase64(b64: string): Uint8Array {
+  const bin = atob(b64);
+  const arr = new Uint8Array(bin.length);
+  for (let i = 0; i < bin.length; ++i) {
+    arr[i] = bin.charCodeAt(i);
+  }
+  return arr;
+}
+
+const btoa: (bin: string) => string =
+  globalThis.btoa ||
+  ((bin) => globalThis.Buffer.from(bin, "binary").toString("base64"));
+function base64FromBytes(arr: Uint8Array): string {
+  const bin: string[] = [];
+  for (let i = 0; i < arr.byteLength; ++i) {
+    bin.push(String.fromCharCode(arr[i]));
+  }
+  return btoa(bin.join(""));
+}
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;
+
+function longToNumber(long: Long): number {
+  if (long.gt(Number.MAX_SAFE_INTEGER)) {
+    throw new globalThis.Error("Value is larger than Number.MAX_SAFE_INTEGER");
+  }
+  return long.toNumber();
+}
+
+if (util.Long !== Long) {
+  util.Long = Long as any;
+  configure();
+}

+ 86 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/osmosis/tokenfactory/v1beta1/authorityMetadata.ts

@@ -0,0 +1,86 @@
+//@ts-nocheck
+/* eslint-disable */
+import { Writer, Reader } from "protobufjs/minimal";
+
+export const protobufPackage = "osmosis.tokenfactory.v1beta1";
+
+/**
+ * DenomAuthorityMetadata specifies metadata for addresses that have specific
+ * capabilities over a token factory denom. Right now there is only one Admin
+ * permission, but is planned to be extended to the future.
+ */
+export interface DenomAuthorityMetadata {
+  /** Can be empty for no admin, or a valid osmosis address */
+  admin: string;
+}
+
+const baseDenomAuthorityMetadata: object = { admin: "" };
+
+export const DenomAuthorityMetadata = {
+  encode(
+    message: DenomAuthorityMetadata,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.admin !== "") {
+      writer.uint32(10).string(message.admin);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): DenomAuthorityMetadata {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseDenomAuthorityMetadata } as DenomAuthorityMetadata;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.admin = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): DenomAuthorityMetadata {
+    const message = { ...baseDenomAuthorityMetadata } as DenomAuthorityMetadata;
+    if (object.admin !== undefined && object.admin !== null) {
+      message.admin = String(object.admin);
+    } else {
+      message.admin = "";
+    }
+    return message;
+  },
+
+  toJSON(message: DenomAuthorityMetadata): unknown {
+    const obj: any = {};
+    message.admin !== undefined && (obj.admin = message.admin);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<DenomAuthorityMetadata>
+  ): DenomAuthorityMetadata {
+    const message = { ...baseDenomAuthorityMetadata } as DenomAuthorityMetadata;
+    if (object.admin !== undefined && object.admin !== null) {
+      message.admin = object.admin;
+    } else {
+      message.admin = "";
+    }
+    return message;
+  },
+};
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;

+ 210 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/osmosis/tokenfactory/v1beta1/genesis.ts

@@ -0,0 +1,210 @@
+//@ts-nocheck
+/* eslint-disable */
+import { Params } from "../../../osmosis/tokenfactory/v1beta1/params";
+import { DenomAuthorityMetadata } from "../../../osmosis/tokenfactory/v1beta1/authorityMetadata";
+import { Writer, Reader } from "protobufjs/minimal";
+
+export const protobufPackage = "osmosis.tokenfactory.v1beta1";
+
+/** GenesisState defines the tokenfactory module's genesis state. */
+export interface GenesisState {
+  /** params defines the paramaters of the module. */
+  params: Params | undefined;
+  factory_denoms: GenesisDenom[];
+}
+
+/**
+ * GenesisDenom defines a tokenfactory denom that is defined within genesis
+ * state. The structure contains DenomAuthorityMetadata which defines the
+ * denom's admin.
+ */
+export interface GenesisDenom {
+  denom: string;
+  authority_metadata: DenomAuthorityMetadata | undefined;
+}
+
+const baseGenesisState: object = {};
+
+export const GenesisState = {
+  encode(message: GenesisState, writer: Writer = Writer.create()): Writer {
+    if (message.params !== undefined) {
+      Params.encode(message.params, writer.uint32(10).fork()).ldelim();
+    }
+    for (const v of message.factory_denoms) {
+      GenesisDenom.encode(v!, writer.uint32(18).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): GenesisState {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseGenesisState } as GenesisState;
+    message.factory_denoms = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.params = Params.decode(reader, reader.uint32());
+          break;
+        case 2:
+          message.factory_denoms.push(
+            GenesisDenom.decode(reader, reader.uint32())
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): GenesisState {
+    const message = { ...baseGenesisState } as GenesisState;
+    message.factory_denoms = [];
+    if (object.params !== undefined && object.params !== null) {
+      message.params = Params.fromJSON(object.params);
+    } else {
+      message.params = undefined;
+    }
+    if (object.factory_denoms !== undefined && object.factory_denoms !== null) {
+      for (const e of object.factory_denoms) {
+        message.factory_denoms.push(GenesisDenom.fromJSON(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: GenesisState): unknown {
+    const obj: any = {};
+    message.params !== undefined &&
+      (obj.params = message.params ? Params.toJSON(message.params) : undefined);
+    if (message.factory_denoms) {
+      obj.factory_denoms = message.factory_denoms.map((e) =>
+        e ? GenesisDenom.toJSON(e) : undefined
+      );
+    } else {
+      obj.factory_denoms = [];
+    }
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<GenesisState>): GenesisState {
+    const message = { ...baseGenesisState } as GenesisState;
+    message.factory_denoms = [];
+    if (object.params !== undefined && object.params !== null) {
+      message.params = Params.fromPartial(object.params);
+    } else {
+      message.params = undefined;
+    }
+    if (object.factory_denoms !== undefined && object.factory_denoms !== null) {
+      for (const e of object.factory_denoms) {
+        message.factory_denoms.push(GenesisDenom.fromPartial(e));
+      }
+    }
+    return message;
+  },
+};
+
+const baseGenesisDenom: object = { denom: "" };
+
+export const GenesisDenom = {
+  encode(message: GenesisDenom, writer: Writer = Writer.create()): Writer {
+    if (message.denom !== "") {
+      writer.uint32(10).string(message.denom);
+    }
+    if (message.authority_metadata !== undefined) {
+      DenomAuthorityMetadata.encode(
+        message.authority_metadata,
+        writer.uint32(18).fork()
+      ).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): GenesisDenom {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseGenesisDenom } as GenesisDenom;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.denom = reader.string();
+          break;
+        case 2:
+          message.authority_metadata = DenomAuthorityMetadata.decode(
+            reader,
+            reader.uint32()
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): GenesisDenom {
+    const message = { ...baseGenesisDenom } as GenesisDenom;
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = String(object.denom);
+    } else {
+      message.denom = "";
+    }
+    if (
+      object.authority_metadata !== undefined &&
+      object.authority_metadata !== null
+    ) {
+      message.authority_metadata = DenomAuthorityMetadata.fromJSON(
+        object.authority_metadata
+      );
+    } else {
+      message.authority_metadata = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: GenesisDenom): unknown {
+    const obj: any = {};
+    message.denom !== undefined && (obj.denom = message.denom);
+    message.authority_metadata !== undefined &&
+      (obj.authority_metadata = message.authority_metadata
+        ? DenomAuthorityMetadata.toJSON(message.authority_metadata)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<GenesisDenom>): GenesisDenom {
+    const message = { ...baseGenesisDenom } as GenesisDenom;
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = object.denom;
+    } else {
+      message.denom = "";
+    }
+    if (
+      object.authority_metadata !== undefined &&
+      object.authority_metadata !== null
+    ) {
+      message.authority_metadata = DenomAuthorityMetadata.fromPartial(
+        object.authority_metadata
+      );
+    } else {
+      message.authority_metadata = undefined;
+    }
+    return message;
+  },
+};
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;

+ 149 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/osmosis/tokenfactory/v1beta1/params.ts

@@ -0,0 +1,149 @@
+//@ts-nocheck
+/* eslint-disable */
+import * as Long from "long";
+import { util, configure, Writer, Reader } from "protobufjs/minimal";
+import { Coin } from "../../../cosmos/base/v1beta1/coin";
+
+export const protobufPackage = "osmosis.tokenfactory.v1beta1";
+
+/** Params defines the parameters for the tokenfactory module. */
+export interface Params {
+  denom_creation_fee: Coin[];
+  /**
+   * if denom_creation_fee is an empty array, then this field is used to add more gas consumption
+   * to the base cost.
+   * https://github.com/CosmWasm/token-factory/issues/11
+   */
+  denom_creation_gas_consume: number;
+}
+
+const baseParams: object = { denom_creation_gas_consume: 0 };
+
+export const Params = {
+  encode(message: Params, writer: Writer = Writer.create()): Writer {
+    for (const v of message.denom_creation_fee) {
+      Coin.encode(v!, writer.uint32(10).fork()).ldelim();
+    }
+    if (message.denom_creation_gas_consume !== 0) {
+      writer.uint32(16).uint64(message.denom_creation_gas_consume);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): Params {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseParams } as Params;
+    message.denom_creation_fee = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.denom_creation_fee.push(Coin.decode(reader, reader.uint32()));
+          break;
+        case 2:
+          message.denom_creation_gas_consume = longToNumber(
+            reader.uint64() as Long
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): Params {
+    const message = { ...baseParams } as Params;
+    message.denom_creation_fee = [];
+    if (
+      object.denom_creation_fee !== undefined &&
+      object.denom_creation_fee !== null
+    ) {
+      for (const e of object.denom_creation_fee) {
+        message.denom_creation_fee.push(Coin.fromJSON(e));
+      }
+    }
+    if (
+      object.denom_creation_gas_consume !== undefined &&
+      object.denom_creation_gas_consume !== null
+    ) {
+      message.denom_creation_gas_consume = Number(
+        object.denom_creation_gas_consume
+      );
+    } else {
+      message.denom_creation_gas_consume = 0;
+    }
+    return message;
+  },
+
+  toJSON(message: Params): unknown {
+    const obj: any = {};
+    if (message.denom_creation_fee) {
+      obj.denom_creation_fee = message.denom_creation_fee.map((e) =>
+        e ? Coin.toJSON(e) : undefined
+      );
+    } else {
+      obj.denom_creation_fee = [];
+    }
+    message.denom_creation_gas_consume !== undefined &&
+      (obj.denom_creation_gas_consume = message.denom_creation_gas_consume);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<Params>): Params {
+    const message = { ...baseParams } as Params;
+    message.denom_creation_fee = [];
+    if (
+      object.denom_creation_fee !== undefined &&
+      object.denom_creation_fee !== null
+    ) {
+      for (const e of object.denom_creation_fee) {
+        message.denom_creation_fee.push(Coin.fromPartial(e));
+      }
+    }
+    if (
+      object.denom_creation_gas_consume !== undefined &&
+      object.denom_creation_gas_consume !== null
+    ) {
+      message.denom_creation_gas_consume = object.denom_creation_gas_consume;
+    } else {
+      message.denom_creation_gas_consume = 0;
+    }
+    return message;
+  },
+};
+
+declare var self: any | undefined;
+declare var window: any | undefined;
+var globalThis: any = (() => {
+  if (typeof globalThis !== "undefined") return globalThis;
+  if (typeof self !== "undefined") return self;
+  if (typeof window !== "undefined") return window;
+  if (typeof global !== "undefined") return global;
+  throw "Unable to locate global object";
+})();
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;
+
+function longToNumber(long: Long): number {
+  if (long.gt(Number.MAX_SAFE_INTEGER)) {
+    throw new globalThis.Error("Value is larger than Number.MAX_SAFE_INTEGER");
+  }
+  return long.toNumber();
+}
+
+if (util.Long !== Long) {
+  util.Long = Long as any;
+  configure();
+}

+ 533 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/osmosis/tokenfactory/v1beta1/query.ts

@@ -0,0 +1,533 @@
+//@ts-nocheck
+/* eslint-disable */
+import { Reader, Writer } from "protobufjs/minimal";
+import { Params } from "../../../osmosis/tokenfactory/v1beta1/params";
+import { DenomAuthorityMetadata } from "../../../osmosis/tokenfactory/v1beta1/authorityMetadata";
+
+export const protobufPackage = "osmosis.tokenfactory.v1beta1";
+
+/** QueryParamsRequest is the request type for the Query/Params RPC method. */
+export interface QueryParamsRequest {}
+
+/** QueryParamsResponse is the response type for the Query/Params RPC method. */
+export interface QueryParamsResponse {
+  /** params defines the parameters of the module. */
+  params: Params | undefined;
+}
+
+/**
+ * QueryDenomAuthorityMetadataRequest defines the request structure for the
+ * DenomAuthorityMetadata gRPC query.
+ */
+export interface QueryDenomAuthorityMetadataRequest {
+  denom: string;
+}
+
+/**
+ * QueryDenomAuthorityMetadataResponse defines the response structure for the
+ * DenomAuthorityMetadata gRPC query.
+ */
+export interface QueryDenomAuthorityMetadataResponse {
+  authority_metadata: DenomAuthorityMetadata | undefined;
+}
+
+/**
+ * QueryDenomsFromCreatorRequest defines the request structure for the
+ * DenomsFromCreator gRPC query.
+ */
+export interface QueryDenomsFromCreatorRequest {
+  creator: string;
+}
+
+/**
+ * QueryDenomsFromCreatorRequest defines the response structure for the
+ * DenomsFromCreator gRPC query.
+ */
+export interface QueryDenomsFromCreatorResponse {
+  denoms: string[];
+}
+
+const baseQueryParamsRequest: object = {};
+
+export const QueryParamsRequest = {
+  encode(_: QueryParamsRequest, writer: Writer = Writer.create()): Writer {
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): QueryParamsRequest {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseQueryParamsRequest } as QueryParamsRequest;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(_: any): QueryParamsRequest {
+    const message = { ...baseQueryParamsRequest } as QueryParamsRequest;
+    return message;
+  },
+
+  toJSON(_: QueryParamsRequest): unknown {
+    const obj: any = {};
+    return obj;
+  },
+
+  fromPartial(_: DeepPartial<QueryParamsRequest>): QueryParamsRequest {
+    const message = { ...baseQueryParamsRequest } as QueryParamsRequest;
+    return message;
+  },
+};
+
+const baseQueryParamsResponse: object = {};
+
+export const QueryParamsResponse = {
+  encode(
+    message: QueryParamsResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.params !== undefined) {
+      Params.encode(message.params, writer.uint32(10).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): QueryParamsResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseQueryParamsResponse } as QueryParamsResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.params = Params.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryParamsResponse {
+    const message = { ...baseQueryParamsResponse } as QueryParamsResponse;
+    if (object.params !== undefined && object.params !== null) {
+      message.params = Params.fromJSON(object.params);
+    } else {
+      message.params = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryParamsResponse): unknown {
+    const obj: any = {};
+    message.params !== undefined &&
+      (obj.params = message.params ? Params.toJSON(message.params) : undefined);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<QueryParamsResponse>): QueryParamsResponse {
+    const message = { ...baseQueryParamsResponse } as QueryParamsResponse;
+    if (object.params !== undefined && object.params !== null) {
+      message.params = Params.fromPartial(object.params);
+    } else {
+      message.params = undefined;
+    }
+    return message;
+  },
+};
+
+const baseQueryDenomAuthorityMetadataRequest: object = { denom: "" };
+
+export const QueryDenomAuthorityMetadataRequest = {
+  encode(
+    message: QueryDenomAuthorityMetadataRequest,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.denom !== "") {
+      writer.uint32(10).string(message.denom);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryDenomAuthorityMetadataRequest {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryDenomAuthorityMetadataRequest,
+    } as QueryDenomAuthorityMetadataRequest;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.denom = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryDenomAuthorityMetadataRequest {
+    const message = {
+      ...baseQueryDenomAuthorityMetadataRequest,
+    } as QueryDenomAuthorityMetadataRequest;
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = String(object.denom);
+    } else {
+      message.denom = "";
+    }
+    return message;
+  },
+
+  toJSON(message: QueryDenomAuthorityMetadataRequest): unknown {
+    const obj: any = {};
+    message.denom !== undefined && (obj.denom = message.denom);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryDenomAuthorityMetadataRequest>
+  ): QueryDenomAuthorityMetadataRequest {
+    const message = {
+      ...baseQueryDenomAuthorityMetadataRequest,
+    } as QueryDenomAuthorityMetadataRequest;
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = object.denom;
+    } else {
+      message.denom = "";
+    }
+    return message;
+  },
+};
+
+const baseQueryDenomAuthorityMetadataResponse: object = {};
+
+export const QueryDenomAuthorityMetadataResponse = {
+  encode(
+    message: QueryDenomAuthorityMetadataResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.authority_metadata !== undefined) {
+      DenomAuthorityMetadata.encode(
+        message.authority_metadata,
+        writer.uint32(10).fork()
+      ).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryDenomAuthorityMetadataResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryDenomAuthorityMetadataResponse,
+    } as QueryDenomAuthorityMetadataResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.authority_metadata = DenomAuthorityMetadata.decode(
+            reader,
+            reader.uint32()
+          );
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryDenomAuthorityMetadataResponse {
+    const message = {
+      ...baseQueryDenomAuthorityMetadataResponse,
+    } as QueryDenomAuthorityMetadataResponse;
+    if (
+      object.authority_metadata !== undefined &&
+      object.authority_metadata !== null
+    ) {
+      message.authority_metadata = DenomAuthorityMetadata.fromJSON(
+        object.authority_metadata
+      );
+    } else {
+      message.authority_metadata = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryDenomAuthorityMetadataResponse): unknown {
+    const obj: any = {};
+    message.authority_metadata !== undefined &&
+      (obj.authority_metadata = message.authority_metadata
+        ? DenomAuthorityMetadata.toJSON(message.authority_metadata)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryDenomAuthorityMetadataResponse>
+  ): QueryDenomAuthorityMetadataResponse {
+    const message = {
+      ...baseQueryDenomAuthorityMetadataResponse,
+    } as QueryDenomAuthorityMetadataResponse;
+    if (
+      object.authority_metadata !== undefined &&
+      object.authority_metadata !== null
+    ) {
+      message.authority_metadata = DenomAuthorityMetadata.fromPartial(
+        object.authority_metadata
+      );
+    } else {
+      message.authority_metadata = undefined;
+    }
+    return message;
+  },
+};
+
+const baseQueryDenomsFromCreatorRequest: object = { creator: "" };
+
+export const QueryDenomsFromCreatorRequest = {
+  encode(
+    message: QueryDenomsFromCreatorRequest,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.creator !== "") {
+      writer.uint32(10).string(message.creator);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryDenomsFromCreatorRequest {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryDenomsFromCreatorRequest,
+    } as QueryDenomsFromCreatorRequest;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.creator = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryDenomsFromCreatorRequest {
+    const message = {
+      ...baseQueryDenomsFromCreatorRequest,
+    } as QueryDenomsFromCreatorRequest;
+    if (object.creator !== undefined && object.creator !== null) {
+      message.creator = String(object.creator);
+    } else {
+      message.creator = "";
+    }
+    return message;
+  },
+
+  toJSON(message: QueryDenomsFromCreatorRequest): unknown {
+    const obj: any = {};
+    message.creator !== undefined && (obj.creator = message.creator);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryDenomsFromCreatorRequest>
+  ): QueryDenomsFromCreatorRequest {
+    const message = {
+      ...baseQueryDenomsFromCreatorRequest,
+    } as QueryDenomsFromCreatorRequest;
+    if (object.creator !== undefined && object.creator !== null) {
+      message.creator = object.creator;
+    } else {
+      message.creator = "";
+    }
+    return message;
+  },
+};
+
+const baseQueryDenomsFromCreatorResponse: object = { denoms: "" };
+
+export const QueryDenomsFromCreatorResponse = {
+  encode(
+    message: QueryDenomsFromCreatorResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    for (const v of message.denoms) {
+      writer.uint32(10).string(v!);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryDenomsFromCreatorResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryDenomsFromCreatorResponse,
+    } as QueryDenomsFromCreatorResponse;
+    message.denoms = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.denoms.push(reader.string());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryDenomsFromCreatorResponse {
+    const message = {
+      ...baseQueryDenomsFromCreatorResponse,
+    } as QueryDenomsFromCreatorResponse;
+    message.denoms = [];
+    if (object.denoms !== undefined && object.denoms !== null) {
+      for (const e of object.denoms) {
+        message.denoms.push(String(e));
+      }
+    }
+    return message;
+  },
+
+  toJSON(message: QueryDenomsFromCreatorResponse): unknown {
+    const obj: any = {};
+    if (message.denoms) {
+      obj.denoms = message.denoms.map((e) => e);
+    } else {
+      obj.denoms = [];
+    }
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryDenomsFromCreatorResponse>
+  ): QueryDenomsFromCreatorResponse {
+    const message = {
+      ...baseQueryDenomsFromCreatorResponse,
+    } as QueryDenomsFromCreatorResponse;
+    message.denoms = [];
+    if (object.denoms !== undefined && object.denoms !== null) {
+      for (const e of object.denoms) {
+        message.denoms.push(e);
+      }
+    }
+    return message;
+  },
+};
+
+/** Query defines the gRPC querier service. */
+export interface Query {
+  /**
+   * Params defines a gRPC query method that returns the tokenfactory module's
+   * parameters.
+   */
+  Params(request: QueryParamsRequest): Promise<QueryParamsResponse>;
+  /**
+   * DenomAuthorityMetadata defines a gRPC query method for fetching
+   * DenomAuthorityMetadata for a particular denom.
+   */
+  DenomAuthorityMetadata(
+    request: QueryDenomAuthorityMetadataRequest
+  ): Promise<QueryDenomAuthorityMetadataResponse>;
+  /**
+   * DenomsFromCreator defines a gRPC query method for fetching all
+   * denominations created by a specific admin/creator.
+   */
+  DenomsFromCreator(
+    request: QueryDenomsFromCreatorRequest
+  ): Promise<QueryDenomsFromCreatorResponse>;
+}
+
+export class QueryClientImpl implements Query {
+  private readonly rpc: Rpc;
+  constructor(rpc: Rpc) {
+    this.rpc = rpc;
+  }
+  Params(request: QueryParamsRequest): Promise<QueryParamsResponse> {
+    const data = QueryParamsRequest.encode(request).finish();
+    const promise = this.rpc.request(
+      "osmosis.tokenfactory.v1beta1.Query",
+      "Params",
+      data
+    );
+    return promise.then((data) => QueryParamsResponse.decode(new Reader(data)));
+  }
+
+  DenomAuthorityMetadata(
+    request: QueryDenomAuthorityMetadataRequest
+  ): Promise<QueryDenomAuthorityMetadataResponse> {
+    const data = QueryDenomAuthorityMetadataRequest.encode(request).finish();
+    const promise = this.rpc.request(
+      "osmosis.tokenfactory.v1beta1.Query",
+      "DenomAuthorityMetadata",
+      data
+    );
+    return promise.then((data) =>
+      QueryDenomAuthorityMetadataResponse.decode(new Reader(data))
+    );
+  }
+
+  DenomsFromCreator(
+    request: QueryDenomsFromCreatorRequest
+  ): Promise<QueryDenomsFromCreatorResponse> {
+    const data = QueryDenomsFromCreatorRequest.encode(request).finish();
+    const promise = this.rpc.request(
+      "osmosis.tokenfactory.v1beta1.Query",
+      "DenomsFromCreator",
+      data
+    );
+    return promise.then((data) =>
+      QueryDenomsFromCreatorResponse.decode(new Reader(data))
+    );
+  }
+}
+
+interface Rpc {
+  request(
+    service: string,
+    method: string,
+    data: Uint8Array
+  ): Promise<Uint8Array>;
+}
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;

+ 1040 - 0
wormchain/ts-sdk/src/modules/osmosis.tokenfactory.v1beta1/types/osmosis/tokenfactory/v1beta1/tx.ts

@@ -0,0 +1,1040 @@
+//@ts-nocheck
+/* eslint-disable */
+import { Reader, Writer } from "protobufjs/minimal";
+import { Coin } from "../../../cosmos/base/v1beta1/coin";
+import { Metadata } from "../../../cosmos/bank/v1beta1/bank";
+
+export const protobufPackage = "osmosis.tokenfactory.v1beta1";
+
+/**
+ * MsgCreateDenom defines the message structure for the CreateDenom gRPC service
+ * method. It allows an account to create a new denom. It requires a sender
+ * address and a sub denomination. The (sender_address, sub_denomination) tuple
+ * must be unique and cannot be re-used.
+ *
+ * The resulting denom created is defined as
+ * <factory/{creatorAddress}/{subdenom}>. The resulting denom's admin is
+ * originally set to be the creator, but this can be changed later. The token
+ * denom does not indicate the current admin.
+ */
+export interface MsgCreateDenom {
+  sender: string;
+  /** subdenom can be up to 44 "alphanumeric" characters long. */
+  subdenom: string;
+}
+
+/**
+ * MsgCreateDenomResponse is the return value of MsgCreateDenom
+ * It returns the full string of the newly created denom
+ */
+export interface MsgCreateDenomResponse {
+  new_token_denom: string;
+}
+
+/**
+ * MsgMint is the sdk.Msg type for allowing an admin account to mint
+ * more of a token.  For now, we only support minting to the sender account
+ */
+export interface MsgMint {
+  sender: string;
+  amount: Coin | undefined;
+  mintToAddress: string;
+}
+
+export interface MsgMintResponse {}
+
+/**
+ * MsgBurn is the sdk.Msg type for allowing an admin account to burn
+ * a token.  For now, we only support burning from the sender account.
+ */
+export interface MsgBurn {
+  sender: string;
+  amount: Coin | undefined;
+  burnFromAddress: string;
+}
+
+export interface MsgBurnResponse {}
+
+/**
+ * MsgChangeAdmin is the sdk.Msg type for allowing an admin account to reassign
+ * adminship of a denom to a new account
+ */
+export interface MsgChangeAdmin {
+  sender: string;
+  denom: string;
+  new_admin: string;
+}
+
+/**
+ * MsgChangeAdminResponse defines the response structure for an executed
+ * MsgChangeAdmin message.
+ */
+export interface MsgChangeAdminResponse {}
+
+/**
+ * MsgSetDenomMetadata is the sdk.Msg type for allowing an admin account to set
+ * the denom's bank metadata
+ */
+export interface MsgSetDenomMetadata {
+  sender: string;
+  metadata: Metadata | undefined;
+}
+
+/**
+ * MsgSetDenomMetadataResponse defines the response structure for an executed
+ * MsgSetDenomMetadata message.
+ */
+export interface MsgSetDenomMetadataResponse {}
+
+export interface MsgForceTransfer {
+  sender: string;
+  amount: Coin | undefined;
+  transferFromAddress: string;
+  transferToAddress: string;
+}
+
+export interface MsgForceTransferResponse {}
+
+const baseMsgCreateDenom: object = { sender: "", subdenom: "" };
+
+export const MsgCreateDenom = {
+  encode(message: MsgCreateDenom, writer: Writer = Writer.create()): Writer {
+    if (message.sender !== "") {
+      writer.uint32(10).string(message.sender);
+    }
+    if (message.subdenom !== "") {
+      writer.uint32(18).string(message.subdenom);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgCreateDenom {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMsgCreateDenom } as MsgCreateDenom;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.sender = reader.string();
+          break;
+        case 2:
+          message.subdenom = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MsgCreateDenom {
+    const message = { ...baseMsgCreateDenom } as MsgCreateDenom;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = String(object.sender);
+    } else {
+      message.sender = "";
+    }
+    if (object.subdenom !== undefined && object.subdenom !== null) {
+      message.subdenom = String(object.subdenom);
+    } else {
+      message.subdenom = "";
+    }
+    return message;
+  },
+
+  toJSON(message: MsgCreateDenom): unknown {
+    const obj: any = {};
+    message.sender !== undefined && (obj.sender = message.sender);
+    message.subdenom !== undefined && (obj.subdenom = message.subdenom);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<MsgCreateDenom>): MsgCreateDenom {
+    const message = { ...baseMsgCreateDenom } as MsgCreateDenom;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = object.sender;
+    } else {
+      message.sender = "";
+    }
+    if (object.subdenom !== undefined && object.subdenom !== null) {
+      message.subdenom = object.subdenom;
+    } else {
+      message.subdenom = "";
+    }
+    return message;
+  },
+};
+
+const baseMsgCreateDenomResponse: object = { new_token_denom: "" };
+
+export const MsgCreateDenomResponse = {
+  encode(
+    message: MsgCreateDenomResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.new_token_denom !== "") {
+      writer.uint32(10).string(message.new_token_denom);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgCreateDenomResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMsgCreateDenomResponse } as MsgCreateDenomResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.new_token_denom = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MsgCreateDenomResponse {
+    const message = { ...baseMsgCreateDenomResponse } as MsgCreateDenomResponse;
+    if (
+      object.new_token_denom !== undefined &&
+      object.new_token_denom !== null
+    ) {
+      message.new_token_denom = String(object.new_token_denom);
+    } else {
+      message.new_token_denom = "";
+    }
+    return message;
+  },
+
+  toJSON(message: MsgCreateDenomResponse): unknown {
+    const obj: any = {};
+    message.new_token_denom !== undefined &&
+      (obj.new_token_denom = message.new_token_denom);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<MsgCreateDenomResponse>
+  ): MsgCreateDenomResponse {
+    const message = { ...baseMsgCreateDenomResponse } as MsgCreateDenomResponse;
+    if (
+      object.new_token_denom !== undefined &&
+      object.new_token_denom !== null
+    ) {
+      message.new_token_denom = object.new_token_denom;
+    } else {
+      message.new_token_denom = "";
+    }
+    return message;
+  },
+};
+
+const baseMsgMint: object = { sender: "", mintToAddress: "" };
+
+export const MsgMint = {
+  encode(message: MsgMint, writer: Writer = Writer.create()): Writer {
+    if (message.sender !== "") {
+      writer.uint32(10).string(message.sender);
+    }
+    if (message.amount !== undefined) {
+      Coin.encode(message.amount, writer.uint32(18).fork()).ldelim();
+    }
+    if (message.mintToAddress !== "") {
+      writer.uint32(26).string(message.mintToAddress);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgMint {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMsgMint } as MsgMint;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.sender = reader.string();
+          break;
+        case 2:
+          message.amount = Coin.decode(reader, reader.uint32());
+          break;
+        case 3:
+          message.mintToAddress = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MsgMint {
+    const message = { ...baseMsgMint } as MsgMint;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = String(object.sender);
+    } else {
+      message.sender = "";
+    }
+    if (object.amount !== undefined && object.amount !== null) {
+      message.amount = Coin.fromJSON(object.amount);
+    } else {
+      message.amount = undefined;
+    }
+    if (object.mintToAddress !== undefined && object.mintToAddress !== null) {
+      message.mintToAddress = String(object.mintToAddress);
+    } else {
+      message.mintToAddress = "";
+    }
+    return message;
+  },
+
+  toJSON(message: MsgMint): unknown {
+    const obj: any = {};
+    message.sender !== undefined && (obj.sender = message.sender);
+    message.amount !== undefined &&
+      (obj.amount = message.amount ? Coin.toJSON(message.amount) : undefined);
+    message.mintToAddress !== undefined &&
+      (obj.mintToAddress = message.mintToAddress);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<MsgMint>): MsgMint {
+    const message = { ...baseMsgMint } as MsgMint;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = object.sender;
+    } else {
+      message.sender = "";
+    }
+    if (object.amount !== undefined && object.amount !== null) {
+      message.amount = Coin.fromPartial(object.amount);
+    } else {
+      message.amount = undefined;
+    }
+    if (object.mintToAddress !== undefined && object.mintToAddress !== null) {
+      message.mintToAddress = object.mintToAddress;
+    } else {
+      message.mintToAddress = "";
+    }
+    return message;
+  },
+};
+
+const baseMsgMintResponse: object = {};
+
+export const MsgMintResponse = {
+  encode(_: MsgMintResponse, writer: Writer = Writer.create()): Writer {
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgMintResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMsgMintResponse } as MsgMintResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(_: any): MsgMintResponse {
+    const message = { ...baseMsgMintResponse } as MsgMintResponse;
+    return message;
+  },
+
+  toJSON(_: MsgMintResponse): unknown {
+    const obj: any = {};
+    return obj;
+  },
+
+  fromPartial(_: DeepPartial<MsgMintResponse>): MsgMintResponse {
+    const message = { ...baseMsgMintResponse } as MsgMintResponse;
+    return message;
+  },
+};
+
+const baseMsgBurn: object = { sender: "", burnFromAddress: "" };
+
+export const MsgBurn = {
+  encode(message: MsgBurn, writer: Writer = Writer.create()): Writer {
+    if (message.sender !== "") {
+      writer.uint32(10).string(message.sender);
+    }
+    if (message.amount !== undefined) {
+      Coin.encode(message.amount, writer.uint32(18).fork()).ldelim();
+    }
+    if (message.burnFromAddress !== "") {
+      writer.uint32(26).string(message.burnFromAddress);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgBurn {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMsgBurn } as MsgBurn;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.sender = reader.string();
+          break;
+        case 2:
+          message.amount = Coin.decode(reader, reader.uint32());
+          break;
+        case 3:
+          message.burnFromAddress = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MsgBurn {
+    const message = { ...baseMsgBurn } as MsgBurn;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = String(object.sender);
+    } else {
+      message.sender = "";
+    }
+    if (object.amount !== undefined && object.amount !== null) {
+      message.amount = Coin.fromJSON(object.amount);
+    } else {
+      message.amount = undefined;
+    }
+    if (
+      object.burnFromAddress !== undefined &&
+      object.burnFromAddress !== null
+    ) {
+      message.burnFromAddress = String(object.burnFromAddress);
+    } else {
+      message.burnFromAddress = "";
+    }
+    return message;
+  },
+
+  toJSON(message: MsgBurn): unknown {
+    const obj: any = {};
+    message.sender !== undefined && (obj.sender = message.sender);
+    message.amount !== undefined &&
+      (obj.amount = message.amount ? Coin.toJSON(message.amount) : undefined);
+    message.burnFromAddress !== undefined &&
+      (obj.burnFromAddress = message.burnFromAddress);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<MsgBurn>): MsgBurn {
+    const message = { ...baseMsgBurn } as MsgBurn;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = object.sender;
+    } else {
+      message.sender = "";
+    }
+    if (object.amount !== undefined && object.amount !== null) {
+      message.amount = Coin.fromPartial(object.amount);
+    } else {
+      message.amount = undefined;
+    }
+    if (
+      object.burnFromAddress !== undefined &&
+      object.burnFromAddress !== null
+    ) {
+      message.burnFromAddress = object.burnFromAddress;
+    } else {
+      message.burnFromAddress = "";
+    }
+    return message;
+  },
+};
+
+const baseMsgBurnResponse: object = {};
+
+export const MsgBurnResponse = {
+  encode(_: MsgBurnResponse, writer: Writer = Writer.create()): Writer {
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgBurnResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMsgBurnResponse } as MsgBurnResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(_: any): MsgBurnResponse {
+    const message = { ...baseMsgBurnResponse } as MsgBurnResponse;
+    return message;
+  },
+
+  toJSON(_: MsgBurnResponse): unknown {
+    const obj: any = {};
+    return obj;
+  },
+
+  fromPartial(_: DeepPartial<MsgBurnResponse>): MsgBurnResponse {
+    const message = { ...baseMsgBurnResponse } as MsgBurnResponse;
+    return message;
+  },
+};
+
+const baseMsgChangeAdmin: object = { sender: "", denom: "", new_admin: "" };
+
+export const MsgChangeAdmin = {
+  encode(message: MsgChangeAdmin, writer: Writer = Writer.create()): Writer {
+    if (message.sender !== "") {
+      writer.uint32(10).string(message.sender);
+    }
+    if (message.denom !== "") {
+      writer.uint32(18).string(message.denom);
+    }
+    if (message.new_admin !== "") {
+      writer.uint32(26).string(message.new_admin);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgChangeAdmin {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMsgChangeAdmin } as MsgChangeAdmin;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.sender = reader.string();
+          break;
+        case 2:
+          message.denom = reader.string();
+          break;
+        case 3:
+          message.new_admin = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MsgChangeAdmin {
+    const message = { ...baseMsgChangeAdmin } as MsgChangeAdmin;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = String(object.sender);
+    } else {
+      message.sender = "";
+    }
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = String(object.denom);
+    } else {
+      message.denom = "";
+    }
+    if (object.new_admin !== undefined && object.new_admin !== null) {
+      message.new_admin = String(object.new_admin);
+    } else {
+      message.new_admin = "";
+    }
+    return message;
+  },
+
+  toJSON(message: MsgChangeAdmin): unknown {
+    const obj: any = {};
+    message.sender !== undefined && (obj.sender = message.sender);
+    message.denom !== undefined && (obj.denom = message.denom);
+    message.new_admin !== undefined && (obj.new_admin = message.new_admin);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<MsgChangeAdmin>): MsgChangeAdmin {
+    const message = { ...baseMsgChangeAdmin } as MsgChangeAdmin;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = object.sender;
+    } else {
+      message.sender = "";
+    }
+    if (object.denom !== undefined && object.denom !== null) {
+      message.denom = object.denom;
+    } else {
+      message.denom = "";
+    }
+    if (object.new_admin !== undefined && object.new_admin !== null) {
+      message.new_admin = object.new_admin;
+    } else {
+      message.new_admin = "";
+    }
+    return message;
+  },
+};
+
+const baseMsgChangeAdminResponse: object = {};
+
+export const MsgChangeAdminResponse = {
+  encode(_: MsgChangeAdminResponse, writer: Writer = Writer.create()): Writer {
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgChangeAdminResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMsgChangeAdminResponse } as MsgChangeAdminResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(_: any): MsgChangeAdminResponse {
+    const message = { ...baseMsgChangeAdminResponse } as MsgChangeAdminResponse;
+    return message;
+  },
+
+  toJSON(_: MsgChangeAdminResponse): unknown {
+    const obj: any = {};
+    return obj;
+  },
+
+  fromPartial(_: DeepPartial<MsgChangeAdminResponse>): MsgChangeAdminResponse {
+    const message = { ...baseMsgChangeAdminResponse } as MsgChangeAdminResponse;
+    return message;
+  },
+};
+
+const baseMsgSetDenomMetadata: object = { sender: "" };
+
+export const MsgSetDenomMetadata = {
+  encode(
+    message: MsgSetDenomMetadata,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.sender !== "") {
+      writer.uint32(10).string(message.sender);
+    }
+    if (message.metadata !== undefined) {
+      Metadata.encode(message.metadata, writer.uint32(18).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgSetDenomMetadata {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMsgSetDenomMetadata } as MsgSetDenomMetadata;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.sender = reader.string();
+          break;
+        case 2:
+          message.metadata = Metadata.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MsgSetDenomMetadata {
+    const message = { ...baseMsgSetDenomMetadata } as MsgSetDenomMetadata;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = String(object.sender);
+    } else {
+      message.sender = "";
+    }
+    if (object.metadata !== undefined && object.metadata !== null) {
+      message.metadata = Metadata.fromJSON(object.metadata);
+    } else {
+      message.metadata = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: MsgSetDenomMetadata): unknown {
+    const obj: any = {};
+    message.sender !== undefined && (obj.sender = message.sender);
+    message.metadata !== undefined &&
+      (obj.metadata = message.metadata
+        ? Metadata.toJSON(message.metadata)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<MsgSetDenomMetadata>): MsgSetDenomMetadata {
+    const message = { ...baseMsgSetDenomMetadata } as MsgSetDenomMetadata;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = object.sender;
+    } else {
+      message.sender = "";
+    }
+    if (object.metadata !== undefined && object.metadata !== null) {
+      message.metadata = Metadata.fromPartial(object.metadata);
+    } else {
+      message.metadata = undefined;
+    }
+    return message;
+  },
+};
+
+const baseMsgSetDenomMetadataResponse: object = {};
+
+export const MsgSetDenomMetadataResponse = {
+  encode(
+    _: MsgSetDenomMetadataResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): MsgSetDenomMetadataResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseMsgSetDenomMetadataResponse,
+    } as MsgSetDenomMetadataResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(_: any): MsgSetDenomMetadataResponse {
+    const message = {
+      ...baseMsgSetDenomMetadataResponse,
+    } as MsgSetDenomMetadataResponse;
+    return message;
+  },
+
+  toJSON(_: MsgSetDenomMetadataResponse): unknown {
+    const obj: any = {};
+    return obj;
+  },
+
+  fromPartial(
+    _: DeepPartial<MsgSetDenomMetadataResponse>
+  ): MsgSetDenomMetadataResponse {
+    const message = {
+      ...baseMsgSetDenomMetadataResponse,
+    } as MsgSetDenomMetadataResponse;
+    return message;
+  },
+};
+
+const baseMsgForceTransfer: object = {
+  sender: "",
+  transferFromAddress: "",
+  transferToAddress: "",
+};
+
+export const MsgForceTransfer = {
+  encode(message: MsgForceTransfer, writer: Writer = Writer.create()): Writer {
+    if (message.sender !== "") {
+      writer.uint32(10).string(message.sender);
+    }
+    if (message.amount !== undefined) {
+      Coin.encode(message.amount, writer.uint32(18).fork()).ldelim();
+    }
+    if (message.transferFromAddress !== "") {
+      writer.uint32(26).string(message.transferFromAddress);
+    }
+    if (message.transferToAddress !== "") {
+      writer.uint32(34).string(message.transferToAddress);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): MsgForceTransfer {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseMsgForceTransfer } as MsgForceTransfer;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.sender = reader.string();
+          break;
+        case 2:
+          message.amount = Coin.decode(reader, reader.uint32());
+          break;
+        case 3:
+          message.transferFromAddress = reader.string();
+          break;
+        case 4:
+          message.transferToAddress = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): MsgForceTransfer {
+    const message = { ...baseMsgForceTransfer } as MsgForceTransfer;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = String(object.sender);
+    } else {
+      message.sender = "";
+    }
+    if (object.amount !== undefined && object.amount !== null) {
+      message.amount = Coin.fromJSON(object.amount);
+    } else {
+      message.amount = undefined;
+    }
+    if (
+      object.transferFromAddress !== undefined &&
+      object.transferFromAddress !== null
+    ) {
+      message.transferFromAddress = String(object.transferFromAddress);
+    } else {
+      message.transferFromAddress = "";
+    }
+    if (
+      object.transferToAddress !== undefined &&
+      object.transferToAddress !== null
+    ) {
+      message.transferToAddress = String(object.transferToAddress);
+    } else {
+      message.transferToAddress = "";
+    }
+    return message;
+  },
+
+  toJSON(message: MsgForceTransfer): unknown {
+    const obj: any = {};
+    message.sender !== undefined && (obj.sender = message.sender);
+    message.amount !== undefined &&
+      (obj.amount = message.amount ? Coin.toJSON(message.amount) : undefined);
+    message.transferFromAddress !== undefined &&
+      (obj.transferFromAddress = message.transferFromAddress);
+    message.transferToAddress !== undefined &&
+      (obj.transferToAddress = message.transferToAddress);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<MsgForceTransfer>): MsgForceTransfer {
+    const message = { ...baseMsgForceTransfer } as MsgForceTransfer;
+    if (object.sender !== undefined && object.sender !== null) {
+      message.sender = object.sender;
+    } else {
+      message.sender = "";
+    }
+    if (object.amount !== undefined && object.amount !== null) {
+      message.amount = Coin.fromPartial(object.amount);
+    } else {
+      message.amount = undefined;
+    }
+    if (
+      object.transferFromAddress !== undefined &&
+      object.transferFromAddress !== null
+    ) {
+      message.transferFromAddress = object.transferFromAddress;
+    } else {
+      message.transferFromAddress = "";
+    }
+    if (
+      object.transferToAddress !== undefined &&
+      object.transferToAddress !== null
+    ) {
+      message.transferToAddress = object.transferToAddress;
+    } else {
+      message.transferToAddress = "";
+    }
+    return message;
+  },
+};
+
+const baseMsgForceTransferResponse: object = {};
+
+export const MsgForceTransferResponse = {
+  encode(
+    _: MsgForceTransferResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): MsgForceTransferResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseMsgForceTransferResponse,
+    } as MsgForceTransferResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(_: any): MsgForceTransferResponse {
+    const message = {
+      ...baseMsgForceTransferResponse,
+    } as MsgForceTransferResponse;
+    return message;
+  },
+
+  toJSON(_: MsgForceTransferResponse): unknown {
+    const obj: any = {};
+    return obj;
+  },
+
+  fromPartial(
+    _: DeepPartial<MsgForceTransferResponse>
+  ): MsgForceTransferResponse {
+    const message = {
+      ...baseMsgForceTransferResponse,
+    } as MsgForceTransferResponse;
+    return message;
+  },
+};
+
+/** Msg defines the tokefactory module's gRPC message service. */
+export interface Msg {
+  CreateDenom(request: MsgCreateDenom): Promise<MsgCreateDenomResponse>;
+  Mint(request: MsgMint): Promise<MsgMintResponse>;
+  Burn(request: MsgBurn): Promise<MsgBurnResponse>;
+  ChangeAdmin(request: MsgChangeAdmin): Promise<MsgChangeAdminResponse>;
+  SetDenomMetadata(
+    request: MsgSetDenomMetadata
+  ): Promise<MsgSetDenomMetadataResponse>;
+  ForceTransfer(request: MsgForceTransfer): Promise<MsgForceTransferResponse>;
+}
+
+export class MsgClientImpl implements Msg {
+  private readonly rpc: Rpc;
+  constructor(rpc: Rpc) {
+    this.rpc = rpc;
+  }
+  CreateDenom(request: MsgCreateDenom): Promise<MsgCreateDenomResponse> {
+    const data = MsgCreateDenom.encode(request).finish();
+    const promise = this.rpc.request(
+      "osmosis.tokenfactory.v1beta1.Msg",
+      "CreateDenom",
+      data
+    );
+    return promise.then((data) =>
+      MsgCreateDenomResponse.decode(new Reader(data))
+    );
+  }
+
+  Mint(request: MsgMint): Promise<MsgMintResponse> {
+    const data = MsgMint.encode(request).finish();
+    const promise = this.rpc.request(
+      "osmosis.tokenfactory.v1beta1.Msg",
+      "Mint",
+      data
+    );
+    return promise.then((data) => MsgMintResponse.decode(new Reader(data)));
+  }
+
+  Burn(request: MsgBurn): Promise<MsgBurnResponse> {
+    const data = MsgBurn.encode(request).finish();
+    const promise = this.rpc.request(
+      "osmosis.tokenfactory.v1beta1.Msg",
+      "Burn",
+      data
+    );
+    return promise.then((data) => MsgBurnResponse.decode(new Reader(data)));
+  }
+
+  ChangeAdmin(request: MsgChangeAdmin): Promise<MsgChangeAdminResponse> {
+    const data = MsgChangeAdmin.encode(request).finish();
+    const promise = this.rpc.request(
+      "osmosis.tokenfactory.v1beta1.Msg",
+      "ChangeAdmin",
+      data
+    );
+    return promise.then((data) =>
+      MsgChangeAdminResponse.decode(new Reader(data))
+    );
+  }
+
+  SetDenomMetadata(
+    request: MsgSetDenomMetadata
+  ): Promise<MsgSetDenomMetadataResponse> {
+    const data = MsgSetDenomMetadata.encode(request).finish();
+    const promise = this.rpc.request(
+      "osmosis.tokenfactory.v1beta1.Msg",
+      "SetDenomMetadata",
+      data
+    );
+    return promise.then((data) =>
+      MsgSetDenomMetadataResponse.decode(new Reader(data))
+    );
+  }
+
+  ForceTransfer(request: MsgForceTransfer): Promise<MsgForceTransferResponse> {
+    const data = MsgForceTransfer.encode(request).finish();
+    const promise = this.rpc.request(
+      "osmosis.tokenfactory.v1beta1.Msg",
+      "ForceTransfer",
+      data
+    );
+    return promise.then((data) =>
+      MsgForceTransferResponse.decode(new Reader(data))
+    );
+  }
+}
+
+interface Rpc {
+  request(
+    service: string,
+    method: string,
+    data: Uint8Array
+  ): Promise<Uint8Array>;
+}
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;

+ 24 - 6
wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/index.ts

@@ -5,17 +5,29 @@ import { StdFee } from "@cosmjs/launchpad";
 import { SigningStargateClient } from "@cosmjs/stargate";
 import { Registry, OfflineSigner, EncodeObject, DirectSecp256k1HdWallet } from "@cosmjs/proto-signing";
 import { Api } from "./rest";
-import { MsgExecuteGovernanceVAA } from "./types/wormhole/tx";
-import { MsgStoreCode } from "./types/wormhole/tx";
+import { MsgExecuteGatewayGovernanceVaa } from "./types/wormhole/tx";
 import { MsgRegisterAccountAsGuardian } from "./types/wormhole/tx";
 import { MsgInstantiateContract } from "./types/wormhole/tx";
+import { MsgExecuteGovernanceVAA } from "./types/wormhole/tx";
+import { MsgStoreCode } from "./types/wormhole/tx";
+import { MsgAddWasmInstantiateAllowlist } from "./types/wormhole/tx";
+import { MsgDeleteWasmInstantiateAllowlist } from "./types/wormhole/tx";
+import { MsgMigrateContract } from "./types/wormhole/tx";
+import { MsgDeleteAllowlistEntryRequest } from "./types/wormhole/tx";
+import { MsgCreateAllowlistEntryRequest } from "./types/wormhole/tx";
 
 
 const types = [
-  ["/wormhole_foundation.wormchain.wormhole.MsgExecuteGovernanceVAA", MsgExecuteGovernanceVAA],
-  ["/wormhole_foundation.wormchain.wormhole.MsgStoreCode", MsgStoreCode],
+  ["/wormhole_foundation.wormchain.wormhole.MsgExecuteGatewayGovernanceVaa", MsgExecuteGatewayGovernanceVaa],
   ["/wormhole_foundation.wormchain.wormhole.MsgRegisterAccountAsGuardian", MsgRegisterAccountAsGuardian],
   ["/wormhole_foundation.wormchain.wormhole.MsgInstantiateContract", MsgInstantiateContract],
+  ["/wormhole_foundation.wormchain.wormhole.MsgExecuteGovernanceVAA", MsgExecuteGovernanceVAA],
+  ["/wormhole_foundation.wormchain.wormhole.MsgStoreCode", MsgStoreCode],
+  ["/wormhole_foundation.wormchain.wormhole.MsgAddWasmInstantiateAllowlist", MsgAddWasmInstantiateAllowlist],
+  ["/wormhole_foundation.wormchain.wormhole.MsgDeleteWasmInstantiateAllowlist", MsgDeleteWasmInstantiateAllowlist],
+  ["/wormhole_foundation.wormchain.wormhole.MsgMigrateContract", MsgMigrateContract],
+  ["/wormhole_foundation.wormchain.wormhole.MsgDeleteAllowlistEntryRequest", MsgDeleteAllowlistEntryRequest],
+  ["/wormhole_foundation.wormchain.wormhole.MsgCreateAllowlistEntryRequest", MsgCreateAllowlistEntryRequest],
   
 ];
 export const MissingWalletError = new Error("wallet is required");
@@ -48,10 +60,16 @@ const txClient = async (wallet: OfflineSigner, { addr: addr }: TxClientOptions =
 
   return {
     signAndBroadcast: (msgs: EncodeObject[], { fee, memo }: SignAndBroadcastOptions = {fee: defaultFee, memo: ""}) => client.signAndBroadcast(address, msgs, fee,memo),
-    msgExecuteGovernanceVAA: (data: MsgExecuteGovernanceVAA): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgExecuteGovernanceVAA", value: MsgExecuteGovernanceVAA.fromPartial( data ) }),
-    msgStoreCode: (data: MsgStoreCode): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgStoreCode", value: MsgStoreCode.fromPartial( data ) }),
+    msgExecuteGatewayGovernanceVaa: (data: MsgExecuteGatewayGovernanceVaa): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgExecuteGatewayGovernanceVaa", value: MsgExecuteGatewayGovernanceVaa.fromPartial( data ) }),
     msgRegisterAccountAsGuardian: (data: MsgRegisterAccountAsGuardian): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgRegisterAccountAsGuardian", value: MsgRegisterAccountAsGuardian.fromPartial( data ) }),
     msgInstantiateContract: (data: MsgInstantiateContract): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgInstantiateContract", value: MsgInstantiateContract.fromPartial( data ) }),
+    msgExecuteGovernanceVAA: (data: MsgExecuteGovernanceVAA): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgExecuteGovernanceVAA", value: MsgExecuteGovernanceVAA.fromPartial( data ) }),
+    msgStoreCode: (data: MsgStoreCode): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgStoreCode", value: MsgStoreCode.fromPartial( data ) }),
+    msgAddWasmInstantiateAllowlist: (data: MsgAddWasmInstantiateAllowlist): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgAddWasmInstantiateAllowlist", value: MsgAddWasmInstantiateAllowlist.fromPartial( data ) }),
+    msgDeleteWasmInstantiateAllowlist: (data: MsgDeleteWasmInstantiateAllowlist): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgDeleteWasmInstantiateAllowlist", value: MsgDeleteWasmInstantiateAllowlist.fromPartial( data ) }),
+    msgMigrateContract: (data: MsgMigrateContract): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgMigrateContract", value: MsgMigrateContract.fromPartial( data ) }),
+    msgDeleteAllowlistEntryRequest: (data: MsgDeleteAllowlistEntryRequest): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgDeleteAllowlistEntryRequest", value: MsgDeleteAllowlistEntryRequest.fromPartial( data ) }),
+    msgCreateAllowlistEntryRequest: (data: MsgCreateAllowlistEntryRequest): EncodeObject => ({ typeUrl: "/wormhole_foundation.wormchain.wormhole.MsgCreateAllowlistEntryRequest", value: MsgCreateAllowlistEntryRequest.fromPartial( data ) }),
     
   };
 };

+ 171 - 0
wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/rest.ts

@@ -103,6 +103,8 @@ export interface WormholeConsensusGuardianSetIndex {
   index?: number;
 }
 
+export type WormholeEmptyResponse = object;
+
 export interface WormholeGuardianSet {
   /** @format int64 */
   index?: number;
@@ -120,6 +122,8 @@ export interface WormholeGuardianValidator {
   validatorAddr?: string;
 }
 
+export type WormholeMsgAllowlistResponse = object;
+
 export type WormholeMsgExecuteGovernanceVAAResponse = object;
 
 export interface WormholeMsgInstantiateContractResponse {
@@ -130,13 +134,26 @@ export interface WormholeMsgInstantiateContractResponse {
   data?: string;
 }
 
+/**
+ * MsgMigrateContractResponse returns contract migration result data.
+ */
+export interface WormholeMsgMigrateContractResponse {
+  /** @format byte */
+  data?: string;
+}
+
 export type WormholeMsgRegisterAccountAsGuardianResponse = object;
 
 export interface WormholeMsgStoreCodeResponse {
   /** @format uint64 */
   code_id?: string;
+
+  /** @format byte */
+  checksum?: string;
 }
 
+export type WormholeMsgWasmInstantiateAllowlistResponse = object;
+
 export interface WormholeQueryAllGuardianSetResponse {
   GuardianSet?: WormholeGuardianSet[];
 
@@ -197,6 +214,36 @@ export interface WormholeQueryAllSequenceCounterResponse {
   pagination?: V1Beta1PageResponse;
 }
 
+export interface WormholeQueryAllValidatorAllowlistResponse {
+  allowlist?: WormholeValidatorAllowedAddress[];
+
+  /**
+   * PageResponse is to be embedded in gRPC response messages where the
+   * corresponding request message has used PageRequest.
+   *
+   *  message SomeResponse {
+   *          repeated Bar results = 1;
+   *          PageResponse page = 2;
+   *  }
+   */
+  pagination?: V1Beta1PageResponse;
+}
+
+export interface WormholeQueryAllWasmInstantiateAllowlistResponse {
+  allowlist?: WormholeWasmInstantiateAllowedContractCodeId[];
+
+  /**
+   * PageResponse is to be embedded in gRPC response messages where the
+   * corresponding request message has used PageRequest.
+   *
+   *  message SomeResponse {
+   *          repeated Bar results = 1;
+   *          PageResponse page = 2;
+   *  }
+   */
+  pagination?: V1Beta1PageResponse;
+}
+
 export interface WormholeQueryGetConfigResponse {
   Config?: WormholeConfig;
 }
@@ -221,11 +268,31 @@ export interface WormholeQueryGetSequenceCounterResponse {
   sequenceCounter?: WormholeSequenceCounter;
 }
 
+export interface WormholeQueryIbcComposabilityMwContractResponse {
+  contractAddress?: string;
+}
+
 export interface WormholeQueryLatestGuardianSetIndexResponse {
   /** @format int64 */
   latestGuardianSetIndex?: number;
 }
 
+export interface WormholeQueryValidatorAllowlistResponse {
+  validator_address?: string;
+  allowlist?: WormholeValidatorAllowedAddress[];
+
+  /**
+   * PageResponse is to be embedded in gRPC response messages where the
+   * corresponding request message has used PageRequest.
+   *
+   *  message SomeResponse {
+   *          repeated Bar results = 1;
+   *          PageResponse page = 2;
+   *  }
+   */
+  pagination?: V1Beta1PageResponse;
+}
+
 export interface WormholeReplayProtection {
   index?: string;
 }
@@ -237,6 +304,19 @@ export interface WormholeSequenceCounter {
   sequence?: string;
 }
 
+export interface WormholeValidatorAllowedAddress {
+  validator_address?: string;
+  allowed_address?: string;
+  name?: string;
+}
+
+export interface WormholeWasmInstantiateAllowedContractCodeId {
+  contract_address?: string;
+
+  /** @format uint64 */
+  code_id?: string;
+}
+
 export type QueryParamsType = Record<string | number, any>;
 export type ResponseFormat = keyof Omit<Body, "body" | "bodyUsed">;
 
@@ -433,6 +513,57 @@ export class HttpClient<SecurityDataType = unknown> {
  * @version version not set
  */
 export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDataType> {
+  /**
+   * No description
+   *
+   * @tags Query
+   * @name QueryAllowlistAll
+   * @request GET:/wormhole_foundation/wormchain/wormhole/allowlist
+   */
+  queryAllowlistAll = (
+    query?: {
+      "pagination.key"?: string;
+      "pagination.offset"?: string;
+      "pagination.limit"?: string;
+      "pagination.count_total"?: boolean;
+      "pagination.reverse"?: boolean;
+    },
+    params: RequestParams = {},
+  ) =>
+    this.request<WormholeQueryAllValidatorAllowlistResponse, RpcStatus>({
+      path: `/wormhole_foundation/wormchain/wormhole/allowlist`,
+      method: "GET",
+      query: query,
+      format: "json",
+      ...params,
+    });
+
+  /**
+   * No description
+   *
+   * @tags Query
+   * @name QueryAllowlist
+   * @request GET:/wormhole_foundation/wormchain/wormhole/allowlist/{validator_address}
+   */
+  queryAllowlist = (
+    validator_address: string,
+    query?: {
+      "pagination.key"?: string;
+      "pagination.offset"?: string;
+      "pagination.limit"?: string;
+      "pagination.count_total"?: boolean;
+      "pagination.reverse"?: boolean;
+    },
+    params: RequestParams = {},
+  ) =>
+    this.request<WormholeQueryValidatorAllowlistResponse, RpcStatus>({
+      path: `/wormhole_foundation/wormchain/wormhole/allowlist/${validator_address}`,
+      method: "GET",
+      query: query,
+      format: "json",
+      ...params,
+    });
+
   /**
    * No description
    *
@@ -549,6 +680,21 @@ export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDa
       ...params,
     });
 
+  /**
+   * No description
+   *
+   * @tags Query
+   * @name QueryIbcComposabilityMwContract
+   * @request GET:/wormhole_foundation/wormchain/wormhole/ibc_composability_mw_contract
+   */
+  queryIbcComposabilityMwContract = (params: RequestParams = {}) =>
+    this.request<WormholeQueryIbcComposabilityMwContractResponse, RpcStatus>({
+      path: `/wormhole_foundation/wormchain/wormhole/ibc_composability_mw_contract`,
+      method: "GET",
+      format: "json",
+      ...params,
+    });
+
   /**
    * No description
    *
@@ -648,4 +794,29 @@ export class Api<SecurityDataType extends unknown> extends HttpClient<SecurityDa
       format: "json",
       ...params,
     });
+
+  /**
+   * No description
+   *
+   * @tags Query
+   * @name QueryWasmInstantiateAllowlistAll
+   * @request GET:/wormhole_foundation/wormchain/wormhole/wasm_instantiate_allowlist
+   */
+  queryWasmInstantiateAllowlistAll = (
+    query?: {
+      "pagination.key"?: string;
+      "pagination.offset"?: string;
+      "pagination.limit"?: string;
+      "pagination.count_total"?: boolean;
+      "pagination.reverse"?: boolean;
+    },
+    params: RequestParams = {},
+  ) =>
+    this.request<WormholeQueryAllWasmInstantiateAllowlistResponse, RpcStatus>({
+      path: `/wormhole_foundation/wormchain/wormhole/wasm_instantiate_allowlist`,
+      method: "GET",
+      query: query,
+      format: "json",
+      ...params,
+    });
 }

+ 122 - 3
wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/genesis.ts

@@ -1,11 +1,16 @@
 //@ts-nocheck
 /* eslint-disable */
-import { GuardianSet } from "../wormhole/guardian_set";
+import {
+  GuardianSet,
+  GuardianValidator,
+  ValidatorAllowedAddress,
+  WasmInstantiateAllowedContractCodeId,
+  IbcComposabilityMwContract,
+} from "../wormhole/guardian";
 import { Config } from "../wormhole/config";
 import { ReplayProtection } from "../wormhole/replay_protection";
 import { SequenceCounter } from "../wormhole/sequence_counter";
 import { ConsensusGuardianSetIndex } from "../wormhole/consensus_guardian_set_index";
-import { GuardianValidator } from "../wormhole/guardian_validator";
 import { Writer, Reader } from "protobufjs/minimal";
 
 export const protobufPackage = "wormhole_foundation.wormchain.wormhole";
@@ -17,8 +22,11 @@ export interface GenesisState {
   replayProtectionList: ReplayProtection[];
   sequenceCounterList: SequenceCounter[];
   consensusGuardianSetIndex: ConsensusGuardianSetIndex | undefined;
-  /** this line is used by starport scaffolding # genesis/proto/state */
   guardianValidatorList: GuardianValidator[];
+  allowedAddresses: ValidatorAllowedAddress[];
+  wasmInstantiateAllowlist: WasmInstantiateAllowedContractCodeId[];
+  /** this line is used by starport scaffolding # genesis/proto/state */
+  ibcComposabilityMwContract: IbcComposabilityMwContract | undefined;
 }
 
 const baseGenesisState: object = {};
@@ -46,6 +54,21 @@ export const GenesisState = {
     for (const v of message.guardianValidatorList) {
       GuardianValidator.encode(v!, writer.uint32(50).fork()).ldelim();
     }
+    for (const v of message.allowedAddresses) {
+      ValidatorAllowedAddress.encode(v!, writer.uint32(58).fork()).ldelim();
+    }
+    for (const v of message.wasmInstantiateAllowlist) {
+      WasmInstantiateAllowedContractCodeId.encode(
+        v!,
+        writer.uint32(66).fork()
+      ).ldelim();
+    }
+    if (message.ibcComposabilityMwContract !== undefined) {
+      IbcComposabilityMwContract.encode(
+        message.ibcComposabilityMwContract,
+        writer.uint32(74).fork()
+      ).ldelim();
+    }
     return writer;
   },
 
@@ -57,6 +80,8 @@ export const GenesisState = {
     message.replayProtectionList = [];
     message.sequenceCounterList = [];
     message.guardianValidatorList = [];
+    message.allowedAddresses = [];
+    message.wasmInstantiateAllowlist = [];
     while (reader.pos < end) {
       const tag = reader.uint32();
       switch (tag >>> 3) {
@@ -89,6 +114,22 @@ export const GenesisState = {
             GuardianValidator.decode(reader, reader.uint32())
           );
           break;
+        case 7:
+          message.allowedAddresses.push(
+            ValidatorAllowedAddress.decode(reader, reader.uint32())
+          );
+          break;
+        case 8:
+          message.wasmInstantiateAllowlist.push(
+            WasmInstantiateAllowedContractCodeId.decode(reader, reader.uint32())
+          );
+          break;
+        case 9:
+          message.ibcComposabilityMwContract = IbcComposabilityMwContract.decode(
+            reader,
+            reader.uint32()
+          );
+          break;
         default:
           reader.skipType(tag & 7);
           break;
@@ -103,6 +144,8 @@ export const GenesisState = {
     message.replayProtectionList = [];
     message.sequenceCounterList = [];
     message.guardianValidatorList = [];
+    message.allowedAddresses = [];
+    message.wasmInstantiateAllowlist = [];
     if (
       object.guardianSetList !== undefined &&
       object.guardianSetList !== null
@@ -150,6 +193,34 @@ export const GenesisState = {
         message.guardianValidatorList.push(GuardianValidator.fromJSON(e));
       }
     }
+    if (
+      object.allowedAddresses !== undefined &&
+      object.allowedAddresses !== null
+    ) {
+      for (const e of object.allowedAddresses) {
+        message.allowedAddresses.push(ValidatorAllowedAddress.fromJSON(e));
+      }
+    }
+    if (
+      object.wasmInstantiateAllowlist !== undefined &&
+      object.wasmInstantiateAllowlist !== null
+    ) {
+      for (const e of object.wasmInstantiateAllowlist) {
+        message.wasmInstantiateAllowlist.push(
+          WasmInstantiateAllowedContractCodeId.fromJSON(e)
+        );
+      }
+    }
+    if (
+      object.ibcComposabilityMwContract !== undefined &&
+      object.ibcComposabilityMwContract !== null
+    ) {
+      message.ibcComposabilityMwContract = IbcComposabilityMwContract.fromJSON(
+        object.ibcComposabilityMwContract
+      );
+    } else {
+      message.ibcComposabilityMwContract = undefined;
+    }
     return message;
   },
 
@@ -189,6 +260,24 @@ export const GenesisState = {
     } else {
       obj.guardianValidatorList = [];
     }
+    if (message.allowedAddresses) {
+      obj.allowedAddresses = message.allowedAddresses.map((e) =>
+        e ? ValidatorAllowedAddress.toJSON(e) : undefined
+      );
+    } else {
+      obj.allowedAddresses = [];
+    }
+    if (message.wasmInstantiateAllowlist) {
+      obj.wasmInstantiateAllowlist = message.wasmInstantiateAllowlist.map((e) =>
+        e ? WasmInstantiateAllowedContractCodeId.toJSON(e) : undefined
+      );
+    } else {
+      obj.wasmInstantiateAllowlist = [];
+    }
+    message.ibcComposabilityMwContract !== undefined &&
+      (obj.ibcComposabilityMwContract = message.ibcComposabilityMwContract
+        ? IbcComposabilityMwContract.toJSON(message.ibcComposabilityMwContract)
+        : undefined);
     return obj;
   },
 
@@ -198,6 +287,8 @@ export const GenesisState = {
     message.replayProtectionList = [];
     message.sequenceCounterList = [];
     message.guardianValidatorList = [];
+    message.allowedAddresses = [];
+    message.wasmInstantiateAllowlist = [];
     if (
       object.guardianSetList !== undefined &&
       object.guardianSetList !== null
@@ -245,6 +336,34 @@ export const GenesisState = {
         message.guardianValidatorList.push(GuardianValidator.fromPartial(e));
       }
     }
+    if (
+      object.allowedAddresses !== undefined &&
+      object.allowedAddresses !== null
+    ) {
+      for (const e of object.allowedAddresses) {
+        message.allowedAddresses.push(ValidatorAllowedAddress.fromPartial(e));
+      }
+    }
+    if (
+      object.wasmInstantiateAllowlist !== undefined &&
+      object.wasmInstantiateAllowlist !== null
+    ) {
+      for (const e of object.wasmInstantiateAllowlist) {
+        message.wasmInstantiateAllowlist.push(
+          WasmInstantiateAllowedContractCodeId.fromPartial(e)
+        );
+      }
+    }
+    if (
+      object.ibcComposabilityMwContract !== undefined &&
+      object.ibcComposabilityMwContract !== null
+    ) {
+      message.ibcComposabilityMwContract = IbcComposabilityMwContract.fromPartial(
+        object.ibcComposabilityMwContract
+      );
+    } else {
+      message.ibcComposabilityMwContract = undefined;
+    }
     return message;
   },
 };

+ 1 - 1
wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/governance.ts

@@ -1,6 +1,6 @@
 //@ts-nocheck
 /* eslint-disable */
-import { GuardianSet } from "../wormhole/guardian_set";
+import { GuardianSet } from "../wormhole/guardian";
 import { Writer, Reader } from "protobufjs/minimal";
 
 export const protobufPackage = "wormhole_foundation.wormchain.wormhole";

+ 621 - 0
wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/guardian.ts

@@ -0,0 +1,621 @@
+//@ts-nocheck
+/* eslint-disable */
+import * as Long from "long";
+import { util, configure, Writer, Reader } from "protobufjs/minimal";
+
+export const protobufPackage = "wormhole_foundation.wormchain.wormhole";
+
+export interface GuardianKey {
+  key: Uint8Array;
+}
+
+export interface GuardianValidator {
+  guardianKey: Uint8Array;
+  validatorAddr: Uint8Array;
+}
+
+export interface GuardianSet {
+  index: number;
+  keys: Uint8Array[];
+  expirationTime: number;
+}
+
+export interface ValidatorAllowedAddress {
+  /** the validator/guardian that controls this entry */
+  validator_address: string;
+  /** the allowlisted account */
+  allowed_address: string;
+  /** human readable name */
+  name: string;
+}
+
+export interface WasmInstantiateAllowedContractCodeId {
+  /** bech32 address of the contract that can call wasm instantiate without a VAA */
+  contract_address: string;
+  /** reference to the stored WASM code that can be instantiated */
+  code_id: number;
+}
+
+export interface IbcComposabilityMwContract {
+  /** bech32 address of the contract that is used by the ibc composability middleware */
+  contract_address: string;
+}
+
+const baseGuardianKey: object = {};
+
+export const GuardianKey = {
+  encode(message: GuardianKey, writer: Writer = Writer.create()): Writer {
+    if (message.key.length !== 0) {
+      writer.uint32(10).bytes(message.key);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): GuardianKey {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseGuardianKey } as GuardianKey;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.key = reader.bytes();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): GuardianKey {
+    const message = { ...baseGuardianKey } as GuardianKey;
+    if (object.key !== undefined && object.key !== null) {
+      message.key = bytesFromBase64(object.key);
+    }
+    return message;
+  },
+
+  toJSON(message: GuardianKey): unknown {
+    const obj: any = {};
+    message.key !== undefined &&
+      (obj.key = base64FromBytes(
+        message.key !== undefined ? message.key : new Uint8Array()
+      ));
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<GuardianKey>): GuardianKey {
+    const message = { ...baseGuardianKey } as GuardianKey;
+    if (object.key !== undefined && object.key !== null) {
+      message.key = object.key;
+    } else {
+      message.key = new Uint8Array();
+    }
+    return message;
+  },
+};
+
+const baseGuardianValidator: object = {};
+
+export const GuardianValidator = {
+  encode(message: GuardianValidator, writer: Writer = Writer.create()): Writer {
+    if (message.guardianKey.length !== 0) {
+      writer.uint32(10).bytes(message.guardianKey);
+    }
+    if (message.validatorAddr.length !== 0) {
+      writer.uint32(18).bytes(message.validatorAddr);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): GuardianValidator {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseGuardianValidator } as GuardianValidator;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.guardianKey = reader.bytes();
+          break;
+        case 2:
+          message.validatorAddr = reader.bytes();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): GuardianValidator {
+    const message = { ...baseGuardianValidator } as GuardianValidator;
+    if (object.guardianKey !== undefined && object.guardianKey !== null) {
+      message.guardianKey = bytesFromBase64(object.guardianKey);
+    }
+    if (object.validatorAddr !== undefined && object.validatorAddr !== null) {
+      message.validatorAddr = bytesFromBase64(object.validatorAddr);
+    }
+    return message;
+  },
+
+  toJSON(message: GuardianValidator): unknown {
+    const obj: any = {};
+    message.guardianKey !== undefined &&
+      (obj.guardianKey = base64FromBytes(
+        message.guardianKey !== undefined
+          ? message.guardianKey
+          : new Uint8Array()
+      ));
+    message.validatorAddr !== undefined &&
+      (obj.validatorAddr = base64FromBytes(
+        message.validatorAddr !== undefined
+          ? message.validatorAddr
+          : new Uint8Array()
+      ));
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<GuardianValidator>): GuardianValidator {
+    const message = { ...baseGuardianValidator } as GuardianValidator;
+    if (object.guardianKey !== undefined && object.guardianKey !== null) {
+      message.guardianKey = object.guardianKey;
+    } else {
+      message.guardianKey = new Uint8Array();
+    }
+    if (object.validatorAddr !== undefined && object.validatorAddr !== null) {
+      message.validatorAddr = object.validatorAddr;
+    } else {
+      message.validatorAddr = new Uint8Array();
+    }
+    return message;
+  },
+};
+
+const baseGuardianSet: object = { index: 0, expirationTime: 0 };
+
+export const GuardianSet = {
+  encode(message: GuardianSet, writer: Writer = Writer.create()): Writer {
+    if (message.index !== 0) {
+      writer.uint32(8).uint32(message.index);
+    }
+    for (const v of message.keys) {
+      writer.uint32(18).bytes(v!);
+    }
+    if (message.expirationTime !== 0) {
+      writer.uint32(24).uint64(message.expirationTime);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): GuardianSet {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = { ...baseGuardianSet } as GuardianSet;
+    message.keys = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.index = reader.uint32();
+          break;
+        case 2:
+          message.keys.push(reader.bytes());
+          break;
+        case 3:
+          message.expirationTime = longToNumber(reader.uint64() as Long);
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): GuardianSet {
+    const message = { ...baseGuardianSet } as GuardianSet;
+    message.keys = [];
+    if (object.index !== undefined && object.index !== null) {
+      message.index = Number(object.index);
+    } else {
+      message.index = 0;
+    }
+    if (object.keys !== undefined && object.keys !== null) {
+      for (const e of object.keys) {
+        message.keys.push(bytesFromBase64(e));
+      }
+    }
+    if (object.expirationTime !== undefined && object.expirationTime !== null) {
+      message.expirationTime = Number(object.expirationTime);
+    } else {
+      message.expirationTime = 0;
+    }
+    return message;
+  },
+
+  toJSON(message: GuardianSet): unknown {
+    const obj: any = {};
+    message.index !== undefined && (obj.index = message.index);
+    if (message.keys) {
+      obj.keys = message.keys.map((e) =>
+        base64FromBytes(e !== undefined ? e : new Uint8Array())
+      );
+    } else {
+      obj.keys = [];
+    }
+    message.expirationTime !== undefined &&
+      (obj.expirationTime = message.expirationTime);
+    return obj;
+  },
+
+  fromPartial(object: DeepPartial<GuardianSet>): GuardianSet {
+    const message = { ...baseGuardianSet } as GuardianSet;
+    message.keys = [];
+    if (object.index !== undefined && object.index !== null) {
+      message.index = object.index;
+    } else {
+      message.index = 0;
+    }
+    if (object.keys !== undefined && object.keys !== null) {
+      for (const e of object.keys) {
+        message.keys.push(e);
+      }
+    }
+    if (object.expirationTime !== undefined && object.expirationTime !== null) {
+      message.expirationTime = object.expirationTime;
+    } else {
+      message.expirationTime = 0;
+    }
+    return message;
+  },
+};
+
+const baseValidatorAllowedAddress: object = {
+  validator_address: "",
+  allowed_address: "",
+  name: "",
+};
+
+export const ValidatorAllowedAddress = {
+  encode(
+    message: ValidatorAllowedAddress,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.validator_address !== "") {
+      writer.uint32(10).string(message.validator_address);
+    }
+    if (message.allowed_address !== "") {
+      writer.uint32(18).string(message.allowed_address);
+    }
+    if (message.name !== "") {
+      writer.uint32(26).string(message.name);
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): ValidatorAllowedAddress {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseValidatorAllowedAddress,
+    } as ValidatorAllowedAddress;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.validator_address = reader.string();
+          break;
+        case 2:
+          message.allowed_address = reader.string();
+          break;
+        case 3:
+          message.name = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): ValidatorAllowedAddress {
+    const message = {
+      ...baseValidatorAllowedAddress,
+    } as ValidatorAllowedAddress;
+    if (
+      object.validator_address !== undefined &&
+      object.validator_address !== null
+    ) {
+      message.validator_address = String(object.validator_address);
+    } else {
+      message.validator_address = "";
+    }
+    if (
+      object.allowed_address !== undefined &&
+      object.allowed_address !== null
+    ) {
+      message.allowed_address = String(object.allowed_address);
+    } else {
+      message.allowed_address = "";
+    }
+    if (object.name !== undefined && object.name !== null) {
+      message.name = String(object.name);
+    } else {
+      message.name = "";
+    }
+    return message;
+  },
+
+  toJSON(message: ValidatorAllowedAddress): unknown {
+    const obj: any = {};
+    message.validator_address !== undefined &&
+      (obj.validator_address = message.validator_address);
+    message.allowed_address !== undefined &&
+      (obj.allowed_address = message.allowed_address);
+    message.name !== undefined && (obj.name = message.name);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<ValidatorAllowedAddress>
+  ): ValidatorAllowedAddress {
+    const message = {
+      ...baseValidatorAllowedAddress,
+    } as ValidatorAllowedAddress;
+    if (
+      object.validator_address !== undefined &&
+      object.validator_address !== null
+    ) {
+      message.validator_address = object.validator_address;
+    } else {
+      message.validator_address = "";
+    }
+    if (
+      object.allowed_address !== undefined &&
+      object.allowed_address !== null
+    ) {
+      message.allowed_address = object.allowed_address;
+    } else {
+      message.allowed_address = "";
+    }
+    if (object.name !== undefined && object.name !== null) {
+      message.name = object.name;
+    } else {
+      message.name = "";
+    }
+    return message;
+  },
+};
+
+const baseWasmInstantiateAllowedContractCodeId: object = {
+  contract_address: "",
+  code_id: 0,
+};
+
+export const WasmInstantiateAllowedContractCodeId = {
+  encode(
+    message: WasmInstantiateAllowedContractCodeId,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.contract_address !== "") {
+      writer.uint32(10).string(message.contract_address);
+    }
+    if (message.code_id !== 0) {
+      writer.uint32(16).uint64(message.code_id);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): WasmInstantiateAllowedContractCodeId {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseWasmInstantiateAllowedContractCodeId,
+    } as WasmInstantiateAllowedContractCodeId;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.contract_address = reader.string();
+          break;
+        case 2:
+          message.code_id = longToNumber(reader.uint64() as Long);
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): WasmInstantiateAllowedContractCodeId {
+    const message = {
+      ...baseWasmInstantiateAllowedContractCodeId,
+    } as WasmInstantiateAllowedContractCodeId;
+    if (
+      object.contract_address !== undefined &&
+      object.contract_address !== null
+    ) {
+      message.contract_address = String(object.contract_address);
+    } else {
+      message.contract_address = "";
+    }
+    if (object.code_id !== undefined && object.code_id !== null) {
+      message.code_id = Number(object.code_id);
+    } else {
+      message.code_id = 0;
+    }
+    return message;
+  },
+
+  toJSON(message: WasmInstantiateAllowedContractCodeId): unknown {
+    const obj: any = {};
+    message.contract_address !== undefined &&
+      (obj.contract_address = message.contract_address);
+    message.code_id !== undefined && (obj.code_id = message.code_id);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<WasmInstantiateAllowedContractCodeId>
+  ): WasmInstantiateAllowedContractCodeId {
+    const message = {
+      ...baseWasmInstantiateAllowedContractCodeId,
+    } as WasmInstantiateAllowedContractCodeId;
+    if (
+      object.contract_address !== undefined &&
+      object.contract_address !== null
+    ) {
+      message.contract_address = object.contract_address;
+    } else {
+      message.contract_address = "";
+    }
+    if (object.code_id !== undefined && object.code_id !== null) {
+      message.code_id = object.code_id;
+    } else {
+      message.code_id = 0;
+    }
+    return message;
+  },
+};
+
+const baseIbcComposabilityMwContract: object = { contract_address: "" };
+
+export const IbcComposabilityMwContract = {
+  encode(
+    message: IbcComposabilityMwContract,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.contract_address !== "") {
+      writer.uint32(10).string(message.contract_address);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): IbcComposabilityMwContract {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseIbcComposabilityMwContract,
+    } as IbcComposabilityMwContract;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.contract_address = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): IbcComposabilityMwContract {
+    const message = {
+      ...baseIbcComposabilityMwContract,
+    } as IbcComposabilityMwContract;
+    if (
+      object.contract_address !== undefined &&
+      object.contract_address !== null
+    ) {
+      message.contract_address = String(object.contract_address);
+    } else {
+      message.contract_address = "";
+    }
+    return message;
+  },
+
+  toJSON(message: IbcComposabilityMwContract): unknown {
+    const obj: any = {};
+    message.contract_address !== undefined &&
+      (obj.contract_address = message.contract_address);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<IbcComposabilityMwContract>
+  ): IbcComposabilityMwContract {
+    const message = {
+      ...baseIbcComposabilityMwContract,
+    } as IbcComposabilityMwContract;
+    if (
+      object.contract_address !== undefined &&
+      object.contract_address !== null
+    ) {
+      message.contract_address = object.contract_address;
+    } else {
+      message.contract_address = "";
+    }
+    return message;
+  },
+};
+
+declare var self: any | undefined;
+declare var window: any | undefined;
+var globalThis: any = (() => {
+  if (typeof globalThis !== "undefined") return globalThis;
+  if (typeof self !== "undefined") return self;
+  if (typeof window !== "undefined") return window;
+  if (typeof global !== "undefined") return global;
+  throw "Unable to locate global object";
+})();
+
+const atob: (b64: string) => string =
+  globalThis.atob ||
+  ((b64) => globalThis.Buffer.from(b64, "base64").toString("binary"));
+function bytesFromBase64(b64: string): Uint8Array {
+  const bin = atob(b64);
+  const arr = new Uint8Array(bin.length);
+  for (let i = 0; i < bin.length; ++i) {
+    arr[i] = bin.charCodeAt(i);
+  }
+  return arr;
+}
+
+const btoa: (bin: string) => string =
+  globalThis.btoa ||
+  ((bin) => globalThis.Buffer.from(bin, "binary").toString("base64"));
+function base64FromBytes(arr: Uint8Array): string {
+  const bin: string[] = [];
+  for (let i = 0; i < arr.byteLength; ++i) {
+    bin.push(String.fromCharCode(arr[i]));
+  }
+  return btoa(bin.join(""));
+}
+
+type Builtin = Date | Function | Uint8Array | string | number | undefined;
+export type DeepPartial<T> = T extends Builtin
+  ? T
+  : T extends Array<infer U>
+  ? Array<DeepPartial<U>>
+  : T extends ReadonlyArray<infer U>
+  ? ReadonlyArray<DeepPartial<U>>
+  : T extends {}
+  ? { [K in keyof T]?: DeepPartial<T[K]> }
+  : Partial<T>;
+
+function longToNumber(long: Long): number {
+  if (long.gt(Number.MAX_SAFE_INTEGER)) {
+    throw new globalThis.Error("Value is larger than Number.MAX_SAFE_INTEGER");
+  }
+  return long.toNumber();
+}
+
+if (util.Long !== Long) {
+  util.Long = Long as any;
+  configure();
+}

+ 1 - 0
wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/guardian_key.ts

@@ -1,4 +1,5 @@
 //@ts-nocheck
+//@ts-nocheck
 /* eslint-disable */
 import { Writer, Reader } from "protobufjs/minimal";
 

+ 1 - 0
wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/guardian_set.ts

@@ -1,4 +1,5 @@
 //@ts-nocheck
+//@ts-nocheck
 /* eslint-disable */
 import * as Long from "long";
 import { util, configure, Writer, Reader } from "protobufjs/minimal";

+ 1 - 0
wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/guardian_validator.ts

@@ -1,4 +1,5 @@
 //@ts-nocheck
+//@ts-nocheck
 /* eslint-disable */
 import { Writer, Reader } from "protobufjs/minimal";
 

+ 821 - 2
wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/query.ts

@@ -1,19 +1,45 @@
 //@ts-nocheck
 /* eslint-disable */
 import { Reader, Writer } from "protobufjs/minimal";
-import { GuardianSet } from "../wormhole/guardian_set";
 import {
   PageRequest,
   PageResponse,
 } from "../cosmos/base/query/v1beta1/pagination";
+import {
+  ValidatorAllowedAddress,
+  GuardianSet,
+  GuardianValidator,
+  WasmInstantiateAllowedContractCodeId,
+} from "../wormhole/guardian";
 import { Config } from "../wormhole/config";
 import { ReplayProtection } from "../wormhole/replay_protection";
 import { SequenceCounter } from "../wormhole/sequence_counter";
 import { ConsensusGuardianSetIndex } from "../wormhole/consensus_guardian_set_index";
-import { GuardianValidator } from "../wormhole/guardian_validator";
 
 export const protobufPackage = "wormhole_foundation.wormchain.wormhole";
 
+export interface QueryAllValidatorAllowlist {
+  pagination: PageRequest | undefined;
+}
+
+/** all allowlisted entries by all validators */
+export interface QueryAllValidatorAllowlistResponse {
+  allowlist: ValidatorAllowedAddress[];
+  pagination: PageResponse | undefined;
+}
+
+export interface QueryValidatorAllowlist {
+  validator_address: string;
+  pagination: PageRequest | undefined;
+}
+
+/** all allowlisted entries by a specific validator */
+export interface QueryValidatorAllowlistResponse {
+  validator_address: string;
+  allowlist: ValidatorAllowedAddress[];
+  pagination: PageResponse | undefined;
+}
+
 export interface QueryGetGuardianSetRequest {
   index: number;
 }
@@ -100,6 +126,417 @@ export interface QueryLatestGuardianSetIndexResponse {
   latestGuardianSetIndex: number;
 }
 
+export interface QueryIbcComposabilityMwContractRequest {}
+
+export interface QueryIbcComposabilityMwContractResponse {
+  contractAddress: string;
+}
+
+export interface QueryAllWasmInstantiateAllowlist {
+  pagination: PageRequest | undefined;
+}
+
+/** all allowlisted entries by all validators */
+export interface QueryAllWasmInstantiateAllowlistResponse {
+  allowlist: WasmInstantiateAllowedContractCodeId[];
+  pagination: PageResponse | undefined;
+}
+
+const baseQueryAllValidatorAllowlist: object = {};
+
+export const QueryAllValidatorAllowlist = {
+  encode(
+    message: QueryAllValidatorAllowlist,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.pagination !== undefined) {
+      PageRequest.encode(message.pagination, writer.uint32(10).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryAllValidatorAllowlist {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryAllValidatorAllowlist,
+    } as QueryAllValidatorAllowlist;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.pagination = PageRequest.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryAllValidatorAllowlist {
+    const message = {
+      ...baseQueryAllValidatorAllowlist,
+    } as QueryAllValidatorAllowlist;
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageRequest.fromJSON(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryAllValidatorAllowlist): unknown {
+    const obj: any = {};
+    message.pagination !== undefined &&
+      (obj.pagination = message.pagination
+        ? PageRequest.toJSON(message.pagination)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryAllValidatorAllowlist>
+  ): QueryAllValidatorAllowlist {
+    const message = {
+      ...baseQueryAllValidatorAllowlist,
+    } as QueryAllValidatorAllowlist;
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageRequest.fromPartial(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+};
+
+const baseQueryAllValidatorAllowlistResponse: object = {};
+
+export const QueryAllValidatorAllowlistResponse = {
+  encode(
+    message: QueryAllValidatorAllowlistResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    for (const v of message.allowlist) {
+      ValidatorAllowedAddress.encode(v!, writer.uint32(10).fork()).ldelim();
+    }
+    if (message.pagination !== undefined) {
+      PageResponse.encode(
+        message.pagination,
+        writer.uint32(18).fork()
+      ).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryAllValidatorAllowlistResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryAllValidatorAllowlistResponse,
+    } as QueryAllValidatorAllowlistResponse;
+    message.allowlist = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.allowlist.push(
+            ValidatorAllowedAddress.decode(reader, reader.uint32())
+          );
+          break;
+        case 2:
+          message.pagination = PageResponse.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryAllValidatorAllowlistResponse {
+    const message = {
+      ...baseQueryAllValidatorAllowlistResponse,
+    } as QueryAllValidatorAllowlistResponse;
+    message.allowlist = [];
+    if (object.allowlist !== undefined && object.allowlist !== null) {
+      for (const e of object.allowlist) {
+        message.allowlist.push(ValidatorAllowedAddress.fromJSON(e));
+      }
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageResponse.fromJSON(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryAllValidatorAllowlistResponse): unknown {
+    const obj: any = {};
+    if (message.allowlist) {
+      obj.allowlist = message.allowlist.map((e) =>
+        e ? ValidatorAllowedAddress.toJSON(e) : undefined
+      );
+    } else {
+      obj.allowlist = [];
+    }
+    message.pagination !== undefined &&
+      (obj.pagination = message.pagination
+        ? PageResponse.toJSON(message.pagination)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryAllValidatorAllowlistResponse>
+  ): QueryAllValidatorAllowlistResponse {
+    const message = {
+      ...baseQueryAllValidatorAllowlistResponse,
+    } as QueryAllValidatorAllowlistResponse;
+    message.allowlist = [];
+    if (object.allowlist !== undefined && object.allowlist !== null) {
+      for (const e of object.allowlist) {
+        message.allowlist.push(ValidatorAllowedAddress.fromPartial(e));
+      }
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageResponse.fromPartial(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+};
+
+const baseQueryValidatorAllowlist: object = { validator_address: "" };
+
+export const QueryValidatorAllowlist = {
+  encode(
+    message: QueryValidatorAllowlist,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.validator_address !== "") {
+      writer.uint32(10).string(message.validator_address);
+    }
+    if (message.pagination !== undefined) {
+      PageRequest.encode(message.pagination, writer.uint32(18).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(input: Reader | Uint8Array, length?: number): QueryValidatorAllowlist {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryValidatorAllowlist,
+    } as QueryValidatorAllowlist;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.validator_address = reader.string();
+          break;
+        case 2:
+          message.pagination = PageRequest.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryValidatorAllowlist {
+    const message = {
+      ...baseQueryValidatorAllowlist,
+    } as QueryValidatorAllowlist;
+    if (
+      object.validator_address !== undefined &&
+      object.validator_address !== null
+    ) {
+      message.validator_address = String(object.validator_address);
+    } else {
+      message.validator_address = "";
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageRequest.fromJSON(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryValidatorAllowlist): unknown {
+    const obj: any = {};
+    message.validator_address !== undefined &&
+      (obj.validator_address = message.validator_address);
+    message.pagination !== undefined &&
+      (obj.pagination = message.pagination
+        ? PageRequest.toJSON(message.pagination)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryValidatorAllowlist>
+  ): QueryValidatorAllowlist {
+    const message = {
+      ...baseQueryValidatorAllowlist,
+    } as QueryValidatorAllowlist;
+    if (
+      object.validator_address !== undefined &&
+      object.validator_address !== null
+    ) {
+      message.validator_address = object.validator_address;
+    } else {
+      message.validator_address = "";
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageRequest.fromPartial(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+};
+
+const baseQueryValidatorAllowlistResponse: object = { validator_address: "" };
+
+export const QueryValidatorAllowlistResponse = {
+  encode(
+    message: QueryValidatorAllowlistResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.validator_address !== "") {
+      writer.uint32(10).string(message.validator_address);
+    }
+    for (const v of message.allowlist) {
+      ValidatorAllowedAddress.encode(v!, writer.uint32(18).fork()).ldelim();
+    }
+    if (message.pagination !== undefined) {
+      PageResponse.encode(
+        message.pagination,
+        writer.uint32(26).fork()
+      ).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryValidatorAllowlistResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryValidatorAllowlistResponse,
+    } as QueryValidatorAllowlistResponse;
+    message.allowlist = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.validator_address = reader.string();
+          break;
+        case 2:
+          message.allowlist.push(
+            ValidatorAllowedAddress.decode(reader, reader.uint32())
+          );
+          break;
+        case 3:
+          message.pagination = PageResponse.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryValidatorAllowlistResponse {
+    const message = {
+      ...baseQueryValidatorAllowlistResponse,
+    } as QueryValidatorAllowlistResponse;
+    message.allowlist = [];
+    if (
+      object.validator_address !== undefined &&
+      object.validator_address !== null
+    ) {
+      message.validator_address = String(object.validator_address);
+    } else {
+      message.validator_address = "";
+    }
+    if (object.allowlist !== undefined && object.allowlist !== null) {
+      for (const e of object.allowlist) {
+        message.allowlist.push(ValidatorAllowedAddress.fromJSON(e));
+      }
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageResponse.fromJSON(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryValidatorAllowlistResponse): unknown {
+    const obj: any = {};
+    message.validator_address !== undefined &&
+      (obj.validator_address = message.validator_address);
+    if (message.allowlist) {
+      obj.allowlist = message.allowlist.map((e) =>
+        e ? ValidatorAllowedAddress.toJSON(e) : undefined
+      );
+    } else {
+      obj.allowlist = [];
+    }
+    message.pagination !== undefined &&
+      (obj.pagination = message.pagination
+        ? PageResponse.toJSON(message.pagination)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryValidatorAllowlistResponse>
+  ): QueryValidatorAllowlistResponse {
+    const message = {
+      ...baseQueryValidatorAllowlistResponse,
+    } as QueryValidatorAllowlistResponse;
+    message.allowlist = [];
+    if (
+      object.validator_address !== undefined &&
+      object.validator_address !== null
+    ) {
+      message.validator_address = object.validator_address;
+    } else {
+      message.validator_address = "";
+    }
+    if (object.allowlist !== undefined && object.allowlist !== null) {
+      for (const e of object.allowlist) {
+        message.allowlist.push(ValidatorAllowedAddress.fromPartial(e));
+      }
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageResponse.fromPartial(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+};
+
 const baseQueryGetGuardianSetRequest: object = { index: 0 };
 
 export const QueryGetGuardianSetRequest = {
@@ -1803,6 +2240,318 @@ export const QueryLatestGuardianSetIndexResponse = {
   },
 };
 
+const baseQueryIbcComposabilityMwContractRequest: object = {};
+
+export const QueryIbcComposabilityMwContractRequest = {
+  encode(
+    _: QueryIbcComposabilityMwContractRequest,
+    writer: Writer = Writer.create()
+  ): Writer {
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryIbcComposabilityMwContractRequest {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryIbcComposabilityMwContractRequest,
+    } as QueryIbcComposabilityMwContractRequest;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(_: any): QueryIbcComposabilityMwContractRequest {
+    const message = {
+      ...baseQueryIbcComposabilityMwContractRequest,
+    } as QueryIbcComposabilityMwContractRequest;
+    return message;
+  },
+
+  toJSON(_: QueryIbcComposabilityMwContractRequest): unknown {
+    const obj: any = {};
+    return obj;
+  },
+
+  fromPartial(
+    _: DeepPartial<QueryIbcComposabilityMwContractRequest>
+  ): QueryIbcComposabilityMwContractRequest {
+    const message = {
+      ...baseQueryIbcComposabilityMwContractRequest,
+    } as QueryIbcComposabilityMwContractRequest;
+    return message;
+  },
+};
+
+const baseQueryIbcComposabilityMwContractResponse: object = {
+  contractAddress: "",
+};
+
+export const QueryIbcComposabilityMwContractResponse = {
+  encode(
+    message: QueryIbcComposabilityMwContractResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.contractAddress !== "") {
+      writer.uint32(10).string(message.contractAddress);
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryIbcComposabilityMwContractResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryIbcComposabilityMwContractResponse,
+    } as QueryIbcComposabilityMwContractResponse;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.contractAddress = reader.string();
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryIbcComposabilityMwContractResponse {
+    const message = {
+      ...baseQueryIbcComposabilityMwContractResponse,
+    } as QueryIbcComposabilityMwContractResponse;
+    if (
+      object.contractAddress !== undefined &&
+      object.contractAddress !== null
+    ) {
+      message.contractAddress = String(object.contractAddress);
+    } else {
+      message.contractAddress = "";
+    }
+    return message;
+  },
+
+  toJSON(message: QueryIbcComposabilityMwContractResponse): unknown {
+    const obj: any = {};
+    message.contractAddress !== undefined &&
+      (obj.contractAddress = message.contractAddress);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryIbcComposabilityMwContractResponse>
+  ): QueryIbcComposabilityMwContractResponse {
+    const message = {
+      ...baseQueryIbcComposabilityMwContractResponse,
+    } as QueryIbcComposabilityMwContractResponse;
+    if (
+      object.contractAddress !== undefined &&
+      object.contractAddress !== null
+    ) {
+      message.contractAddress = object.contractAddress;
+    } else {
+      message.contractAddress = "";
+    }
+    return message;
+  },
+};
+
+const baseQueryAllWasmInstantiateAllowlist: object = {};
+
+export const QueryAllWasmInstantiateAllowlist = {
+  encode(
+    message: QueryAllWasmInstantiateAllowlist,
+    writer: Writer = Writer.create()
+  ): Writer {
+    if (message.pagination !== undefined) {
+      PageRequest.encode(message.pagination, writer.uint32(10).fork()).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryAllWasmInstantiateAllowlist {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryAllWasmInstantiateAllowlist,
+    } as QueryAllWasmInstantiateAllowlist;
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.pagination = PageRequest.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryAllWasmInstantiateAllowlist {
+    const message = {
+      ...baseQueryAllWasmInstantiateAllowlist,
+    } as QueryAllWasmInstantiateAllowlist;
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageRequest.fromJSON(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryAllWasmInstantiateAllowlist): unknown {
+    const obj: any = {};
+    message.pagination !== undefined &&
+      (obj.pagination = message.pagination
+        ? PageRequest.toJSON(message.pagination)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryAllWasmInstantiateAllowlist>
+  ): QueryAllWasmInstantiateAllowlist {
+    const message = {
+      ...baseQueryAllWasmInstantiateAllowlist,
+    } as QueryAllWasmInstantiateAllowlist;
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageRequest.fromPartial(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+};
+
+const baseQueryAllWasmInstantiateAllowlistResponse: object = {};
+
+export const QueryAllWasmInstantiateAllowlistResponse = {
+  encode(
+    message: QueryAllWasmInstantiateAllowlistResponse,
+    writer: Writer = Writer.create()
+  ): Writer {
+    for (const v of message.allowlist) {
+      WasmInstantiateAllowedContractCodeId.encode(
+        v!,
+        writer.uint32(10).fork()
+      ).ldelim();
+    }
+    if (message.pagination !== undefined) {
+      PageResponse.encode(
+        message.pagination,
+        writer.uint32(18).fork()
+      ).ldelim();
+    }
+    return writer;
+  },
+
+  decode(
+    input: Reader | Uint8Array,
+    length?: number
+  ): QueryAllWasmInstantiateAllowlistResponse {
+    const reader = input instanceof Uint8Array ? new Reader(input) : input;
+    let end = length === undefined ? reader.len : reader.pos + length;
+    const message = {
+      ...baseQueryAllWasmInstantiateAllowlistResponse,
+    } as QueryAllWasmInstantiateAllowlistResponse;
+    message.allowlist = [];
+    while (reader.pos < end) {
+      const tag = reader.uint32();
+      switch (tag >>> 3) {
+        case 1:
+          message.allowlist.push(
+            WasmInstantiateAllowedContractCodeId.decode(reader, reader.uint32())
+          );
+          break;
+        case 2:
+          message.pagination = PageResponse.decode(reader, reader.uint32());
+          break;
+        default:
+          reader.skipType(tag & 7);
+          break;
+      }
+    }
+    return message;
+  },
+
+  fromJSON(object: any): QueryAllWasmInstantiateAllowlistResponse {
+    const message = {
+      ...baseQueryAllWasmInstantiateAllowlistResponse,
+    } as QueryAllWasmInstantiateAllowlistResponse;
+    message.allowlist = [];
+    if (object.allowlist !== undefined && object.allowlist !== null) {
+      for (const e of object.allowlist) {
+        message.allowlist.push(
+          WasmInstantiateAllowedContractCodeId.fromJSON(e)
+        );
+      }
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageResponse.fromJSON(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+
+  toJSON(message: QueryAllWasmInstantiateAllowlistResponse): unknown {
+    const obj: any = {};
+    if (message.allowlist) {
+      obj.allowlist = message.allowlist.map((e) =>
+        e ? WasmInstantiateAllowedContractCodeId.toJSON(e) : undefined
+      );
+    } else {
+      obj.allowlist = [];
+    }
+    message.pagination !== undefined &&
+      (obj.pagination = message.pagination
+        ? PageResponse.toJSON(message.pagination)
+        : undefined);
+    return obj;
+  },
+
+  fromPartial(
+    object: DeepPartial<QueryAllWasmInstantiateAllowlistResponse>
+  ): QueryAllWasmInstantiateAllowlistResponse {
+    const message = {
+      ...baseQueryAllWasmInstantiateAllowlistResponse,
+    } as QueryAllWasmInstantiateAllowlistResponse;
+    message.allowlist = [];
+    if (object.allowlist !== undefined && object.allowlist !== null) {
+      for (const e of object.allowlist) {
+        message.allowlist.push(
+          WasmInstantiateAllowedContractCodeId.fromPartial(e)
+        );
+      }
+    }
+    if (object.pagination !== undefined && object.pagination !== null) {
+      message.pagination = PageResponse.fromPartial(object.pagination);
+    } else {
+      message.pagination = undefined;
+    }
+    return message;
+  },
+};
+
 /** Query defines the gRPC querier service. */
 export interface Query {
   /** Queries a guardianSet by index. */
@@ -1847,6 +2596,18 @@ export interface Query {
   LatestGuardianSetIndex(
     request: QueryLatestGuardianSetIndexRequest
   ): Promise<QueryLatestGuardianSetIndexResponse>;
+  AllowlistAll(
+    request: QueryAllValidatorAllowlist
+  ): Promise<QueryAllValidatorAllowlistResponse>;
+  Allowlist(
+    request: QueryValidatorAllowlist
+  ): Promise<QueryValidatorAllowlistResponse>;
+  IbcComposabilityMwContract(
+    request: QueryIbcComposabilityMwContractRequest
+  ): Promise<QueryIbcComposabilityMwContractResponse>;
+  WasmInstantiateAllowlistAll(
+    request: QueryAllWasmInstantiateAllowlist
+  ): Promise<QueryAllWasmInstantiateAllowlistResponse>;
 }
 
 export class QueryClientImpl implements Query {
@@ -2007,6 +2768,64 @@ export class QueryClientImpl implements Query {
       QueryLatestGuardianSetIndexResponse.decode(new Reader(data))
     );
   }
+
+  AllowlistAll(
+    request: QueryAllValidatorAllowlist
+  ): Promise<QueryAllValidatorAllowlistResponse> {
+    const data = QueryAllValidatorAllowlist.encode(request).finish();
+    const promise = this.rpc.request(
+      "wormhole_foundation.wormchain.wormhole.Query",
+      "AllowlistAll",
+      data
+    );
+    return promise.then((data) =>
+      QueryAllValidatorAllowlistResponse.decode(new Reader(data))
+    );
+  }
+
+  Allowlist(
+    request: QueryValidatorAllowlist
+  ): Promise<QueryValidatorAllowlistResponse> {
+    const data = QueryValidatorAllowlist.encode(request).finish();
+    const promise = this.rpc.request(
+      "wormhole_foundation.wormchain.wormhole.Query",
+      "Allowlist",
+      data
+    );
+    return promise.then((data) =>
+      QueryValidatorAllowlistResponse.decode(new Reader(data))
+    );
+  }
+
+  IbcComposabilityMwContract(
+    request: QueryIbcComposabilityMwContractRequest
+  ): Promise<QueryIbcComposabilityMwContractResponse> {
+    const data = QueryIbcComposabilityMwContractRequest.encode(
+      request
+    ).finish();
+    const promise = this.rpc.request(
+      "wormhole_foundation.wormchain.wormhole.Query",
+      "IbcComposabilityMwContract",
+      data
+    );
+    return promise.then((data) =>
+      QueryIbcComposabilityMwContractResponse.decode(new Reader(data))
+    );
+  }
+
+  WasmInstantiateAllowlistAll(
+    request: QueryAllWasmInstantiateAllowlist
+  ): Promise<QueryAllWasmInstantiateAllowlistResponse> {
+    const data = QueryAllWasmInstantiateAllowlist.encode(request).finish();
+    const promise = this.rpc.request(
+      "wormhole_foundation.wormchain.wormhole.Query",
+      "WasmInstantiateAllowlistAll",
+      data
+    );
+    return promise.then((data) =>
+      QueryAllWasmInstantiateAllowlistResponse.decode(new Reader(data))
+    );
+  }
 }
 
 interface Rpc {

파일 크기가 너무 크기때문에 변경 상태를 표시하지 않습니다.
+ 975 - 7
wormchain/ts-sdk/src/modules/wormhole_foundation.wormchain.wormhole/types/wormhole/tx.ts


이 변경점에서 너무 많은 파일들이 변경되어 몇몇 파일들은 표시되지 않았습니다.