@instadapp/interop-x 0.0.0-dev.ef78459 → 0.0.0-dev.f39d622
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.example +2 -1
- package/.github/workflows/ci.yml +19 -0
- package/bin/interop-x +1 -1
- package/dist/package.json +81 -0
- package/dist/src/abi/aaveV2Resolver.json +832 -0
- package/dist/src/abi/balanceResolver.json +211 -0
- package/dist/src/abi/connectors/index.js +36 -0
- package/dist/src/abi/connectors/v1/aave.js +148 -0
- package/dist/src/abi/connectors/v1/aave_claim.js +4 -0
- package/dist/src/abi/connectors/v1/aave_migrate.js +109 -0
- package/dist/src/abi/connectors/v1/aave_polygon_migrate.js +110 -0
- package/dist/src/abi/connectors/v1/aave_stake.js +4 -0
- package/dist/src/abi/connectors/v1/aave_v1_import.js +54 -0
- package/dist/src/abi/connectors/v1/aave_v2.js +230 -0
- package/dist/src/abi/connectors/v1/aave_v2_import.js +59 -0
- package/dist/src/abi/connectors/v1/authority.js +100 -0
- package/dist/src/abi/connectors/v1/basic.js +136 -0
- package/dist/src/abi/connectors/v1/chi.js +36 -0
- package/dist/src/abi/connectors/v1/comp.js +4 -0
- package/dist/src/abi/connectors/v1/compound.js +4 -0
- package/dist/src/abi/connectors/v1/compoundImport.js +69 -0
- package/dist/src/abi/connectors/v1/compoundImport_v2.js +4 -0
- package/dist/src/abi/connectors/v1/compound_old.js +448 -0
- package/dist/src/abi/connectors/v1/curve.js +140 -0
- package/dist/src/abi/connectors/v1/curve_claim.js +63 -0
- package/dist/src/abi/connectors/v1/curve_gauge.js +158 -0
- package/dist/src/abi/connectors/v1/curve_sbtc.js +140 -0
- package/dist/src/abi/connectors/v1/curve_susd.js +140 -0
- package/dist/src/abi/connectors/v1/curve_three.js +79 -0
- package/dist/src/abi/connectors/v1/curve_y.js +140 -0
- package/dist/src/abi/connectors/v1/dsa_migrate_v1_to_v2.js +4 -0
- package/dist/src/abi/connectors/v1/dydx.js +148 -0
- package/dist/src/abi/connectors/v1/dydx_flash.js +52 -0
- package/dist/src/abi/connectors/v1/fee.js +50 -0
- package/dist/src/abi/connectors/v1/gelato.js +1138 -0
- package/dist/src/abi/connectors/v1/index.js +58 -0
- package/dist/src/abi/connectors/v1/instapool.js +439 -0
- package/dist/src/abi/connectors/v1/instapool_v2.js +126 -0
- package/dist/src/abi/connectors/v1/kyber.js +117 -0
- package/dist/src/abi/connectors/v1/maker.js +480 -0
- package/dist/src/abi/connectors/v1/maker_old.js +300 -0
- package/dist/src/abi/connectors/v1/math.js +43 -0
- package/dist/src/abi/connectors/v1/migrate.js +46 -0
- package/dist/src/abi/connectors/v1/oasis.js +198 -0
- package/dist/src/abi/connectors/v1/oneInch.js +160 -0
- package/dist/src/abi/connectors/v1/polygon_bridge.js +4 -0
- package/dist/src/abi/connectors/v1/refinance.js +4 -0
- package/dist/src/abi/connectors/v1/staking.js +220 -0
- package/dist/src/abi/connectors/v1/swerve.js +179 -0
- package/dist/src/abi/connectors/v1/uniswap.js +297 -0
- package/dist/src/abi/connectors/v2/1INCH-A.js +4 -0
- package/dist/src/abi/connectors/v2/1INCH-B.js +4 -0
- package/dist/src/abi/connectors/v2/AAVE-CLAIM-A.js +4 -0
- package/dist/src/abi/connectors/v2/AAVE-CLAIM-B.js +166 -0
- package/dist/src/abi/connectors/v2/AAVE-STAKE-A.js +4 -0
- package/dist/src/abi/connectors/v2/AAVE-V1-A.js +130 -0
- package/dist/src/abi/connectors/v2/AAVE-V1-IMPORT-A.js +4 -0
- package/dist/src/abi/connectors/v2/AAVE-V2-A.js +230 -0
- package/dist/src/abi/connectors/v2/AAVE-V2-IMPORT-A.js +4 -0
- package/dist/src/abi/connectors/v2/AAVE-V2-IMPORT-B.js +225 -0
- package/dist/src/abi/connectors/v2/AUTHORITY-A.js +100 -0
- package/dist/src/abi/connectors/v2/B-COMPOUND-A.js +4 -0
- package/dist/src/abi/connectors/v2/B-LIQUITY-A.js +4 -0
- package/dist/src/abi/connectors/v2/B-MAKERDAO-A.js +4 -0
- package/dist/src/abi/connectors/v2/BASIC-A.js +136 -0
- package/dist/src/abi/connectors/v2/BASIC-B.js +4 -0
- package/dist/src/abi/connectors/v2/BASIC-C.js +4 -0
- package/dist/src/abi/connectors/v2/COMP-A.js +4 -0
- package/dist/src/abi/connectors/v2/COMPOUND-A.js +4 -0
- package/dist/src/abi/connectors/v2/COMPOUND-IMPORT-A.js +4 -0
- package/dist/src/abi/connectors/v2/COMPOUND-IMPORT-B.js +195 -0
- package/dist/src/abi/connectors/v2/G-UNISWAP-A.js +4 -0
- package/dist/src/abi/connectors/v2/GELATO-AAVE-A.js +4 -0
- package/dist/src/abi/connectors/v2/INST-A.js +4 -0
- package/dist/src/abi/connectors/v2/INST-LM-A.js +4 -0
- package/dist/src/abi/connectors/v2/INST-STAKING-A.js +4 -0
- package/dist/src/abi/connectors/v2/INST-STAKING-B.js +4 -0
- package/dist/src/abi/connectors/v2/INSTAPOOL-A.js +4 -0
- package/dist/src/abi/connectors/v2/LIQUITY-A.js +4 -0
- package/dist/src/abi/connectors/v2/MAKERDAO-A.js +4 -0
- package/dist/src/abi/connectors/v2/MAKERDAO-CLAIM-A.js +136 -0
- package/dist/src/abi/connectors/v2/PARASWAP-A.js +4 -0
- package/dist/src/abi/connectors/v2/POLYGON-BRIDGE-A.js +4 -0
- package/dist/src/abi/connectors/v2/REFINANCE-A.js +4 -0
- package/dist/src/abi/connectors/v2/REFLEXER-A.js +4 -0
- package/dist/src/abi/connectors/v2/STAKE-ERC20-A.js +4 -0
- package/dist/src/abi/connectors/v2/UNISWAP-A.js +297 -0
- package/dist/src/abi/connectors/v2/UNISWAP-V2-A.js +4 -0
- package/dist/src/abi/connectors/v2/UNISWAP-V3-A.js +4 -0
- package/dist/src/abi/connectors/v2/UNISWAP-V3-STAKE-A.js +4 -0
- package/dist/src/abi/connectors/v2/WETH-A.js +4 -0
- package/dist/src/abi/connectors/v2/YEARN-VAULT-A.js +4 -0
- package/dist/src/abi/connectors/v2/index.js +89 -0
- package/dist/src/abi/erc20.json +350 -0
- package/dist/src/abi/gnosisSafe.json +747 -0
- package/dist/src/abi/index.js +21 -0
- package/dist/src/abi/instList.json +232 -0
- package/dist/src/abi/interopX.json +1436 -0
- package/dist/src/alias.js +10 -0
- package/dist/src/api/index.js +43 -0
- package/dist/src/config/index.js +31 -0
- package/dist/src/constants/addresses.js +23 -0
- package/dist/src/constants/blockConfirmations.js +8 -0
- package/dist/src/constants/capPerChain.js +8 -0
- package/dist/{constants → src/constants}/index.js +4 -0
- package/dist/src/constants/tokens.js +130 -0
- package/dist/src/constants/wrappedNativeToken.js +8 -0
- package/dist/src/crons/index.js +3 -0
- package/dist/src/crons/prices.js +16 -0
- package/dist/{db → src/db}/index.js +0 -0
- package/dist/{db → src/db}/models/index.js +1 -1
- package/dist/src/db/models/transaction.js +80 -0
- package/dist/{db → src/db}/sequelize.js +2 -1
- package/dist/src/errors/index.js +30 -0
- package/dist/src/gnosis/actions/aaveV2/index.js +11 -0
- package/dist/src/gnosis/actions/aaveV2/source.js +73 -0
- package/dist/src/gnosis/actions/aaveV2/target.js +86 -0
- package/dist/src/gnosis/actions/index.js +9 -0
- package/dist/src/gnosis/index.js +20 -0
- package/dist/src/index.js +120 -0
- package/dist/{logger → src/logger}/index.js +0 -0
- package/dist/{net → src/net}/index.js +0 -0
- package/dist/{net → src/net}/peer/index.js +8 -3
- package/dist/{net → src/net}/pool/index.js +32 -9
- package/dist/{net → src/net}/protocol/dial/BaseDialProtocol.js +0 -0
- package/dist/{net → src/net}/protocol/dial/SignatureDialProtocol.js +19 -12
- package/dist/src/net/protocol/dial/TransactionStatusDialProtocol.js +30 -0
- package/dist/{net → src/net}/protocol/index.js +54 -4
- package/dist/src/services/Prices.js +74 -0
- package/dist/src/services/index.js +8 -0
- package/dist/src/tasks/AutoUpdateTask.js +70 -0
- package/dist/{tasks → src/tasks}/BaseTask.js +13 -5
- package/dist/src/tasks/InteropX/ProcessSubmitEvents.js +244 -0
- package/dist/src/tasks/InteropX/ProcessValidateEvents.js +184 -0
- package/dist/src/tasks/InteropX/SyncLogExecuteEvents.js +112 -0
- package/dist/src/tasks/InteropX/SyncLogSubmitEvents.js +87 -0
- package/dist/src/tasks/InteropX/SyncLogValidateEvents.js +105 -0
- package/dist/src/tasks/Transactions/SyncTransactionStatusTask.js +58 -0
- package/dist/src/tasks/index.js +45 -0
- package/dist/src/typechain/AaveV2Resolver.js +2 -0
- package/dist/src/typechain/BalanceResolver.js +2 -0
- package/dist/src/typechain/Erc20.js +2 -0
- package/dist/src/typechain/GnosisSafe.js +2 -0
- package/dist/src/typechain/InstList.js +2 -0
- package/dist/src/typechain/InteropX.js +2 -0
- package/dist/src/typechain/common.js +2 -0
- package/dist/src/typechain/factories/AaveV2Resolver__factory.js +1191 -0
- package/dist/src/typechain/factories/BalanceResolver__factory.js +228 -0
- package/dist/src/typechain/factories/Erc20__factory.js +367 -0
- package/dist/src/typechain/factories/GnosisSafe__factory.js +1174 -0
- package/dist/src/typechain/factories/InstList__factory.js +249 -0
- package/dist/src/typechain/factories/InteropX__factory.js +1928 -0
- package/dist/src/typechain/factories/index.js +18 -0
- package/dist/src/typechain/index.js +39 -0
- package/dist/{types.js → src/types.js} +0 -0
- package/dist/src/utils/async.js +18 -0
- package/dist/src/utils/dsa.js +24 -0
- package/dist/src/utils/formatting.js +67 -0
- package/dist/src/utils/gnosis.js +62 -0
- package/dist/src/utils/http.js +10 -0
- package/dist/src/utils/index.js +25 -0
- package/dist/src/utils/interop.js +16 -0
- package/dist/src/utils/tokens.js +22 -0
- package/dist/src/utils/validate.js +111 -0
- package/dist/src/utils/web3.js +93 -0
- package/package.json +35 -19
- package/patches/@ethersproject+properties+5.6.0.patch +13 -0
- package/src/abi/aaveV2Resolver.json +832 -0
- package/src/abi/balanceResolver.json +211 -0
- package/src/abi/connectors/index.ts +14 -0
- package/src/abi/connectors/v1/aave.ts +147 -0
- package/src/abi/connectors/v1/aave_claim.ts +3 -0
- package/src/abi/connectors/v1/aave_migrate.ts +108 -0
- package/src/abi/connectors/v1/aave_polygon_migrate.ts +109 -0
- package/src/abi/connectors/v1/aave_stake.ts +3 -0
- package/src/abi/connectors/v1/aave_v1_import.ts +53 -0
- package/src/abi/connectors/v1/aave_v2.ts +229 -0
- package/src/abi/connectors/v1/aave_v2_import.ts +58 -0
- package/src/abi/connectors/v1/authority.ts +99 -0
- package/src/abi/connectors/v1/basic.ts +135 -0
- package/src/abi/connectors/v1/chi.ts +35 -0
- package/src/abi/connectors/v1/comp.ts +3 -0
- package/src/abi/connectors/v1/compound.ts +3 -0
- package/src/abi/connectors/v1/compoundImport.ts +68 -0
- package/src/abi/connectors/v1/compoundImport_v2.ts +3 -0
- package/src/abi/connectors/v1/compound_old.ts +447 -0
- package/src/abi/connectors/v1/curve.ts +139 -0
- package/src/abi/connectors/v1/curve_claim.ts +62 -0
- package/src/abi/connectors/v1/curve_gauge.ts +157 -0
- package/src/abi/connectors/v1/curve_sbtc.ts +139 -0
- package/src/abi/connectors/v1/curve_susd.ts +139 -0
- package/src/abi/connectors/v1/curve_three.ts +78 -0
- package/src/abi/connectors/v1/curve_y.ts +139 -0
- package/src/abi/connectors/v1/dsa_migrate_v1_to_v2.ts +3 -0
- package/src/abi/connectors/v1/dydx.ts +147 -0
- package/src/abi/connectors/v1/dydx_flash.ts +51 -0
- package/src/abi/connectors/v1/fee.ts +49 -0
- package/src/abi/connectors/v1/gelato.ts +1137 -0
- package/src/abi/connectors/v1/index.ts +42 -0
- package/src/abi/connectors/v1/instapool.ts +438 -0
- package/src/abi/connectors/v1/instapool_v2.ts +125 -0
- package/src/abi/connectors/v1/kyber.ts +116 -0
- package/src/abi/connectors/v1/maker.ts +479 -0
- package/src/abi/connectors/v1/maker_old.ts +299 -0
- package/src/abi/connectors/v1/math.ts +42 -0
- package/src/abi/connectors/v1/migrate.ts +45 -0
- package/src/abi/connectors/v1/oasis.ts +197 -0
- package/src/abi/connectors/v1/oneInch.ts +159 -0
- package/src/abi/connectors/v1/polygon_bridge.ts +3 -0
- package/src/abi/connectors/v1/refinance.ts +3 -0
- package/src/abi/connectors/v1/staking.ts +219 -0
- package/src/abi/connectors/v1/swerve.ts +178 -0
- package/src/abi/connectors/v1/uniswap.ts +297 -0
- package/src/abi/connectors/v2/1INCH-A.ts +3 -0
- package/src/abi/connectors/v2/1INCH-B.ts +3 -0
- package/src/abi/connectors/v2/AAVE-CLAIM-A.ts +3 -0
- package/src/abi/connectors/v2/AAVE-CLAIM-B.ts +165 -0
- package/src/abi/connectors/v2/AAVE-STAKE-A.ts +3 -0
- package/src/abi/connectors/v2/AAVE-V1-A.ts +130 -0
- package/src/abi/connectors/v2/AAVE-V1-IMPORT-A.ts +3 -0
- package/src/abi/connectors/v2/AAVE-V2-A.ts +229 -0
- package/src/abi/connectors/v2/AAVE-V2-IMPORT-A.ts +3 -0
- package/src/abi/connectors/v2/AAVE-V2-IMPORT-B.ts +224 -0
- package/src/abi/connectors/v2/AUTHORITY-A.ts +99 -0
- package/src/abi/connectors/v2/B-COMPOUND-A.ts +3 -0
- package/src/abi/connectors/v2/B-LIQUITY-A.ts +3 -0
- package/src/abi/connectors/v2/B-MAKERDAO-A.ts +3 -0
- package/src/abi/connectors/v2/BASIC-A.ts +135 -0
- package/src/abi/connectors/v2/BASIC-B.ts +3 -0
- package/src/abi/connectors/v2/BASIC-C.ts +3 -0
- package/src/abi/connectors/v2/COMP-A.ts +3 -0
- package/src/abi/connectors/v2/COMPOUND-A.ts +3 -0
- package/src/abi/connectors/v2/COMPOUND-IMPORT-A.ts +3 -0
- package/src/abi/connectors/v2/COMPOUND-IMPORT-B.ts +194 -0
- package/src/abi/connectors/v2/G-UNISWAP-A.ts +3 -0
- package/src/abi/connectors/v2/GELATO-AAVE-A.ts +3 -0
- package/src/abi/connectors/v2/INST-A.ts +3 -0
- package/src/abi/connectors/v2/INST-LM-A.ts +3 -0
- package/src/abi/connectors/v2/INST-STAKING-A.ts +3 -0
- package/src/abi/connectors/v2/INST-STAKING-B.ts +3 -0
- package/src/abi/connectors/v2/INSTAPOOL-A.ts +3 -0
- package/src/abi/connectors/v2/LIQUITY-A.ts +3 -0
- package/src/abi/connectors/v2/MAKERDAO-A.ts +3 -0
- package/src/abi/connectors/v2/MAKERDAO-CLAIM-A.ts +135 -0
- package/src/abi/connectors/v2/PARASWAP-A.ts +3 -0
- package/src/abi/connectors/v2/POLYGON-BRIDGE-A.ts +3 -0
- package/src/abi/connectors/v2/REFINANCE-A.ts +3 -0
- package/src/abi/connectors/v2/REFLEXER-A.ts +3 -0
- package/src/abi/connectors/v2/STAKE-ERC20-A.ts +3 -0
- package/src/abi/connectors/v2/UNISWAP-A.ts +297 -0
- package/src/abi/connectors/v2/UNISWAP-V2-A.ts +3 -0
- package/src/abi/connectors/v2/UNISWAP-V3-A.ts +3 -0
- package/src/abi/connectors/v2/UNISWAP-V3-STAKE-A.ts +3 -0
- package/src/abi/connectors/v2/WETH-A.ts +3 -0
- package/src/abi/connectors/v2/YEARN-VAULT-A.ts +3 -0
- package/src/abi/connectors/v2/index.ts +87 -0
- package/src/abi/erc20.json +350 -0
- package/src/abi/gnosisSafe.json +747 -0
- package/src/abi/index.ts +17 -0
- package/src/abi/instList.json +232 -0
- package/src/abi/interopX.json +1436 -0
- package/src/alias.ts +6 -0
- package/src/api/index.ts +44 -0
- package/src/config/index.ts +17 -1
- package/src/constants/addresses.ts +26 -6
- package/src/constants/blockConfirmations.ts +5 -0
- package/src/constants/capPerChain.ts +5 -0
- package/src/constants/index.ts +4 -0
- package/src/constants/tokens.ts +127 -0
- package/src/constants/wrappedNativeToken.ts +5 -0
- package/src/crons/index.ts +1 -0
- package/src/crons/prices.ts +12 -0
- package/src/db/models/index.ts +1 -1
- package/src/db/models/transaction.ts +190 -0
- package/src/db/sequelize.ts +2 -1
- package/src/errors/index.ts +26 -0
- package/src/gnosis/actions/aaveV2/index.ts +9 -0
- package/src/gnosis/actions/aaveV2/source.ts +118 -0
- package/src/gnosis/actions/aaveV2/target.ts +141 -0
- package/src/gnosis/actions/index.ts +5 -0
- package/src/gnosis/index.ts +19 -0
- package/src/index.ts +110 -8
- package/src/net/peer/index.ts +9 -7
- package/src/net/pool/index.ts +41 -11
- package/src/net/protocol/dial/SignatureDialProtocol.ts +23 -15
- package/src/net/protocol/dial/TransactionStatusDialProtocol.ts +33 -0
- package/src/net/protocol/index.ts +70 -4
- package/src/services/Prices.ts +89 -0
- package/src/services/index.ts +1 -0
- package/src/tasks/AutoUpdateTask.ts +82 -0
- package/src/tasks/BaseTask.ts +15 -6
- package/src/tasks/InteropX/ProcessSubmitEvents.ts +344 -0
- package/src/tasks/InteropX/ProcessValidateEvents.ts +271 -0
- package/src/tasks/InteropX/SyncLogExecuteEvents.ts +160 -0
- package/src/tasks/InteropX/SyncLogSubmitEvents.ts +137 -0
- package/src/tasks/InteropX/SyncLogValidateEvents.ts +150 -0
- package/src/tasks/Transactions/SyncTransactionStatusTask.ts +70 -0
- package/src/tasks/index.ts +32 -2
- package/src/typechain/AaveV2Resolver.ts +1017 -0
- package/src/typechain/BalanceResolver.ts +266 -0
- package/src/typechain/Erc20.ts +491 -0
- package/src/typechain/GnosisSafe.ts +1728 -0
- package/src/typechain/InstList.ts +402 -0
- package/src/typechain/InteropX.ts +1216 -0
- package/src/typechain/common.ts +44 -0
- package/src/typechain/factories/AaveV2Resolver__factory.ts +1198 -0
- package/src/typechain/factories/BalanceResolver__factory.ts +235 -0
- package/src/typechain/factories/Erc20__factory.ts +368 -0
- package/src/typechain/factories/GnosisSafe__factory.ts +1178 -0
- package/src/typechain/factories/InstList__factory.ts +253 -0
- package/src/typechain/factories/InteropX__factory.ts +1932 -0
- package/src/typechain/factories/index.ts +9 -0
- package/src/typechain/index.ts +16 -0
- package/src/types.ts +1 -1
- package/src/utils/async.ts +22 -0
- package/src/utils/dsa.ts +30 -0
- package/src/utils/formatting.ts +68 -0
- package/src/utils/gnosis.ts +123 -0
- package/src/utils/http.ts +6 -0
- package/src/utils/index.ts +9 -116
- package/src/utils/interop.ts +28 -0
- package/src/utils/tokens.ts +21 -0
- package/src/utils/validate.ts +173 -0
- package/src/utils/web3.ts +132 -0
- package/tsconfig.json +7 -2
- package/dist/config/index.js +0 -17
- package/dist/constants/addresses.js +0 -13
- package/dist/db/models/execution.js +0 -38
- package/dist/index.js +0 -43
- package/dist/tasks/index.js +0 -19
- package/dist/utils/index.js +0 -89
- package/src/db/models/execution.ts +0 -57
@@ -0,0 +1,9 @@
|
|
1
|
+
/* Autogenerated file. Do not edit manually. */
|
2
|
+
/* tslint:disable */
|
3
|
+
/* eslint-disable */
|
4
|
+
export { AaveV2Resolver__factory } from "./AaveV2Resolver__factory";
|
5
|
+
export { BalanceResolver__factory } from "./BalanceResolver__factory";
|
6
|
+
export { Erc20__factory } from "./Erc20__factory";
|
7
|
+
export { GnosisSafe__factory } from "./GnosisSafe__factory";
|
8
|
+
export { InstList__factory } from "./InstList__factory";
|
9
|
+
export { InteropX__factory } from "./InteropX__factory";
|
@@ -0,0 +1,16 @@
|
|
1
|
+
/* Autogenerated file. Do not edit manually. */
|
2
|
+
/* tslint:disable */
|
3
|
+
/* eslint-disable */
|
4
|
+
export type { AaveV2Resolver } from "./AaveV2Resolver";
|
5
|
+
export type { BalanceResolver } from "./BalanceResolver";
|
6
|
+
export type { Erc20 } from "./Erc20";
|
7
|
+
export type { GnosisSafe } from "./GnosisSafe";
|
8
|
+
export type { InstList } from "./InstList";
|
9
|
+
export type { InteropX } from "./InteropX";
|
10
|
+
export * as factories from "./factories";
|
11
|
+
export { AaveV2Resolver__factory } from "./factories/AaveV2Resolver__factory";
|
12
|
+
export { BalanceResolver__factory } from "./factories/BalanceResolver__factory";
|
13
|
+
export { Erc20__factory } from "./factories/Erc20__factory";
|
14
|
+
export { GnosisSafe__factory } from "./factories/GnosisSafe__factory";
|
15
|
+
export { InstList__factory } from "./factories/InstList__factory";
|
16
|
+
export { InteropX__factory } from "./factories/InteropX__factory";
|
package/src/types.ts
CHANGED
@@ -0,0 +1,22 @@
|
|
1
|
+
/**
|
2
|
+
* Call an async function with a maximum time limit (in milliseconds) for the timeout
|
3
|
+
* Resolved promise for async function call, or an error if time limit reached
|
4
|
+
*/
|
5
|
+
export const asyncCallWithTimeout = async <T>(
|
6
|
+
asyncPromise: Promise<T>,
|
7
|
+
timeout: number
|
8
|
+
) => {
|
9
|
+
let timeoutHandle;
|
10
|
+
|
11
|
+
const timeoutPromise = new Promise((_resolve, reject) => {
|
12
|
+
timeoutHandle = setTimeout(
|
13
|
+
() => reject(new Error("Async call timeout limit reached")),
|
14
|
+
timeout
|
15
|
+
);
|
16
|
+
});
|
17
|
+
|
18
|
+
return Promise.race([asyncPromise, timeoutPromise]).then((result) => {
|
19
|
+
clearTimeout(timeoutHandle);
|
20
|
+
return result;
|
21
|
+
}) as Promise<T>;
|
22
|
+
};
|
package/src/utils/dsa.ts
ADDED
@@ -0,0 +1,30 @@
|
|
1
|
+
import Web3EthAbi from "web3-eth-abi";
|
2
|
+
import { connectors } from "@/abi/connectors";
|
3
|
+
|
4
|
+
export const encodeConnectorMethod = (params: {
|
5
|
+
connector: string;
|
6
|
+
method: string;
|
7
|
+
args: string[];
|
8
|
+
}) => {
|
9
|
+
const connectorInterface = getInterface(
|
10
|
+
connectors.versions[2][params.connector],
|
11
|
+
params.method
|
12
|
+
);
|
13
|
+
|
14
|
+
if (!connectorInterface)
|
15
|
+
throw new Error(`ConnectorInterface '${params.method}' not found`);
|
16
|
+
|
17
|
+
//@ts-ignore
|
18
|
+
return Web3EthAbi.encodeFunctionCall(connectorInterface, params.args);
|
19
|
+
};
|
20
|
+
|
21
|
+
const getInterface = (abiItems: any[], method: string) => {
|
22
|
+
const abiItem = abiItems.find((abiItem) => abiItem.name === method);
|
23
|
+
|
24
|
+
if (!abiItem) {
|
25
|
+
console.error(`${method} is an invalid method.`);
|
26
|
+
return;
|
27
|
+
}
|
28
|
+
|
29
|
+
return abiItem;
|
30
|
+
};
|
@@ -0,0 +1,68 @@
|
|
1
|
+
const locale = "en-US";
|
2
|
+
|
3
|
+
export function formatUsd(value: any, fractionDigits = 0) {
|
4
|
+
const formatter = new Intl.NumberFormat(locale, {
|
5
|
+
style: "currency",
|
6
|
+
currency: "USD",
|
7
|
+
minimumFractionDigits: fractionDigits,
|
8
|
+
maximumFractionDigits: fractionDigits
|
9
|
+
});
|
10
|
+
|
11
|
+
return formatter.format(value);
|
12
|
+
}
|
13
|
+
|
14
|
+
export function shortenHash(hash: string, length: number = 4) {
|
15
|
+
if (!hash) return;
|
16
|
+
|
17
|
+
if (hash.length < 12) return hash;
|
18
|
+
|
19
|
+
const beginningChars = hash.startsWith("0x") ? length + 2 : length;
|
20
|
+
|
21
|
+
const shortened = hash.substr(0, beginningChars) + "…" + hash.substr(-length);
|
22
|
+
|
23
|
+
return shortened;
|
24
|
+
}
|
25
|
+
|
26
|
+
export function short(buffer: Buffer): string {
|
27
|
+
return buffer.toString("hex").slice(0, 8) + "...";
|
28
|
+
}
|
29
|
+
|
30
|
+
export const chainIdToName = (chainId: string | number) => {
|
31
|
+
switch (String(chainId)) {
|
32
|
+
case "1":
|
33
|
+
return "Mainnet";
|
34
|
+
case "137":
|
35
|
+
return "Polygon";
|
36
|
+
case "43114":
|
37
|
+
return "Avalanche";
|
38
|
+
default:
|
39
|
+
return "Mainnet";
|
40
|
+
}
|
41
|
+
};
|
42
|
+
|
43
|
+
export const getChainIdNativeSymbol = (chainId: string | number) => {
|
44
|
+
switch (String(chainId)) {
|
45
|
+
case "137":
|
46
|
+
return "MATIC";
|
47
|
+
case "43114":
|
48
|
+
return "AVAX";
|
49
|
+
case "1":
|
50
|
+
return "ETH";
|
51
|
+
default:
|
52
|
+
return "ETH";
|
53
|
+
}
|
54
|
+
};
|
55
|
+
|
56
|
+
|
57
|
+
export const getExplorerUrl = (chainId: string | number, suffix = '/') => {
|
58
|
+
switch (String(chainId)) {
|
59
|
+
case "1":
|
60
|
+
return `https://etherscan.io${suffix}`;
|
61
|
+
case "137":
|
62
|
+
return `https://polygonscan.com${suffix}`;
|
63
|
+
case "43114":
|
64
|
+
return `https://snowtrace.io${suffix}`;
|
65
|
+
default:
|
66
|
+
return `https://etherscan.io${suffix}`;
|
67
|
+
}
|
68
|
+
}
|
@@ -0,0 +1,123 @@
|
|
1
|
+
import { addresses } from "@/constants";
|
2
|
+
import { GnosisSafe } from "@/typechain";
|
3
|
+
import { ChainId } from "@/types";
|
4
|
+
import { ethers, Wallet } from "ethers";
|
5
|
+
|
6
|
+
export interface Signature {
|
7
|
+
signer: string;
|
8
|
+
hash?: string;
|
9
|
+
data: string;
|
10
|
+
}
|
11
|
+
|
12
|
+
export const buildSignatureBytes = (signatures: Signature[]): string => {
|
13
|
+
signatures.sort((left, right) =>
|
14
|
+
left.signer.toLowerCase().localeCompare(right.signer.toLowerCase())
|
15
|
+
);
|
16
|
+
let signatureBytes = "0x";
|
17
|
+
for (const sig of signatures) {
|
18
|
+
signatureBytes += sig.data.slice(2);
|
19
|
+
}
|
20
|
+
return signatureBytes;
|
21
|
+
};
|
22
|
+
|
23
|
+
export const signGnosisSafeTx = async (
|
24
|
+
{
|
25
|
+
to,
|
26
|
+
data = null as any,
|
27
|
+
value = "0",
|
28
|
+
operation = "1",
|
29
|
+
baseGas = "0",
|
30
|
+
gasPrice = "0",
|
31
|
+
gasToken = "0x0000000000000000000000000000000000000000",
|
32
|
+
refundReceiver = "0x0000000000000000000000000000000000000000",
|
33
|
+
safeTxGas = "79668" as string | number,
|
34
|
+
nonce = "0",
|
35
|
+
chainId = 137 as ChainId,
|
36
|
+
},
|
37
|
+
{ signer }: { signer: Wallet }
|
38
|
+
) => {
|
39
|
+
const gnosisSafe = addresses[chainId].gnosisSafe;
|
40
|
+
|
41
|
+
const domain = {
|
42
|
+
verifyingContract: gnosisSafe,
|
43
|
+
chainId,
|
44
|
+
};
|
45
|
+
|
46
|
+
const types = {
|
47
|
+
SafeTx: [
|
48
|
+
{ type: "address", name: "to" },
|
49
|
+
{ type: "uint256", name: "value" },
|
50
|
+
{ type: "bytes", name: "data" },
|
51
|
+
{ type: "uint8", name: "operation" },
|
52
|
+
{ type: "uint256", name: "safeTxGas" },
|
53
|
+
{ type: "uint256", name: "baseGas" },
|
54
|
+
{ type: "uint256", name: "gasPrice" },
|
55
|
+
{ type: "address", name: "gasToken" },
|
56
|
+
{ type: "address", name: "refundReceiver" },
|
57
|
+
{ type: "uint256", name: "nonce" },
|
58
|
+
],
|
59
|
+
};
|
60
|
+
|
61
|
+
const message = {
|
62
|
+
baseGas,
|
63
|
+
data,
|
64
|
+
gasPrice,
|
65
|
+
gasToken,
|
66
|
+
nonce: Number(nonce),
|
67
|
+
operation,
|
68
|
+
refundReceiver,
|
69
|
+
safeAddress: gnosisSafe,
|
70
|
+
safeTxGas: String(safeTxGas),
|
71
|
+
to,
|
72
|
+
value,
|
73
|
+
};
|
74
|
+
|
75
|
+
return await signer._signTypedData(domain, types, message);
|
76
|
+
};
|
77
|
+
|
78
|
+
export const generateGnosisTransaction = async (
|
79
|
+
transactionData: any,
|
80
|
+
safeContract: GnosisSafe
|
81
|
+
) => {
|
82
|
+
console.log(transactionData);
|
83
|
+
|
84
|
+
let isExecuted = await safeContract.dataHashes(
|
85
|
+
await safeContract.getTransactionHash(
|
86
|
+
transactionData.to,
|
87
|
+
transactionData.value,
|
88
|
+
transactionData.data,
|
89
|
+
transactionData.operation,
|
90
|
+
transactionData.safeTxGas,
|
91
|
+
transactionData.baseGas,
|
92
|
+
transactionData.gasPrice,
|
93
|
+
transactionData.gasToken,
|
94
|
+
transactionData.refundReceiver,
|
95
|
+
transactionData.nonce
|
96
|
+
)
|
97
|
+
);
|
98
|
+
|
99
|
+
while (isExecuted == 1) {
|
100
|
+
transactionData.safeTxGas = ethers.BigNumber.from(
|
101
|
+
String(transactionData.safeTxGas)
|
102
|
+
)
|
103
|
+
.add(1)
|
104
|
+
.toString();
|
105
|
+
|
106
|
+
isExecuted = await safeContract.dataHashes(
|
107
|
+
await safeContract.getTransactionHash(
|
108
|
+
transactionData.to,
|
109
|
+
transactionData.value,
|
110
|
+
transactionData.data,
|
111
|
+
transactionData.operation,
|
112
|
+
transactionData.safeTxGas,
|
113
|
+
transactionData.baseGas,
|
114
|
+
transactionData.gasPrice,
|
115
|
+
transactionData.gasToken,
|
116
|
+
transactionData.refundReceiver,
|
117
|
+
transactionData.nonce
|
118
|
+
)
|
119
|
+
);
|
120
|
+
}
|
121
|
+
|
122
|
+
return transactionData;
|
123
|
+
};
|
package/src/utils/index.ts
CHANGED
@@ -1,116 +1,9 @@
|
|
1
|
-
|
2
|
-
*
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
export
|
10
|
-
|
11
|
-
axiosRetry(http, { retries: 3, retryDelay: axiosRetry.exponentialDelay });
|
12
|
-
|
13
|
-
|
14
|
-
export function short(buffer: Buffer): string {
|
15
|
-
return buffer.toString('hex').slice(0, 8) + '...'
|
16
|
-
}
|
17
|
-
|
18
|
-
export const signGnosisSafeTx = async ({
|
19
|
-
to,
|
20
|
-
data = null as any,
|
21
|
-
value = '0',
|
22
|
-
operation = '1',
|
23
|
-
baseGas = '0',
|
24
|
-
gasPrice = "0",
|
25
|
-
gasToken = "0x0000000000000000000000000000000000000000",
|
26
|
-
refundReceiver = "0x0000000000000000000000000000000000000000",
|
27
|
-
safeTxGas = "79668" as string | number,
|
28
|
-
nonce = "0",
|
29
|
-
chainId = 137 as ChainId,
|
30
|
-
}, { signer }) => {
|
31
|
-
const gnosisSafe = addresses[chainId].gnosisSafe;
|
32
|
-
|
33
|
-
const domain = {
|
34
|
-
verifyingContract: gnosisSafe,
|
35
|
-
chainId,
|
36
|
-
};
|
37
|
-
|
38
|
-
const types = {
|
39
|
-
SafeTx: [
|
40
|
-
{ type: 'address', name: 'to' },
|
41
|
-
{ type: 'uint256', name: 'value' },
|
42
|
-
{ type: 'bytes', name: 'data' },
|
43
|
-
{ type: 'uint8', name: 'operation' },
|
44
|
-
{ type: 'uint256', name: 'safeTxGas' },
|
45
|
-
{ type: 'uint256', name: 'baseGas' },
|
46
|
-
{ type: 'uint256', name: 'gasPrice' },
|
47
|
-
{ type: 'address', name: 'gasToken' },
|
48
|
-
{ type: 'address', name: 'refundReceiver' },
|
49
|
-
{ type: 'uint256', name: 'nonce' },
|
50
|
-
],
|
51
|
-
};
|
52
|
-
|
53
|
-
const message = {
|
54
|
-
baseGas,
|
55
|
-
data,
|
56
|
-
gasPrice,
|
57
|
-
gasToken,
|
58
|
-
nonce: Number(nonce),
|
59
|
-
operation,
|
60
|
-
refundReceiver,
|
61
|
-
safeAddress: gnosisSafe,
|
62
|
-
safeTxGas: String(safeTxGas),
|
63
|
-
to,
|
64
|
-
value,
|
65
|
-
};
|
66
|
-
|
67
|
-
return await signer._signTypedData(domain, types, message)
|
68
|
-
};
|
69
|
-
|
70
|
-
export const getRpcProviderUrl = (chainId: ChainId) => {
|
71
|
-
switch (chainId) {
|
72
|
-
case 1:
|
73
|
-
return 'https://rpc.instadapp.io/mainnet';
|
74
|
-
case 137:
|
75
|
-
return 'https://rpc.instadapp.io/polygon';
|
76
|
-
default:
|
77
|
-
throw new Error(`Unknown chainId: ${chainId}`);
|
78
|
-
}
|
79
|
-
}
|
80
|
-
|
81
|
-
export interface Signature {
|
82
|
-
signer: string;
|
83
|
-
hash?: string;
|
84
|
-
data: string;
|
85
|
-
}
|
86
|
-
|
87
|
-
export const buildSignatureBytes = (signatures: Signature[]): string => {
|
88
|
-
signatures.sort((left, right) =>
|
89
|
-
left.signer.toLowerCase().localeCompare(right.signer.toLowerCase())
|
90
|
-
);
|
91
|
-
let signatureBytes = "0x";
|
92
|
-
for (const sig of signatures) {
|
93
|
-
signatureBytes += sig.data.slice(2);
|
94
|
-
}
|
95
|
-
return signatureBytes;
|
96
|
-
};
|
97
|
-
|
98
|
-
/**
|
99
|
-
* Call an async function with a maximum time limit (in milliseconds) for the timeout
|
100
|
-
* Resolved promise for async function call, or an error if time limit reached
|
101
|
-
*/
|
102
|
-
export const asyncCallWithTimeout = async <T>(asyncPromise: Promise<T>, timeout: number) => {
|
103
|
-
let timeoutHandle;
|
104
|
-
|
105
|
-
const timeoutPromise = new Promise((_resolve, reject) => {
|
106
|
-
timeoutHandle = setTimeout(
|
107
|
-
() => reject(new Error('Async call timeout limit reached')),
|
108
|
-
timeout
|
109
|
-
);
|
110
|
-
});
|
111
|
-
|
112
|
-
return Promise.race([asyncPromise, timeoutPromise]).then(result => {
|
113
|
-
clearTimeout(timeoutHandle);
|
114
|
-
return result;
|
115
|
-
}) as Promise<T>
|
116
|
-
}
|
1
|
+
export * from './async';
|
2
|
+
export * from './dsa';
|
3
|
+
export * from './formatting';
|
4
|
+
export * from './gnosis';
|
5
|
+
export * from './http';
|
6
|
+
export * from './interop';
|
7
|
+
export * from './web3';
|
8
|
+
export * from './validate';
|
9
|
+
export * from './tokens';
|
@@ -0,0 +1,28 @@
|
|
1
|
+
import { ethers } from "ethers";
|
2
|
+
|
3
|
+
type GenerateInteropTransactionHashParam = {
|
4
|
+
actionId: string;
|
5
|
+
vnonce: string;
|
6
|
+
sourceSender: string;
|
7
|
+
sourceChainId: string | number;
|
8
|
+
sourceDsaId: string;
|
9
|
+
targetChainId: string | number;
|
10
|
+
targetDsaId: string;
|
11
|
+
};
|
12
|
+
|
13
|
+
export const generateInteropTransactionHash = (
|
14
|
+
data: GenerateInteropTransactionHashParam
|
15
|
+
) => {
|
16
|
+
return ethers.utils.solidityKeccak256(
|
17
|
+
Array.from({ length: 7 }, () => "string"),
|
18
|
+
[
|
19
|
+
String(data.actionId),
|
20
|
+
String(data.vnonce),
|
21
|
+
String(data.sourceSender),
|
22
|
+
String(data.sourceChainId),
|
23
|
+
String(data.sourceDsaId),
|
24
|
+
String(data.targetChainId),
|
25
|
+
String(data.targetDsaId),
|
26
|
+
]
|
27
|
+
);
|
28
|
+
};
|
@@ -0,0 +1,21 @@
|
|
1
|
+
import { wrappedNativeToken } from "@/constants"
|
2
|
+
|
3
|
+
export const isNativeToken = (tokenAddress: string) => {
|
4
|
+
return tokenAddress.toLowerCase() === "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE".toLowerCase()
|
5
|
+
}
|
6
|
+
|
7
|
+
export const isNativeWrappedToken = (tokenAddress: string, chainId: number | string) => {
|
8
|
+
return wrappedNativeToken[chainId].toLowerCase() == tokenAddress.toLowerCase()
|
9
|
+
}
|
10
|
+
|
11
|
+
export const isNativeOrWrappedToken = (tokenAddress: string, chainId: number | string) => {
|
12
|
+
if (isNativeToken(tokenAddress)) {
|
13
|
+
return true
|
14
|
+
}
|
15
|
+
|
16
|
+
if (isNativeWrappedToken(tokenAddress, chainId)) {
|
17
|
+
return true
|
18
|
+
}
|
19
|
+
|
20
|
+
return false
|
21
|
+
}
|
@@ -0,0 +1,173 @@
|
|
1
|
+
import abi from "@/abi";
|
2
|
+
import { addresses, capPerChain, tokens } from "@/constants";
|
3
|
+
import { InvalidChaindIdError, LowLiquidityError } from "@/errors";
|
4
|
+
import { ethers } from "ethers";
|
5
|
+
import { getContract, getRpcProviderUrl } from "./web3";
|
6
|
+
import BigNumber from "bignumber.js";
|
7
|
+
import { chainIdToName, formatUsd } from "./formatting";
|
8
|
+
import { isNativeWrappedToken } from "./tokens";
|
9
|
+
import { Prices } from "@/services";
|
10
|
+
|
11
|
+
export const validateChains = ({ sourceChainId, targetChainId }) => {
|
12
|
+
if (!sourceChainId) {
|
13
|
+
throw new InvalidChaindIdError("Source chain id is required");
|
14
|
+
}
|
15
|
+
|
16
|
+
if (!targetChainId) {
|
17
|
+
throw new InvalidChaindIdError("Target chain id is required");
|
18
|
+
}
|
19
|
+
|
20
|
+
if (sourceChainId == targetChainId) {
|
21
|
+
throw new InvalidChaindIdError("Source and target chain cannot be the same");
|
22
|
+
}
|
23
|
+
|
24
|
+
if (!addresses[sourceChainId]) {
|
25
|
+
throw new InvalidChaindIdError("Invalid source chain id");
|
26
|
+
}
|
27
|
+
|
28
|
+
if (!addresses[targetChainId]) {
|
29
|
+
throw new InvalidChaindIdError("Invalid target chain id");
|
30
|
+
}
|
31
|
+
};
|
32
|
+
|
33
|
+
|
34
|
+
export const validateSourceLiquidity = async ({
|
35
|
+
position,
|
36
|
+
sourceChainId,
|
37
|
+
isSupply = false,
|
38
|
+
sourceProvider = null as unknown as ethers.providers.JsonRpcProvider,
|
39
|
+
}) => {
|
40
|
+
sourceProvider = sourceProvider || new ethers.providers.JsonRpcProvider(getRpcProviderUrl(sourceChainId));
|
41
|
+
|
42
|
+
|
43
|
+
const sourceBalanceResolverContract = getContract(
|
44
|
+
addresses[sourceChainId].balanceResolver,
|
45
|
+
abi.balanceResolver,
|
46
|
+
sourceProvider,
|
47
|
+
)
|
48
|
+
|
49
|
+
const srcBalance = await sourceBalanceResolverContract.methods
|
50
|
+
.checkLiquidity(position, addresses[sourceChainId].interopX, isSupply, false)
|
51
|
+
.call();
|
52
|
+
|
53
|
+
if (!srcBalance.isOk) {
|
54
|
+
|
55
|
+
let liquidityRequired = ""
|
56
|
+
|
57
|
+
srcBalance.withdraw.forEach(a => {
|
58
|
+
const token = tokens[sourceChainId].find(t => t.address.toLowerCase() === a.token.toLowerCase());
|
59
|
+
|
60
|
+
if (token && (new BigNumber(a.liquidityShort).isZero()) == false) {
|
61
|
+
liquidityRequired += `- Need ${new BigNumber(a.liquidityShort).dividedBy(10 ** token.decimals).toFormat()} ${token.symbol}\n`
|
62
|
+
}
|
63
|
+
})
|
64
|
+
|
65
|
+
throw new LowLiquidityError(`Liquidity low on ${chainIdToName(sourceChainId)}: \n` + liquidityRequired);
|
66
|
+
}
|
67
|
+
};
|
68
|
+
|
69
|
+
export const validateTargetLiquidity = async ({
|
70
|
+
position,
|
71
|
+
targetChainId,
|
72
|
+
targetProvider = null as unknown as ethers.providers.JsonRpcProvider,
|
73
|
+
}) => {
|
74
|
+
targetProvider = targetProvider || new ethers.providers.JsonRpcProvider(getRpcProviderUrl(targetChainId));
|
75
|
+
|
76
|
+
|
77
|
+
const sourceBalanceResolverContract = getContract(
|
78
|
+
addresses[targetChainId].balanceResolver,
|
79
|
+
abi.balanceResolver,
|
80
|
+
targetProvider,
|
81
|
+
)
|
82
|
+
|
83
|
+
const targetBalance = await sourceBalanceResolverContract.methods
|
84
|
+
.checkLiquidity(position, addresses[targetChainId].interopX, true, true)
|
85
|
+
.call();
|
86
|
+
|
87
|
+
if (!targetBalance.isOk) {
|
88
|
+
|
89
|
+
let liquidityRequired = ""
|
90
|
+
|
91
|
+
targetBalance.supply.forEach(a => {
|
92
|
+
const token = tokens[targetChainId].find(t => t.address.toLowerCase() === a.token.toLowerCase());
|
93
|
+
|
94
|
+
|
95
|
+
if (token) {
|
96
|
+
liquidityRequired += `- Need ${new BigNumber(a.liquidityShort).dividedBy(10 ** token.decimals).toFormat()} ${token.symbol}\n`
|
97
|
+
}
|
98
|
+
})
|
99
|
+
|
100
|
+
throw new LowLiquidityError(`Liquidity low on ${chainIdToName(targetChainId)}: \n` + liquidityRequired);
|
101
|
+
}
|
102
|
+
};
|
103
|
+
|
104
|
+
const mapTokenAddressToMainnetToken = (
|
105
|
+
address: string,
|
106
|
+
targetChainId: number|string
|
107
|
+
) => {
|
108
|
+
targetChainId = String(targetChainId);
|
109
|
+
const token = tokens[targetChainId].find(
|
110
|
+
(t) => t.address.toLowerCase() === address.toLowerCase()
|
111
|
+
);
|
112
|
+
|
113
|
+
if (targetChainId === "1") {
|
114
|
+
return token;
|
115
|
+
}
|
116
|
+
|
117
|
+
if (!token) {
|
118
|
+
return null;
|
119
|
+
}
|
120
|
+
|
121
|
+
return tokens["1"].find((t) => t.symbol === token.symbol);
|
122
|
+
};
|
123
|
+
|
124
|
+
export const validateLiquidityCap = async (
|
125
|
+
position: any,
|
126
|
+
sourceChainId: number|string,
|
127
|
+
targetChainId: number|string
|
128
|
+
) => {
|
129
|
+
const cap = capPerChain[targetChainId] || 1_000_000;
|
130
|
+
const mainnetPrices = Prices.getMainnetPrices();
|
131
|
+
const nativeTokenPrice = Prices.getNetworkTokenPrices()[targetChainId];
|
132
|
+
|
133
|
+
let total = new BigNumber(0);
|
134
|
+
|
135
|
+
const supplyPosition = position[0];
|
136
|
+
|
137
|
+
for (const [srcTokenAddress, tokenAddress, amount] of supplyPosition) {
|
138
|
+
let tokenPrice;
|
139
|
+
let token;
|
140
|
+
|
141
|
+
if (isNativeWrappedToken(srcTokenAddress, sourceChainId)) {
|
142
|
+
tokenPrice = nativeTokenPrice;
|
143
|
+
token = tokens[targetChainId].find(t => t.address === '0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE');
|
144
|
+
} else {
|
145
|
+
const mainnetToken = mapTokenAddressToMainnetToken(
|
146
|
+
tokenAddress,
|
147
|
+
targetChainId
|
148
|
+
);
|
149
|
+
if (!mainnetToken) {
|
150
|
+
throw new Error(`Token ${tokenAddress} is not valid.`);
|
151
|
+
}
|
152
|
+
|
153
|
+
tokenPrice = mainnetPrices[mainnetToken.address];
|
154
|
+
|
155
|
+
if (!tokenPrice) {
|
156
|
+
throw new Error(`Token ${tokenAddress} is not valid!`);
|
157
|
+
}
|
158
|
+
|
159
|
+
token = mainnetToken;
|
160
|
+
}
|
161
|
+
|
162
|
+
|
163
|
+
total = total.plus((tokenPrice * amount) / 10 ** token.decimals);
|
164
|
+
}
|
165
|
+
|
166
|
+
if (total.isGreaterThan(cap)) {
|
167
|
+
throw new Error(
|
168
|
+
`Total amount of tokens in the transaction is greater than the maximum limit of estimated ${formatUsd(
|
169
|
+
cap
|
170
|
+
)}`
|
171
|
+
);
|
172
|
+
}
|
173
|
+
};
|