Assessment reports>SAX>Discussion>Checks-effects-interactions pattern

Checks-effects-interactions pattern

We recommend following the checks-effects-interactions pattern in the buyTokens() and sellTokens() functions by changing the state of the contract before calling the external contract. Although we did not identify any reentrancy attacks, it is a best practice to prioritize security and prevent potential future attacks.

function buyTokens(address token, uint256 amount) public whenNotPaused onlyRegistered(token) {
        ...
        IERC20(paymentToken).safeTransferFrom(msg.sender, address(this), totalPrice);

        TrendingERC20(token).mint(msg.sender, amount);

        registeredTokens[token].supply += amount;
        feesEarned[owner()] += protocolFee;
        registeredTokens[token].liquidity += price;
        ...
    }

    function sellTokens(address token, uint256 amount) public whenNotPaused onlyRegistered(token) {
        ...
        TrendingERC20(token).burn(msg.sender, amount);
        IERC20(paymentToken).safeTransfer(msg.sender, totalPrice);

        registeredTokens[token].supply -= amount;
        feesEarned[owner()] += protocolFee;
        registeredTokens[token].liquidity -= price;
        ...
    }

The recommended changes were implemented in commit .

Zellic © 2025Back to top ↑