UNPKG

@broxus/js-bridge-essentials

Version:

Bridge JavaScript Essentials library

93 lines (92 loc) 4.64 kB
import { getFullContractState } from '@broxus/js-core'; import { evmTvmBaseEventContract } from '../../models/evm-tvm-base-event/contracts'; export var EvmTvmBaseEventStatus; (function (EvmTvmBaseEventStatus) { EvmTvmBaseEventStatus["Initializing"] = "0"; EvmTvmBaseEventStatus["Pending"] = "1"; EvmTvmBaseEventStatus["Confirmed"] = "2"; EvmTvmBaseEventStatus["Rejected"] = "3"; EvmTvmBaseEventStatus["Cancelled"] = "4"; EvmTvmBaseEventStatus["LimitReached"] = "5"; EvmTvmBaseEventStatus["LiquidityRequested"] = "6"; EvmTvmBaseEventStatus["LiquidityProvided"] = "7"; EvmTvmBaseEventStatus["Verified"] = "8"; })(EvmTvmBaseEventStatus || (EvmTvmBaseEventStatus = {})); export class EvmTvmBaseEventUtils { static async getDetails(connection, eventAddress, cachedState) { const state = cachedState ?? await getFullContractState(connection, eventAddress); const result = await evmTvmBaseEventContract(connection, eventAddress) .methods.getDetails({ answerId: 0 }) .call({ cachedState: state, responsible: true }); return { balance: result.balance, confirms: result._confirms, empty: result.empty, eventInitData: { chainId: result._eventInitData.chainId, configuration: result._eventInitData.configuration, staking: result._eventInitData.staking, voteData: { eventBlock: Number(result._eventInitData.voteData.eventBlock), eventBlockNumber: Number(result._eventInitData.voteData.eventBlockNumber), eventData: result._eventInitData.voteData.eventData, eventIndex: Number(result._eventInitData.voteData.eventIndex), eventTransaction: result._eventInitData.voteData.eventTransaction, }, }, initializer: result._initializer, meta: result._meta, rejects: result._rejects, requiredVotes: Number(result._requiredVotes), status: result._status, }; } static async getEventInitData(connection, eventAddress, cachedState) { const state = cachedState ?? await getFullContractState(connection, eventAddress); const result = await evmTvmBaseEventContract(connection, eventAddress) .methods.getEventInitData({ answerId: 0 }) .call({ cachedState: state, responsible: true }); return { chainId: result.value0.chainId, configuration: result.value0.configuration, staking: result.value0.staking, voteData: { eventBlock: Number(result.value0.voteData.eventBlock), eventBlockNumber: Number(result.value0.voteData.eventBlockNumber), eventData: result.value0.voteData.eventData, eventIndex: Number(result.value0.voteData.eventIndex), eventTransaction: result.value0.voteData.eventTransaction, }, }; } static async nonce(connection, eventAddress, cachedState) { const state = cachedState ?? await getFullContractState(connection, eventAddress); const result = await evmTvmBaseEventContract(connection, eventAddress) .methods.nonce() .call({ cachedState: state }); return result.nonce; } static async relayRound(connection, eventAddress, cachedState) { const state = cachedState ?? await getFullContractState(connection, eventAddress); const result = await evmTvmBaseEventContract(connection, eventAddress) .methods.relay_round() .call({ cachedState: state }); return result.relay_round; } static async roundNumber(connection, eventAddress, cachedState) { const state = cachedState ?? await getFullContractState(connection, eventAddress); const result = await evmTvmBaseEventContract(connection, eventAddress) .methods.round_number() .call({ cachedState: state }); return Number(result.round_number); } static decodeEvent(connection, eventAddress, args) { return evmTvmBaseEventContract(connection, eventAddress).decodeEvent(args); } static decodeTransaction(connection, eventAddress, args) { return evmTvmBaseEventContract(connection, eventAddress).decodeTransaction(args); } static decodeTransactionEvents(connection, eventAddress, transaction) { return evmTvmBaseEventContract(connection, eventAddress).decodeTransactionEvents({ transaction }); } }