UNPKG

interchainjs

Version:

InterchainJS is a JavaScript library for interacting with Cosmos SDK based blockchains.

448 lines (447 loc) 20.2 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.EvidenceList = exports.LightClientAttackEvidence = exports.DuplicateVoteEvidence = exports.Evidence = void 0; const types_1 = require("./types"); const timestamp_1 = require("../../google/protobuf/timestamp"); const validator_1 = require("./validator"); const binary_1 = require("../../binary"); const registry_1 = require("../../registry"); const helpers_1 = require("../../helpers"); function createBaseEvidence() { return { duplicateVoteEvidence: undefined, lightClientAttackEvidence: undefined }; } /** * @name Evidence * @package tendermint.types * @see proto type: tendermint.types.Evidence */ exports.Evidence = { typeUrl: "/tendermint.types.Evidence", is(o) { return o && o.$typeUrl === exports.Evidence.typeUrl; }, isAmino(o) { return o && o.$typeUrl === exports.Evidence.typeUrl; }, encode(message, writer = binary_1.BinaryWriter.create()) { if (message.duplicateVoteEvidence !== undefined) { exports.DuplicateVoteEvidence.encode(message.duplicateVoteEvidence, writer.uint32(10).fork()).ldelim(); } if (message.lightClientAttackEvidence !== undefined) { exports.LightClientAttackEvidence.encode(message.lightClientAttackEvidence, writer.uint32(18).fork()).ldelim(); } return writer; }, decode(input, length) { const reader = input instanceof binary_1.BinaryReader ? input : new binary_1.BinaryReader(input); let end = length === undefined ? reader.len : reader.pos + length; const message = createBaseEvidence(); while (reader.pos < end) { const tag = reader.uint32(); switch (tag >>> 3) { case 1: message.duplicateVoteEvidence = exports.DuplicateVoteEvidence.decode(reader, reader.uint32()); break; case 2: message.lightClientAttackEvidence = exports.LightClientAttackEvidence.decode(reader, reader.uint32()); break; default: reader.skipType(tag & 7); break; } } return message; }, fromPartial(object) { const message = createBaseEvidence(); message.duplicateVoteEvidence = object.duplicateVoteEvidence !== undefined && object.duplicateVoteEvidence !== null ? exports.DuplicateVoteEvidence.fromPartial(object.duplicateVoteEvidence) : undefined; message.lightClientAttackEvidence = object.lightClientAttackEvidence !== undefined && object.lightClientAttackEvidence !== null ? exports.LightClientAttackEvidence.fromPartial(object.lightClientAttackEvidence) : undefined; return message; }, fromAmino(object) { const message = createBaseEvidence(); if (object.duplicate_vote_evidence !== undefined && object.duplicate_vote_evidence !== null) { message.duplicateVoteEvidence = exports.DuplicateVoteEvidence.fromAmino(object.duplicate_vote_evidence); } if (object.light_client_attack_evidence !== undefined && object.light_client_attack_evidence !== null) { message.lightClientAttackEvidence = exports.LightClientAttackEvidence.fromAmino(object.light_client_attack_evidence); } return message; }, toAmino(message) { const obj = {}; obj.duplicate_vote_evidence = message.duplicateVoteEvidence ? exports.DuplicateVoteEvidence.toAmino(message.duplicateVoteEvidence) : undefined; obj.light_client_attack_evidence = message.lightClientAttackEvidence ? exports.LightClientAttackEvidence.toAmino(message.lightClientAttackEvidence) : undefined; return obj; }, fromAminoMsg(object) { return exports.Evidence.fromAmino(object.value); }, fromProtoMsg(message) { return exports.Evidence.decode(message.value); }, toProto(message) { return exports.Evidence.encode(message).finish(); }, toProtoMsg(message) { return { typeUrl: "/tendermint.types.Evidence", value: exports.Evidence.encode(message).finish() }; }, registerTypeUrl() { if (!registry_1.GlobalDecoderRegistry.registerExistingTypeUrl(exports.Evidence.typeUrl)) { return; } exports.DuplicateVoteEvidence.registerTypeUrl(); exports.LightClientAttackEvidence.registerTypeUrl(); } }; function createBaseDuplicateVoteEvidence() { return { voteA: undefined, voteB: undefined, totalVotingPower: BigInt(0), validatorPower: BigInt(0), timestamp: new Date() }; } /** * DuplicateVoteEvidence contains evidence of a validator signed two conflicting votes. * @name DuplicateVoteEvidence * @package tendermint.types * @see proto type: tendermint.types.DuplicateVoteEvidence */ exports.DuplicateVoteEvidence = { typeUrl: "/tendermint.types.DuplicateVoteEvidence", is(o) { return o && (o.$typeUrl === exports.DuplicateVoteEvidence.typeUrl || typeof o.totalVotingPower === "bigint" && typeof o.validatorPower === "bigint" && timestamp_1.Timestamp.is(o.timestamp)); }, isAmino(o) { return o && (o.$typeUrl === exports.DuplicateVoteEvidence.typeUrl || typeof o.total_voting_power === "bigint" && typeof o.validator_power === "bigint" && timestamp_1.Timestamp.isAmino(o.timestamp)); }, encode(message, writer = binary_1.BinaryWriter.create()) { if (message.voteA !== undefined) { types_1.Vote.encode(message.voteA, writer.uint32(10).fork()).ldelim(); } if (message.voteB !== undefined) { types_1.Vote.encode(message.voteB, writer.uint32(18).fork()).ldelim(); } if (message.totalVotingPower !== BigInt(0)) { writer.uint32(24).int64(message.totalVotingPower); } if (message.validatorPower !== BigInt(0)) { writer.uint32(32).int64(message.validatorPower); } if (message.timestamp !== undefined) { timestamp_1.Timestamp.encode((0, helpers_1.toTimestamp)(message.timestamp), writer.uint32(42).fork()).ldelim(); } return writer; }, decode(input, length) { const reader = input instanceof binary_1.BinaryReader ? input : new binary_1.BinaryReader(input); let end = length === undefined ? reader.len : reader.pos + length; const message = createBaseDuplicateVoteEvidence(); while (reader.pos < end) { const tag = reader.uint32(); switch (tag >>> 3) { case 1: message.voteA = types_1.Vote.decode(reader, reader.uint32()); break; case 2: message.voteB = types_1.Vote.decode(reader, reader.uint32()); break; case 3: message.totalVotingPower = reader.int64(); break; case 4: message.validatorPower = reader.int64(); break; case 5: message.timestamp = (0, helpers_1.fromTimestamp)(timestamp_1.Timestamp.decode(reader, reader.uint32())); break; default: reader.skipType(tag & 7); break; } } return message; }, fromPartial(object) { const message = createBaseDuplicateVoteEvidence(); message.voteA = object.voteA !== undefined && object.voteA !== null ? types_1.Vote.fromPartial(object.voteA) : undefined; message.voteB = object.voteB !== undefined && object.voteB !== null ? types_1.Vote.fromPartial(object.voteB) : undefined; message.totalVotingPower = object.totalVotingPower !== undefined && object.totalVotingPower !== null ? BigInt(object.totalVotingPower.toString()) : BigInt(0); message.validatorPower = object.validatorPower !== undefined && object.validatorPower !== null ? BigInt(object.validatorPower.toString()) : BigInt(0); message.timestamp = object.timestamp ?? undefined; return message; }, fromAmino(object) { const message = createBaseDuplicateVoteEvidence(); if (object.vote_a !== undefined && object.vote_a !== null) { message.voteA = types_1.Vote.fromAmino(object.vote_a); } if (object.vote_b !== undefined && object.vote_b !== null) { message.voteB = types_1.Vote.fromAmino(object.vote_b); } if (object.total_voting_power !== undefined && object.total_voting_power !== null) { message.totalVotingPower = BigInt(object.total_voting_power); } if (object.validator_power !== undefined && object.validator_power !== null) { message.validatorPower = BigInt(object.validator_power); } if (object.timestamp !== undefined && object.timestamp !== null) { message.timestamp = (0, helpers_1.fromTimestamp)(timestamp_1.Timestamp.fromAmino(object.timestamp)); } return message; }, toAmino(message) { const obj = {}; obj.vote_a = message.voteA ? types_1.Vote.toAmino(message.voteA) : undefined; obj.vote_b = message.voteB ? types_1.Vote.toAmino(message.voteB) : undefined; obj.total_voting_power = message.totalVotingPower !== BigInt(0) ? message.totalVotingPower?.toString() : undefined; obj.validator_power = message.validatorPower !== BigInt(0) ? message.validatorPower?.toString() : undefined; obj.timestamp = message.timestamp ? timestamp_1.Timestamp.toAmino((0, helpers_1.toTimestamp)(message.timestamp)) : undefined; return obj; }, fromAminoMsg(object) { return exports.DuplicateVoteEvidence.fromAmino(object.value); }, fromProtoMsg(message) { return exports.DuplicateVoteEvidence.decode(message.value); }, toProto(message) { return exports.DuplicateVoteEvidence.encode(message).finish(); }, toProtoMsg(message) { return { typeUrl: "/tendermint.types.DuplicateVoteEvidence", value: exports.DuplicateVoteEvidence.encode(message).finish() }; }, registerTypeUrl() { if (!registry_1.GlobalDecoderRegistry.registerExistingTypeUrl(exports.DuplicateVoteEvidence.typeUrl)) { return; } types_1.Vote.registerTypeUrl(); } }; function createBaseLightClientAttackEvidence() { return { conflictingBlock: undefined, commonHeight: BigInt(0), byzantineValidators: [], totalVotingPower: BigInt(0), timestamp: new Date() }; } /** * LightClientAttackEvidence contains evidence of a set of validators attempting to mislead a light client. * @name LightClientAttackEvidence * @package tendermint.types * @see proto type: tendermint.types.LightClientAttackEvidence */ exports.LightClientAttackEvidence = { typeUrl: "/tendermint.types.LightClientAttackEvidence", is(o) { return o && (o.$typeUrl === exports.LightClientAttackEvidence.typeUrl || typeof o.commonHeight === "bigint" && Array.isArray(o.byzantineValidators) && (!o.byzantineValidators.length || validator_1.Validator.is(o.byzantineValidators[0])) && typeof o.totalVotingPower === "bigint" && timestamp_1.Timestamp.is(o.timestamp)); }, isAmino(o) { return o && (o.$typeUrl === exports.LightClientAttackEvidence.typeUrl || typeof o.common_height === "bigint" && Array.isArray(o.byzantine_validators) && (!o.byzantine_validators.length || validator_1.Validator.isAmino(o.byzantine_validators[0])) && typeof o.total_voting_power === "bigint" && timestamp_1.Timestamp.isAmino(o.timestamp)); }, encode(message, writer = binary_1.BinaryWriter.create()) { if (message.conflictingBlock !== undefined) { types_1.LightBlock.encode(message.conflictingBlock, writer.uint32(10).fork()).ldelim(); } if (message.commonHeight !== BigInt(0)) { writer.uint32(16).int64(message.commonHeight); } for (const v of message.byzantineValidators) { validator_1.Validator.encode(v, writer.uint32(26).fork()).ldelim(); } if (message.totalVotingPower !== BigInt(0)) { writer.uint32(32).int64(message.totalVotingPower); } if (message.timestamp !== undefined) { timestamp_1.Timestamp.encode((0, helpers_1.toTimestamp)(message.timestamp), writer.uint32(42).fork()).ldelim(); } return writer; }, decode(input, length) { const reader = input instanceof binary_1.BinaryReader ? input : new binary_1.BinaryReader(input); let end = length === undefined ? reader.len : reader.pos + length; const message = createBaseLightClientAttackEvidence(); while (reader.pos < end) { const tag = reader.uint32(); switch (tag >>> 3) { case 1: message.conflictingBlock = types_1.LightBlock.decode(reader, reader.uint32()); break; case 2: message.commonHeight = reader.int64(); break; case 3: message.byzantineValidators.push(validator_1.Validator.decode(reader, reader.uint32())); break; case 4: message.totalVotingPower = reader.int64(); break; case 5: message.timestamp = (0, helpers_1.fromTimestamp)(timestamp_1.Timestamp.decode(reader, reader.uint32())); break; default: reader.skipType(tag & 7); break; } } return message; }, fromPartial(object) { const message = createBaseLightClientAttackEvidence(); message.conflictingBlock = object.conflictingBlock !== undefined && object.conflictingBlock !== null ? types_1.LightBlock.fromPartial(object.conflictingBlock) : undefined; message.commonHeight = object.commonHeight !== undefined && object.commonHeight !== null ? BigInt(object.commonHeight.toString()) : BigInt(0); message.byzantineValidators = object.byzantineValidators?.map(e => validator_1.Validator.fromPartial(e)) || []; message.totalVotingPower = object.totalVotingPower !== undefined && object.totalVotingPower !== null ? BigInt(object.totalVotingPower.toString()) : BigInt(0); message.timestamp = object.timestamp ?? undefined; return message; }, fromAmino(object) { const message = createBaseLightClientAttackEvidence(); if (object.conflicting_block !== undefined && object.conflicting_block !== null) { message.conflictingBlock = types_1.LightBlock.fromAmino(object.conflicting_block); } if (object.common_height !== undefined && object.common_height !== null) { message.commonHeight = BigInt(object.common_height); } message.byzantineValidators = object.byzantine_validators?.map(e => validator_1.Validator.fromAmino(e)) || []; if (object.total_voting_power !== undefined && object.total_voting_power !== null) { message.totalVotingPower = BigInt(object.total_voting_power); } if (object.timestamp !== undefined && object.timestamp !== null) { message.timestamp = (0, helpers_1.fromTimestamp)(timestamp_1.Timestamp.fromAmino(object.timestamp)); } return message; }, toAmino(message) { const obj = {}; obj.conflicting_block = message.conflictingBlock ? types_1.LightBlock.toAmino(message.conflictingBlock) : undefined; obj.common_height = message.commonHeight !== BigInt(0) ? message.commonHeight?.toString() : undefined; if (message.byzantineValidators) { obj.byzantine_validators = message.byzantineValidators.map(e => e ? validator_1.Validator.toAmino(e) : undefined); } else { obj.byzantine_validators = message.byzantineValidators; } obj.total_voting_power = message.totalVotingPower !== BigInt(0) ? message.totalVotingPower?.toString() : undefined; obj.timestamp = message.timestamp ? timestamp_1.Timestamp.toAmino((0, helpers_1.toTimestamp)(message.timestamp)) : undefined; return obj; }, fromAminoMsg(object) { return exports.LightClientAttackEvidence.fromAmino(object.value); }, fromProtoMsg(message) { return exports.LightClientAttackEvidence.decode(message.value); }, toProto(message) { return exports.LightClientAttackEvidence.encode(message).finish(); }, toProtoMsg(message) { return { typeUrl: "/tendermint.types.LightClientAttackEvidence", value: exports.LightClientAttackEvidence.encode(message).finish() }; }, registerTypeUrl() { if (!registry_1.GlobalDecoderRegistry.registerExistingTypeUrl(exports.LightClientAttackEvidence.typeUrl)) { return; } types_1.LightBlock.registerTypeUrl(); validator_1.Validator.registerTypeUrl(); } }; function createBaseEvidenceList() { return { evidence: [] }; } /** * @name EvidenceList * @package tendermint.types * @see proto type: tendermint.types.EvidenceList */ exports.EvidenceList = { typeUrl: "/tendermint.types.EvidenceList", is(o) { return o && (o.$typeUrl === exports.EvidenceList.typeUrl || Array.isArray(o.evidence) && (!o.evidence.length || exports.Evidence.is(o.evidence[0]))); }, isAmino(o) { return o && (o.$typeUrl === exports.EvidenceList.typeUrl || Array.isArray(o.evidence) && (!o.evidence.length || exports.Evidence.isAmino(o.evidence[0]))); }, encode(message, writer = binary_1.BinaryWriter.create()) { for (const v of message.evidence) { exports.Evidence.encode(v, writer.uint32(10).fork()).ldelim(); } return writer; }, decode(input, length) { const reader = input instanceof binary_1.BinaryReader ? input : new binary_1.BinaryReader(input); let end = length === undefined ? reader.len : reader.pos + length; const message = createBaseEvidenceList(); while (reader.pos < end) { const tag = reader.uint32(); switch (tag >>> 3) { case 1: message.evidence.push(exports.Evidence.decode(reader, reader.uint32())); break; default: reader.skipType(tag & 7); break; } } return message; }, fromPartial(object) { const message = createBaseEvidenceList(); message.evidence = object.evidence?.map(e => exports.Evidence.fromPartial(e)) || []; return message; }, fromAmino(object) { const message = createBaseEvidenceList(); message.evidence = object.evidence?.map(e => exports.Evidence.fromAmino(e)) || []; return message; }, toAmino(message) { const obj = {}; if (message.evidence) { obj.evidence = message.evidence.map(e => e ? exports.Evidence.toAmino(e) : undefined); } else { obj.evidence = message.evidence; } return obj; }, fromAminoMsg(object) { return exports.EvidenceList.fromAmino(object.value); }, fromProtoMsg(message) { return exports.EvidenceList.decode(message.value); }, toProto(message) { return exports.EvidenceList.encode(message).finish(); }, toProtoMsg(message) { return { typeUrl: "/tendermint.types.EvidenceList", value: exports.EvidenceList.encode(message).finish() }; }, registerTypeUrl() { if (!registry_1.GlobalDecoderRegistry.registerExistingTypeUrl(exports.EvidenceList.typeUrl)) { return; } exports.Evidence.registerTypeUrl(); } };