@gearbox-protocol/sdk 3.0.0-next.5 → 3.0.0-next.50
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/contracts/IAirdropDistributor.sol +55 -0
- package/contracts/IDegenDistributor.sol +28 -0
- package/contracts/IOffchainOracle.sol +17 -0
- package/contracts/IWETHGateway.sol +33 -0
- package/contracts/IwstETHGateway.sol +24 -0
- package/contracts/index.sol +11 -3
- package/lib/apy/curveAPY.js +2 -1
- package/lib/apy/index.d.ts +2 -2
- package/lib/apy/yearnAPY.js +1 -1
- package/lib/config.d.ts +0 -1
- package/lib/config.js +1 -2
- package/lib/core/assets.d.ts +4 -4
- package/lib/core/assets.js +28 -17
- package/lib/core/creditAccount.d.ts +31 -6
- package/lib/core/creditAccount.js +101 -37
- package/lib/core/creditAccount.spec.js +693 -10
- package/lib/core/creditManager.d.ts +22 -8
- package/lib/core/creditManager.js +86 -30
- package/lib/core/events.js +14 -14
- package/lib/core/gauge.d.ts +26 -0
- package/lib/core/gauge.js +63 -0
- package/lib/core/gaugeMath.d.ts +40 -0
- package/lib/core/gaugeMath.js +108 -0
- package/lib/core/gaugeMath.spec.d.ts +1 -0
- package/lib/core/gaugeMath.spec.js +388 -0
- package/lib/core/{pool/data.d.ts → pool.d.ts} +18 -10
- package/lib/core/{pool/data.js → pool.js} +69 -24
- package/lib/core/strategy.js +2 -2
- package/lib/core/trade.d.ts +5 -23
- package/lib/core/trade.js +4 -61
- package/lib/core/transactions.d.ts +50 -3
- package/lib/core/transactions.js +136 -105
- package/lib/index.d.ts +3 -0
- package/lib/index.js +3 -0
- package/lib/parsers/abstractParser.js +1 -2
- package/lib/parsers/creditFacadeParser.d.ts +2 -1
- package/lib/parsers/creditFacadeParser.js +17 -5
- package/lib/parsers/creditFacadeParser.spec.js +2 -3
- package/lib/parsers/curveAdapterParser.js +2 -3
- package/lib/parsers/txParser.d.ts +4 -4
- package/lib/parsers/txParser.js +9 -3
- package/lib/parsers/uniV2AdapterParser.js +2 -2
- package/lib/parsers/uniV3AdapterParser.js +3 -3
- package/lib/pathfinder/core.d.ts +4 -4
- package/lib/pathfinder/pathOptions.d.ts +2 -1
- package/lib/pathfinder/pathOptions.js +20 -1
- package/lib/pathfinder/pathOptions.spec.js +2 -2
- package/lib/pathfinder/pathfinder.js +4 -3
- package/lib/pathfinder/pathfinder.spec.js +3 -1
- package/lib/payload/creditAccount.d.ts +2 -2
- package/lib/payload/gauge.d.ts +12 -0
- package/lib/payload/pool.d.ts +6 -1
- package/lib/types/IAirdropDistributor.sol/IAirdropDistributor.d.ts +124 -0
- package/lib/types/IAirdropDistributor.sol/IAirdropDistributorEvents.d.ts +73 -0
- package/lib/types/IAirdropDistributor.sol/index.d.ts +2 -0
- package/lib/types/IConvexToken.d.ts +9 -1
- package/lib/types/IConvexV1BaseRewardPoolAdapter.d.ts +17 -1
- package/lib/types/{IConvexV1BoosterAdapter.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter.d.ts} +19 -4
- package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents.d.ts +43 -0
- package/lib/types/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
- package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3.d.ts +716 -0
- package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events.d.ts +275 -0
- package/lib/types/ICreditConfiguratorV3.sol/index.d.ts +2 -0
- package/lib/types/ICreditFacadeV2.sol/ICreditFacadeV2Extended.d.ts +7 -11
- package/lib/types/ICreditFacadeV3.sol/ICreditFacadeV3.d.ts +165 -20
- package/lib/types/ICreditFacadeV3.sol/ICreditFacadeV3Events.d.ts +5 -7
- package/lib/types/ICreditFacadeV3Multicall.d.ts +35 -12
- package/lib/types/ICreditManagerV3.sol/ICreditManagerV3.d.ts +273 -39
- package/lib/types/IDataCompressorV2_10.d.ts +43 -9
- package/lib/types/IDataCompressorV3_00.d.ts +140 -10
- package/lib/types/IDegenDistributor.sol/IDegenDistributor.d.ts +96 -0
- package/lib/types/IDegenDistributor.sol/IDegenDistributorEvents.d.ts +53 -0
- package/lib/types/IDegenDistributor.sol/index.d.ts +2 -0
- package/lib/types/{draft-IERC20Permit.sol/IERC20Permit.d.ts → IERC20Permit.d.ts} +1 -1
- package/lib/types/IERC20ZapperDeposits.d.ts +117 -0
- package/lib/types/IETHZapperDeposits.d.ts +66 -0
- package/lib/types/IGasPricer.d.ts +44 -0
- package/lib/types/IGearStakingV3.sol/IGearStakingV3.d.ts +408 -0
- package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.d.ts +117 -0
- package/lib/types/IGearStakingV3.sol/index.d.ts +2 -0
- package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.d.ts → ILidoV1Adapter.d.ts} +5 -40
- package/lib/types/ILidoV1Adapter.js +2 -0
- package/lib/types/IOffchainOracle.d.ts +58 -0
- package/lib/types/IOffchainOracle.js +2 -0
- package/lib/types/IPoolV3.sol/IPoolV3.d.ts +43 -11
- package/lib/types/IPoolV3.sol/index.d.ts +0 -1
- package/lib/types/IWETHGateway.d.ts +90 -0
- package/lib/types/IWETHGateway.js +2 -0
- package/lib/types/IZapper.d.ts +130 -0
- package/lib/types/IZapper.js +2 -0
- package/lib/types/IwstETHGateway.sol/IwstETHGateWay.d.ts +70 -0
- package/lib/types/IwstETHGateway.sol/IwstETHGateWay.js +2 -0
- package/lib/types/IwstETHGateway.sol/index.d.ts +1 -0
- package/lib/types/IwstETHGateway.sol/index.js +2 -0
- package/lib/types/factories/AddressProvider__factory.d.ts +1 -1
- package/lib/types/factories/AddressProvider__factory.js +1 -1
- package/lib/types/factories/Balances.sol/BalanceOps__factory.d.ts +1 -1
- package/lib/types/factories/Balances.sol/BalanceOps__factory.js +1 -1
- package/lib/types/factories/Claimable__factory.d.ts +1 -1
- package/lib/types/factories/Claimable__factory.js +1 -1
- package/lib/types/factories/Errors__factory.d.ts +1 -1
- package/lib/types/factories/Errors__factory.js +1 -1
- package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributorEvents__factory.d.ts +63 -0
- package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributorEvents__factory.js +88 -0
- package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributor__factory.d.ts +119 -0
- package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributor__factory.js +161 -0
- package/lib/types/factories/IAirdropDistributor.sol/index.d.ts +2 -0
- package/lib/types/factories/IAirdropDistributor.sol/index.js +10 -0
- package/lib/types/factories/IConvexToken__factory.d.ts +10 -0
- package/lib/types/factories/IConvexToken__factory.js +13 -0
- package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.d.ts +20 -0
- package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.js +26 -0
- package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.d.ts +23 -0
- package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.js +38 -0
- package/lib/types/factories/{IConvexV1BoosterAdapter__factory.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.d.ts} +16 -1
- package/lib/types/factories/{IConvexV1BoosterAdapter__factory.js → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.js} +19 -0
- package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
- package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.js +10 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.d.ts +273 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.js +357 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.d.ts +605 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.js +785 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/index.d.ts +2 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/index.js +10 -0
- package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.d.ts +0 -4
- package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.js +0 -5
- package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.d.ts +1 -6
- package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.js +1 -7
- package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.d.ts +144 -13
- package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.js +185 -15
- package/lib/types/factories/ICreditFacadeV3Multicall__factory.d.ts +35 -5
- package/lib/types/factories/ICreditFacadeV3Multicall__factory.js +43 -5
- package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.d.ts +199 -25
- package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.js +252 -28
- package/lib/types/factories/IDataCompressorV2_10__factory.d.ts +110 -12
- package/lib/types/factories/IDataCompressorV2_10__factory.js +138 -14
- package/lib/types/factories/IDataCompressorV3_00__factory.d.ts +400 -16
- package/lib/types/factories/IDataCompressorV3_00__factory.js +508 -19
- package/lib/types/factories/IDegenDistributor.sol/IDegenDistributorEvents__factory.d.ts +38 -0
- package/lib/types/factories/{AaveV2_WrappedAToken.sol/IWrappedATokenEvents__factory.js → IDegenDistributor.sol/IDegenDistributorEvents__factory.js} +13 -25
- package/lib/types/factories/IDegenDistributor.sol/IDegenDistributor__factory.d.ts +84 -0
- package/lib/types/factories/{IPoolV3.sol/IPoolBase__factory.js → IDegenDistributor.sol/IDegenDistributor__factory.js} +46 -41
- package/lib/types/factories/IDegenDistributor.sol/index.d.ts +2 -0
- package/lib/types/factories/IDegenDistributor.sol/index.js +10 -0
- package/lib/types/factories/{draft-IERC20Permit.sol/IERC20Permit__factory.d.ts → IERC20Permit__factory.d.ts} +1 -1
- package/lib/types/factories/IERC20ZapperDeposits__factory.d.ts +120 -0
- package/lib/types/factories/IERC20ZapperDeposits__factory.js +165 -0
- package/lib/types/factories/IETHZapperDeposits__factory.d.ts +40 -0
- package/lib/types/factories/IETHZapperDeposits__factory.js +62 -0
- package/lib/types/factories/IGasPricer__factory.d.ts +22 -0
- package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.js → IGasPricer__factory.js} +14 -8
- package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3Events__factory.d.ts +113 -0
- package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3Events__factory.js +152 -0
- package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.d.ts +504 -0
- package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.js +660 -0
- package/lib/types/factories/IGearStakingV3.sol/index.d.ts +2 -0
- package/lib/types/factories/IGearStakingV3.sol/index.js +10 -0
- package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.d.ts → ILidoV1Adapter__factory.d.ts} +1 -35
- package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.js → ILidoV1Adapter__factory.js} +0 -44
- package/lib/types/factories/IOffchainOracle__factory.d.ts +48 -0
- package/lib/types/factories/IOffchainOracle__factory.js +72 -0
- package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.d.ts +62 -14
- package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.js +79 -17
- package/lib/types/factories/IPoolV3.sol/index.d.ts +0 -1
- package/lib/types/factories/IPoolV3.sol/index.js +1 -3
- package/lib/types/factories/IWETHGateway__factory.d.ts +58 -0
- package/lib/types/factories/IWETHGateway__factory.js +83 -0
- package/lib/types/factories/{WERC20ZapperBase__factory.d.ts → IZapper__factory.d.ts} +57 -61
- package/lib/types/factories/{WERC20ZapperBase__factory.js → IZapper__factory.js} +65 -71
- package/lib/types/factories/{ZapperBase__factory.d.ts → IwstETHGateway.sol/IwstETHGateWay__factory.d.ts} +22 -34
- package/lib/types/factories/{ZapperBase__factory.js → IwstETHGateway.sol/IwstETHGateWay__factory.js} +22 -39
- package/lib/types/factories/IwstETHGateway.sol/index.d.ts +1 -0
- package/lib/types/factories/IwstETHGateway.sol/index.js +8 -0
- package/lib/types/factories/SafeERC20__factory.d.ts +1 -1
- package/lib/types/factories/SafeERC20__factory.js +1 -1
- package/lib/types/factories/index.d.ts +15 -13
- package/lib/types/factories/index.js +25 -25
- package/lib/types/factories/{IRouter__factory.d.ts → interfaces/IRouter__factory.d.ts} +15 -1
- package/lib/types/factories/{IRouter__factory.js → interfaces/IRouter__factory.js} +19 -0
- package/lib/types/factories/interfaces/index.d.ts +1 -0
- package/lib/types/factories/interfaces/index.js +8 -0
- package/lib/types/index.d.ts +62 -48
- package/lib/types/index.js +52 -46
- package/lib/types/{IRouter.d.ts → interfaces/IRouter.d.ts} +12 -2
- package/lib/types/interfaces/IRouter.js +2 -0
- package/lib/types/interfaces/index.d.ts +1 -0
- package/lib/types/interfaces/index.js +2 -0
- package/lib/utils/formatter.d.ts +0 -3
- package/lib/utils/formatter.js +1 -67
- package/lib/utils/math.d.ts +2 -0
- package/lib/utils/math.js +2 -0
- package/lib/utils/types.d.ts +1 -0
- package/lib/watchers/creditAccountWatcher.d.ts +3 -2
- package/lib/watchers/creditAccountWatcher.js +19 -13
- package/lib/watchers/creditAccountWatcher.spec.js +18 -18
- package/lib/watchers/creditManagerWatcher.d.ts +5 -3
- package/lib/watchers/creditManagerWatcher.js +32 -10
- package/lib/watchers/creditManagerWatcher.spec.js +12 -4
- package/package.json +10 -9
- package/contracts/IRouter.sol +0 -100
- package/lib/core/pool/index.d.ts +0 -1
- package/lib/core/pool/index.js +0 -17
- package/lib/types/AaveV2_WrappedAToken.sol/IWrappedATokenEvents.d.ts +0 -60
- package/lib/types/AaveV2_WrappedAToken.sol/WrappedAToken.d.ts +0 -332
- package/lib/types/AaveV2_WrappedAToken.sol/index.d.ts +0 -2
- package/lib/types/ERC20.d.ts +0 -198
- package/lib/types/IAToken.d.ts +0 -182
- package/lib/types/ILendingPool.d.ts +0 -140
- package/lib/types/ILidoV1Adapter.sol/ILidoV1AdapterEvents.d.ts +0 -39
- package/lib/types/ILidoV1Adapter.sol/ILidoV1AdapterExceptions.d.ts +0 -27
- package/lib/types/ILidoV1Adapter.sol/index.d.ts +0 -3
- package/lib/types/IPoolV3.sol/IPoolBase.d.ts +0 -102
- package/lib/types/WATokenZapper.d.ts +0 -134
- package/lib/types/WERC20ZapperBase.d.ts +0 -134
- package/lib/types/WETHZapper.d.ts +0 -122
- package/lib/types/WstETHZapper.d.ts +0 -134
- package/lib/types/ZapperBase.d.ts +0 -70
- package/lib/types/draft-IERC20Permit.sol/index.d.ts +0 -1
- package/lib/types/factories/AaveV2_WrappedAToken.sol/IWrappedATokenEvents__factory.d.ts +0 -48
- package/lib/types/factories/AaveV2_WrappedAToken.sol/WrappedAToken__factory.d.ts +0 -397
- package/lib/types/factories/AaveV2_WrappedAToken.sol/WrappedAToken__factory.js +0 -535
- package/lib/types/factories/AaveV2_WrappedAToken.sol/index.d.ts +0 -2
- package/lib/types/factories/AaveV2_WrappedAToken.sol/index.js +0 -10
- package/lib/types/factories/ERC20__factory.d.ts +0 -239
- package/lib/types/factories/ERC20__factory.js +0 -328
- package/lib/types/factories/IAToken__factory.d.ts +0 -198
- package/lib/types/factories/IAToken__factory.js +0 -267
- package/lib/types/factories/ILendingPool__factory.d.ts +0 -134
- package/lib/types/factories/ILendingPool__factory.js +0 -183
- package/lib/types/factories/ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.d.ts +0 -18
- package/lib/types/factories/ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.d.ts +0 -12
- package/lib/types/factories/ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.js +0 -24
- package/lib/types/factories/ILidoV1Adapter.sol/index.d.ts +0 -3
- package/lib/types/factories/ILidoV1Adapter.sol/index.js +0 -12
- package/lib/types/factories/IPoolV3.sol/IPoolBase__factory.d.ts +0 -80
- package/lib/types/factories/WATokenZapper__factory.d.ts +0 -161
- package/lib/types/factories/WATokenZapper__factory.js +0 -227
- package/lib/types/factories/WETHZapper__factory.d.ts +0 -138
- package/lib/types/factories/WETHZapper__factory.js +0 -198
- package/lib/types/factories/WstETHZapper__factory.d.ts +0 -161
- package/lib/types/factories/WstETHZapper__factory.js +0 -227
- package/lib/types/factories/draft-IERC20Permit.sol/index.d.ts +0 -1
- package/lib/types/factories/draft-IERC20Permit.sol/index.js +0 -8
- /package/lib/{types/AaveV2_WrappedAToken.sol/IWrappedATokenEvents.js → payload/gauge.js} +0 -0
- /package/lib/types/{AaveV2_WrappedAToken.sol/WrappedAToken.js → IAirdropDistributor.sol/IAirdropDistributor.js} +0 -0
- /package/lib/types/{AaveV2_WrappedAToken.sol/index.js → IAirdropDistributor.sol/IAirdropDistributorEvents.js} +0 -0
- /package/lib/types/{ILidoV1Adapter.sol → IAirdropDistributor.sol}/index.js +0 -0
- /package/lib/types/{IConvexV1BoosterAdapter.js → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter.js} +0 -0
- /package/lib/types/{ERC20.js → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents.js} +0 -0
- /package/lib/types/{draft-IERC20Permit.sol → IConvexV1BoosterAdapter.sol}/index.js +0 -0
- /package/lib/types/{IAToken.js → ICreditConfiguratorV3.sol/ICreditConfiguratorV3.js} +0 -0
- /package/lib/types/{ILendingPool.js → ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events.js} +0 -0
- /package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.js → ICreditConfiguratorV3.sol/index.js} +0 -0
- /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.js → IDegenDistributor.sol/IDegenDistributor.js} +0 -0
- /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.js → IDegenDistributor.sol/IDegenDistributorEvents.js} +0 -0
- /package/lib/types/{IPoolV3.sol/IPoolBase.js → IDegenDistributor.sol/index.js} +0 -0
- /package/lib/types/{draft-IERC20Permit.sol/IERC20Permit.js → IERC20Permit.js} +0 -0
- /package/lib/types/{IRouter.js → IERC20ZapperDeposits.js} +0 -0
- /package/lib/types/{WATokenZapper.js → IETHZapperDeposits.js} +0 -0
- /package/lib/types/{WERC20ZapperBase.js → IGasPricer.js} +0 -0
- /package/lib/types/{WETHZapper.js → IGearStakingV3.sol/IGearStakingV3.js} +0 -0
- /package/lib/types/{WstETHZapper.js → IGearStakingV3.sol/IGearStakingV3Events.js} +0 -0
- /package/lib/types/{ZapperBase.js → IGearStakingV3.sol/index.js} +0 -0
- /package/lib/types/factories/{draft-IERC20Permit.sol/IERC20Permit__factory.js → IERC20Permit__factory.js} +0 -0
|
@@ -55,7 +55,7 @@ const newConfiguratorLog = (managerAddr = CREDIT_MANAGER_ADDRESS, configuratorAd
|
|
|
55
55
|
]);
|
|
56
56
|
describe("CreditAccountTracker test", () => {
|
|
57
57
|
it("detects update events correctly", () => {
|
|
58
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
58
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([openLog()], [cmDumb])).to.be.eql({
|
|
59
59
|
updated: [expectedHash],
|
|
60
60
|
deleted: [],
|
|
61
61
|
});
|
|
@@ -63,7 +63,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
63
63
|
creditFacadeInterface.getEventTopic("IncreaseBorrowedAmount"),
|
|
64
64
|
encode("address", BORROWER),
|
|
65
65
|
], ethers_1.utils.defaultAbiCoder.encode(["uint256"], [10]));
|
|
66
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
66
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([log], [cmDumb])).to.be.eql({
|
|
67
67
|
updated: [expectedHash],
|
|
68
68
|
deleted: [],
|
|
69
69
|
});
|
|
@@ -71,7 +71,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
71
71
|
creditFacadeInterface.getEventTopic("DecreaseBorrowedAmount"),
|
|
72
72
|
encode("address", BORROWER),
|
|
73
73
|
], ethers_1.utils.defaultAbiCoder.encode(["uint256"], [10]));
|
|
74
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
74
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([log], [cmDumb])).to.be.eql({
|
|
75
75
|
updated: [expectedHash],
|
|
76
76
|
deleted: [],
|
|
77
77
|
});
|
|
@@ -80,7 +80,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
80
80
|
encode("address", BORROWER),
|
|
81
81
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
82
82
|
], ethers_1.utils.defaultAbiCoder.encode(["uint256"], [10]));
|
|
83
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
83
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([log], [cmDumb])).to.be.eql({
|
|
84
84
|
updated: [expectedHash],
|
|
85
85
|
deleted: [],
|
|
86
86
|
});
|
|
@@ -88,7 +88,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
88
88
|
creditFacadeInterface.getEventTopic("MultiCallStarted"),
|
|
89
89
|
encode("address", BORROWER),
|
|
90
90
|
]);
|
|
91
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
91
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([log], [cmDumb])).to.be.eql({
|
|
92
92
|
updated: [expectedHash],
|
|
93
93
|
deleted: [],
|
|
94
94
|
});
|
|
@@ -97,7 +97,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
97
97
|
encode("address", BORROWER),
|
|
98
98
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
99
99
|
]);
|
|
100
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
100
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([log], [cmDumb])).to.be.eql({
|
|
101
101
|
updated: [expectedHash],
|
|
102
102
|
deleted: [],
|
|
103
103
|
});
|
|
@@ -106,7 +106,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
106
106
|
encode("address", BORROWER),
|
|
107
107
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
108
108
|
]);
|
|
109
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
109
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([log], [cmDumb])).to.be.eql({
|
|
110
110
|
updated: [expectedHash],
|
|
111
111
|
deleted: [],
|
|
112
112
|
});
|
|
@@ -115,7 +115,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
115
115
|
encode("address", BORROWER),
|
|
116
116
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
117
117
|
]);
|
|
118
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
118
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([log], [cmDumb])).to.be.eql({
|
|
119
119
|
updated: [expectedHash],
|
|
120
120
|
deleted: [],
|
|
121
121
|
});
|
|
@@ -124,7 +124,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
124
124
|
// DELETED
|
|
125
125
|
//
|
|
126
126
|
it("detects delete events correctly", () => {
|
|
127
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
127
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([closeLog()], [cmDumb])).to.be.eql({
|
|
128
128
|
updated: [],
|
|
129
129
|
deleted: [expectedHash],
|
|
130
130
|
});
|
|
@@ -135,7 +135,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
135
135
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
136
136
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
137
137
|
], ethers_1.utils.defaultAbiCoder.encode(["uint256"], [10]));
|
|
138
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
138
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([log], [cmDumb])).to.be.eql({
|
|
139
139
|
updated: [],
|
|
140
140
|
deleted: [expectedHash],
|
|
141
141
|
});
|
|
@@ -146,27 +146,27 @@ describe("CreditAccountTracker test", () => {
|
|
|
146
146
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
147
147
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
148
148
|
], ethers_1.utils.defaultAbiCoder.encode(["uint256"], [10]));
|
|
149
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
149
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([log], [cmDumb])).to.be.eql({
|
|
150
150
|
updated: [],
|
|
151
151
|
deleted: [expectedHash],
|
|
152
152
|
});
|
|
153
153
|
});
|
|
154
154
|
it("doesn't make duplicated", () => {
|
|
155
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
155
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([openLog(), openLog(), openLog()], [cmDumb])).to.be.eql({
|
|
156
156
|
updated: [expectedHash],
|
|
157
157
|
deleted: [],
|
|
158
158
|
});
|
|
159
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
159
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([closeLog(), closeLog(), closeLog()], [cmDumb])).to.be.eql({
|
|
160
160
|
updated: [],
|
|
161
161
|
deleted: [expectedHash],
|
|
162
162
|
});
|
|
163
163
|
});
|
|
164
164
|
it("updates accounts were created and deleted in the batch", () => {
|
|
165
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
165
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([openLog(), closeLog()], [cmDumb])).to.be.eql({
|
|
166
166
|
updated: [],
|
|
167
167
|
deleted: [expectedHash],
|
|
168
168
|
});
|
|
169
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
169
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([openLog(), closeLog(), openLog()], [cmDumb])).to.be.eql({
|
|
170
170
|
updated: [expectedHash],
|
|
171
171
|
deleted: [expectedHash],
|
|
172
172
|
});
|
|
@@ -177,7 +177,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
177
177
|
encode("address", BORROWER),
|
|
178
178
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
179
179
|
]);
|
|
180
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
180
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([openLog(), transferLog], [cmDumb])).to.be.eql({
|
|
181
181
|
updated: [
|
|
182
182
|
`${CREDIT_MANAGER_ADDRESS.toLowerCase()}:${sdk_gov_1.DUMB_ADDRESS.toLowerCase()}`,
|
|
183
183
|
],
|
|
@@ -185,7 +185,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
185
185
|
});
|
|
186
186
|
});
|
|
187
187
|
it("correctly handles credit configurator change", () => {
|
|
188
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
188
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([
|
|
189
189
|
openLog(),
|
|
190
190
|
newConfiguratorLog(),
|
|
191
191
|
upgradeFacadeLog(),
|
|
@@ -194,7 +194,7 @@ describe("CreditAccountTracker test", () => {
|
|
|
194
194
|
updated: [],
|
|
195
195
|
deleted: [expectedHash],
|
|
196
196
|
});
|
|
197
|
-
(0, chai_1.expect)(creditAccountWatcher_1.
|
|
197
|
+
(0, chai_1.expect)(creditAccountWatcher_1.CreditAccountWatcherV2.detectChanges([
|
|
198
198
|
openLog(),
|
|
199
199
|
closeLog(),
|
|
200
200
|
newConfiguratorLog(),
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { providers, Signer } from "ethers";
|
|
2
2
|
import { CreditManagerData } from "../core/creditManager";
|
|
3
3
|
export declare class CreditManagerWatcher {
|
|
4
|
-
static
|
|
5
|
-
static
|
|
6
|
-
static
|
|
4
|
+
private static newConfiguratorV2Topic;
|
|
5
|
+
private static newConfiguratorV3Topic;
|
|
6
|
+
static getAllCreditManagers(addressProvider: string, signer: Signer | providers.Provider, atBlock?: number): Promise<Record<string, CreditManagerData>>;
|
|
7
|
+
static getV2CreditManagers(dataCompressorV210: string, signer: Signer | providers.Provider, atBlock?: number): Promise<Record<string, CreditManagerData>>;
|
|
8
|
+
static getV3CreditManagers(dataCompressorV300: string, signer: Signer | providers.Provider, atBlock?: number): Promise<Record<string, CreditManagerData>>;
|
|
7
9
|
static detectConfigChanges(freshLogs: Array<providers.Log>, creditManagers: Array<CreditManagerData>): boolean;
|
|
8
10
|
}
|
|
@@ -1,18 +1,40 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.CreditManagerWatcher = void 0;
|
|
4
|
-
const
|
|
4
|
+
const utils_1 = require("ethers/lib/utils");
|
|
5
5
|
const creditManager_1 = require("../core/creditManager");
|
|
6
6
|
const types_1 = require("../types");
|
|
7
7
|
class CreditManagerWatcher {
|
|
8
|
-
static
|
|
9
|
-
static
|
|
10
|
-
static async
|
|
8
|
+
static newConfiguratorV2Topic = types_1.ICreditManagerV2__factory.createInterface().getEventTopic("NewConfigurator");
|
|
9
|
+
static newConfiguratorV3Topic = types_1.ICreditManagerV3__factory.createInterface().getEventTopic("SetCreditConfigurator");
|
|
10
|
+
static async getAllCreditManagers(addressProvider, signer, atBlock) {
|
|
11
|
+
const ap = types_1.IAddressProviderV3__factory.connect(addressProvider, signer);
|
|
12
|
+
const [dc210, dc300] = await Promise.all([
|
|
13
|
+
ap.getAddressOrRevert((0, utils_1.formatBytes32String)("DATA_COMPRESSOR"), 210, {
|
|
14
|
+
blockTag: atBlock,
|
|
15
|
+
}),
|
|
16
|
+
ap.getAddressOrRevert((0, utils_1.formatBytes32String)("DATA_COMPRESSOR"), 300, {
|
|
17
|
+
blockTag: atBlock,
|
|
18
|
+
}),
|
|
19
|
+
]);
|
|
20
|
+
const [cms2, cms3] = await Promise.all([
|
|
21
|
+
CreditManagerWatcher.getV2CreditManagers(dc210, signer, atBlock),
|
|
22
|
+
CreditManagerWatcher.getV3CreditManagers(dc300, signer, atBlock),
|
|
23
|
+
]);
|
|
24
|
+
return { ...cms2, ...cms3 };
|
|
25
|
+
}
|
|
26
|
+
static async getV2CreditManagers(dataCompressorV210, signer, atBlock) {
|
|
27
|
+
const creditManagers = {};
|
|
28
|
+
const creditManagersPayload = await types_1.IDataCompressorV2_10__factory.connect(dataCompressorV210, signer).getCreditManagersV2List({ blockTag: atBlock });
|
|
29
|
+
creditManagersPayload.forEach(c => {
|
|
30
|
+
creditManagers[c.addr.toLowerCase()] = new creditManager_1.CreditManagerData(c);
|
|
31
|
+
});
|
|
32
|
+
return creditManagers;
|
|
33
|
+
}
|
|
34
|
+
static async getV3CreditManagers(dataCompressorV300, signer, atBlock) {
|
|
11
35
|
const creditManagers = {};
|
|
12
|
-
const creditManagersPayload = await types_1.
|
|
13
|
-
creditManagersPayload
|
|
14
|
-
.filter(c => (0, sdk_gov_1.toBigInt)(c.cfVersion) === 2n || (0, sdk_gov_1.toBigInt)(c.cfVersion) === 210n)
|
|
15
|
-
.forEach(c => {
|
|
36
|
+
const creditManagersPayload = await types_1.IDataCompressorV3_00__factory.connect(dataCompressorV300, signer).getCreditManagersV3List({ blockTag: atBlock });
|
|
37
|
+
creditManagersPayload.forEach(c => {
|
|
16
38
|
creditManagers[c.addr.toLowerCase()] = new creditManager_1.CreditManagerData(c);
|
|
17
39
|
});
|
|
18
40
|
return creditManagers;
|
|
@@ -22,8 +44,8 @@ class CreditManagerWatcher {
|
|
|
22
44
|
const ccs = creditManagers.map(c => c.creditConfigurator);
|
|
23
45
|
for (let log of freshLogs) {
|
|
24
46
|
if (cms.includes(log.address.toLowerCase())) {
|
|
25
|
-
|
|
26
|
-
|
|
47
|
+
if (log.topics[0] === CreditManagerWatcher.newConfiguratorV2Topic ||
|
|
48
|
+
log.topics[0] === CreditManagerWatcher.newConfiguratorV3Topic) {
|
|
27
49
|
return true;
|
|
28
50
|
}
|
|
29
51
|
}
|
|
@@ -26,20 +26,28 @@ const makeLog = (address, topics, data = sdk_gov_1.ADDRESS_0X0) => {
|
|
|
26
26
|
};
|
|
27
27
|
};
|
|
28
28
|
describe("CreditManagerTracker test", () => {
|
|
29
|
-
it("detects
|
|
30
|
-
const
|
|
29
|
+
it("detects CreditManagerV2 events correctly", () => {
|
|
30
|
+
const cmV2Interface = types_1.ICreditManagerV2__factory.createInterface();
|
|
31
31
|
let log = makeLog(CREDIT_MANAGER_ADDRESS, [
|
|
32
|
-
|
|
32
|
+
cmV2Interface.getEventTopic("NewConfigurator"),
|
|
33
33
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
34
34
|
]);
|
|
35
35
|
(0, chai_1.expect)(creditManagerWatcher_1.CreditManagerWatcher.detectConfigChanges([log], [cmDumb])).to.be.eq(true);
|
|
36
36
|
log = makeLog(CREDIT_MANAGER_ADDRESS, [
|
|
37
|
-
|
|
37
|
+
cmV2Interface.getEventTopic("ExecuteOrder"),
|
|
38
38
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
39
39
|
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
40
40
|
]);
|
|
41
41
|
(0, chai_1.expect)(creditManagerWatcher_1.CreditManagerWatcher.detectConfigChanges([log], [cmDumb])).to.be.eq(false);
|
|
42
42
|
});
|
|
43
|
+
it("detects CreditManagerV3 events correctly", () => {
|
|
44
|
+
const cmV3Interface = types_1.ICreditManagerV3__factory.createInterface();
|
|
45
|
+
let log = makeLog(CREDIT_MANAGER_ADDRESS, [
|
|
46
|
+
cmV3Interface.getEventTopic("SetCreditConfigurator"),
|
|
47
|
+
encode("address", sdk_gov_1.DUMB_ADDRESS),
|
|
48
|
+
]);
|
|
49
|
+
(0, chai_1.expect)(creditManagerWatcher_1.CreditManagerWatcher.detectConfigChanges([log], [cmDumb])).to.be.eq(true);
|
|
50
|
+
});
|
|
43
51
|
it("detects CreditConfigurator events correctly", () => {
|
|
44
52
|
const ccInterface = types_1.ICreditConfiguratorV2__factory.createInterface();
|
|
45
53
|
let log = makeLog(CREDIT_CONFIGIURATOR_ADDRESS, [
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@gearbox-protocol/sdk",
|
|
3
|
-
"version": "3.0.0-next.
|
|
3
|
+
"version": "3.0.0-next.50",
|
|
4
4
|
"description": "Gearbox SDK",
|
|
5
5
|
"main": "./lib/index.js",
|
|
6
6
|
"types": "./lib/index.d.ts",
|
|
@@ -30,9 +30,7 @@
|
|
|
30
30
|
"test": "npx mocha -r ts-node/register -r dotenv/config src/**/*.spec.ts"
|
|
31
31
|
},
|
|
32
32
|
"dependencies": {
|
|
33
|
-
"@gearbox-protocol/
|
|
34
|
-
"@gearbox-protocol/sdk-gov": "^1.5.25",
|
|
35
|
-
"@types/deep-eql": "^4.0.0",
|
|
33
|
+
"@gearbox-protocol/sdk-gov": "^1.14.0",
|
|
36
34
|
"axios": "^1.2.6",
|
|
37
35
|
"decimal.js-light": "^2.5.1",
|
|
38
36
|
"deep-eql": "^4.1.0",
|
|
@@ -42,15 +40,18 @@
|
|
|
42
40
|
"@1inch/solidity-utils": "^2.2.27",
|
|
43
41
|
"@commitlint/cli": "^17.6.3",
|
|
44
42
|
"@commitlint/config-conventional": "^17.0.3",
|
|
45
|
-
"@gearbox-protocol/core-v2": "1.19.0-base.
|
|
46
|
-
"@gearbox-protocol/core-v3": "^1.
|
|
43
|
+
"@gearbox-protocol/core-v2": "1.19.0-base.17",
|
|
44
|
+
"@gearbox-protocol/core-v3": "^1.43.0",
|
|
47
45
|
"@gearbox-protocol/eslint-config": "^1.4.1",
|
|
48
|
-
"@gearbox-protocol/
|
|
49
|
-
"@gearbox-protocol/
|
|
46
|
+
"@gearbox-protocol/integrations-v3": "^1.21.0",
|
|
47
|
+
"@gearbox-protocol/oracles-v3": "^1.8.0",
|
|
48
|
+
"@gearbox-protocol/periphery-v3": "^1.3.8",
|
|
50
49
|
"@gearbox-protocol/prettier-config": "^1.4.1",
|
|
51
|
-
"@
|
|
50
|
+
"@gearbox-protocol/router-v3": "^1.4.0",
|
|
51
|
+
"@openzeppelin/contracts": "^4.9.3",
|
|
52
52
|
"@typechain/ethers-v5": "^10.1.0",
|
|
53
53
|
"@types/chai": "^4.3.3",
|
|
54
|
+
"@types/deep-eql": "^4.0.0",
|
|
54
55
|
"@types/jest": "^28.1.7",
|
|
55
56
|
"@types/mocha": "^10.0.1",
|
|
56
57
|
"@types/node": "^18.7.6",
|
package/contracts/IRouter.sol
DELETED
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
2
|
-
// Gearbox Protocol. Generalized leverage for DeFi protocols
|
|
3
|
-
// (c) Gearbox Holdings, 2021
|
|
4
|
-
pragma solidity ^0.8.10;
|
|
5
|
-
|
|
6
|
-
import {Balance} from "@gearbox-protocol/core-v2/contracts/libraries/Balances.sol";
|
|
7
|
-
import {IVersion} from "@gearbox-protocol/core-v2/contracts/interfaces/IVersion.sol";
|
|
8
|
-
import {MultiCall} from "@gearbox-protocol/core-v2/contracts/libraries/MultiCall.sol";
|
|
9
|
-
|
|
10
|
-
struct PathOption {
|
|
11
|
-
address target;
|
|
12
|
-
uint8 option;
|
|
13
|
-
uint8 totalOptions;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
enum SwapOperation {
|
|
17
|
-
EXACT_INPUT,
|
|
18
|
-
EXACT_INPUT_ALL,
|
|
19
|
-
EXACT_OUTPUT
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
struct SwapTask {
|
|
23
|
-
SwapOperation swapOperation;
|
|
24
|
-
address creditAccount;
|
|
25
|
-
address tokenIn;
|
|
26
|
-
address tokenOut;
|
|
27
|
-
address[] connectors;
|
|
28
|
-
uint256 amount;
|
|
29
|
-
uint256 slippage;
|
|
30
|
-
bool externalSlippage;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
struct RouterResult {
|
|
34
|
-
uint256 amount;
|
|
35
|
-
uint256 gasUsage;
|
|
36
|
-
MultiCall[] calls;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
interface IRouter is IVersion {
|
|
40
|
-
/// @dev Emits each time when routerComponent is set / updated
|
|
41
|
-
event RouterComponentUpdate(uint8 indexed, address indexed);
|
|
42
|
-
|
|
43
|
-
/// @dev Emits each time when resolver is set / updated
|
|
44
|
-
event ResolverUpdate(uint8 indexed ttIn, uint8 indexed ttOut, uint8 indexed rc);
|
|
45
|
-
|
|
46
|
-
event TokenTypeUpdate(address indexed tokenAddress, uint8 indexed tt);
|
|
47
|
-
|
|
48
|
-
/// @dev Finds all available swaps for NORMAL tokens
|
|
49
|
-
function findAllSwaps(SwapTask memory swapTask) external returns (RouterResult[] memory);
|
|
50
|
-
|
|
51
|
-
/// @dev Finds best path to swap all Normal tokens and tokens "on the way" to target one and vice versa
|
|
52
|
-
function findOneTokenPath(
|
|
53
|
-
address tokenIn,
|
|
54
|
-
uint256 amount,
|
|
55
|
-
address tokenOut,
|
|
56
|
-
address creditAccount,
|
|
57
|
-
address[] calldata connectors,
|
|
58
|
-
uint256 slippage
|
|
59
|
-
) external returns (RouterResult memory);
|
|
60
|
-
|
|
61
|
-
/// @dev Finds the best swap to deposit (or swap) all provided tokens into target one
|
|
62
|
-
/// Currently it takes ALL Normal tokens and all LP "on the way" tokens into target one.
|
|
63
|
-
/// It some token is not "on the way" it would be skipped.
|
|
64
|
-
/// @param creditManager Address of creditManager
|
|
65
|
-
/// @param balances Expected balances on credit account
|
|
66
|
-
/// @param target Address of target token
|
|
67
|
-
/// @param connectors Addresses of "connectors" - internidiatery tokens which're used for swap operations
|
|
68
|
-
/// @param slippage Slippage in PERCENTAGE_FORMAT
|
|
69
|
-
function findOpenStrategyPath(
|
|
70
|
-
address creditManager,
|
|
71
|
-
Balance[] calldata balances,
|
|
72
|
-
address target,
|
|
73
|
-
address[] calldata connectors,
|
|
74
|
-
uint256 slippage
|
|
75
|
-
) external returns (Balance[] memory, RouterResult memory);
|
|
76
|
-
|
|
77
|
-
/// @dev Finds the best close path - withdraw all tokens and swap them into underlying one
|
|
78
|
-
/// @param creditAccount Address of closing creditAccount
|
|
79
|
-
/// @param connectors Addresses of "connectors" - internidiatery tokens which're used for swap operations
|
|
80
|
-
/// @param slippage Slippage in PERCENTAGE_FORMAT
|
|
81
|
-
/// @param pathOptions Starting point for iterating routes. More info in PathOption file
|
|
82
|
-
/// @param iterations How many iterations algo should compute starting from PathOptions
|
|
83
|
-
function findBestClosePath(
|
|
84
|
-
address creditAccount,
|
|
85
|
-
address[] memory connectors,
|
|
86
|
-
uint256 slippage,
|
|
87
|
-
PathOption[] memory pathOptions,
|
|
88
|
-
uint256 iterations,
|
|
89
|
-
bool force
|
|
90
|
-
) external returns (RouterResult memory result, uint256 gasPriceTargetRAY);
|
|
91
|
-
|
|
92
|
-
/// @dev Returns TokenType for provided token
|
|
93
|
-
function tokenTypes(address) external view returns (uint8);
|
|
94
|
-
|
|
95
|
-
/// @dev Returns current address for RouterComponent. Used for self-discovery
|
|
96
|
-
function componentAddressById(uint8) external view returns (address);
|
|
97
|
-
|
|
98
|
-
/// @dev @return True if address is router configurator, otherwise false
|
|
99
|
-
function isRouterConfigurator(address account) external view returns (bool);
|
|
100
|
-
}
|
package/lib/core/pool/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from "./data";
|
package/lib/core/pool/index.js
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./data"), exports);
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
import type { BaseContract, BigNumber, Signer, utils } from "ethers";
|
|
2
|
-
import type { EventFragment } from "@ethersproject/abi";
|
|
3
|
-
import type { Listener, Provider } from "@ethersproject/providers";
|
|
4
|
-
import type { TypedEventFilter, TypedEvent, TypedListener, OnEvent, PromiseOrValue } from "../common";
|
|
5
|
-
export interface IWrappedATokenEventsInterface extends utils.Interface {
|
|
6
|
-
functions: {};
|
|
7
|
-
events: {
|
|
8
|
-
"Deposit(address,uint256,uint256)": EventFragment;
|
|
9
|
-
"Withdraw(address,uint256,uint256)": EventFragment;
|
|
10
|
-
};
|
|
11
|
-
getEvent(nameOrSignatureOrTopic: "Deposit"): EventFragment;
|
|
12
|
-
getEvent(nameOrSignatureOrTopic: "Withdraw"): EventFragment;
|
|
13
|
-
}
|
|
14
|
-
export interface DepositEventObject {
|
|
15
|
-
account: string;
|
|
16
|
-
assets: BigNumber;
|
|
17
|
-
shares: BigNumber;
|
|
18
|
-
}
|
|
19
|
-
export type DepositEvent = TypedEvent<[
|
|
20
|
-
string,
|
|
21
|
-
BigNumber,
|
|
22
|
-
BigNumber
|
|
23
|
-
], DepositEventObject>;
|
|
24
|
-
export type DepositEventFilter = TypedEventFilter<DepositEvent>;
|
|
25
|
-
export interface WithdrawEventObject {
|
|
26
|
-
account: string;
|
|
27
|
-
assets: BigNumber;
|
|
28
|
-
shares: BigNumber;
|
|
29
|
-
}
|
|
30
|
-
export type WithdrawEvent = TypedEvent<[
|
|
31
|
-
string,
|
|
32
|
-
BigNumber,
|
|
33
|
-
BigNumber
|
|
34
|
-
], WithdrawEventObject>;
|
|
35
|
-
export type WithdrawEventFilter = TypedEventFilter<WithdrawEvent>;
|
|
36
|
-
export interface IWrappedATokenEvents extends BaseContract {
|
|
37
|
-
connect(signerOrProvider: Signer | Provider | string): this;
|
|
38
|
-
attach(addressOrName: string): this;
|
|
39
|
-
deployed(): Promise<this>;
|
|
40
|
-
interface: IWrappedATokenEventsInterface;
|
|
41
|
-
queryFilter<TEvent extends TypedEvent>(event: TypedEventFilter<TEvent>, fromBlockOrBlockhash?: string | number | undefined, toBlock?: string | number | undefined): Promise<Array<TEvent>>;
|
|
42
|
-
listeners<TEvent extends TypedEvent>(eventFilter?: TypedEventFilter<TEvent>): Array<TypedListener<TEvent>>;
|
|
43
|
-
listeners(eventName?: string): Array<Listener>;
|
|
44
|
-
removeAllListeners<TEvent extends TypedEvent>(eventFilter: TypedEventFilter<TEvent>): this;
|
|
45
|
-
removeAllListeners(eventName?: string): this;
|
|
46
|
-
off: OnEvent<this>;
|
|
47
|
-
on: OnEvent<this>;
|
|
48
|
-
once: OnEvent<this>;
|
|
49
|
-
removeListener: OnEvent<this>;
|
|
50
|
-
functions: {};
|
|
51
|
-
callStatic: {};
|
|
52
|
-
filters: {
|
|
53
|
-
"Deposit(address,uint256,uint256)"(account?: PromiseOrValue<string> | null, assets?: null, shares?: null): DepositEventFilter;
|
|
54
|
-
Deposit(account?: PromiseOrValue<string> | null, assets?: null, shares?: null): DepositEventFilter;
|
|
55
|
-
"Withdraw(address,uint256,uint256)"(account?: PromiseOrValue<string> | null, assets?: null, shares?: null): WithdrawEventFilter;
|
|
56
|
-
Withdraw(account?: PromiseOrValue<string> | null, assets?: null, shares?: null): WithdrawEventFilter;
|
|
57
|
-
};
|
|
58
|
-
estimateGas: {};
|
|
59
|
-
populateTransaction: {};
|
|
60
|
-
}
|