An unverified contract lost about $140k in several tx. This is a staking contract. There are “stake”, “unstake” functions and also a function for swap tokens.
data:image/s3,"s3://crabby-images/dc307/dc307f61325632989980a34ac8b062de2a154bf5" alt=""
“stake” function stakes usdt token and call “_swap” function. “_swap” function exchanges 10 usdt to other tokens and adds reward according to swap result.
data:image/s3,"s3://crabby-images/e2a2d/e2a2dd9c11955d185af567714260c6c57201fcc5" alt=""
data:image/s3,"s3://crabby-images/a5c1d/a5c1db42bf4c9dc8ad216058f797313cf23a65f6" alt=""
But “_swap” can be called once a day. To evade this, hacker exploited reentrance.
data:image/s3,"s3://crabby-images/94f73/94f73e6e1ae683c0194f80ae7665879ce398c667" alt=""
As you can see in photo, nextTime is set after swap tokens. Hacker prepared a token(0x5f8b14fb6cc6008528e461e8073727c38a6a5bf3) that calls “enter” function of attack contract in “transfer” function. Using this token, hacker was able to perform reentrancy attack. 30 times reenter.
data:image/s3,"s3://crabby-images/8708f/8708f17bcd239c5bc8b641c1627ecabf61ce96fc" alt=""
Leave a Reply