//@ts-nocheck
import { Coin, CoinAmino, CoinSDKType } from "../../base/v1beta1/coin";
import { Any, AnyProtoMsg, AnyAmino, AnySDKType } from "../../../google/protobuf/any";
import { Timestamp } from "../../../google/protobuf/timestamp";
import { Duration, DurationAmino, DurationSDKType } from "../../../google/protobuf/duration";
import { CommunityPoolSpendProposal, CommunityPoolSpendProposalProtoMsg, CommunityPoolSpendProposalSDKType, CommunityPoolSpendProposalWithDeposit, CommunityPoolSpendProposalWithDepositProtoMsg, CommunityPoolSpendProposalWithDepositSDKType } from "../../distribution/v1beta1/distribution";
import { ParameterChangeProposal, ParameterChangeProposalProtoMsg, ParameterChangeProposalSDKType } from "../../params/v1beta1/params";
import { SoftwareUpgradeProposal, SoftwareUpgradeProposalProtoMsg, SoftwareUpgradeProposalSDKType, CancelSoftwareUpgradeProposal, CancelSoftwareUpgradeProposalProtoMsg, CancelSoftwareUpgradeProposalSDKType } from "../../upgrade/v1beta1/upgrade";
import { StoreCodeProposal, StoreCodeProposalProtoMsg, StoreCodeProposalSDKType, InstantiateContractProposal, InstantiateContractProposalProtoMsg, InstantiateContractProposalSDKType, InstantiateContract2Proposal, InstantiateContract2ProposalProtoMsg, InstantiateContract2ProposalSDKType, MigrateContractProposal, MigrateContractProposalProtoMsg, MigrateContractProposalSDKType, SudoContractProposal, SudoContractProposalProtoMsg, SudoContractProposalSDKType, ExecuteContractProposal, ExecuteContractProposalProtoMsg, ExecuteContractProposalSDKType, UpdateAdminProposal, UpdateAdminProposalProtoMsg, UpdateAdminProposalSDKType, ClearAdminProposal, ClearAdminProposalProtoMsg, ClearAdminProposalSDKType, PinCodesProposal, PinCodesProposalProtoMsg, PinCodesProposalSDKType, UnpinCodesProposal, UnpinCodesProposalProtoMsg, UnpinCodesProposalSDKType, UpdateInstantiateConfigProposal, UpdateInstantiateConfigProposalProtoMsg, UpdateInstantiateConfigProposalSDKType, StoreAndInstantiateContractProposal, StoreAndInstantiateContractProposalProtoMsg, StoreAndInstantiateContractProposalSDKType } from "../../../cosmwasm/wasm/v1/proposal";
import { isSet, toTimestamp, fromTimestamp, fromJsonTimestamp, bytesFromBase64, base64FromBytes } from "../../../helpers";
import { BinaryReader, BinaryWriter } from "../../../binary";
import { Decimal } from "@cosmjs/math";
import { JsonSafe } from "../../../json-safe";
import { GlobalDecoderRegistry } from "../../../registry";
/** VoteOption enumerates the valid vote options for a given governance proposal. */
export enum VoteOption {
/** VOTE_OPTION_UNSPECIFIED - VOTE_OPTION_UNSPECIFIED defines a no-op vote option. */
VOTE_OPTION_UNSPECIFIED = 0,
/** VOTE_OPTION_YES - VOTE_OPTION_YES defines a yes vote option. */
VOTE_OPTION_YES = 1,
/** VOTE_OPTION_ABSTAIN - VOTE_OPTION_ABSTAIN defines an abstain vote option. */
VOTE_OPTION_ABSTAIN = 2,
/** VOTE_OPTION_NO - VOTE_OPTION_NO defines a no vote option. */
VOTE_OPTION_NO = 3,
/** VOTE_OPTION_NO_WITH_VETO - VOTE_OPTION_NO_WITH_VETO defines a no with veto vote option. */
VOTE_OPTION_NO_WITH_VETO = 4,
UNRECOGNIZED = -1,
}
export const VoteOptionSDKType = VoteOption;
export const VoteOptionAmino = VoteOption;
export function voteOptionFromJSON(object: any): VoteOption {
switch (object) {
case 0:
case "VOTE_OPTION_UNSPECIFIED":
return VoteOption.VOTE_OPTION_UNSPECIFIED;
case 1:
case "VOTE_OPTION_YES":
return VoteOption.VOTE_OPTION_YES;
case 2:
case "VOTE_OPTION_ABSTAIN":
return VoteOption.VOTE_OPTION_ABSTAIN;
case 3:
case "VOTE_OPTION_NO":
return VoteOption.VOTE_OPTION_NO;
case 4:
case "VOTE_OPTION_NO_WITH_VETO":
return VoteOption.VOTE_OPTION_NO_WITH_VETO;
case -1:
case "UNRECOGNIZED":
default:
return VoteOption.UNRECOGNIZED;
}
}
export function voteOptionToJSON(object: VoteOption): string {
switch (object) {
case VoteOption.VOTE_OPTION_UNSPECIFIED:
return "VOTE_OPTION_UNSPECIFIED";
case VoteOption.VOTE_OPTION_YES:
return "VOTE_OPTION_YES";
case VoteOption.VOTE_OPTION_ABSTAIN:
return "VOTE_OPTION_ABSTAIN";
case VoteOption.VOTE_OPTION_NO:
return "VOTE_OPTION_NO";
case VoteOption.VOTE_OPTION_NO_WITH_VETO:
return "VOTE_OPTION_NO_WITH_VETO";
case VoteOption.UNRECOGNIZED:
default:
return "UNRECOGNIZED";
}
}
/** ProposalStatus enumerates the valid statuses of a proposal. */
export enum ProposalStatus {
/** PROPOSAL_STATUS_UNSPECIFIED - PROPOSAL_STATUS_UNSPECIFIED defines the default propopsal status. */
PROPOSAL_STATUS_UNSPECIFIED = 0,
/**
* PROPOSAL_STATUS_DEPOSIT_PERIOD - PROPOSAL_STATUS_DEPOSIT_PERIOD defines a proposal status during the deposit
* period.
*/
PROPOSAL_STATUS_DEPOSIT_PERIOD = 1,
/**
* PROPOSAL_STATUS_VOTING_PERIOD - PROPOSAL_STATUS_VOTING_PERIOD defines a proposal status during the voting
* period.
*/
PROPOSAL_STATUS_VOTING_PERIOD = 2,
/**
* PROPOSAL_STATUS_PASSED - PROPOSAL_STATUS_PASSED defines a proposal status of a proposal that has
* passed.
*/
PROPOSAL_STATUS_PASSED = 3,
/**
* PROPOSAL_STATUS_REJECTED - PROPOSAL_STATUS_REJECTED defines a proposal status of a proposal that has
* been rejected.
*/
PROPOSAL_STATUS_REJECTED = 4,
/**
* PROPOSAL_STATUS_FAILED - PROPOSAL_STATUS_FAILED defines a proposal status of a proposal that has
* failed.
*/
PROPOSAL_STATUS_FAILED = 5,
UNRECOGNIZED = -1,
}
export const ProposalStatusSDKType = ProposalStatus;
export const ProposalStatusAmino = ProposalStatus;
export function proposalStatusFromJSON(object: any): ProposalStatus {
switch (object) {
case 0:
case "PROPOSAL_STATUS_UNSPECIFIED":
return ProposalStatus.PROPOSAL_STATUS_UNSPECIFIED;
case 1:
case "PROPOSAL_STATUS_DEPOSIT_PERIOD":
return ProposalStatus.PROPOSAL_STATUS_DEPOSIT_PERIOD;
case 2:
case "PROPOSAL_STATUS_VOTING_PERIOD":
return ProposalStatus.PROPOSAL_STATUS_VOTING_PERIOD;
case 3:
case "PROPOSAL_STATUS_PASSED":
return ProposalStatus.PROPOSAL_STATUS_PASSED;
case 4:
case "PROPOSAL_STATUS_REJECTED":
return ProposalStatus.PROPOSAL_STATUS_REJECTED;
case 5:
case "PROPOSAL_STATUS_FAILED":
return ProposalStatus.PROPOSAL_STATUS_FAILED;
case -1:
case "UNRECOGNIZED":
default:
return ProposalStatus.UNRECOGNIZED;
}
}
export function proposalStatusToJSON(object: ProposalStatus): string {
switch (object) {
case ProposalStatus.PROPOSAL_STATUS_UNSPECIFIED:
return "PROPOSAL_STATUS_UNSPECIFIED";
case ProposalStatus.PROPOSAL_STATUS_DEPOSIT_PERIOD:
return "PROPOSAL_STATUS_DEPOSIT_PERIOD";
case ProposalStatus.PROPOSAL_STATUS_VOTING_PERIOD:
return "PROPOSAL_STATUS_VOTING_PERIOD";
case ProposalStatus.PROPOSAL_STATUS_PASSED:
return "PROPOSAL_STATUS_PASSED";
case ProposalStatus.PROPOSAL_STATUS_REJECTED:
return "PROPOSAL_STATUS_REJECTED";
case ProposalStatus.PROPOSAL_STATUS_FAILED:
return "PROPOSAL_STATUS_FAILED";
case ProposalStatus.UNRECOGNIZED:
default:
return "UNRECOGNIZED";
}
}
/**
* WeightedVoteOption defines a unit of vote for vote split.
*
* Since: cosmos-sdk 0.43
*/
export interface WeightedVoteOption {
option: VoteOption;
weight: string;
}
export interface WeightedVoteOptionProtoMsg {
typeUrl: "/cosmos.gov.v1beta1.WeightedVoteOption";
value: Uint8Array;
}
/**
* WeightedVoteOption defines a unit of vote for vote split.
*
* Since: cosmos-sdk 0.43
*/
export interface WeightedVoteOptionAmino {
option?: VoteOption;
weight?: string;
}
export interface WeightedVoteOptionAminoMsg {
type: "cosmos-sdk/WeightedVoteOption";
value: WeightedVoteOptionAmino;
}
/**
* WeightedVoteOption defines a unit of vote for vote split.
*
* Since: cosmos-sdk 0.43
*/
export interface WeightedVoteOptionSDKType {
option: VoteOption;
weight: string;
}
/**
* TextProposal defines a standard text proposal whose changes need to be
* manually updated in case of approval.
*/
export interface TextProposal {
$typeUrl?: "/cosmos.gov.v1beta1.TextProposal";
title: string;
description: string;
}
export interface TextProposalProtoMsg {
typeUrl: "/cosmos.gov.v1beta1.TextProposal";
value: Uint8Array;
}
/**
* TextProposal defines a standard text proposal whose changes need to be
* manually updated in case of approval.
*/
export interface TextProposalAmino {
title?: string;
description?: string;
}
export interface TextProposalAminoMsg {
type: "cosmos-sdk/TextProposal";
value: TextProposalAmino;
}
/**
* TextProposal defines a standard text proposal whose changes need to be
* manually updated in case of approval.
*/
export interface TextProposalSDKType {
$typeUrl?: "/cosmos.gov.v1beta1.TextProposal";
title: string;
description: string;
}
/**
* Deposit defines an amount deposited by an account address to an active
* proposal.
*/
export interface Deposit {
proposalId: bigint;
depositor: string;
amount: Coin[];
}
export interface DepositProtoMsg {
typeUrl: "/cosmos.gov.v1beta1.Deposit";
value: Uint8Array;
}
/**
* Deposit defines an amount deposited by an account address to an active
* proposal.
*/
export interface DepositAmino {
proposal_id?: string;
depositor?: string;
amount?: CoinAmino[];
}
export interface DepositAminoMsg {
type: "cosmos-sdk/Deposit";
value: DepositAmino;
}
/**
* Deposit defines an amount deposited by an account address to an active
* proposal.
*/
export interface DepositSDKType {
proposal_id: bigint;
depositor: string;
amount: CoinSDKType[];
}
/** Proposal defines the core field members of a governance proposal. */
export interface Proposal {
proposalId: bigint;
content?: TextProposal | CommunityPoolSpendProposal | CommunityPoolSpendProposalWithDeposit | ParameterChangeProposal | SoftwareUpgradeProposal | CancelSoftwareUpgradeProposal | StoreCodeProposal | InstantiateContractProposal | InstantiateContract2Proposal | MigrateContractProposal | SudoContractProposal | ExecuteContractProposal | UpdateAdminProposal | ClearAdminProposal | PinCodesProposal | UnpinCodesProposal | UpdateInstantiateConfigProposal | StoreAndInstantiateContractProposal | Any | undefined;
status: ProposalStatus;
/**
* final_tally_result is the final tally result of the proposal. When
* querying a proposal via gRPC, this field is not populated until the
* proposal's voting period has ended.
*/
finalTallyResult: TallyResult;
submitTime: Date;
depositEndTime: Date;
totalDeposit: Coin[];
votingStartTime: Date;
votingEndTime: Date;
}
export interface ProposalProtoMsg {
typeUrl: "/cosmos.gov.v1beta1.Proposal";
value: Uint8Array;
}
export type ProposalEncoded = Omit<Proposal, "content"> & {
content?: TextProposalProtoMsg | CommunityPoolSpendProposalProtoMsg | CommunityPoolSpendProposalWithDepositProtoMsg | ParameterChangeProposalProtoMsg | SoftwareUpgradeProposalProtoMsg | CancelSoftwareUpgradeProposalProtoMsg | StoreCodeProposalProtoMsg | InstantiateContractProposalProtoMsg | InstantiateContract2ProposalProtoMsg | MigrateContractProposalProtoMsg | SudoContractProposalProtoMsg | ExecuteContractProposalProtoMsg | UpdateAdminProposalProtoMsg | ClearAdminProposalProtoMsg | PinCodesProposalProtoMsg | UnpinCodesProposalProtoMsg | UpdateInstantiateConfigProposalProtoMsg | StoreAndInstantiateContractProposalProtoMsg | AnyProtoMsg | undefined;
};
/** Proposal defines the core field members of a governance proposal. */
export interface ProposalAmino {
proposal_id?: string;
content?: AnyAmino;
status?: ProposalStatus;
/**
* final_tally_result is the final tally result of the proposal. When
* querying a proposal via gRPC, this field is not populated until the
* proposal's voting period has ended.
*/
final_tally_result?: TallyResultAmino;
submit_time?: string;
deposit_end_time?: string;
total_deposit?: CoinAmino[];
voting_start_time?: string;
voting_end_time?: string;
}
export interface ProposalAminoMsg {
type: "cosmos-sdk/Proposal";
value: ProposalAmino;
}
/** Proposal defines the core field members of a governance proposal. */
export interface ProposalSDKType {
proposal_id: bigint;
content?: TextProposalSDKType | CommunityPoolSpendProposalSDKType | CommunityPoolSpendProposalWithDepositSDKType | ParameterChangeProposalSDKType | SoftwareUpgradeProposalSDKType | CancelSoftwareUpgradeProposalSDKType | StoreCodeProposalSDKType | InstantiateContractProposalSDKType | InstantiateContract2ProposalSDKType | MigrateContractProposalSDKType | SudoContractProposalSDKType | ExecuteContractProposalSDKType | UpdateAdminProposalSDKType | ClearAdminProposalSDKType | PinCodesProposalSDKType | UnpinCodesProposalSDKType | UpdateInstantiateConfigProposalSDKType | StoreAndInstantiateContractProposalSDKType | AnySDKType | undefined;
status: ProposalStatus;
final_tally_result: TallyResultSDKType;
submit_time: Date;
deposit_end_time: Date;
total_deposit: CoinSDKType[];
voting_start_time: Date;
voting_end_time: Date;
}
/** TallyResult defines a standard tally for a governance proposal. */
export interface TallyResult {
yes: string;
abstain: string;
no: string;
noWithVeto: string;
}
export interface TallyResultProtoMsg {
typeUrl: "/cosmos.gov.v1beta1.TallyResult";
value: Uint8Array;
}
/** TallyResult defines a standard tally for a governance proposal. */
export interface TallyResultAmino {
yes?: string;
abstain?: string;
no?: string;
no_with_veto?: string;
}
export interface TallyResultAminoMsg {
type: "cosmos-sdk/TallyResult";
value: TallyResultAmino;
}
/** TallyResult defines a standard tally for a governance proposal. */
export interface TallyResultSDKType {
yes: string;
abstain: string;
no: string;
no_with_veto: string;
}
/**
* Vote defines a vote on a governance proposal.
* A Vote consists of a proposal ID, the voter, and the vote option.
*/
export interface Vote {
proposalId: bigint;
voter: string;
/**
* Deprecated: Prefer to use `options` instead. This field is set in queries
* if and only if `len(options) == 1` and that option has weight 1. In all
* other cases, this field will default to VOTE_OPTION_UNSPECIFIED.
*/
/** @deprecated */
option: VoteOption;
/** Since: cosmos-sdk 0.43 */
options: WeightedVoteOption[];
}
export interface VoteProtoMsg {
typeUrl: "/cosmos.gov.v1beta1.Vote";
value: Uint8Array;
}
/**
* Vote defines a vote on a governance proposal.
* A Vote consists of a proposal ID, the voter, and the vote option.
*/
export interface VoteAmino {
proposal_id: string;
voter?: string;
/**
* Deprecated: Prefer to use `options` instead. This field is set in queries
* if and only if `len(options) == 1` and that option has weight 1. In all
* other cases, this field will default to VOTE_OPTION_UNSPECIFIED.
*/
/** @deprecated */
option?: VoteOption;
/** Since: cosmos-sdk 0.43 */
options?: WeightedVoteOptionAmino[];
}
export interface VoteAminoMsg {
type: "cosmos-sdk/Vote";
value: VoteAmino;
}
/**
* Vote defines a vote on a governance proposal.
* A Vote consists of a proposal ID, the voter, and the vote option.
*/
export interface VoteSDKType {
proposal_id: bigint;
voter: string;
/** @deprecated */
option: VoteOption;
options: WeightedVoteOptionSDKType[];
}
/** DepositParams defines the params for deposits on governance proposals. */
export interface DepositParams {
/** Minimum deposit for a proposal to enter voting period. */
minDeposit: Coin[];
/**
* Maximum period for Atom holders to deposit on a proposal. Initial value: 2
* months.
*/
maxDepositPeriod: Duration;
}
export interface DepositParamsProtoMsg {
typeUrl: "/cosmos.gov.v1beta1.DepositParams";
value: Uint8Array;
}
/** DepositParams defines the params for deposits on governance proposals. */
export interface DepositParamsAmino {
/** Minimum deposit for a proposal to enter voting period. */
min_deposit?: CoinAmino[];
/**
* Maximum period for Atom holders to deposit on a proposal. Initial value: 2
* months.
*/
max_deposit_period?: DurationAmino;
}
export interface DepositParamsAminoMsg {
type: "cosmos-sdk/DepositParams";
value: DepositParamsAmino;
}
/** DepositParams defines the params for deposits on governance proposals. */
export interface DepositParamsSDKType {
min_deposit: CoinSDKType[];
max_deposit_period: DurationSDKType;
}
/** VotingParams defines the params for voting on governance proposals. */
export interface VotingParams {
/** Length of the voting period. */
votingPeriod: Duration;
}
export interface VotingParamsProtoMsg {
typeUrl: "/cosmos.gov.v1beta1.VotingParams";
value: Uint8Array;
}
/** VotingParams defines the params for voting on governance proposals. */
export interface VotingParamsAmino {
/** Length of the voting period. */
voting_period?: DurationAmino;
}
export interface VotingParamsAminoMsg {
type: "cosmos-sdk/VotingParams";
value: VotingParamsAmino;
}
/** VotingParams defines the params for voting on governance proposals. */
export interface VotingParamsSDKType {
voting_period: DurationSDKType;
}
/** TallyParams defines the params for tallying votes on governance proposals. */
export interface TallyParams {
/**
* Minimum percentage of total stake needed to vote for a result to be
* considered valid.
*/
quorum: Uint8Array;
/** Minimum proportion of Yes votes for proposal to pass. Default value: 0.5. */
threshold: Uint8Array;
/**
* Minimum value of Veto votes to Total votes ratio for proposal to be
* vetoed. Default value: 1/3.
*/
vetoThreshold: Uint8Array;
}
export interface TallyParamsProtoMsg {
typeUrl: "/cosmos.gov.v1beta1.TallyParams";
value: Uint8Array;
}
/** TallyParams defines the params for tallying votes on governance proposals. */
export interface TallyParamsAmino {
/**
* Minimum percentage of total stake needed to vote for a result to be
* considered valid.
*/
quorum?: string;
/** Minimum proportion of Yes votes for proposal to pass. Default value: 0.5. */
threshold?: string;
/**
* Minimum value of Veto votes to Total votes ratio for proposal to be
* vetoed. Default value: 1/3.
*/
veto_threshold?: string;
}
export interface TallyParamsAminoMsg {
type: "cosmos-sdk/TallyParams";
value: TallyParamsAmino;
}
/** TallyParams defines the params for tallying votes on governance proposals. */
export interface TallyParamsSDKType {
quorum: Uint8Array;
threshold: Uint8Array;
veto_threshold: Uint8Array;
}
function createBaseWeightedVoteOption(): WeightedVoteOption {
return {
option: 0,
weight: ""
};
}
export const WeightedVoteOption = {
typeUrl: "/cosmos.gov.v1beta1.WeightedVoteOption",
aminoType: "cosmos-sdk/WeightedVoteOption",
is(o: any): o is WeightedVoteOption {
return o && (o.$typeUrl === WeightedVoteOption.typeUrl || isSet(o.option) && typeof o.weight === "string");
},
isSDK(o: any): o is WeightedVoteOptionSDKType {
return o && (o.$typeUrl === WeightedVoteOption.typeUrl || isSet(o.option) && typeof o.weight === "string");
},
isAmino(o: any): o is WeightedVoteOptionAmino {
return o && (o.$typeUrl === WeightedVoteOption.typeUrl || isSet(o.option) && typeof o.weight === "string");
},
encode(message: WeightedVoteOption, writer: BinaryWriter = BinaryWriter.create()): BinaryWriter {
if (message.option !== 0) {
writer.uint32(8).int32(message.option);
}
if (message.weight !== "") {
writer.uint32(18).string(Decimal.fromUserInput(message.weight, 18).atomics);
}
return writer;
},
decode(input: BinaryReader | Uint8Array, length?: number): WeightedVoteOption {
const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseWeightedVoteOption();
while (reader.pos < end) {
const tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.option = reader.int32() as any;
break;
case 2:
message.weight = Decimal.fromAtomics(reader.string(), 18).toString();
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
},
fromJSON(object: any): WeightedVoteOption {
return {
option: isSet(object.option) ? voteOptionFromJSON(object.option) : -1,
weight: isSet(object.weight) ? String(object.weight) : ""
};
},
toJSON(message: WeightedVoteOption): JsonSafe<WeightedVoteOption> {
const obj: any = {};
message.option !== undefined && (obj.option = voteOptionToJSON(message.option));
message.weight !== undefined && (obj.weight = message.weight);
return obj;
},
fromPartial(object: Partial<WeightedVoteOption>): WeightedVoteOption {
const message = createBaseWeightedVoteOption();
message.option = object.option ?? 0;
message.weight = object.weight ?? "";
return message;
},
fromAmino(object: WeightedVoteOptionAmino): WeightedVoteOption {
const message = createBaseWeightedVoteOption();
if (object.option !== undefined && object.option !== null) {
message.option = object.option;
}
if (object.weight !== undefined && object.weight !== null) {
message.weight = object.weight;
}
return message;
},
toAmino(message: WeightedVoteOption): WeightedVoteOptionAmino {
const obj: any = {};
obj.option = message.option === 0 ? undefined : message.option;
obj.weight = message.weight === "" ? undefined : message.weight;
return obj;
},
fromAminoMsg(object: WeightedVoteOptionAminoMsg): WeightedVoteOption {
return WeightedVoteOption.fromAmino(object.value);
},
toAminoMsg(message: WeightedVoteOption): WeightedVoteOptionAminoMsg {
return {
type: "cosmos-sdk/WeightedVoteOption",
value: WeightedVoteOption.toAmino(message)
};
},
fromProtoMsg(message: WeightedVoteOptionProtoMsg): WeightedVoteOption {
return WeightedVoteOption.decode(message.value);
},
toProto(message: WeightedVoteOption): Uint8Array {
return WeightedVoteOption.encode(message).finish();
},
toProtoMsg(message: WeightedVoteOption): WeightedVoteOptionProtoMsg {
return {
typeUrl: "/cosmos.gov.v1beta1.WeightedVoteOption",
value: WeightedVoteOption.encode(message).finish()
};
}
};
GlobalDecoderRegistry.register(WeightedVoteOption.typeUrl, WeightedVoteOption);
GlobalDecoderRegistry.registerAminoProtoMapping(WeightedVoteOption.aminoType, WeightedVoteOption.typeUrl);
function createBaseTextProposal(): TextProposal {
return {
$typeUrl: "/cosmos.gov.v1beta1.TextProposal",
title: "",
description: ""
};
}
export const TextProposal = {
typeUrl: "/cosmos.gov.v1beta1.TextProposal",
aminoType: "cosmos-sdk/TextProposal",
is(o: any): o is TextProposal {
return o && (o.$typeUrl === TextProposal.typeUrl || typeof o.title === "string" && typeof o.description === "string");
},
isSDK(o: any): o is TextProposalSDKType {
return o && (o.$typeUrl === TextProposal.typeUrl || typeof o.title === "string" && typeof o.description === "string");
},
isAmino(o: any): o is TextProposalAmino {
return o && (o.$typeUrl === TextProposal.typeUrl || typeof o.title === "string" && typeof o.description === "string");
},
encode(message: TextProposal, writer: BinaryWriter = BinaryWriter.create()): BinaryWriter {
if (message.title !== "") {
writer.uint32(10).string(message.title);
}
if (message.description !== "") {
writer.uint32(18).string(message.description);
}
return writer;
},
decode(input: BinaryReader | Uint8Array, length?: number): TextProposal {
const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseTextProposal();
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;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
},
fromJSON(object: any): TextProposal {
return {
title: isSet(object.title) ? String(object.title) : "",
description: isSet(object.description) ? String(object.description) : ""
};
},
toJSON(message: TextProposal): JsonSafe<TextProposal> {
const obj: any = {};
message.title !== undefined && (obj.title = message.title);
message.description !== undefined && (obj.description = message.description);
return obj;
},
fromPartial(object: Partial<TextProposal>): TextProposal {
const message = createBaseTextProposal();
message.title = object.title ?? "";
message.description = object.description ?? "";
return message;
},
fromAmino(object: TextProposalAmino): TextProposal {
const message = createBaseTextProposal();
if (object.title !== undefined && object.title !== null) {
message.title = object.title;
}
if (object.description !== undefined && object.description !== null) {
message.description = object.description;
}
return message;
},
toAmino(message: TextProposal): TextProposalAmino {
const obj: any = {};
obj.title = message.title === "" ? undefined : message.title;
obj.description = message.description === "" ? undefined : message.description;
return obj;
},
fromAminoMsg(object: TextProposalAminoMsg): TextProposal {
return TextProposal.fromAmino(object.value);
},
toAminoMsg(message: TextProposal): TextProposalAminoMsg {
return {
type: "cosmos-sdk/TextProposal",
value: TextProposal.toAmino(message)
};
},
fromProtoMsg(message: TextProposalProtoMsg): TextProposal {
return TextProposal.decode(message.value);
},
toProto(message: TextProposal): Uint8Array {
return TextProposal.encode(message).finish();
},
toProtoMsg(message: TextProposal): TextProposalProtoMsg {
return {
typeUrl: "/cosmos.gov.v1beta1.TextProposal",
value: TextProposal.encode(message).finish()
};
}
};
GlobalDecoderRegistry.register(TextProposal.typeUrl, TextProposal);
GlobalDecoderRegistry.registerAminoProtoMapping(TextProposal.aminoType, TextProposal.typeUrl);
function createBaseDeposit(): Deposit {
return {
proposalId: BigInt(0),
depositor: "",
amount: []
};
}
export const Deposit = {
typeUrl: "/cosmos.gov.v1beta1.Deposit",
aminoType: "cosmos-sdk/Deposit",
is(o: any): o is Deposit {
return o && (o.$typeUrl === Deposit.typeUrl || typeof o.proposalId === "bigint" && typeof o.depositor === "string" && Array.isArray(o.amount) && (!o.amount.length || Coin.is(o.amount[0])));
},
isSDK(o: any): o is DepositSDKType {
return o && (o.$typeUrl === Deposit.typeUrl || typeof o.proposal_id === "bigint" && typeof o.depositor === "string" && Array.isArray(o.amount) && (!o.amount.length || Coin.isSDK(o.amount[0])));
},
isAmino(o: any): o is DepositAmino {
return o && (o.$typeUrl === Deposit.typeUrl || typeof o.proposal_id === "bigint" && typeof o.depositor === "string" && Array.isArray(o.amount) && (!o.amount.length || Coin.isAmino(o.amount[0])));
},
encode(message: Deposit, writer: BinaryWriter = BinaryWriter.create()): BinaryWriter {
if (message.proposalId !== BigInt(0)) {
writer.uint32(8).uint64(message.proposalId);
}
if (message.depositor !== "") {
writer.uint32(18).string(message.depositor);
}
for (const v of message.amount) {
Coin.encode(v!, writer.uint32(26).fork()).ldelim();
}
return writer;
},
decode(input: BinaryReader | Uint8Array, length?: number): Deposit {
const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseDeposit();
while (reader.pos < end) {
const tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.proposalId = reader.uint64();
break;
case 2:
message.depositor = reader.string();
break;
case 3:
message.amount.push(Coin.decode(reader, reader.uint32()));
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
},
fromJSON(object: any): Deposit {
return {
proposalId: isSet(object.proposalId) ? BigInt(object.proposalId.toString()) : BigInt(0),
depositor: isSet(object.depositor) ? String(object.depositor) : "",
amount: Array.isArray(object?.amount) ? object.amount.map((e: any) => Coin.fromJSON(e)) : []
};
},
toJSON(message: Deposit): JsonSafe<Deposit> {
const obj: any = {};
message.proposalId !== undefined && (obj.proposalId = (message.proposalId || BigInt(0)).toString());
message.depositor !== undefined && (obj.depositor = message.depositor);
if (message.amount) {
obj.amount = message.amount.map(e => e ? Coin.toJSON(e) : undefined);
} else {
obj.amount = [];
}
return obj;
},
fromPartial(object: Partial<Deposit>): Deposit {
const message = createBaseDeposit();
message.proposalId = object.proposalId !== undefined && object.proposalId !== null ? BigInt(object.proposalId.toString()) : BigInt(0);
message.depositor = object.depositor ?? "";
message.amount = object.amount?.map(e => Coin.fromPartial(e)) || [];
return message;
},
fromAmino(object: DepositAmino): Deposit {
const message = createBaseDeposit();
if (object.proposal_id !== undefined && object.proposal_id !== null) {
message.proposalId = BigInt(object.proposal_id);
}
if (object.depositor !== undefined && object.depositor !== null) {
message.depositor = object.depositor;
}
message.amount = object.amount?.map(e => Coin.fromAmino(e)) || [];
return message;
},
toAmino(message: Deposit): DepositAmino {
const obj: any = {};
obj.proposal_id = message.proposalId !== BigInt(0) ? message.proposalId.toString() : undefined;
obj.depositor = message.depositor === "" ? undefined : message.depositor;
if (message.amount) {
obj.amount = message.amount.map(e => e ? Coin.toAmino(e) : undefined);
} else {
obj.amount = message.amount;
}
return obj;
},
fromAminoMsg(object: DepositAminoMsg): Deposit {
return Deposit.fromAmino(object.value);
},
toAminoMsg(message: Deposit): DepositAminoMsg {
return {
type: "cosmos-sdk/Deposit",
value: Deposit.toAmino(message)
};
},
fromProtoMsg(message: DepositProtoMsg): Deposit {
return Deposit.decode(message.value);
},
toProto(message: Deposit): Uint8Array {
return Deposit.encode(message).finish();
},
toProtoMsg(message: Deposit): DepositProtoMsg {
return {
typeUrl: "/cosmos.gov.v1beta1.Deposit",
value: Deposit.encode(message).finish()
};
}
};
GlobalDecoderRegistry.register(Deposit.typeUrl, Deposit);
GlobalDecoderRegistry.registerAminoProtoMapping(Deposit.aminoType, Deposit.typeUrl);
function createBaseProposal(): Proposal {
return {
proposalId: BigInt(0),
content: undefined,
status: 0,
finalTallyResult: TallyResult.fromPartial({}),
submitTime: new Date(),
depositEndTime: new Date(),
totalDeposit: [],
votingStartTime: new Date(),
votingEndTime: new Date()
};
}
export const Proposal = {
typeUrl: "/cosmos.gov.v1beta1.Proposal",
aminoType: "cosmos-sdk/Proposal",
is(o: any): o is Proposal {
return o && (o.$typeUrl === Proposal.typeUrl || typeof o.proposalId === "bigint" && isSet(o.status) && TallyResult.is(o.finalTallyResult) && Timestamp.is(o.submitTime) && Timestamp.is(o.depositEndTime) && Array.isArray(o.totalDeposit) && (!o.totalDeposit.length || Coin.is(o.totalDeposit[0])) && Timestamp.is(o.votingStartTime) && Timestamp.is(o.votingEndTime));
},
isSDK(o: any): o is ProposalSDKType {
return o && (o.$typeUrl === Proposal.typeUrl || typeof o.proposal_id === "bigint" && isSet(o.status) && TallyResult.isSDK(o.final_tally_result) && Timestamp.isSDK(o.submit_time) && Timestamp.isSDK(o.deposit_end_time) && Array.isArray(o.total_deposit) && (!o.total_deposit.length || Coin.isSDK(o.total_deposit[0])) && Timestamp.isSDK(o.voting_start_time) && Timestamp.isSDK(o.voting_end_time));
},
isAmino(o: any): o is ProposalAmino {
return o && (o.$typeUrl === Proposal.typeUrl || typeof o.proposal_id === "bigint" && isSet(o.status) && TallyResult.isAmino(o.final_tally_result) && Timestamp.isAmino(o.submit_time) && Timestamp.isAmino(o.deposit_end_time) && Array.isArray(o.total_deposit) && (!o.total_deposit.length || Coin.isAmino(o.total_deposit[0])) && Timestamp.isAmino(o.voting_start_time) && Timestamp.isAmino(o.voting_end_time));
},
encode(message: Proposal, writer: BinaryWriter = BinaryWriter.create()): BinaryWriter {
if (message.proposalId !== BigInt(0)) {
writer.uint32(8).uint64(message.proposalId);
}
if (message.content !== undefined) {
Any.encode(GlobalDecoderRegistry.wrapAny(message.content), writer.uint32(18).fork()).ldelim();
}
if (message.status !== 0) {
writer.uint32(24).int32(message.status);
}
if (message.finalTallyResult !== undefined) {
TallyResult.encode(message.finalTallyResult, writer.uint32(34).fork()).ldelim();
}
if (message.submitTime !== undefined) {
Timestamp.encode(toTimestamp(message.submitTime), writer.uint32(42).fork()).ldelim();
}
if (message.depositEndTime !== undefined) {
Timestamp.encode(toTimestamp(message.depositEndTime), writer.uint32(50).fork()).ldelim();
}
for (const v of message.totalDeposit) {
Coin.encode(v!, writer.uint32(58).fork()).ldelim();
}
if (message.votingStartTime !== undefined) {
Timestamp.encode(toTimestamp(message.votingStartTime), writer.uint32(66).fork()).ldelim();
}
if (message.votingEndTime !== undefined) {
Timestamp.encode(toTimestamp(message.votingEndTime), writer.uint32(74).fork()).ldelim();
}
return writer;
},
decode(input: BinaryReader | Uint8Array, length?: number): Proposal {
const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseProposal();
while (reader.pos < end) {
const tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.proposalId = reader.uint64();
break;
case 2:
message.content = GlobalDecoderRegistry.unwrapAny(reader);
break;
case 3:
message.status = reader.int32() as any;
break;
case 4:
message.finalTallyResult = TallyResult.decode(reader, reader.uint32());
break;
case 5:
message.submitTime = fromTimestamp(Timestamp.decode(reader, reader.uint32()));
break;
case 6:
message.depositEndTime = fromTimestamp(Timestamp.decode(reader, reader.uint32()));
break;
case 7:
message.totalDeposit.push(Coin.decode(reader, reader.uint32()));
break;
case 8:
message.votingStartTime = fromTimestamp(Timestamp.decode(reader, reader.uint32()));
break;
case 9:
message.votingEndTime = fromTimestamp(Timestamp.decode(reader, reader.uint32()));
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
},
fromJSON(object: any): Proposal {
return {
proposalId: isSet(object.proposalId) ? BigInt(object.proposalId.toString()) : BigInt(0),
content: isSet(object.content) ? GlobalDecoderRegistry.fromJSON(object.content) : undefined,
status: isSet(object.status) ? proposalStatusFromJSON(object.status) : -1,
finalTallyResult: isSet(object.finalTallyResult) ? TallyResult.fromJSON(object.finalTallyResult) : undefined,
submitTime: isSet(object.submitTime) ? fromJsonTimestamp(object.submitTime) : undefined,
depositEndTime: isSet(object.depositEndTime) ? fromJsonTimestamp(object.depositEndTime) : undefined,
totalDeposit: Array.isArray(object?.totalDeposit) ? object.totalDeposit.map((e: any) => Coin.fromJSON(e)) : [],
votingStartTime: isSet(object.votingStartTime) ? fromJsonTimestamp(object.votingStartTime) : undefined,
votingEndTime: isSet(object.votingEndTime) ? fromJsonTimestamp(object.votingEndTime) : undefined
};
},
toJSON(message: Proposal): JsonSafe<Proposal> {
const obj: any = {};
message.proposalId !== undefined && (obj.proposalId = (message.proposalId || BigInt(0)).toString());
message.content !== undefined && (obj.content = message.content ? GlobalDecoderRegistry.toJSON(message.content) : undefined);
message.status !== undefined && (obj.status = proposalStatusToJSON(message.status));
message.finalTallyResult !== undefined && (obj.finalTallyResult = message.finalTallyResult ? TallyResult.toJSON(message.finalTallyResult) : undefined);
message.submitTime !== undefined && (obj.submitTime = message.submitTime.toISOString());
message.depositEndTime !== undefined && (obj.depositEndTime = message.depositEndTime.toISOString());
if (message.totalDeposit) {
obj.totalDeposit = message.totalDeposit.map(e => e ? Coin.toJSON(e) : undefined);
} else {
obj.totalDeposit = [];
}
message.votingStartTime !== undefined && (obj.votingStartTime = message.votingStartTime.toISOString());
message.votingEndTime !== undefined && (obj.votingEndTime = message.votingEndTime.toISOString());
return obj;
},
fromPartial(object: Partial<Proposal>): Proposal {
const message = createBaseProposal();
message.proposalId = object.proposalId !== undefined && object.proposalId !== null ? BigInt(object.proposalId.toString()) : BigInt(0);
message.content = object.content !== undefined && object.content !== null ? GlobalDecoderRegistry.fromPartial(object.content) : undefined;
message.status = object.status ?? 0;
message.finalTallyResult = object.finalTallyResult !== undefined && object.finalTallyResult !== null ? TallyResult.fromPartial(object.finalTallyResult) : undefined;
message.submitTime = object.submitTime ?? undefined;
message.depositEndTime = object.depositEndTime ?? undefined;
message.totalDeposit = object.totalDeposit?.map(e => Coin.fromPartial(e)) || [];
message.votingStartTime = object.votingStartTime ?? undefined;
message.votingEndTime = object.votingEndTime ?? undefined;
return message;
},
fromAmino(object: ProposalAmino): Proposal {
const message = createBaseProposal();
if (object.proposal_id !== undefined && object.proposal_id !== null) {
message.proposalId = BigInt(object.proposal_id);
}
if (object.content !== undefined && object.content !== null) {
message.content = GlobalDecoderRegistry.fromAminoMsg(object.content);
}
if (object.status !== undefined && object.status !== null) {
message.status = object.status;
}
if (object.final_tally_result !== undefined && object.final_tally_result !== null) {
message.finalTallyResult = TallyResult.fromAmino(object.final_tally_result);
}
if (object.submit_time !== undefined && object.submit_time !== null) {
message.submitTime = fromTimestamp(Timestamp.fromAmino(object.submit_time));
}
if (object.deposit_end_time !== undefined && object.deposit_end_time !== null) {
message.depositEndTime = fromTimestamp(Timestamp.fromAmino(object.deposit_end_time));
}
message.totalDeposit = object.total_deposit?.map(e => Coin.fromAmino(e)) || [];
if (object.voting_start_time !== undefined && object.voting_start_time !== null) {
message.votingStartTime = fromTimestamp(Timestamp.fromAmino(object.voting_start_time));
}
if (object.voting_end_time !== undefined && object.voting_end_time !== null) {
message.votingEndTime = fromTimestamp(Timestamp.fromAmino(object.voting_end_time));
}
return message;
},
toAmino(message: Proposal): ProposalAmino {
const obj: any = {};
obj.proposal_id = message.proposalId !== BigInt(0) ? message.proposalId.toString() : undefined;
obj.content = message.content ? GlobalDecoderRegistry.toAminoMsg(message.content) : undefined;
obj.status = message.status === 0 ? undefined : message.status;
obj.final_tally_result = message.finalTallyResult ? TallyResult.toAmino(message.finalTallyResult) : undefined;
obj.submit_time = message.submitTime ? Timestamp.toAmino(toTimestamp(message.submitTime)) : undefined;
obj.deposit_end_time = message.depositEndTime ? Timestamp.toAmino(toTimestamp(message.depositEndTime)) : undefined;
if (message.totalDeposit) {
obj.total_deposit = message.totalDeposit.map(e => e ? Coin.toAmino(e) : undefined);
} else {
obj.total_deposit = message.totalDeposit;
}
obj.voting_start_time = message.votingStartTime ? Timestamp.toAmino(toTimestamp(message.votingStartTime)) : undefined;
obj.voting_end_time = message.votingEndTime ? Timestamp.toAmino(toTimestamp(message.votingEndTime)) : undefined;
return obj;
},
fromAminoMsg(object: ProposalAminoMsg): Proposal {
return Proposal.fromAmino(object.value);
},
toAminoMsg(message: Proposal): ProposalAminoMsg {
return {
type: "cosmos-sdk/Proposal",
value: Proposal.toAmino(message)
};
},
fromProtoMsg(message: ProposalProtoMsg): Proposal {
return Proposal.decode(message.value);
},
toProto(message: Proposal): Uint8Array {
return Proposal.encode(message).finish();
},
toProtoMsg(message: Proposal): ProposalProtoMsg {
return {
typeUrl: "/cosmos.gov.v1beta1.Proposal",
value: Proposal.encode(message).finish()
};
}
};
GlobalDecoderRegistry.register(Proposal.typeUrl, Proposal);
GlobalDecoderRegistry.registerAminoProtoMapping(Proposal.aminoType, Proposal.typeUrl);
function createBaseTallyResult(): TallyResult {
return {
yes: "",
abstain: "",
no: "",
noWithVeto: ""
};
}
export const TallyResult = {
typeUrl: "/cosmos.gov.v1beta1.TallyResult",
aminoType: "cosmos-sdk/TallyResult",
is(o: any): o is TallyResult {
return o && (o.$typeUrl === TallyResult.typeUrl || typeof o.yes === "string" && typeof o.abstain === "string" && typeof o.no === "string" && typeof o.noWithVeto === "string");
},
isSDK(o: any): o is TallyResultSDKType {
return o && (o.$typeUrl === TallyResult.typeUrl || typeof o.yes === "string" && typeof o.abstain === "string" && typeof o.no === "string" && typeof o.no_with_veto === "string");
},
isAmino(o: any): o is TallyResultAmino {
return o && (o.$typeUrl === TallyResult.typeUrl || typeof o.yes === "string" && typeof o.abstain === "string" && typeof o.no === "string" && typeof o.no_with_veto === "string");
},
encode(message: TallyResult, writer: BinaryWriter = BinaryWriter.create()): BinaryWriter {
if (message.yes !== "") {
writer.uint32(10).string(message.yes);
}
if (message.abstain !== "") {
writer.uint32(18).string(message.abstain);
}
if (message.no !== "") {
writer.uint32(26).string(message.no);
}
if (message.noWithVeto !== "") {
writer.uint32(34).string(message.noWithVeto);
}
return writer;
},
decode(input: BinaryReader | Uint8Array, length?: number): TallyResult {
const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseTallyResult();
while (reader.pos < end) {
const tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.yes = reader.string();
break;
case 2:
message.abstain = reader.string();
break;
case 3:
message.no = reader.string();
break;
case 4:
message.noWithVeto = reader.string();
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
},
fromJSON(object: any): TallyResult {
return {
yes: isSet(object.yes) ? String(object.yes) : "",
abstain: isSet(object.abstain) ? String(object.abstain) : "",
no: isSet(object.no) ? String(object.no) : "",
noWithVeto: isSet(object.noWithVeto) ? String(object.noWithVeto) : ""
};
},
toJSON(message: TallyResult): JsonSafe<TallyResult> {
const obj: any = {};
message.yes !== undefined && (obj.yes = message.yes);
message.abstain !== undefined && (obj.abstain = message.abstain);
message.no !== undefined && (obj.no = message.no);
message.noWithVeto !== undefined && (obj.noWithVeto = message.noWithVeto);
return obj;
},
fromPartial(object: Partial<TallyResult>): TallyResult {
const message = createBaseTallyResult();
message.yes = object.yes ?? "";
message.abstain = object.abstain ?? "";
message.no = object.no ?? "";
message.noWithVeto = object.noWithVeto ?? "";
return message;
},
fromAmino(object: TallyResultAmino): TallyResult {
const message = createBaseTallyResult();
if (object.yes !== undefined && object.yes !== null) {
message.yes = object.yes;
}
if (object.abstain !== undefined && object.abstain !== null) {
message.abstain = object.abstain;
}
if (object.no !== undefined && object.no !== null) {
message.no = object.no;
}
if (object.no_with_veto !== undefined && object.no_with_veto !== null) {
message.noWithVeto = object.no_with_veto;
}
return message;
},
toAmino(message: TallyResult): TallyResultAmino {
const obj: any = {};
obj.yes = message.yes === "" ? undefined : message.yes;
obj.abstain = message.abstain === "" ? undefined : message.abstain;
obj.no = message.no === "" ? undefined : message.no;
obj.no_with_veto = message.noWithVeto === "" ? undefined : message.noWithVeto;
return obj;
},
fromAminoMsg(object: TallyResultAminoMsg): TallyResult {
return TallyResult.fromAmino(object.value);
},
toAminoMsg(message: TallyResult): TallyResultAminoMsg {
return {
type: "cosmos-sdk/TallyResult",
value: TallyResult.toAmino(message)
};
},
fromProtoMsg(message: TallyResultProtoMsg): TallyResult {
return TallyResult.decode(message.value);
},
toProto(message: TallyResult): Uint8Array {
return TallyResult.encode(message).finish();
},
toProtoMsg(message: TallyResult): TallyResultProtoMsg {
return {
typeUrl: "/cosmos.gov.v1beta1.TallyResult",
value: TallyResult.encode(message).finish()
};
}
};
GlobalDecoderRegistry.register(TallyResult.typeUrl, TallyResult);
GlobalDecoderRegistry.registerAminoProtoMapping(TallyResult.aminoType, TallyResult.typeUrl);
function createBaseVote(): Vote {
return {
proposalId: BigInt(0),
voter: "",
option: 0,
options: []
};
}
export const Vote = {
typeUrl: "/cosmos.gov.v1beta1.Vote",
aminoType: "cosmos-sdk/Vote",
is(o: any): o is Vote {
return o && (o.$typeUrl === Vote.typeUrl || typeof o.proposalId === "bigint" && typeof o.voter === "string" && isSet(o.option) && Array.isArray(o.options) && (!o.options.length || WeightedVoteOption.is(o.options[0])));
},
isSDK(o: any): o is VoteSDKType {
return o && (o.$typeUrl === Vote.typeUrl || typeof o.proposal_id === "bigint" && typeof o.voter === "string" && isSet(o.option) && Array.isArray(o.options) && (!o.options.length || WeightedVoteOption.isSDK(o.options[0])));
},
isAmino(o: any): o is VoteAmino {
return o && (o.$typeUrl === Vote.typeUrl || typeof o.proposal_id === "bigint" && typeof o.voter === "string" && isSet(o.option) && Array.isArray(o.options) && (!o.options.length || WeightedVoteOption.isAmino(o.options[0])));
},
encode(message: Vote, writer: BinaryWriter = BinaryWriter.create()): BinaryWriter {
if (message.proposalId !== BigInt(0)) {
writer.uint32(8).uint64(message.proposalId);
}
if (message.voter !== "") {
writer.uint32(18).string(message.voter);
}
if (message.option !== 0) {
writer.uint32(24).int32(message.option);
}
for (const v of message.options) {
WeightedVoteOption.encode(v!, writer.uint32(34).fork()).ldelim();
}
return writer;
},
decode(input: BinaryReader | Uint8Array, length?: number): Vote {
const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseVote();
while (reader.pos < end) {
const tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.proposalId = reader.uint64();
break;
case 2:
message.voter = reader.string();
break;
case 3:
message.option = reader.int32() as any;
break;
case 4:
message.options.push(WeightedVoteOption.decode(reader, reader.uint32()));
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
},
fromJSON(object: any): Vote {
return {
proposalId: isSet(object.proposalId) ? BigInt(object.proposalId.toString()) : BigInt(0),
voter: isSet(object.voter) ? String(object.voter) : "",
option: isSet(object.option) ? voteOptionFromJSON(object.option) : -1,
options: Array.isArray(object?.options) ? object.options.map((e: any) => WeightedVoteOption.fromJSON(e)) : []
};
},
toJSON(message: Vote): JsonSafe<Vote> {
const obj: any = {};
message.proposalId !== undefined && (obj.proposalId = (message.proposalId || BigInt(0)).toString());
message.voter !== undefined && (obj.voter = message.voter);
message.option !== undefined && (obj.option = voteOptionToJSON(message.option));
if (message.options) {
obj.options = message.options.map(e => e ? WeightedVoteOption.toJSON(e) : undefined);
} else {
obj.options = [];
}
return obj;
},
fromPartial(object: Partial<Vote>): Vote {
const message = createBaseVote();
message.proposalId = object.proposalId !== undefined && object.proposalId !== null ? BigInt(object.proposalId.toString()) : BigInt(0);
message.voter = object.voter ?? "";
message.option = object.option ?? 0;
message.options = object.options?.map(e => WeightedVoteOption.fromPartial(e)) || [];
return message;
},
fromAmino(object: VoteAmino): Vote {
const message = createBaseVote();
if (object.proposal_id !== undefined && object.proposal_id !== null) {
message.proposalId = BigInt(object.proposal_id);
}
if (object.voter !== undefined && object.voter !== null) {
message.voter = object.voter;
}
if (object.option !== undefined && object.option !== null) {
message.option = object.option;
}
message.options = object.options?.map(e => WeightedVoteOption.fromAmino(e)) || [];
return message;
},
toAmino(message: Vote): VoteAmino {
const obj: any = {};
obj.proposal_id = message.proposalId ? message.proposalId.toString() : "0";
obj.voter = message.voter === "" ? undefined : message.voter;
obj.option = message.option === 0 ? undefined : message.option;
if (message.options) {
obj.options = message.options.map(e => e ? WeightedVoteOption.toAmino(e) : undefined);
} else {
obj.options = message.options;
}
return obj;
},
fromAminoMsg(object: VoteAminoMsg): Vote {
return Vote.fromAmino(object.value);
},
toAminoMsg(message: Vote): VoteAminoMsg {
return {
type: "cosmos-sdk/Vote",
value: Vote.toAmino(message)
};
},
fromProtoMsg(message: VoteProtoMsg): Vote {
return Vote.decode(message.value);
},
toProto(message: Vote): Uint8Array {
return Vote.encode(message).finish();
},
toProtoMsg(message: Vote): VoteProtoMsg {
return {
typeUrl: "/cosmos.gov.v1beta1.Vote",
value: Vote.encode(message).finish()
};
}
};
GlobalDecoderRegistry.register(Vote.typeUrl, Vote);
GlobalDecoderRegistry.registerAminoProtoMapping(Vote.aminoType, Vote.typeUrl);
function createBaseDepositParams(): DepositParams {
return {
minDeposit: [],
maxDepositPeriod: Duration.fromPartial({})
};
}
export const DepositParams = {
typeUrl: "/cosmos.gov.v1beta1.DepositParams",
aminoType: "cosmos-sdk/DepositParams",
is(o: any): o is DepositParams {
return o && (o.$typeUrl === DepositParams.typeUrl || Array.isArray(o.minDeposit) && (!o.minDeposit.length || Coin.is(o.minDeposit[0])) && Duration.is(o.maxDepositPeriod));
},
isSDK(o: any): o is DepositParamsSDKType {
return o && (o.$typeUrl === DepositParams.typeUrl || Array.isArray(o.min_deposit) && (!o.min_deposit.length || Coin.isSDK(o.min_deposit[0])) && Duration.isSDK(o.max_deposit_period));
},
isAmino(o: any): o is DepositParamsAmino {
return o && (o.$typeUrl === DepositParams.typeUrl || Array.isArray(o.min_deposit) && (!o.min_deposit.length || Coin.isAmino(o.min_deposit[0])) && Duration.isAmino(o.max_deposit_period));
},
encode(message: DepositParams, writer: BinaryWriter = BinaryWriter.create()): BinaryWriter {
for (const v of message.minDeposit) {
Coin.encode(v!, writer.uint32(10).fork()).ldelim();
}
if (message.maxDepositPeriod !== undefined) {
Duration.encode(message.maxDepositPeriod, writer.uint32(18).fork()).ldelim();
}
return writer;
},
decode(input: BinaryReader | Uint8Array, length?: number): DepositParams {
const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseDepositParams();
while (reader.pos < end) {
const tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.minDeposit.push(Coin.decode(reader, reader.uint32()));
break;
case 2:
message.maxDepositPeriod = Duration.decode(reader, reader.uint32());
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
},
fromJSON(object: any): DepositParams {
return {
minDeposit: Array.isArray(object?.minDeposit) ? object.minDeposit.map((e: any) => Coin.fromJSON(e)) : [],
maxDepositPeriod: isSet(object.maxDepositPeriod) ? Duration.fromJSON(object.maxDepositPeriod) : undefined
};
},
toJSON(message: DepositParams): JsonSafe<DepositParams> {
const obj: any = {};
if (message.minDeposit) {
obj.minDeposit = message.minDeposit.map(e => e ? Coin.toJSON(e) : undefined);
} else {
obj.minDeposit = [];
}
message.maxDepositPeriod !== undefined && (obj.maxDepositPeriod = message.maxDepositPeriod ? Duration.toJSON(message.maxDepositPeriod) : undefined);
return obj;
},
fromPartial(object: Partial<DepositParams>): DepositParams {
const message = createBaseDepositParams();
message.minDeposit = object.minDeposit?.map(e => Coin.fromPartial(e)) || [];
message.maxDepositPeriod = object.maxDepositPeriod !== undefined && object.maxDepositPeriod !== null ? Duration.fromPartial(object.maxDepositPeriod) : undefined;
return message;
},
fromAmino(object: DepositParamsAmino): DepositParams {
const message = createBaseDepositParams();
message.minDeposit = object.min_deposit?.map(e => Coin.fromAmino(e)) || [];
if (object.max_deposit_period !== undefined && object.max_deposit_period !== null) {
message.maxDepositPeriod = Duration.fromAmino(object.max_deposit_period);
}
return message;
},
toAmino(message: DepositParams): DepositParamsAmino {
const obj: any = {};
if (message.minDeposit) {
obj.min_deposit = message.minDeposit.map(e => e ? Coin.toAmino(e) : undefined);
} else {
obj.min_deposit = message.minDeposit;
}
obj.max_deposit_period = message.maxDepositPeriod ? Duration.toAmino(message.maxDepositPeriod) : undefined;
return obj;
},
fromAminoMsg(object: DepositParamsAminoMsg): DepositParams {
return DepositParams.fromAmino(object.value);
},
toAminoMsg(message: DepositParams): DepositParamsAminoMsg {
return {
type: "cosmos-sdk/DepositParams",
value: DepositParams.toAmino(message)
};
},
fromProtoMsg(message: DepositParamsProtoMsg): DepositParams {
return DepositParams.decode(message.value);
},
toProto(message: DepositParams): Uint8Array {
return DepositParams.encode(message).finish();
},
toProtoMsg(message: DepositParams): DepositParamsProtoMsg {
return {
typeUrl: "/cosmos.gov.v1beta1.DepositParams",
value: DepositParams.encode(message).finish()
};
}
};
GlobalDecoderRegistry.register(DepositParams.typeUrl, DepositParams);
GlobalDecoderRegistry.registerAminoProtoMapping(DepositParams.aminoType, DepositParams.typeUrl);
function createBaseVotingParams(): VotingParams {
return {
votingPeriod: Duration.fromPartial({})
};
}
export const VotingParams = {
typeUrl: "/cosmos.gov.v1beta1.VotingParams",
aminoType: "cosmos-sdk/VotingParams",
is(o: any): o is VotingParams {
return o && (o.$typeUrl === VotingParams.typeUrl || Duration.is(o.votingPeriod));
},
isSDK(o: any): o is VotingParamsSDKType {
return o && (o.$typeUrl === VotingParams.typeUrl || Duration.isSDK(o.voting_period));
},
isAmino(o: any): o is VotingParamsAmino {
return o && (o.$typeUrl === VotingParams.typeUrl || Duration.isAmino(o.voting_period));
},
encode(message: VotingParams, writer: BinaryWriter = BinaryWriter.create()): BinaryWriter {
if (message.votingPeriod !== undefined) {
Duration.encode(message.votingPeriod, writer.uint32(10).fork()).ldelim();
}
return writer;
},
decode(input: BinaryReader | Uint8Array, length?: number): VotingParams {
const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseVotingParams();
while (reader.pos < end) {
const tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.votingPeriod = Duration.decode(reader, reader.uint32());
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
},
fromJSON(object: any): VotingParams {
return {
votingPeriod: isSet(object.votingPeriod) ? Duration.fromJSON(object.votingPeriod) : undefined
};
},
toJSON(message: VotingParams): JsonSafe<VotingParams> {
const obj: any = {};
message.votingPeriod !== undefined && (obj.votingPeriod = message.votingPeriod ? Duration.toJSON(message.votingPeriod) : undefined);
return obj;
},
fromPartial(object: Partial<VotingParams>): VotingParams {
const message = createBaseVotingParams();
message.votingPeriod = object.votingPeriod !== undefined && object.votingPeriod !== null ? Duration.fromPartial(object.votingPeriod) : undefined;
return message;
},
fromAmino(object: VotingParamsAmino): VotingParams {
const message = createBaseVotingParams();
if (object.voting_period !== undefined && object.voting_period !== null) {
message.votingPeriod = Duration.fromAmino(object.voting_period);
}
return message;
},
toAmino(message: VotingParams): VotingParamsAmino {
const obj: any = {};
obj.voting_period = message.votingPeriod ? Duration.toAmino(message.votingPeriod) : undefined;
return obj;
},
fromAminoMsg(object: VotingParamsAminoMsg): VotingParams {
return VotingParams.fromAmino(object.value);
},
toAminoMsg(message: VotingParams): VotingParamsAminoMsg {
return {
type: "cosmos-sdk/VotingParams",
value: VotingParams.toAmino(message)
};
},
fromProtoMsg(message: VotingParamsProtoMsg): VotingParams {
return VotingParams.decode(message.value);
},
toProto(message: VotingParams): Uint8Array {
return VotingParams.encode(message).finish();
},
toProtoMsg(message: VotingParams): VotingParamsProtoMsg {
return {
typeUrl: "/cosmos.gov.v1beta1.VotingParams",
value: VotingParams.encode(message).finish()
};
}
};
GlobalDecoderRegistry.register(VotingParams.typeUrl, VotingParams);
GlobalDecoderRegistry.registerAminoProtoMapping(VotingParams.aminoType, VotingParams.typeUrl);
function createBaseTallyParams(): TallyParams {
return {
quorum: new Uint8Array(),
threshold: new Uint8Array(),
vetoThreshold: new Uint8Array()
};
}
export const TallyParams = {
typeUrl: "/cosmos.gov.v1beta1.TallyParams",
aminoType: "cosmos-sdk/TallyParams",
is(o: any): o is TallyParams {
return o && (o.$typeUrl === TallyParams.typeUrl || (o.quorum instanceof Uint8Array || typeof o.quorum === "string") && (o.threshold instanceof Uint8Array || typeof o.threshold === "string") && (o.vetoThreshold instanceof Uint8Array || typeof o.vetoThreshold === "string"));
},
isSDK(o: any): o is TallyParamsSDKType {
return o && (o.$typeUrl === TallyParams.typeUrl || (o.quorum instanceof Uint8Array || typeof o.quorum === "string") && (o.threshold instanceof Uint8Array || typeof o.threshold === "string") && (o.veto_threshold instanceof Uint8Array || typeof o.veto_threshold === "string"));
},
isAmino(o: any): o is TallyParamsAmino {
return o && (o.$typeUrl === TallyParams.typeUrl || (o.quorum instanceof Uint8Array || typeof o.quorum === "string") && (o.threshold instanceof Uint8Array || typeof o.threshold === "string") && (o.veto_threshold instanceof Uint8Array || typeof o.veto_threshold === "string"));
},
encode(message: TallyParams, writer: BinaryWriter = BinaryWriter.create()): BinaryWriter {
if (message.quorum.length !== 0) {
writer.uint32(10).bytes(message.quorum);
}
if (message.threshold.length !== 0) {
writer.uint32(18).bytes(message.threshold);
}
if (message.vetoThreshold.length !== 0) {
writer.uint32(26).bytes(message.vetoThreshold);
}
return writer;
},
decode(input: BinaryReader | Uint8Array, length?: number): TallyParams {
const reader = input instanceof BinaryReader ? input : new BinaryReader(input);
let end = length === undefined ? reader.len : reader.pos + length;
const message = createBaseTallyParams();
while (reader.pos < end) {
const tag = reader.uint32();
switch (tag >>> 3) {
case 1:
message.quorum = reader.bytes();
break;
case 2:
message.threshold = reader.bytes();
break;
case 3:
message.vetoThreshold = reader.bytes();
break;
default:
reader.skipType(tag & 7);
break;
}
}
return message;
},
fromJSON(object: any): TallyParams {
return {
quorum: isSet(object.quorum) ? bytesFromBase64(object.quorum) : new Uint8Array(),
threshold: isSet(object.threshold) ? bytesFromBase64(object.threshold) : new Uint8Array(),
vetoThreshold: isSet(object.vetoThreshold) ? bytesFromBase64(object.vetoThreshold) : new Uint8Array()
};
},
toJSON(message: TallyParams): JsonSafe<TallyParams> {
const obj: any = {};
message.quorum !== undefined && (obj.quorum = base64FromBytes(message.quorum !== undefined ? message.quorum : new Uint8Array()));
message.threshold !== undefined && (obj.threshold = base64FromBytes(message.threshold !== undefined ? message.threshold : new Uint8Array()));
message.vetoThreshold !== undefined && (obj.vetoThreshold = base64FromBytes(message.vetoThreshold !== undefined ? message.vetoThreshold : new Uint8Array()));
return obj;
},
fromPartial(object: Partial<TallyParams>): TallyParams {
const message = createBaseTallyParams();
message.quorum = object.quorum ?? new Uint8Array();
message.threshold = object.threshold ?? new Uint8Array();
message.vetoThreshold = object.vetoThreshold ?? new Uint8Array();
return message;
},
fromAmino(object: TallyParamsAmino): TallyParams {
const message = createBaseTallyParams();
if (object.quorum !== undefined && object.quorum !== null) {
message.quorum = bytesFromBase64(object.quorum);
}
if (object.threshold !== undefined && object.threshold !== null) {
message.threshold = bytesFromBase64(object.threshold);
}
if (object.veto_threshold !== undefined && object.veto_threshold !== null) {
message.vetoThreshold = bytesFromBase64(object.veto_threshold);
}
return message;
},
toAmino(message: TallyParams): TallyParamsAmino {
const obj: any = {};
obj.quorum = message.quorum ? base64FromBytes(message.quorum) : undefined;
obj.threshold = message.threshold ? base64FromBytes(message.threshold) : undefined;
obj.veto_threshold = message.vetoThreshold ? base64FromBytes(message.vetoThreshold) : undefined;
return obj;
},
fromAminoMsg(object: TallyParamsAminoMsg): TallyParams {
return TallyParams.fromAmino(object.value);
},
toAminoMsg(message: TallyParams): TallyParamsAminoMsg {
return {
type: "cosmos-sdk/TallyParams",
value: TallyParams.toAmino(message)
};
},
fromProtoMsg(message: TallyParamsProtoMsg): TallyParams {
return TallyParams.decode(message.value);
},
toProto(message: TallyParams): Uint8Array {
return TallyParams.encode(message).finish();
},
toProtoMsg(message: TallyParams): TallyParamsProtoMsg {
return {
typeUrl: "/cosmos.gov.v1beta1.TallyParams",
value: TallyParams.encode(message).finish()
};
}
};
GlobalDecoderRegistry.register(TallyParams.typeUrl, TallyParams);
GlobalDecoderRegistry.registerAminoProtoMapping(TallyParams.aminoType, TallyParams.typeUrl);