🥾Omitted Approval for Contract Interactions Within a Protocol

A recurring vulnerability in smart contract programming is the omission of approval when one contract within a protocol needs to interact with another. The ERC20 token standard requires a contract or an account to grant permission ("approval") to another contract or account to spend its tokens. However, this crucial approval step is sometimes overlooked, leading to failures in contract interactions.

Consider three case examples where the approval was overlooked:

Case 1: The BasicSale contract was making a vest() function call to the VestLock contract, but it forgot to set the approval for the VestLock contract. This oversight led to a failure in the function call, rendering the BasicSale contract useless as the main tokens sent to it would become irretrievable.[H-01] Contract BasicSale is missing an approve(address(vestLock), 2**256-1) call (Bug Bounty)

Case 2: In the setZapConfig function of the SettToRenIbbtcZap contract, the curvePool or token was updated, but the token was not approved for the curvePool. This oversight caused a malfunction in the contract and broke the minting process.[M-02] Missing _token.approve() to curvePool in setZapConfig (Bug Bounty)

Case 3: The liquidateDai() function was meant to swap Dai to ETH using Uniswap’s swapExactTokensForETH, but the FSD contract (acting as msg.sender) hadn't approved UniswapV2 with an allowance for the tokens being attempted to swap. This caused the swap to fail.[M-02] Call to swapExactTokensForETH in liquidateDai() will always fail (Bug Bounty)

Last updated