View Source: contracts/libraries/NTransferUtilV2.sol
NTransferUtilV2
- ensureApproval(IERC20 malicious, address spender, uint256 amount)
- ensureTransfer(IERC20 malicious, address recipient, uint256 amount)
- ensureTransferFrom(IERC20 malicious, address sender, address recipient, uint256 amount)
Ensures approval of ERC20-like token
function ensureApproval(IERC20 malicious, address spender, uint256 amount) external nonpayable
Arguments
Name | Type | Description |
---|---|---|
malicious | IERC20 | |
spender | address | |
amount | uint256 |
Source Code
function ensureApproval(
IERC20 malicious,
address spender,
uint256 amount
) external {
require(address(malicious) != address(0), "Invalid token address");
require(spender != address(0), "Invalid spender");
require(amount > 0, "Invalid transfer amount");
malicious.safeIncreaseAllowance(spender, amount);
}
Ensures transfer of ERC20-like token
function ensureTransfer(IERC20 malicious, address recipient, uint256 amount) external nonpayable
Arguments
Name | Type | Description |
---|---|---|
malicious | IERC20 | |
recipient | address | |
amount | uint256 |
Source Code
function ensureTransfer(
IERC20 malicious,
address recipient,
uint256 amount
) external {
require(address(malicious) != address(0), "Invalid token address");
require(recipient != address(0), "Spender can't be zero");
require(amount > 0, "Invalid transfer amount");
uint256 balanceBeforeTransfer = malicious.balanceOf(recipient);
malicious.safeTransfer(recipient, amount);
uint256 balanceAfterTransfer = malicious.balanceOf(recipient);
// @suppress-subtraction
uint256 actualTransferAmount = balanceAfterTransfer - balanceBeforeTransfer;
require(actualTransferAmount == amount, "Invalid transfer");
}
Ensures transferFrom of ERC20-like token
function ensureTransferFrom(IERC20 malicious, address sender, address recipient, uint256 amount) external nonpayable
Arguments
Name | Type | Description |
---|---|---|
malicious | IERC20 | |
sender | address | |
recipient | address | |
amount | uint256 |
Source Code
function ensureTransferFrom(
IERC20 malicious,
address sender,
address recipient,
uint256 amount
) external {
require(address(malicious) != address(0), "Invalid token address");
require(sender != address(0), "Invalid sender");
require(recipient != address(0), "Invalid recipient");
require(amount > 0, "Invalid transfer amount");
uint256 balanceBeforeTransfer = malicious.balanceOf(recipient);
malicious.safeTransferFrom(sender, recipient, amount);
uint256 balanceAfterTransfer = malicious.balanceOf(recipient);
// @suppress-subtraction
uint256 actualTransferAmount = balanceAfterTransfer - balanceBeforeTransfer;
require(actualTransferAmount == amount, "Invalid transfer");
}
- AaveStrategy
- AccessControl
- AccessControlLibV1
- Address
- BaseLibV1
- BokkyPooBahsDateTimeLibrary
- BondPool
- BondPoolBase
- BondPoolLibV1
- CompoundStrategy
- Context
- Cover
- CoverBase
- CoverLibV1
- CoverReassurance
- CoverStake
- CoverUtilV1
- cxToken
- cxTokenFactory
- cxTokenFactoryLibV1
- Delayable
- Destroyable
- ERC165
- ERC20
- FakeAaveLendingPool
- FakeCompoundDaiDelegator
- FakePriceOracle
- FakeRecoverable
- FakeStore
- FakeToken
- FakeUniswapPair
- FakeUniswapV2FactoryLike
- FakeUniswapV2PairLike
- FakeUniswapV2RouterLike
- FaultyAaveLendingPool
- FaultyCompoundDaiDelegator
- Finalization
- ForceEther
- Governance
- GovernanceUtilV1
- IAaveV2LendingPoolLike
- IAccessControl
- IBondPool
- IClaimsProcessor
- ICompoundERC20DelegatorLike
- ICover
- ICoverReassurance
- ICoverStake
- ICxToken
- ICxTokenFactory
- IERC165
- IERC20
- IERC20Detailed
- IERC20Metadata
- IERC3156FlashBorrower
- IERC3156FlashLender
- IFinalization
- IGovernance
- ILendingStrategy
- ILiquidityEngine
- IMember
- INeptuneRouterV1
- InvalidStrategy
- IPausable
- IPolicy
- IPolicyAdmin
- IPriceOracle
- IProtocol
- IRecoverable
- IReporter
- IResolution
- IResolvable
- IStakingPools
- IStore
- IStoreLike
- IUniswapV2FactoryLike
- IUniswapV2PairLike
- IUniswapV2RouterLike
- IUnstakable
- IVault
- IVaultDelegate
- IVaultFactory
- IWitness
- LiquidityEngine
- MaliciousToken
- MockAccessControlUser
- MockCoverUtilUser
- MockCxToken
- MockCxTokenPolicy
- MockCxTokenStore
- MockFlashBorrower
- MockLiquidityEngineUser
- MockProcessorStore
- MockProcessorStoreLib
- MockProtocol
- MockRegistryClient
- MockStore
- MockStoreKeyUtilUser
- MockValidationLibUser
- MockVault
- MockVaultLibUser
- NeptuneRouterV1
- NPM
- NpmDistributor
- NTransferUtilV2
- NTransferUtilV2Intermediate
- Ownable
- Pausable
- Policy
- PolicyAdmin
- PolicyHelperV1
- PoorMansERC20
- POT
- PriceLibV1
- Processor
- ProtoBase
- Protocol
- ProtoUtilV1
- Recoverable
- ReentrancyGuard
- RegistryLibV1
- Reporter
- Resolution
- Resolvable
- RoutineInvokerLibV1
- SafeERC20
- StakingPoolBase
- StakingPoolCoreLibV1
- StakingPoolInfo
- StakingPoolLibV1
- StakingPoolReward
- StakingPools
- Store
- StoreBase
- StoreKeyUtil
- StrategyLibV1
- Strings
- TimelockController
- Unstakable
- ValidationLibV1
- Vault
- VaultBase
- VaultDelegate
- VaultDelegateBase
- VaultDelegateWithFlashLoan
- VaultFactory
- VaultFactoryLibV1
- VaultLibV1
- VaultLiquidity
- VaultStrategy
- WithFlashLoan
- WithPausability
- WithRecovery
- Witness