From f6d6e71e41e635448b609a87873c84ddcf7a8322 Mon Sep 17 00:00:00 2001 From: Jorge Galat Date: Thu, 21 Sep 2023 10:21:32 -0300 Subject: [PATCH] =?UTF-8?q?=E2=99=BB=EF=B8=8F=20leverager:=20re-work=20all?= =?UTF-8?q?owance=20for=20msigs?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- components/operations/Faucet/index.tsx | 2 +- .../operations/RepayAtMaturity/index.tsx | 2 + contexts/LeveragerContext.tsx | 51 ++++++++++--------- 3 files changed, 30 insertions(+), 25 deletions(-) diff --git a/components/operations/Faucet/index.tsx b/components/operations/Faucet/index.tsx index a4bfcbecc..a3c1d2448 100644 --- a/components/operations/Faucet/index.tsx +++ b/components/operations/Faucet/index.tsx @@ -44,7 +44,7 @@ function Faucet() { setLoading(symbol); const amounts: Record = { DAI: '50000', - USDC: '50000', + USDC: '50000000', WBTC: '2', }; diff --git a/components/operations/RepayAtMaturity/index.tsx b/components/operations/RepayAtMaturity/index.tsx index 7e48bc1d2..7b7997ae6 100644 --- a/components/operations/RepayAtMaturity/index.tsx +++ b/components/operations/RepayAtMaturity/index.tsx @@ -119,6 +119,7 @@ const RepayAtMaturity: FC = () => { positionAssets, walletAddress ?? zeroAddress, ]); + const feeAtMaturity = ((((positionAssets > pool.position.principal ? pool.position.principal : positionAssets) * pool.position.fee) / WEI_PER_ETHER) * @@ -128,6 +129,7 @@ const RepayAtMaturity: FC = () => { const discount = assets - positionAssets; if (cancelled()) return; + setPreviewData({ principal: formatNumber(formatUnits(principal, marketAccount.decimals), marketAccount.symbol, true), amountWithDiscount: formatNumber(formatUnits(assets, marketAccount.decimals), marketAccount.symbol, true), diff --git a/contexts/LeveragerContext.tsx b/contexts/LeveragerContext.tsx index 037b2bd30..9c4a6c9df 100644 --- a/contexts/LeveragerContext.tsx +++ b/contexts/LeveragerContext.tsx @@ -69,10 +69,6 @@ type Input = { export type ApprovalStatus = 'INIT' | 'ERC20' | 'ERC20-PERMIT2' | 'MARKET-IN' | 'MARKET-OUT' | 'APPROVED'; -const DEFAULT_SLIPPAGE = 2n; - -const slippage = (value: bigint, up = true) => (value * (100n + (up ? 1n : -1n) * DEFAULT_SLIPPAGE)) / 100n; - const initState: Input = { collateralSymbol: undefined, borrowSymbol: undefined, @@ -588,23 +584,26 @@ export const LeveragerContextProvider: FC = ({ children }) => setApprovalStatus('MARKET-OUT'); const marketOutAllownce = await marketOut.read.allowance([walletAddress, debtManager.address], opts); - if ( - marketOutAllownce < - (await marketOut.read.previewWithdraw([limit.borrow - leverageStatus.borrow + 100n], opts)) - ) - return true; + const _slippage = (leverageStatus.borrow * ((maIn.floatingBorrowRate * 300n) / 31_536_000n)) / WEI_PER_ETHER; + const borrowShares = await marketIn.read.previewWithdraw( + [limit.borrow - leverageStatus.borrow + _slippage], + opts, + ); + if (marketOutAllownce < borrowShares) return true; } else { setApprovalStatus('MARKET-IN'); const marketInAllownce = await marketIn.read.allowance([walletAddress, debtManager.address], opts); - const permitAssets = await marketOut.read.previewWithdraw( + const _slippage = + (maIn.floatingBorrowAssets * ((maIn.floatingBorrowRate * 300n) / 31_536_000n)) / WEI_PER_ETHER; + const permitShares = await marketIn.read.previewWithdraw( [ - slippage( - (maIn.floatingBorrowAssets < limit.borrow ? 0n : maIn.floatingBorrowAssets - limit.borrow) + userInput, - ), + (maIn.floatingBorrowAssets < limit.borrow ? 0n : maIn.floatingBorrowAssets - limit.borrow) + + userInput + + _slippage, ], opts, ); - if (marketInAllownce < permitAssets) return true; + if (marketInAllownce < permitShares) return true; } setApprovalStatus('APPROVED'); @@ -669,15 +668,17 @@ export const LeveragerContextProvider: FC = ({ children }) => break; } case 'MARKET-IN': { - const permitAssets = await marketOut.read.previewWithdraw( + const _slippage = + (maIn.floatingBorrowAssets * ((maIn.floatingBorrowRate * 5000n) / 31_536_000n)) / WEI_PER_ETHER; + const permitShares = await marketIn.read.previewWithdraw( [ - slippage( - (maIn.floatingBorrowAssets < limit.borrow ? 0n : maIn.floatingBorrowAssets - limit.borrow) + userInput, - ), + (maIn.floatingBorrowAssets < limit.borrow ? 0n : maIn.floatingBorrowAssets - limit.borrow) + + userInput + + _slippage, ], opts, ); - const args = [debtManager.address, slippage(permitAssets)] as const; + const args = [debtManager.address, permitShares] as const; const gasEstimation = await marketIn.estimateGas.approve(args, opts); hash = await marketIn.write.approve(args, { ...opts, @@ -686,10 +687,12 @@ export const LeveragerContextProvider: FC = ({ children }) => break; } case 'MARKET-OUT': { - const args = [ - debtManager.address, - await marketOut.read.previewWithdraw([limit.borrow - leverageStatus.borrow + 100n], opts), - ] as const; + const _slippage = (leverageStatus.borrow * ((maIn.floatingBorrowRate * 5000n) / 31_536_000n)) / WEI_PER_ETHER; + const borrowShares = await marketIn.read.previewWithdraw( + [limit.borrow - leverageStatus.borrow + _slippage], + opts, + ); + const args = [debtManager.address, borrowShares] as const; const gasEstimation = await marketOut.estimateGas.approve(args, opts); hash = await marketOut.write.approve(args, { ...opts, @@ -935,9 +938,9 @@ export const LeveragerContextProvider: FC = ({ children }) => }); break; } + const _slippage = (maIn.floatingBorrowAssets * ((maIn.floatingBorrowRate * 300n) / 31_536_000n)) / WEI_PER_ETHER; - const permitShares = await marketIn.read.previewWithdraw( [ (maIn.floatingBorrowAssets < limit.borrow ? 0n : maIn.floatingBorrowAssets - limit.borrow) +