@broxus/js-bridge-essentials
Version:
Bridge JavaScript Essentials library
117 lines (116 loc) • 6.2 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.TonAlienProxyUtils = void 0;
const js_core_1 = require("@broxus/js-core");
const js_utils_1 = require("@broxus/js-utils");
const jetton_alien_evm_1 = require("../../models/jetton-alien-evm");
const contracts_1 = require("../../models/ton-alien-proxy/contracts");
const utils_1 = require("../../utils");
class TonAlienProxyUtils {
static async getConfiguration(connection, proxyAddress, cachedState) {
const state = cachedState ?? await (0, js_core_1.getFullContractState)(connection, proxyAddress);
return (0, contracts_1.tonAlienProxyContract)(connection, proxyAddress)
.methods.getConfiguration({ answerId: 0 })
.call({ cachedState: state, responsible: true });
}
static async getTonEvmConfiguration(connection, proxyAddress, cachedState) {
const result = await TonAlienProxyUtils.getConfiguration(connection, proxyAddress, cachedState);
return result.value0.everscaleConfiguration;
}
/**
* Derive EVM alien token address in TVM by the given proxy address and EVM token params
* @param {ProviderRpcClient} connection
* @param {Address | string} proxyAddress
* @param {Omit<DecodedAbiFunctionInputs<typeof TonAlienProxyAbi, 'deriveEVMAlienTokenRoot'>, 'answerId'>} params
* @param {FullContractState} [cachedState] - optional. Full contract state of the alien proxy contract
*/
static async deriveEvmAlienTokenRoot(connection, proxyAddress, params, cachedState) {
const state = cachedState ?? await (0, js_core_1.getFullContractState)(connection, proxyAddress);
const result = await (0, contracts_1.tonAlienProxyContract)(connection, proxyAddress)
.methods.deriveEVMAlienTokenRoot({ answerId: 0, ...params })
.call({ cachedState: state, responsible: true });
return result.value0;
}
/**
* Get derive merge router address by the given TVM-like token and proxy addresses
* @param {ProviderRpcClient} connection
* @param {Address | string} proxyAddress
* @param {Address | string} tokenAddress
* @param {FullContractState} [cachedState] - optional. Full contract state of the alien proxy contract
*/
static async deriveMergeRouter(connection, proxyAddress, tokenAddress, cachedState) {
const state = cachedState ?? await (0, js_core_1.getFullContractState)(connection, proxyAddress);
const result = await (0, contracts_1.tonAlienProxyContract)(connection, proxyAddress)
.methods.deriveMergeRouter({
answerId: 0,
token: (0, js_core_1.resolveTvmAddress)(tokenAddress),
})
.call({ cachedState: state, responsible: true });
return result.router;
}
/**
* Get merge pool address by the given merge router address
* @param {ProviderRpcClient} connection
* @param {Address | string} mergeRouterAddress
* @param {FullContractState} [cachedState] - optional. Full contract state of the merge router contract
*/
static async getMergePoolAddress(connection, mergeRouterAddress, cachedState) {
const state = cachedState ?? await (0, js_core_1.getFullContractState)(connection, mergeRouterAddress);
const result = await (0, contracts_1.tonMergeRouterContract)(connection, mergeRouterAddress)
.methods.getPool({ answerId: 0 })
.call({ cachedState: state, responsible: true });
return result.value0;
}
static async getMergePoolTokens(connection, mergePoolAddress, cachedState) {
const state = cachedState ?? await (0, js_core_1.getFullContractState)(connection, mergePoolAddress);
const result = await (0, contracts_1.tonMergePoolContract)(connection, mergePoolAddress)
.methods.getTokens({ answerId: 0 })
.call({ cachedState: state, responsible: true });
return {
canon: result._canon,
tokens: result._tokens.map(([addr, settings]) => [addr, settings]),
};
}
static async getEvmTokenMergeDetails(connection, proxyAddress, tokenAddress, chainId, cachedState) {
try {
const state = cachedState ?? await (0, js_core_1.getFullContractState)(connection, proxyAddress);
const tonTokenAddress = (0, js_core_1.resolveTvmAddress)(tokenAddress);
const mergeRouterAddress = await TonAlienProxyUtils.deriveMergeRouter(connection, proxyAddress, tokenAddress, state);
const mergePoolAddress = await TonAlienProxyUtils.getMergePoolAddress(connection, mergeRouterAddress);
const mergedTokens = await TonAlienProxyUtils.getMergePoolTokens(connection, mergePoolAddress);
const aliens = await Promise.all(mergedTokens.tokens.map(async ([address, settings]) => {
if (!settings.enabled) {
return { isMerged: false };
}
try {
const meta = await jetton_alien_evm_1.JettonAlienEvm.Utils.getOffchainMeta((0, utils_1.resolveTonAddress)(address.toString()));
return {
canonicalAddress: mergedTokens.canon,
evmTokenAddress: meta.evmTokenAddress,
isMerged: meta.baseChainId === chainId,
tonTokenAddress,
};
}
catch (e) {
return { isMerged: false };
}
}));
const merged = aliens.find(e => e.isMerged);
return merged
? {
canonicalAddress: merged.canonicalAddress,
evmTokenAddress: merged.evmTokenAddress,
isMerged: true,
mergePoolAddress,
mergeRouterAddress,
tonTokenAddress,
}
: undefined;
}
catch (e) {
(0, js_utils_1.debug)('JettonAlienProxy.getEvmTokenMergeDetails failed with an error', e);
return undefined;
}
}
}
exports.TonAlienProxyUtils = TonAlienProxyUtils;