@broxus/js-bridge-essentials
Version:
Bridge JavaScript Essentials library
219 lines (218 loc) • 9.34 kB
JavaScript
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
import { ProviderNotDefinedError, SmartContractModel, contractStateChangeDebugMessage, isAddressesEquals, subscribeDebugMessage, syncErrorMessage, unsubscribeDebugMessage, unsubscribeErrorMessage, } from '@broxus/js-core';
import { debounce, throwException } from '@broxus/js-utils';
import { action, computed, makeObservable } from 'mobx';
import { EvmTvmEventConfigurationUtils, } from '../../models/evm-tvm-event-configuration/EvmTvmEventConfigurationUtils';
export class EvmTvmEventConfiguration extends SmartContractModel {
_connection;
options;
_provider;
static Utils = EvmTvmEventConfigurationUtils;
/**
* @param {ProviderRpcClient} _connection Standalone RPC client that doesn't require connection
* to the TVM wallet provider
* @param {Address | string} address Alien Event Configuration root address
* @param {Readonly<EvmTvmEventConfigurationCtorOptions>} [options] (optional) Alien Event
* Configuration ABI Wrapper options
* @param {ProviderRpcClient} [_provider] (optional) RPC provider that require connection to
* the TVM wallet
*/
constructor(_connection, address, options, _provider) {
super(_connection, address);
this._connection = _connection;
this.options = options;
this._provider = _provider;
makeObservable(this);
}
/**
* @param {ProviderRpcClient} connection Standalone RPC client that doesn't require connection
* to the TVM wallet provider
* @param {Address | string} address Alien Event Configuration root address
* @param {Readonly<EvmTvmEventConfigurationCreateOptions>} [options] (optional) Alien Event
* Configuration ABI Wrapper options
* @param {ProviderRpcClient} [provider] (optional) RPC provider that require connection to the
* TVM wallet
*/
static async create(connection, address, options, provider) {
const { sync = true, watch, watchCallback, ...restOptions } = { ...options };
const configuration = new EvmTvmEventConfiguration(connection, address, restOptions, provider);
if (sync) {
await configuration.sync({ force: false });
}
if (watch) {
await configuration.watch(watchCallback);
}
return configuration;
}
async sync(options) {
if (!options?.force && this.isSyncing) {
return;
}
try {
this.setState('isSyncing', !options?.silent);
const state = await this.syncContractState({ force: options?.force || !this.contractState });
if (!this.isDeployed) {
throwException('EvmTmvEventConfiguration is not deployed');
}
const [details, flags] = await Promise.all([
EvmTvmEventConfiguration.Utils.getDetails(this._connection, this.address, state),
EvmTvmEventConfiguration.Utils.getFlags(this._connection, this.address, state),
]);
this.setData({ ...details, flags });
}
catch (e) {
if (process.env.NODE_ENV !== 'production') {
syncErrorMessage(this.constructor.name, this.address, e);
}
}
finally {
this.setState('isSyncing', false);
}
}
async watch(callback) {
try {
this.contractSubscriber = new this._connection.Subscriber();
await this.contractSubscriber.states(this.address).delayed(stream => {
if (process.env.NODE_ENV !== 'production') {
subscribeDebugMessage(this.constructor.name, this.address);
}
return stream.on(debounce(async (event) => {
if (process.env.NODE_ENV !== 'production') {
contractStateChangeDebugMessage(this.constructor.name, this.address, event);
}
if (isAddressesEquals(event.address, this.address)) {
await this.sync({ force: !this.isSyncing, silent: true });
callback?.();
return;
}
await this.unwatch();
}, this.options?.watchDebounceDelay ?? 3000));
});
return this.contractSubscriber;
}
catch (e) {
await this.unwatch();
throw e;
}
}
async unwatch() {
try {
await this.contractSubscriber?.unsubscribe();
this.contractSubscriber = undefined;
if (process.env.NODE_ENV !== 'production') {
unsubscribeDebugMessage(this.constructor.name, this.address);
}
}
catch (e) {
if (process.env.NODE_ENV !== 'production') {
unsubscribeErrorMessage(this.constructor.name, this.address, e);
}
}
}
deployEvent(params, args) {
if (this._provider == null) {
throw new ProviderNotDefinedError(this.constructor.name);
}
return EvmTvmEventConfiguration.Utils.deployEvent(this._provider, this.address, params, { amount: this.basicConfiguration.eventInitialBalance, ...args });
}
deriveEventAddress(params) {
return EvmTvmEventConfiguration.Utils.deriveEventAddress(this._connection, this.address, params);
}
get basicConfiguration() {
return this._data.basicConfiguration;
}
get networkConfiguration() {
return this._data.networkConfiguration;
}
get meta() {
return this._data.meta;
}
get flags() {
return this._data.flags;
}
decodeEvent(args) {
return EvmTvmEventConfiguration.Utils.decodeEvent(this._connection, this.address, args);
}
decodeTransaction(args) {
return EvmTvmEventConfiguration.Utils.decodeTransaction(this._connection, this.address, args);
}
decodeTransactionEvents(transaction) {
return EvmTvmEventConfiguration.Utils.decodeTransactionEvents(this._connection, this.address, transaction);
}
}
__decorate([
action.bound,
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], EvmTvmEventConfiguration.prototype, "sync", null);
__decorate([
action.bound,
__metadata("design:type", Function),
__metadata("design:paramtypes", [Function]),
__metadata("design:returntype", Promise)
], EvmTvmEventConfiguration.prototype, "watch", null);
__decorate([
action.bound,
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", Promise)
], EvmTvmEventConfiguration.prototype, "unwatch", null);
__decorate([
action.bound,
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object, Object]),
__metadata("design:returntype", Promise)
], EvmTvmEventConfiguration.prototype, "deployEvent", null);
__decorate([
action.bound,
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], EvmTvmEventConfiguration.prototype, "deriveEventAddress", null);
__decorate([
computed,
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], EvmTvmEventConfiguration.prototype, "basicConfiguration", null);
__decorate([
computed,
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], EvmTvmEventConfiguration.prototype, "networkConfiguration", null);
__decorate([
computed,
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], EvmTvmEventConfiguration.prototype, "meta", null);
__decorate([
computed,
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], EvmTvmEventConfiguration.prototype, "flags", null);
__decorate([
action.bound,
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], EvmTvmEventConfiguration.prototype, "decodeEvent", null);
__decorate([
action.bound,
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], EvmTvmEventConfiguration.prototype, "decodeTransaction", null);
__decorate([
action.bound,
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], EvmTvmEventConfiguration.prototype, "decodeTransactionEvents", null);