Mosca on BSC was hacked because of wrong balance calculation.
data:image/s3,"s3://crabby-images/88d2e/88d2e7ada3ca47c5b50e3f3fedf91d8159f54ec4" alt=""
As you can see in picture, withdraw balance is calculated by user.balance + user.balanceUSDT + user.balanceUSDC.
data:image/s3,"s3://crabby-images/5047a/5047a52e5adcc38afa0d6ad547b0396e46505a81" alt=""
But after “withdrawAll()”, only user.balance is set 0, USDT and USDC balance not changed, this means anyone can withdraw tokens several times if USDT or USDC balance is not 0 and rewardQueue is not empty.
To increase USDC balance, hacker called “buy” function, and called “join” function before “exitProgram” to push into rewardQueue.
data:image/s3,"s3://crabby-images/7c40a/7c40a44c4dced7cc3f352a69fc40d4cc83097f9c" alt=""
He repeated this step multiple times, gained $19k. There were several hacking attack on this contract.
Leave a Reply