-
Notifications
You must be signed in to change notification settings - Fork 5
fix: batchDeposit #139
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
fix: batchDeposit #139
Conversation
Summary of Test Results if Merged To Main:
❌ 1 tests failed, 142 passed, 0 skipped (Total: 143) Failing Tests in this PR Branch
Stack Trace
Test Results for Merge
🔒 Security AnalysisHigh Severity Issuesarbitrary-send-ethImpact: AtomWallet._call(address,uint256,bytes) (src/AtomWallet.sol#214-221) sends eth to arbitrary user Dangerous calls: - (success,result) = target.call{value: value}(data) (src/AtomWallet.sol#215) Affected Files:
View Detailed Findings
reentrancy-ethImpact: Reentrancy in EthMultiVault.batchDepositCurve(address,uint256[],uint256[],uint256[]) (src/EthMultiVault.sol#1296-1338): External calls: - _transferFeesToProtocolMultisig(protocolFee) (src/EthMultiVault.sol#1334) - (success,None) = address(generalConfig.protocolMultisig).call{value: value}() (src/EthMultiVault.sol#1452) State variables written after the call(s): - shares[i_scope_0] = _depositCurve(receiver,termIds[i_scope_0],curveIds[i_scope_0],userDepositAfterprotocolFee) (src/EthMultiVault.sol#1332) - bondingCurveVaults[id][curveId].totalAssets += assetsDelta (src/EthMultiVault.sol#1810) - bondingCurveVaults[id][curveId].balanceOf[to] += amount (src/EthMultiVault.sol#1752) - bondingCurveVaults[id][curveId].totalShares += sharesDelta (src/EthMultiVault.sol#1811) EthMultiVault.bondingCurveVaults (src/EthMultiVault.sol#132) can be used in cross function reentrancies: - EthMultiVault.bondingCurveVaults (src/EthMultiVault.sol#132) - EthMultiVault.convertToAssetsCurve(uint256,uint256,uint256) (src/EthMultiVault.sol#2228-2233) - EthMultiVault.convertToSharesCurve(uint256,uint256,uint256) (src/EthMultiVault.sol#2193-2199) - EthMultiVault.currentSharePriceCurve(uint256,uint256) (src/EthMultiVault.sol#2125-2129) - EthMultiVault.getCurveVaultState(uint256,uint256) (src/EthMultiVault.sol#2365-2367) - EthMultiVault.getDepositSharesAndFeesCurve(uint256,uint256,uint256) (src/EthMultiVault.sol#1934-1961) - EthMultiVault.getRedeemAssetsAndFeesCurve(uint256,uint256,uint256) (src/EthMultiVault.sol#2008-2042) - EthMultiVault.getVaultStateForUserCurve(uint256,uint256,address) (src/EthMultiVault.sol#2355-2363) - EthMultiVault.maxRedeemCurve(address,uint256,uint256) (src/EthMultiVault.sol#2161-2164) - shares[i_scope_0] = _depositCurve(receiver,termIds[i_scope_0],curveIds[i_scope_0],userDepositAfterprotocolFee) (src/EthMultiVault.sol#1332) - vaults[id].totalAssets = totalAssets (src/EthMultiVault.sol#1793) - vaults[id].totalShares = totalShares (src/EthMultiVault.sol#1794) EthMultiVault.vaults (src/EthMultiVault.sol#97) can be used in cross function reentrancies: - EthMultiVault.convertToAssets(uint256,uint256) (src/EthMultiVault.sol#2212-2216) - EthMultiVault.convertToShares(uint256,uint256) (src/EthMultiVault.sol#2177-2181) - EthMultiVault.currentSharePrice(uint256) (src/EthMultiVault.sol#2113-2119) - EthMultiVault.getDepositSharesAndFees(uint256,uint256) (src/EthMultiVault.sol#1905-1932) - EthMultiVault.getRedeemAssetsAndFees(uint256,uint256) (src/EthMultiVault.sol#1972-2006) - EthMultiVault.getVaultStateForUser(uint256,address) (src/EthMultiVault.sol#2349-2353) - EthMultiVault.maxRedeem(address,uint256) (src/EthMultiVault.sol#2151-2154) - EthMultiVault.vaults (src/EthMultiVault.sol#97) Affected Files:
View Detailed Findings
Medium Severity IssuesView Medium Severity Issues##### incorrect-equality **Impact**: EthMultiVault._validateTimelock(bytes32) (src/EthMultiVault.sol#2446-2458) uses a dangerous strict equality: - timelock.readyTime == 0 (src/EthMultiVault.sol#2449)Affected Files:
uninitialized-localImpact: EthMultiVault.batchCreateAtom(bytes[]).protocolDepositFeeTotal (src/EthMultiVault.sol#625) is a local variable never initialized Affected Files:
Recommended Actions
⛽ Gas Analysis |
Good work |
Summary of Test Results if Merged To Main:
🔒 Security Analysis⛽ Gas Analysis |
Note: I'm just a community member and Intuition fren.