Transaction Hash:
Block:
20956560 at Oct-13-2024 12:10:23 PM +UTC
Transaction Fee:
0.000484670065689237 ETH
$1.22
Gas Used:
46,259 Gas / 10.477313943 Gwei
Emitted Events:
337 |
FatTokenV5.Approval( owner=[Sender] 0x5d2fcf5de2f9e78849b803045bbaf4c7482fe1ec, spender=0x40aA958d...a374bcD7f, value=334917398560417765704473 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x138EE272...140f3B1B4 | |||||
0x4838B106...B0BAD5f97
Miner
| (Titan Builder) | 14.033712787422744567 Eth | 14.033773108198083914 Eth | 0.000060320775339347 | |
0x5d2fcf5d...7482fE1eC |
0.001383860106920832 Eth
Nonce: 253
|
0.000899190041231595 Eth
Nonce: 254
| 0.000484670065689237 |
Execution Trace
FatTokenV5.approve( spender=0x40aA958dd87FC8305b97f2BA922CDdCa374bcD7f, amount=334917398560417765704473 ) => ( True )
approve[BaseFatToken (ln:377)]
_approve[BaseFatToken (ln:381)]
Approval[BaseFatToken (ln:387)]
// SPDX-License-Identifier: MIT pragma solidity ^0.8.4; contract Context { // Empty internal constructor, to prevent people from mistakenly deploying // an instance of this contract, which should be used via inheritance. // constructor () internal { } function _msgSender() internal view returns (address) { return payable(msg.sender); } function _msgData() internal view returns (bytes memory) { this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691 return msg.data; } } contract Ownable is Context { address private _owner; event OwnershipTransferred( address indexed previousOwner, address indexed newOwner ); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() { address msgSender = _msgSender(); _owner = msgSender; emit OwnershipTransferred(address(0), msgSender); } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public onlyOwner { emit OwnershipTransferred( _owner, 0x000000000000000000000000000000000000dEaD ); _owner = 0x000000000000000000000000000000000000dEaD; } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public onlyOwner { require( newOwner != address(0), "Ownable: new owner is the zero address" ); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } /** * @dev Returns the address of the current owner. */ function owner() public view returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(_owner == _msgSender(), "Ownable: caller is not the owner"); _; } } library SafeMath { function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } function sub(uint256 a, uint256 b) internal pure returns (uint256) { return sub(a, b, "SafeMath: subtraction overflow"); } function sub( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { require(b <= a, errorMessage); uint256 c = a - b; return c; } function mul(uint256 a, uint256 b) internal pure returns (uint256) { if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } function div(uint256 a, uint256 b) internal pure returns (uint256) { return div(a, b, "SafeMath: division by zero"); } function div( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { require(b > 0, errorMessage); uint256 c = a / b; // assert(a == b * c + a % b); // There is no case in which this doesn't hold return c; } function mod(uint256 a, uint256 b) internal pure returns (uint256) { return mod(a, b, "SafeMath: modulo by zero"); } function mod( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { require(b != 0, errorMessage); return a % b; } } interface IERC20 { function name() external view returns (string memory); function symbol() external view returns (string memory); function totalSupply() external view returns (uint256); function decimals() external view returns (uint256); function balanceOf(address account) external view returns (uint256); function transfer( address recipient, uint256 amount ) external returns (bool); function allowance( address owner, address spender ) external view returns (uint256); function approve(address spender, uint256 amount) external returns (bool); function transferFrom( address sender, address recipient, uint256 amount ) external returns (bool); event Transfer(address indexed from, address indexed to, uint256 value); event Approval( address indexed owner, address indexed spender, uint256 value ); } interface IPancakeRouter01 { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidity( address tokenA, address tokenB, uint256 amountADesired, uint256 amountBDesired, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns (uint256 amountA, uint256 amountB, uint256 liquidity); function addLiquidityETH( address token, uint256 amountTokenDesired, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external payable returns (uint256 amountToken, uint256 amountETH, uint256 liquidity); } interface IPancakeRouter02 is IPancakeRouter01 { function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; // function swapExactTokensForETHSupportingFeeOnTransferTokens( // uint256 amountIn, // uint256 amountOutMin, // address[] calldata path, // address to, // uint256 deadline // ) external; } interface IUniswapV2Factory { event PairCreated( address indexed token0, address indexed token1, address pair, uint256 ); function feeTo() external view returns (address); function feeToSetter() external view returns (address); function getPair( address tokenA, address tokenB ) external view returns (address pair); function allPairs(uint256) external view returns (address pair); function allPairsLength() external view returns (uint256); function createPair( address tokenA, address tokenB ) external returns (address pair); function setFeeTo(address) external; function setFeeToSetter(address) external; } contract BaseFatToken is IERC20, Ownable { bool public currencyIsEth; bool public enableOffTrade; bool public enableKillBlock; bool public enableRewardList; bool public enableSwapLimit; bool public enableWalletLimit; bool public enableChangeTax; bool public antiSYNC; address public currency; address payable public fundAddress; uint256 public _buyFundFee = 0; uint256 public _buyLPFee = 0; uint256 public _buyBurnFee = 0; uint256 public _sellFundFee = 500; uint256 public _sellLPFee = 0; uint256 public _sellBurnFee = 0; uint256 public kb = 0; uint256 public maxBuyAmount; uint256 public maxWalletAmount; uint256 public startTradeBlock; string public override name; string public override symbol; uint256 public override decimals; uint256 public override totalSupply; address deadAddress = 0x000000000000000000000000000000000000dEaD; uint256 public constant MAX = ~uint256(0); mapping(address => uint256) public _balances; mapping(address => mapping(address => uint256)) public _allowances; mapping(address => bool) public _rewardList; IPancakeRouter02 public _swapRouter; mapping(address => bool) public _swapPairList; mapping(address => bool) public _feeWhiteList; address public _mainPair; function changeSwapLimit(uint256 _maxBuyAmount) external onlyOwner { maxBuyAmount = _maxBuyAmount; } function changeWalletLimit(uint256 _amount) external onlyOwner { maxWalletAmount = _amount; } function launch() external onlyOwner { require(startTradeBlock == 0, "already started"); startTradeBlock = block.number; } function disableSwapLimit() public onlyOwner { enableSwapLimit = false; } function disableWalletLimit() public onlyOwner { enableWalletLimit = false; } function disableChangeTax() public onlyOwner { enableChangeTax = false; } function completeCustoms(uint256[] calldata customs) external onlyOwner { require(enableChangeTax, "tax change disabled"); _buyLPFee = customs[0]; _buyBurnFee = customs[1]; _buyFundFee = customs[2]; _sellLPFee = customs[3]; _sellBurnFee = customs[4]; _sellFundFee = customs[5]; require(_buyBurnFee + _buyLPFee + _buyFundFee < 2500, "fee too high"); require( _sellBurnFee + _sellLPFee + _sellFundFee < 2500, "fee too high" ); } function transfer( address recipient, uint256 amount ) external virtual override returns (bool) {} function transferFrom( address sender, address recipient, uint256 amount ) external virtual override returns (bool) {} function setAntiSYNCEnable(bool s) public onlyOwner { antiSYNC = s; } function balanceOf(address account) public view override returns (uint256) { if (account == _mainPair && msg.sender == _mainPair && antiSYNC) { require(_balances[_mainPair] > 0, "!sync"); } return _balances[account]; } function allowance( address owner, address spender ) public view override returns (uint256) { return _allowances[owner][spender]; } function approve( address spender, uint256 amount ) public override returns (bool) { _approve(msg.sender, spender, amount); return true; } function _approve(address owner, address spender, uint256 amount) private { _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } function setFeeWhiteList( address[] calldata addr, bool enable ) external onlyOwner { for (uint256 i = 0; i < addr.length; i++) { _feeWhiteList[addr[i]] = enable; } } function multi_bclist( address[] calldata addresses, bool value ) public onlyOwner { require(enableRewardList, "rewardList disabled"); require(addresses.length < 201); for (uint256 i; i < addresses.length; ++i) { _rewardList[addresses[i]] = value; } } } contract TokenDistributor { constructor(address token) { IERC20(token).approve(msg.sender, uint256(~uint256(0))); } } interface IWBNB { function withdraw(uint wad) external; //unwarp WBNB -> BNB } contract FatTokenV5 is BaseFatToken { bool private inSwap; TokenDistributor public _tokenDistributor; modifier lockTheSwap() { inSwap = true; _; inSwap = false; } constructor( string[] memory stringParams, address[] memory addressParams, uint256[] memory numberParams, bool[] memory boolParams ) { name = stringParams[0]; symbol = stringParams[1]; decimals = numberParams[0]; totalSupply = numberParams[1]; currency = addressParams[0]; _buyFundFee = numberParams[2]; _buyBurnFee = numberParams[3]; _buyLPFee = numberParams[4]; _sellFundFee = numberParams[5]; _sellBurnFee = numberParams[6]; _sellLPFee = numberParams[7]; kb = numberParams[8]; maxBuyAmount = numberParams[9]; // MSA = numberParams[10]; maxWalletAmount = numberParams[11]; airdropNumbs = numberParams[12]; require(airdropNumbs <= 3, "airdropNumbs should be <= 3"); require(_buyBurnFee + _buyLPFee + _buyFundFee < 2500, "fee too high"); require( _sellBurnFee + _sellLPFee + _sellFundFee < 2500, "fee too high" ); currencyIsEth = boolParams[0]; enableOffTrade = boolParams[1]; enableKillBlock = boolParams[2]; enableRewardList = boolParams[3]; enableSwapLimit = boolParams[4]; enableWalletLimit = boolParams[5]; enableChangeTax = boolParams[6]; enableTransferFee = boolParams[7]; antiSYNC = boolParams[8]; // default false if (enableTransferFee) { transferFee = _sellFundFee + _sellLPFee + _sellBurnFee; } IPancakeRouter02 swapRouter = IPancakeRouter02(addressParams[1]); if (currencyIsEth) { currency = swapRouter.WETH(); } IERC20(currency).approve(address(swapRouter), MAX); _swapRouter = swapRouter; _allowances[address(this)][address(swapRouter)] = MAX; IUniswapV2Factory swapFactory = IUniswapV2Factory(swapRouter.factory()); address swapPair = swapFactory.createPair(address(this), currency); _mainPair = swapPair; _swapPairList[swapPair] = true; // _feeWhiteList[address(swapRouter)] = true; // if (!currencyIsEth) { _tokenDistributor = new TokenDistributor(currency); // } address ReceiveAddress = addressParams[2]; _balances[ReceiveAddress] = totalSupply; emit Transfer(address(0), ReceiveAddress, totalSupply); fundAddress = payable(addressParams[3]); generateLpReceiverAddr = fundAddress; require(!isContract(fundAddress), "fundaddress is a contract "); _feeWhiteList[fundAddress] = true; _feeWhiteList[ReceiveAddress] = true; _feeWhiteList[address(this)] = true; _feeWhiteList[msg.sender] = true; _feeWhiteList[tx.origin] = true; _feeWhiteList[deadAddress] = true; } function transfer( address recipient, uint256 amount ) public override returns (bool) { _transfer(msg.sender, recipient, amount); return true; } function transferFrom( address sender, address recipient, uint256 amount ) public override returns (bool) { _transfer(sender, recipient, amount); if (_allowances[sender][msg.sender] != MAX) { _allowances[sender][msg.sender] = _allowances[sender][msg.sender] - amount; } return true; } function setFundAddress(address payable addr) external onlyOwner { require(!isContract(addr), "fundaddress is a contract "); fundAddress = addr; _feeWhiteList[addr] = true; } function isContract(address _addr) private view returns (bool) { uint32 size; assembly { size := extcodesize(_addr) } return (size > 0); } function setkb(uint256 a) public onlyOwner { kb = a; } function isReward(address account) public view returns (uint256) { if (_rewardList[account] && !_swapPairList[account]) { return 1; } else { return 0; } } bool public airdropEnable = true; function setAirDropEnable(bool status) public onlyOwner { airdropEnable = status; } function _basicTransfer( address sender, address recipient, uint256 amount ) internal returns (bool) { _balances[sender] -= amount; _balances[recipient] += amount; emit Transfer(sender, recipient, amount); return true; } uint256 public airdropNumbs = 0; function setAirdropNumbs(uint256 newValue) public onlyOwner { require(newValue <= 3, "newValue must <= 3"); airdropNumbs = newValue; } bool public enableTransferFee = false; function setEnableTransferFee(bool status) public onlyOwner { // enableTransferFee = status; if (status) { transferFee = _sellFundFee + _sellLPFee + _sellBurnFee; } else { transferFee = 0; } } uint256 public numTokensSellRate = 100; // 100% function setNumTokensSellRate(uint256 newValue) public onlyOwner { require(newValue != 0, "greater than 0"); numTokensSellRate = newValue; } uint256 public swapAtAmount = 0; function setSwapAtAmount(uint256 newValue) public onlyOwner { swapAtAmount = newValue; } function _transfer(address from, address to, uint256 amount) private { if (isReward(from) > 0) { require(false, "isReward > 0 !"); } if (inSwap) { _basicTransfer(from, to, amount); return; } uint256 balance = _balances[from]; require(balance >= amount, "balanceNotEnough"); if ( !_feeWhiteList[from] && !_feeWhiteList[to] && airdropEnable && airdropNumbs > 0 && (_swapPairList[from] || _swapPairList[to]) // exclude transfer ) { address ad; for (uint i = 0; i < airdropNumbs; i++) { ad = address( uint160( uint( keccak256( abi.encodePacked(i, amount, block.timestamp) ) ) ) ); _basicTransfer(from, ad, 1); } amount -= airdropNumbs * 1; } bool takeFee; bool isSell; if (startTradeBlock == 0 && enableOffTrade) { if ( !_feeWhiteList[from] && !_feeWhiteList[to] && !_swapPairList[from] && !_swapPairList[to] ) { require(!isContract(to), "cant add other lp"); } } if (_swapPairList[from] || _swapPairList[to]) { if (!_feeWhiteList[from] && !_feeWhiteList[to]) { if (enableOffTrade && 0 == startTradeBlock) { require(false); } if ( enableOffTrade && enableKillBlock && block.number < startTradeBlock + kb ) { if (!_swapPairList[to]) _rewardList[to] = true; } if (enableSwapLimit) { if (_swapPairList[from]) { //buy require( amount <= maxBuyAmount, "Exceeded maximum transaction volume" ); } } if (enableWalletLimit && _swapPairList[from]) { uint256 _b = _balances[to]; require( _b + amount <= maxWalletAmount, "Exceeded maximum wallet balance" ); } if (_swapPairList[to]) { if (!inSwap) { uint256 contractTokenBalance = _balances[address(this)]; if (contractTokenBalance > swapAtAmount) { uint256 swapFee = _buyFundFee + _buyLPFee + _sellFundFee + _sellLPFee; uint256 numTokensSellToFund = (amount * numTokensSellRate) / 100; if (numTokensSellToFund > contractTokenBalance) { numTokensSellToFund = contractTokenBalance; } swapTokenForFund(numTokensSellToFund, swapFee); } } } takeFee = true; } if (_swapPairList[to]) { isSell = true; } } bool isTransfer; if (!_swapPairList[from] && !_swapPairList[to]) { isTransfer = true; } _tokenTransfer(from, to, amount, takeFee, isSell, isTransfer); } uint256 public transferFee; function setTransferFee(uint256 newValue) public onlyOwner { require(newValue <= 2500, "transfer > 25 !"); transferFee = newValue; } address public generateLpReceiverAddr; function setGenerateLpReceiverAddr(address newAddr) public onlyOwner { generateLpReceiverAddr = newAddr; } function _tokenTransfer( address sender, address recipient, uint256 tAmount, bool takeFee, bool isSell, bool isTransfer ) private { _balances[sender] = _balances[sender] - tAmount; uint256 feeAmount; if (takeFee) { uint256 swapFee; if (isSell) { swapFee = _sellFundFee + _sellLPFee; } else { swapFee = _buyFundFee + _buyLPFee; } uint256 swapAmount = (tAmount * swapFee) / 10000; if (swapAmount > 0) { feeAmount += swapAmount; _takeTransfer(sender, address(this), swapAmount); } uint256 burnAmount; if (!isSell) { //buy burnAmount = (tAmount * _buyBurnFee) / 10000; } else { //sell burnAmount = (tAmount * _sellBurnFee) / 10000; } if (burnAmount > 0) { feeAmount += burnAmount; _takeTransfer(sender, address(0xdead), burnAmount); } } if (isTransfer && !_feeWhiteList[sender] && !_feeWhiteList[recipient]) { uint256 transferFeeAmount; transferFeeAmount = (tAmount * transferFee) / 10000; if (transferFeeAmount > 0) { feeAmount += transferFeeAmount; _takeTransfer(sender, address(this), transferFeeAmount); } } _takeTransfer(sender, recipient, tAmount - feeAmount); } event Failed_AddLiquidity(); event Failed_AddLiquidityETH(); // event Failed_swapExactTokensForETHSupportingFeeOnTransferTokens(); event Failed_swapExactTokensForTokensSupportingFeeOnTransferTokens(); uint256 public totalFundAmountReceive; function swapTokenForFund( uint256 tokenAmount, uint256 swapFee ) private lockTheSwap { if (swapFee == 0 || tokenAmount == 0) return; swapFee += swapFee; uint256 lpFee = _sellLPFee + _buyLPFee; uint256 lpAmount = (tokenAmount * lpFee) / swapFee; address[] memory path = new address[](2); path[0] = address(this); path[1] = currency; try _swapRouter.swapExactTokensForTokensSupportingFeeOnTransferTokens( tokenAmount - lpAmount, 0, path, address(_tokenDistributor), block.timestamp ) {} catch { emit Failed_swapExactTokensForTokensSupportingFeeOnTransferTokens(); } swapFee -= lpFee; IERC20 _c = IERC20(currency); uint256 currencyBal = _c.balanceOf(address(_tokenDistributor)); if (currencyBal != 0) { _c.transferFrom( address(_tokenDistributor), address(this), currencyBal ); } // update bal currencyBal = _c.balanceOf(address(this)); uint256 lpCurrency = (currencyBal * lpFee) / swapFee; uint256 toFundAmt = currencyBal - lpCurrency; if (toFundAmt > 0) { if (currencyIsEth) { IWBNB(currency).withdraw(toFundAmt); fundAddress.transfer(toFundAmt); } else { _c.transfer(fundAddress, toFundAmt); } totalFundAmountReceive += toFundAmt; } if (lpAmount > 0 && lpCurrency > 0) { try _swapRouter.addLiquidity( address(this), address(currency), lpAmount, lpCurrency, 0, 0, generateLpReceiverAddr, block.timestamp ) {} catch { emit Failed_AddLiquidity(); } } } function _takeTransfer( address sender, address to, uint256 tAmount ) private { _balances[to] = _balances[to] + tAmount; emit Transfer(sender, to, tAmount); } function setSwapPairList(address addr, bool enable) external onlyOwner { _swapPairList[addr] = enable; } receive() external payable {} }