@broxus/js-bridge-essentials
Version:
Bridge JavaScript Essentials library
86 lines (85 loc) • 4.19 kB
JavaScript
import { getFullContractState } from '@broxus/js-core';
import { solTvmBaseEventContract } from '../../models/sol-tvm-base-event/contracts';
export var SolTvmBaseEventStatus;
(function (SolTvmBaseEventStatus) {
SolTvmBaseEventStatus["Initializing"] = "0";
SolTvmBaseEventStatus["Pending"] = "1";
SolTvmBaseEventStatus["Confirmed"] = "2";
SolTvmBaseEventStatus["Rejected"] = "3";
})(SolTvmBaseEventStatus || (SolTvmBaseEventStatus = {}));
export class SolTvmBaseEventUtils {
static async getDetails(connection, eventAddress, cachedState) {
const state = cachedState ?? await getFullContractState(connection, eventAddress);
const result = await solTvmBaseEventContract(connection, eventAddress)
.methods.getDetails({ answerId: 0 })
.call({ cachedState: state, responsible: true });
return {
balance: result.balance,
confirms: result._confirms,
empty: result.empty,
eventInitData: {
configuration: result._eventInitData.configuration,
staking: result._eventInitData.staking,
voteData: {
accountSeed: result._eventInitData.voteData.accountSeed,
blockTime: Number(result._eventInitData.voteData.blockTime),
eventData: result._eventInitData.voteData.eventData,
slot: result._eventInitData.voteData.slot,
txSignature: result._eventInitData.voteData.txSignature,
},
},
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 solTvmBaseEventContract(connection, eventAddress)
.methods.getEventInitData({ answerId: 0 })
.call({ cachedState: state, responsible: true });
return {
configuration: result.value0.configuration,
staking: result.value0.staking,
voteData: {
accountSeed: result.value0.voteData.accountSeed,
blockTime: Number(result.value0.voteData.blockTime),
eventData: result.value0.voteData.eventData,
slot: result.value0.voteData.slot,
txSignature: result.value0.voteData.txSignature,
},
};
}
static async nonce(connection, eventAddress, cachedState) {
const state = cachedState ?? await getFullContractState(connection, eventAddress);
const result = await solTvmBaseEventContract(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 solTvmBaseEventContract(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 solTvmBaseEventContract(connection, eventAddress)
.methods.round_number()
.call({ cachedState: state });
return Number(result.round_number);
}
static decodeEvent(connection, eventAddress, args) {
return solTvmBaseEventContract(connection, eventAddress).decodeEvent(args);
}
static decodeTransaction(connection, eventAddress, args) {
return solTvmBaseEventContract(connection, eventAddress).decodeTransaction(args);
}
static decodeTransactionEvents(connection, eventAddress, transaction) {
return solTvmBaseEventContract(connection, eventAddress).decodeTransactionEvents({ transaction });
}
}