Payouts
1st Places
2nd Places
3rd Places
All
Sherlock
Code4rena
Feb '25
Sep '24
high
NFTs in protected listings that are unlocked but not withdrawn can be stolen
high
Native tokens donations to UniswapV4 pools can be stolen by adding/removing liquidity before/after a swap
high
Quorum votes downcasting in `CollectionShutdown.sol` leads to lower quorum and stolen funds
high
Voters can't withdraw their collection tokens after a shutdown is canceled
high
It's possible to cancel a shutdown after it's been executed
high
It's possible to create listings with an arbitrary start timestamp
high
Relisting liquidated listings should not distribute taxes and refunds
high
`ProtectedListings::_createCheckpoint()` returns wrong checkpoint index in some cases
high
`ProtectedListings::adjustPosition()` doesn't adjust the taxes to pay
high
First liquidity providers lose all of their assets
high
Lack of caller validation in `InfernalRiftAbove::claimRoyalties()` allows to steal royalties
high
`InfernalRiftBelow` lacks a way to withdraw ERC1155 royalties
high
`Listings::reserve()` doesn't delete the old listing
high
`Listings::reserve()` doesn't clear the `isLiquidation[collection][tokenId]` mapping
high
Protected listings checkpoints are not always updated when the total supply changes
high
Collection tokens fees price can be manipulated in the `beforeSwap()` hook
medium
`CollectionShutdown::execute()` doesn't ensure that all locked NFTs are sold
medium
Fee exemptions are never applied
medium
If the royalties receiver it's a smart contract it might be impossible to collect L2 royalties
medium
Moongate assumes royalties are always implemented as a fixed percentage of the price, leading to discrepancies or locked tokens
medium
`UniswapImplementation::beforeSwap()` might revert when swapping native tokens to collection tokens
medium
Maximum borrowable amount in protected listings should be lower
medium
`initializeCollection()` doesn't refund native tokens
Jun '24
Findings not publicly available for private contests.
May '24
high
Users can frontrun LSTs/LRTs tokens prices decrease in order to avoid losses
medium
`_stake()` function in `PufEthAdapter` will always revert
medium
Adapters revert when 0 shares are minted, making it impossible to deposit under certain conditions
medium
Kelp adapter won't allow users to deposit in some situations
medium
Kelp adapter won't allow users to deposit if `getAssetCurrentLimit` returns `0`
medium
`_stake()` function in `RenzoAdaper` and `RsETHAdapter` doesn't check if max TVL is reached
medium
`RsETHAdapter` adapter `_stake()` function lacks slippage control
Apr '24
high
The amount of `xezETH` in circulation will not represent the amount of `ezETH` tokens 1:1
high
Incorrect withdraw queue balance in TVL calculation
high
Withdrawals logic allows MEV exploits of TVL changes and zero-slippage zero-fee swaps
high
ETH withdrawals from EigenLayer always fail due to `OperatorDelegator`'s nonReentrant `receive()`
medium
Deposits will always revert if the amount being deposited is less than the bufferToFill value
medium
`calculateTVL` may run out of gas for modest number of operators and tokens breaking deposits, withdrawals, and trades
Mar '24
high
Claiming a deposit (or redeem) on the same epoch it has been requested leads to stuck funds
high
Exchange rate is calculated incorrectly when the vault is closed, potentially leading to funds being stolen
high
Requesting a redeem sets `lastRedeemRequestId` to the wrong address
medium
Wrong allowance check on the vault zapper
Feb '24
high
It's possible to steal funds via donations to Eigenlayer strategies
high
Operators can undelegate `LRTRioOperatorDelegator` instances from Eigenlayer, leading to loss of funds
high
Malicious operator can steal stakers ETH by setting a validator withdrawal credentials to an address he controls
high
Epoch currently queued for settlement might get settled via `rebalance()` leading to stuck funds
medium
Increase in Eigenlayer strategies shares value might lead `rebalance()` reverting
medium
`RioLRTOperatorRegistry::verifyWithdrawalCredentials()` doesn't verify that the validator has 32ETH deposited from the rio protocol
medium
The protocol can't receive rewards because of low gas limits on ETH transfers
medium
Stakers can avoid validator penalties
medium
LRT that accepts both ETH and non-ETH assets can be forced to exit validators and receive less rewards
medium
Up to 1 ETH might get stuck in an EigenPod
medium
A part of ETH rewards can be stolen by sandwiching `claimDelayedWithdrawals()`
Jan '24
high
Lending pools that accept both ERC777 and UniswapV3 positions as collateral can be drained
high
Lending pools with ERC777 as an underlying asset can be drained
medium
Account auction price will keep decreasing even when bids can't be placed
medium
Possible griefing attack on lending pools interest rates
medium
Stargate `STG` rewards are accounted incorrectly by `StakedStargateAM.sol`
May '23
Dec '22
Nov '22
Oct '22
high
ecrecover missing address(0) check allows for fund draining, if the vault delegate is the 0 address
high
`_deleteLienPosition` visibility allows for fund draining
high
`yIntercept` is not correctly updated in `PublicVault.beforePayment()`
high
Users calling `makePayment()` for collaterals with multiple liens might lose funds
high
The function buyoutLien always revert
high
in `_validateCommitment` the potentialDebt is calculated wrongly
medium
VAULT_FEE() getter returns from the wrong offset, returning a wrong fee
Sep '22