You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The router contract currently uses a low-level call for executing swaps on KyberSwap, without verifying that the target address is a valid, existing contract. Since the EVM design allows low-level call to return “success” even when the target address is non-existent or points to a destroyed contract, this can lead to unintended behavior. If the Kyber router address is set incorrectly or if the router contract at that address is destroyed, calls will still return success, leading users to mistakenly believe their swap was executed when it was not.
The owner updates the Kyber router address to a new official address.
The new Kyber router address points to a contract with a selfdestruct function.
At some point, the new Kyber router contract self-destructs or is otherwise destroyed.
A user initiates a swap using the router, but due to the missing contract existence check, the call succeeds without actually performing the swap, resulting in potential fund loss.
another scenario will be the owner setting a Kyber router address to the wrong address.
Impact
This oversight could lead to users losing funds, as they may not receive their expected swap returns if the Kyber router contract is unavailable or destroyed.
Mitigation
To prevent this issue:
Contract Existence Check: Before executing a low-level call, implement a check to ensure the target address is a deployed contract. Solidity has various methods for this check.
Balance Verification: Before and after each Kyber router call, verify that the minAmountOut criteria have been met by comparing token balances.
The text was updated successfully, but these errors were encountered:
We classified this issue as Invalid because we assume the owner is not malicious, and is responsible for checking that the correct Kyber Router address is being used, and we assume that Kyber will not selfdestruct their router without any warning.
Github username: @0xmahdirostami
Twitter username: 0xmahdirostami
Submission hash (on-chain): 0x4a7a612fd62ef9364c23b61b1f39f0277f2ed86f38f288f403cc2da0f79386c3
Severity: high
Description:
Description
The router contract currently uses a low-level
call
for executing swaps on KyberSwap, without verifying that the target address is a valid, existing contract. Since the EVM design allows low-levelcall
to return “success” even when the target address is non-existent or points to a destroyed contract, this can lead to unintended behavior. If the Kyber router address is set incorrectly or if the router contract at that address is destroyed, calls will still return success, leading users to mistakenly believe their swap was executed when it was not.Spectra-0x4b792db3d2a5d1c1ccf9938380756b200c240e5d/src/router/Dispatcher.sol
Lines 339 to 349 in 06b05fc
Scenario
selfdestruct
function.another scenario will be the owner setting a Kyber router address to the wrong address.
Impact
This oversight could lead to users losing funds, as they may not receive their expected swap returns if the Kyber router contract is unavailable or destroyed.
Mitigation
To prevent this issue:
Contract Existence Check: Before executing a low-level
call
, implement a check to ensure the target address is a deployed contract. Solidity has various methods for this check.Balance Verification: Before and after each Kyber router call, verify that the
minAmountOut
criteria have been met by comparing token balances.The text was updated successfully, but these errors were encountered: