rubic-sdk
Version:
Simplify dApp creation
169 lines • 9.29 kB
JavaScript
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ScrollBridgeTrade = void 0;
const sdk_1 = require("@arbitrum/sdk");
const providers_1 = require("@ethersproject/providers");
const bignumber_js_1 = __importDefault(require("bignumber.js"));
const errors_1 = require("../../../../../common/errors");
const blockchain_name_1 = require("../../../../../core/blockchain/models/blockchain-name");
const blockchain_id_1 = require("../../../../../core/blockchain/utils/blockchains-info/constants/blockchain-id");
const evm_web3_pure_1 = require("../../../../../core/blockchain/web3-pure/typed-web3-pure/evm-web3-pure/evm-web3-pure");
const web3_pure_1 = require("../../../../../core/blockchain/web3-pure/web3-pure");
const injector_1 = require("../../../../../core/injector/injector");
const cross_chain_trade_type_1 = require("../../models/cross-chain-trade-type");
const outbox_abi_1 = require("../arbitrum-rbc-bridge/constants/outbox-abi");
const retryable_factory_abi_1 = require("../arbitrum-rbc-bridge/constants/retryable-factory-abi");
const evm_cross_chain_trade_1 = require("../common/evm-cross-chain-trade/evm-cross-chain-trade");
const bridge_type_1 = require("../common/models/bridge-type");
const l1_erc20_scroll_gateway_abi_1 = require("./constants/l1-erc20-scroll-gateway-abi");
const l2_erc20_scroll_gateway_abi_1 = require("./constants/l2-erc20-scroll-gateway-abi");
const scroll_bridge_contract_address_1 = require("./constants/scroll-bridge-contract-address");
class ScrollBridgeTrade extends evm_cross_chain_trade_1.EvmCrossChainTrade {
get fromBlockchain() {
return this.from.blockchain;
}
get fromContractAddress() {
return scroll_bridge_contract_address_1.scrollBridgeContractAddress[this.fromBlockchain].providerGateway;
}
get methodName() {
return this.onChainTrade
? 'swapAndStartBridgeTokensViaGenericCrossChain'
: 'startBridgeTokensViaGenericCrossChain';
}
constructor(crossChainTrade, providerAddress, routePath, useProxy) {
super(providerAddress, routePath, useProxy);
this.onChainSubtype = { from: undefined, to: undefined };
this.type = cross_chain_trade_type_1.CROSS_CHAIN_TRADE_TYPE.SCROLL_BRIDGE;
this.isAggregator = false;
this.bridgeType = bridge_type_1.BRIDGE_TYPE.SCROLL_BRIDGE;
this.feeInfo = {};
this.onChainTrade = null;
this.from = crossChainTrade.from;
this.to = crossChainTrade.to;
this.gasData = crossChainTrade.gasData;
this.toTokenAmountMin = crossChainTrade.to.tokenAmount;
}
async getContractParams(_options) {
throw new Error('Method is not supported');
}
getTradeAmountRatio(_fromUsd) {
return new bignumber_js_1.default(1);
}
getTradeInfo() {
return {
estimatedGas: this.estimatedGas,
feeInfo: this.feeInfo,
priceImpact: null,
slippage: 0,
routePath: this.routePath
};
}
static async claimTargetTokens(sourceTransaction, options) {
const web3Private = injector_1.Injector.web3PrivateService.getWeb3PrivateByBlockchain(blockchain_name_1.BLOCKCHAIN_NAME.ETHEREUM);
await web3Private.checkBlockchainCorrect(blockchain_name_1.BLOCKCHAIN_NAME.ETHEREUM);
const rpcProviders = injector_1.Injector.web3PublicService.rpcProvider;
const l1Provider = new providers_1.JsonRpcProvider(rpcProviders[blockchain_name_1.BLOCKCHAIN_NAME.ETHEREUM].rpcList[0], blockchain_id_1.blockchainId[blockchain_name_1.BLOCKCHAIN_NAME.ETHEREUM]);
const l2Provider = new providers_1.JsonRpcProvider(rpcProviders[blockchain_name_1.BLOCKCHAIN_NAME.ARBITRUM].rpcList[0], blockchain_id_1.blockchainId[blockchain_name_1.BLOCKCHAIN_NAME.ARBITRUM]);
const targetReceipt = await l2Provider.getTransactionReceipt(sourceTransaction);
const l2TxReceipt = new sdk_1.L2TransactionReceipt(targetReceipt);
const [event] = l2TxReceipt.getL2ToL1Events();
if (!event) {
throw new errors_1.RubicSdkError('Transaction is not ready');
}
const messageReader = new sdk_1.L2ToL1MessageReader(l1Provider, event);
const proof = await messageReader.getOutboxProof(l2Provider);
const l2network = await (0, sdk_1.getL2Network)(blockchain_id_1.blockchainId[blockchain_name_1.BLOCKCHAIN_NAME.ARBITRUM]);
const { onConfirm, gasLimit, gasPriceOptions } = options;
const onTransactionHash = (hash) => {
if (onConfirm) {
onConfirm(hash);
}
};
return web3Private.tryExecuteContractMethod(l2network.ethBridge.outbox, outbox_abi_1.outboxAbi, 'executeTransaction', [
proof,
event.position.toString(),
event.caller,
event.destination,
event.arbBlockNum.toString(),
event.ethBlockNum.toString(),
event.timestamp.toString(),
event.callvalue.toString(),
event.data
], {
onTransactionHash,
gas: gasLimit,
gasPriceOptions
});
}
static async redeemTokens(sourceTransactionHash, options) {
const rpcProviders = injector_1.Injector.web3PublicService.rpcProvider;
const l1Provider = new providers_1.JsonRpcProvider(rpcProviders[blockchain_name_1.BLOCKCHAIN_NAME.ETHEREUM].rpcList[0], blockchain_id_1.blockchainId[blockchain_name_1.BLOCKCHAIN_NAME.ETHEREUM]);
const l2Provider = new providers_1.JsonRpcProvider(rpcProviders[blockchain_name_1.BLOCKCHAIN_NAME.ARBITRUM].rpcList[0], blockchain_id_1.blockchainId[blockchain_name_1.BLOCKCHAIN_NAME.ARBITRUM]);
const receipt = await l1Provider.getTransactionReceipt(sourceTransactionHash);
const messages = await new sdk_1.L1TransactionReceipt(receipt).getL1ToL2Messages(l2Provider);
const creationIdMessage = messages.find(el => el.retryableCreationId);
if (!creationIdMessage) {
throw new errors_1.RubicSdkError('Can not find creation id message.');
}
const { retryableCreationId } = creationIdMessage;
const web3Private = injector_1.Injector.web3PrivateService.getWeb3PrivateByBlockchain(blockchain_name_1.BLOCKCHAIN_NAME.ARBITRUM);
await web3Private.checkBlockchainCorrect(blockchain_name_1.BLOCKCHAIN_NAME.ARBITRUM);
const { onConfirm, gasLimit, gasPriceOptions } = options;
const onTransactionHash = (hash) => {
if (onConfirm) {
onConfirm(hash);
}
};
return web3Private.tryExecuteContractMethod('0x000000000000000000000000000000000000006E', retryable_factory_abi_1.retryableFactoryAbi, 'redeem', [retryableCreationId], {
onTransactionHash,
gas: gasLimit,
gasPriceOptions
});
}
async getTransactionConfigAndAmount(receiverAddress) {
let contractParams = null;
if (this.fromBlockchain === blockchain_name_1.BLOCKCHAIN_NAME.GOERLI) {
const methodArguments = [
...(this.from.isNative ? [] : [this.from.address]),
...(receiverAddress ? [receiverAddress] : []),
this.from.stringWeiAmount,
'40000'
];
const fee = web3_pure_1.Web3Pure.toWei(0.005);
contractParams = {
contractAddress: scroll_bridge_contract_address_1.scrollBridgeContractAddress[this.fromBlockchain].providerGateway,
contractAbi: l1_erc20_scroll_gateway_abi_1.l1Erc20ScrollGatewayAbi,
methodName: this.from.isNative ? 'depositETH' : 'depositERC20',
methodArguments,
value: this.from.isNative
? this.from.weiAmount.plus(fee).toFixed()
: this.from.stringWeiAmount
};
}
else {
const methodArguments = [
...(this.from.isNative ? [] : [this.from.address]),
...(receiverAddress ? [receiverAddress] : []),
this.from.stringWeiAmount,
'160000'
];
const fee = web3_pure_1.Web3Pure.toWei(0.005);
contractParams = {
contractAddress: scroll_bridge_contract_address_1.scrollBridgeContractAddress[this.fromBlockchain].providerGateway,
contractAbi: l2_erc20_scroll_gateway_abi_1.l2Erc20ScrollGatewayAbi,
methodName: this.from.isNative ? 'withdrawETH' : 'withdrawERC20',
methodArguments,
value: this.from.isNative
? this.from.weiAmount.plus(fee).toFixed()
: this.from.stringWeiAmount
};
}
const config = evm_web3_pure_1.EvmWeb3Pure.encodeMethodCall(contractParams.contractAddress, contractParams.contractAbi, contractParams.methodName, contractParams.methodArguments, contractParams.value);
return { config, amount: this.to.stringWeiAmount };
}
}
exports.ScrollBridgeTrade = ScrollBridgeTrade;
//# sourceMappingURL=scroll-bridge-trade.js.map