Transaction Hash:
Block:
20823004 at Sep-24-2024 08:59:59 PM +UTC
Transaction Fee:
0.001362783262675036 ETH
$3.66
Gas Used:
46,972 Gas / 29.012672713 Gwei
Emitted Events:
378 |
CreateAI.Approval( owner=[Sender] 0x9374176ba0e0e56d1f244b2f4ba32a794bf06e0e, spender=0x00000000...43aC78BA3, value=3510066038991980293635 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x4838B106...B0BAD5f97
Miner
| (Titan Builder) | 21.480982899767879704 Eth | 21.481119588287879704 Eth | 0.00013668852 | |
0x9374176B...94BF06e0e |
0.023412911585888225 Eth
Nonce: 226
|
0.022050128323213189 Eth
Nonce: 227
| 0.001362783262675036 | ||
0xa2D4af83...F8ac43380 |
Execution Trace
CreateAI.approve( spender=0x000000000022D473030F116dDEE9F6B43aC78BA3, value=3510066038991980293635 ) => ( True )
approve[ERC20 (ln:135)]
_msgSender[ERC20 (ln:140)]
_approve[ERC20 (ln:141)]
_approve[ERC20 (ln:223)]
/* Create AI - [CREATE] The Ultimate AI Ecosystem suite for content creators and game developers. Advanced tools Powering an immersive world of creative ideas and content WEB: https://create-ai.io/ Twitter(X): https://x.com/createai_ PORTAL: https://t.me/createai_portal */ // SPDX-License-Identifier: MIT pragma solidity 0.8.27; interface IERC20 { event Transfer(address indexed from, address indexed to, uint256 value); event Approval( address indexed owner, address indexed spender, uint256 value ); function totalSupply() external view returns (uint256); function balanceOf(address account) external view returns (uint256); function transfer(address to, uint256 value) external returns (bool); function allowance(address owner, address spender) external view returns (uint256); function approve(address spender, uint256 value) external returns (bool); function transferFrom( address from, address to, uint256 value ) external returns (bool); } interface IERC20Metadata is IERC20 { function name() external view returns (string memory); function symbol() external view returns (string memory); function decimals() external view returns (uint8); } abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } } interface IERC20Errors { error ERC20InsufficientBalance( address sender, uint256 balance, uint256 needed ); error ERC20InvalidSender(address sender); error ERC20InvalidReceiver(address receiver); error ERC20InsufficientAllowance( address spender, uint256 allowance, uint256 needed ); error ERC20InvalidApprover(address approver); error ERC20InvalidSpender(address spender); } abstract contract ERC20 is Context, IERC20, IERC20Metadata, IERC20Errors { mapping(address => uint256) private _balances; mapping(address => mapping(address => uint256)) private _allowances; uint256 private _totalSupply; string private _name; string private _symbol; constructor(string memory name_, string memory symbol_) { _name = name_; _symbol = symbol_; } function name() public view virtual returns (string memory) { return _name; } function symbol() public view virtual returns (string memory) { return _symbol; } function decimals() public view virtual returns (uint8) { return 18; } function totalSupply() public view virtual returns (uint256) { return _totalSupply; } function balanceOf(address account) public view virtual returns (uint256) { return _balances[account]; } function transfer(address to, uint256 value) public virtual returns (bool) { address owner = _msgSender(); _transfer(owner, to, value); return true; } function allowance(address owner, address spender) public view virtual returns (uint256) { return _allowances[owner][spender]; } function approve(address spender, uint256 value) public virtual returns (bool) { address owner = _msgSender(); _approve(owner, spender, value); return true; } function transferFrom( address from, address to, uint256 value ) public virtual returns (bool) { address spender = _msgSender(); _spendAllowance(from, spender, value); _transfer(from, to, value); return true; } function _transfer( address from, address to, uint256 value ) internal { if (from == address(0)) { revert ERC20InvalidSender(address(0)); } if (to == address(0)) { revert ERC20InvalidReceiver(address(0)); } _update(from, to, value); } function _update( address from, address to, uint256 value ) internal virtual { if (from == address(0)) { _totalSupply += value; } else { uint256 fromBalance = _balances[from]; if (fromBalance < value) { revert ERC20InsufficientBalance(from, fromBalance, value); } unchecked { _balances[from] = fromBalance - value; } } if (to == address(0)) { unchecked { _totalSupply -= value; } } else { unchecked { _balances[to] += value; } } emit Transfer(from, to, value); } function _mint(address account, uint256 value) internal { if (account == address(0)) { revert ERC20InvalidReceiver(address(0)); } _update(address(0), account, value); } function _burn(address account, uint256 value) internal { if (account == address(0)) { revert ERC20InvalidSender(address(0)); } _update(account, address(0), value); } function _approve( address owner, address spender, uint256 value ) internal { _approve(owner, spender, value, true); } function _approve( address owner, address spender, uint256 value, bool emitEvent ) internal virtual { if (owner == address(0)) { revert ERC20InvalidApprover(address(0)); } if (spender == address(0)) { revert ERC20InvalidSpender(address(0)); } _allowances[owner][spender] = value; if (emitEvent) { emit Approval(owner, spender, value); } } function _spendAllowance( address owner, address spender, uint256 value ) internal virtual { uint256 currentAllowance = allowance(owner, spender); if (currentAllowance != type(uint256).max) { if (currentAllowance < value) { revert ERC20InsufficientAllowance( spender, currentAllowance, value ); } unchecked { _approve(owner, spender, currentAllowance - value, false); } } } } abstract contract Ownable is Context { address private _owner; error OwnableUnauthorizedAccount(address account); error OwnableInvalidOwner(address owner); event OwnershipTransferred( address indexed previousOwner, address indexed newOwner ); constructor(address initialOwner) { if (initialOwner == address(0)) { revert OwnableInvalidOwner(address(0)); } _transferOwnership(initialOwner); } modifier onlyOwner() { _checkOwner(); _; } function owner() public view virtual returns (address) { return _owner; } function _checkOwner() internal view virtual { if (owner() != _msgSender()) { revert OwnableUnauthorizedAccount(_msgSender()); } } function renounceOwnership() public virtual onlyOwner { _transferOwnership(address(0)); } function transferOwnership(address newOwner) public virtual onlyOwner { if (newOwner == address(0)) { revert OwnableInvalidOwner(address(0)); } _transferOwnership(newOwner); } function _transferOwnership(address newOwner) internal virtual { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } } interface IUniswapV2Factory { function createPair(address tokenA, address tokenB) external returns (address pair); } interface IUniswapV2Router { function factory() external pure returns (address); function WETH() external pure returns (address); function swapExactTokensForETHSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; function addLiquidityETH( address token, uint amountTokenDesired, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external payable returns (uint amountToken, uint amountETH, uint liquidity); } contract CreateAI is Ownable, ERC20 { IUniswapV2Router public immutable uniswapV2Router; address public constant ZERO_ADDRESS = address(0); address public constant DEAD_ADDRESS = address(0xdEaD); address public uniswapV2Pair; address public operationsWallet; address public marketingWallet; address public adminWallet; address public expenseWallet; bool public isLimitsEnabled; bool public isCooldownEnabled; bool public isTaxEnabled; bool private inSwapBack; bool public isLaunched; bool public CanAddBots; uint256 public launchBlock; uint256 public launchTime; uint256 private lastSwapBackExecutionBlock; uint256 public maxBuy; uint256 public maxSell; uint256 public maxWallet; uint256 public swapTokensAtAmount; uint256 public buyFee; uint256 public sellFee; uint256 public transferFee; mapping(address => bool) public isBot; mapping(address => bool) public isExcludedFromFees; mapping(address => bool) public isExcludedFromLimits; mapping(address => bool) public automatedMarketMakerPairs; mapping(address => uint256) private _holderLastTransferTimestamp; event Launch(); event SetOperationsWallet(address newWallet, address oldWallet); event SetmarketingWallet(address newWallet, address oldWallet); event SetLimitsEnabled(bool status); event SetCooldownEnabled(bool status); event SetTaxesEnabled(bool status); event SetMaxBuy(uint256 amount); event SetMaxSell(uint256 amount); event SetMaxWallet(uint256 amount); event SetSwapTokensAtAmount(uint256 newValue, uint256 oldValue); event SetBuyFees(uint256 newValue, uint256 oldValue); event SetSellFees(uint256 newValue, uint256 oldValue); event SetTransferFees(uint256 newValue, uint256 oldValue); event ExcludeFromFees(address account, bool isExcluded); event ExcludeFromLimits(address account, bool isExcluded); event SetBots(address account, bool isExcluded); event SetAutomatedMarketMakerPair(address pair, bool value); event WithdrawStuckTokens(address token, uint256 amount); error AlreadyLaunched(); error AddressZero(); error AmountTooLow(); error AmountTooHigh(); error FeeTooHigh(); error AMMAlreadySet(); error NoNativeTokens(); error NoTokens(); error FailedToWithdrawNativeTokens(); error BotDetected(); error TransferDelay(); error MaxBuyAmountExceed(); error MaxSellAmountExceed(); error MaxWalletAmountExceed(); error NotLaunched(); modifier lockSwapBack() { inSwapBack = true; _; inSwapBack = false; } constructor() Ownable(msg.sender) ERC20("Create AI", "CREATE") { address sender = msg.sender; _mint(sender, 100_000_000 ether); uint256 totalSupply = totalSupply(); operationsWallet = 0x94e817a2d10D5D7fd3268480F4a263c1b6951a73; //31.5 marketingWallet = 0x6816559Da854ad4272f6ABF3999D770F58487A02; //40.5 adminWallet = 0x65a14Ace692bA6Df5D3A31AFC224a22fB504219B; //18 expenseWallet = 0x35EaeA96Bc652925C8084F723365069DE78B4dB6; //10 maxBuy = (totalSupply * 12) / 1000; maxSell = (totalSupply * 12) / 1000; maxWallet = (totalSupply * 12) / 1000; swapTokensAtAmount = (totalSupply * 375) / 1000000; isLimitsEnabled = true; isCooldownEnabled = true; isTaxEnabled = true; CanAddBots = true; buyFee = 20; sellFee = 70; transferFee = 70; uniswapV2Router = IUniswapV2Router(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D); _excludeFromFees(address(this), true); _excludeFromFees(address(0xdead), true); _excludeFromFees(sender, true); _excludeFromFees(operationsWallet, true); _excludeFromFees(marketingWallet, true); _excludeFromLimits(address(this), true); _excludeFromLimits(address(0xdead), true); _excludeFromLimits(sender, true); _excludeFromLimits(operationsWallet, true); _excludeFromLimits(marketingWallet, true); } receive() external payable {} fallback() external payable {} function _transferOwnership(address newOwner) internal override { address oldOwner = owner(); if (oldOwner != address(0)) { _excludeFromFees(oldOwner, false); _excludeFromLimits(oldOwner, false); } _excludeFromFees(newOwner, true); _excludeFromLimits(newOwner, true); super._transferOwnership(newOwner); } function launch() external onlyOwner { require(!isLaunched, AlreadyLaunched()); uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair( address(this), uniswapV2Router.WETH() ); _setAutomatedMarketMakerPair(uniswapV2Pair, true); _approve(address(this), address(uniswapV2Router), type(uint256).max); uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp); IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max); isLaunched = true; launchBlock = block.number; launchTime = block.timestamp; emit Launch(); } function setOperationsWallet(address _operationsWallet) external onlyOwner { require(_operationsWallet != address(0), AddressZero()); address oldWallet = operationsWallet; operationsWallet = _operationsWallet; emit SetOperationsWallet(operationsWallet, oldWallet); } function setmarketingWallet(address _marketingWallet) external onlyOwner { require(_marketingWallet != address(0), AddressZero()); address oldWallet = marketingWallet; marketingWallet = _marketingWallet; emit SetmarketingWallet(marketingWallet, oldWallet); } function RemoveLimits() external onlyOwner { isLimitsEnabled = false; emit SetLimitsEnabled(false); } function RemoveCooldown() external onlyOwner { isCooldownEnabled = false; emit SetCooldownEnabled(false); } function setTaxesEnabled(bool value) external onlyOwner { isTaxEnabled = value; emit SetTaxesEnabled(value); } function setSwapTokensAtAmount(uint256 amount) external onlyOwner { uint256 _totalSupply = totalSupply(); require(amount >= (_totalSupply * 1) / 1000000, AmountTooLow()); require(amount <= (_totalSupply * 5) / 1000, AmountTooHigh()); uint256 oldValue = swapTokensAtAmount; swapTokensAtAmount = amount; emit SetSwapTokensAtAmount(amount, oldValue); } function ReduceBuyFees(uint256 _buyFee) external onlyOwner { if (block.number == launchBlock){ buyFee = _buyFee; } else { require(_buyFee <= buyFee, FeeTooHigh()); uint256 oldValue = buyFee; buyFee = _buyFee; emit SetBuyFees(_buyFee, oldValue); }} function ReduceSellFees(uint256 _sellFee) external onlyOwner { require(_sellFee <= sellFee, FeeTooHigh()); uint256 oldValue = sellFee; sellFee = _sellFee; emit SetSellFees(_sellFee, oldValue); } function ReduceTransferFees(uint256 _transferFee) external onlyOwner { require(_transferFee <= transferFee, FeeTooHigh()); uint256 oldValue = transferFee; transferFee = _transferFee; emit SetTransferFees(_transferFee, oldValue); } function excludeFromFees(address[] calldata accounts, bool value) external onlyOwner { for (uint256 i = 0; i < accounts.length; i++) { _excludeFromFees(accounts[i], value); } } function excludeFromLimits(address[] calldata accounts, bool value) external onlyOwner { for (uint256 i = 0; i < accounts.length; i++) { _excludeFromLimits(accounts[i], value); } } function DisableAddBots() external onlyOwner { require(CanAddBots, "Already Disabled"); CanAddBots = false; } function setBots(address[] calldata accounts, bool value) external onlyOwner { require(CanAddBots, "Can't Add more bots now"); for (uint256 i = 0; i < accounts.length; i++) { if ( (!automatedMarketMakerPairs[accounts[i]]) && (accounts[i] != address(uniswapV2Router)) && (accounts[i] != address(this)) && (accounts[i] != ZERO_ADDRESS) && (!isExcludedFromFees[accounts[i]] && !isExcludedFromLimits[accounts[i]]) ) _setBots(accounts[i], value); } } function RemoveBotWallet(address _wallet) external onlyOwner { _setBots(_wallet, false); } function withdrawStuckTokens(address _token) external onlyOwner { address sender = msg.sender; uint256 amount; if (_token == ZERO_ADDRESS) { bool success; amount = address(this).balance; require(amount > 0, NoNativeTokens()); (success, ) = address(sender).call{value: amount}(""); require(success, FailedToWithdrawNativeTokens()); } else { amount = IERC20(_token).balanceOf(address(this)); require(amount > 0, NoTokens()); IERC20(_token).transfer(msg.sender, amount); } emit WithdrawStuckTokens(_token, amount); } function _update( address from, address to, uint256 amount ) internal virtual override { address sender = msg.sender; address origin = tx.origin; require(!isBot[from], BotDetected()); require(sender == from || !isBot[sender], BotDetected()); require( origin == from || origin == sender || !isBot[origin], BotDetected() ); require( isLaunched || isExcludedFromLimits[from] || isExcludedFromLimits[to], NotLaunched() ); bool limits = isLimitsEnabled && !inSwapBack && !(isExcludedFromLimits[from] || isExcludedFromLimits[to]); if (limits) { if ( from != owner() && to != owner() && to != ZERO_ADDRESS && to != DEAD_ADDRESS ) { if (isCooldownEnabled) { if (to != address(uniswapV2Router) && to != uniswapV2Pair) { require( _holderLastTransferTimestamp[origin] < block.number - 3 && _holderLastTransferTimestamp[to] < block.number - 3, TransferDelay() ); _holderLastTransferTimestamp[origin] = block.number; _holderLastTransferTimestamp[to] = block.number; } } if ( automatedMarketMakerPairs[from] && !isExcludedFromLimits[to] ) { require(amount <= maxBuy, MaxBuyAmountExceed()); require( amount + balanceOf(to) <= maxWallet, MaxWalletAmountExceed() ); } else if ( automatedMarketMakerPairs[to] && !isExcludedFromLimits[from] ) { require(amount <= maxSell, MaxSellAmountExceed()); } else if (!isExcludedFromLimits[to]) { require( amount + balanceOf(to) <= maxWallet, MaxWalletAmountExceed() ); } } } bool takeFee = isTaxEnabled && !inSwapBack && !(isExcludedFromFees[from] || isExcludedFromFees[to]); if (takeFee) { uint256 fees = 0; if (automatedMarketMakerPairs[to] && sellFee > 0) { fees = (amount * sellFee) / 100; } else if (automatedMarketMakerPairs[from] && buyFee > 0) { fees = (amount * buyFee) / 100; } else if ( !automatedMarketMakerPairs[to] && !automatedMarketMakerPairs[from] && transferFee > 0 ) { fees = (amount * transferFee) / 100; } if (fees > 0) { amount -= fees; super._update(from, address(this), fees); } } uint256 balance = balanceOf(address(this)); bool shouldSwap = balance >= swapTokensAtAmount; if (takeFee && !automatedMarketMakerPairs[from] && shouldSwap) { if (block.number > lastSwapBackExecutionBlock) { _swapBack(balance); lastSwapBackExecutionBlock = block.number; } } super._update(from, to, amount); } function _swapBack(uint256 balance) internal virtual lockSwapBack { bool success; address[] memory path = new address[](2); path[0] = address(this); path[1] = uniswapV2Router.WETH(); uint256 maxSwapAmount = swapTokensAtAmount * 20; if (balance > maxSwapAmount) { balance = maxSwapAmount; } uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens( balance, 0, path, address(this), block.timestamp ); uint256 ethBalance = address(this).balance; uint256 ethForOperations = (ethBalance * 315) / 1000; uint256 ethForAdmin = (ethBalance * 180) / 1000; uint256 ethForExpense = (ethBalance * 100) / 1000; uint256 ethForMarketing = (ethBalance * 405) / 1000; (success, ) = address(operationsWallet).call{value: ethForOperations}( "" ); (success, ) = address(adminWallet).call{value: ethForAdmin}( "" ); (success, ) = address(expenseWallet).call{value: ethForExpense}( "" ); (success, ) = address(marketingWallet).call{value: ethForMarketing}( "" ); } function _excludeFromFees(address account, bool value) internal virtual { isExcludedFromFees[account] = value; emit ExcludeFromFees(account, value); } function _excludeFromLimits(address account, bool value) internal virtual { isExcludedFromLimits[account] = value; emit ExcludeFromLimits(account, value); } function _setBots(address account, bool value) internal virtual { isBot[account] = value; emit SetBots(account, value); } function _setAutomatedMarketMakerPair(address pair, bool value) internal virtual { automatedMarketMakerPairs[pair] = value; emit SetAutomatedMarketMakerPair(pair, value); } }