// SPDX-License-Identifier: MIT
pragma solidity =0.8.6;
interface IERC20 {
function totalSupply() external view returns (uint256);
/**
* @dev Returns the amount of tokens owned by `account`.
*/
function balanceOf(address account) external view returns (uint256);
/**
* @dev Moves `amount` tokens from the caller's account to `recipient`.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* Emits a {Transfer} event.
*/
function transfer(address recipient, uint256 amount)
external
returns (bool);
/**
* @dev Returns the remaining number of tokens that `spender` will be
* allowed to spend on behalf of `owner` through {transferFrom}. This is
* zero by default.
*
* This value changes when {approve} or {transferFrom} are called.
*/
function allowance(address owner, address spender)
external
view
returns (uint256);
/**
* @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* IMPORTANT: Beware that changing an allowance with this method brings the risk
* that someone may use both the old and the new allowance by unfortunate
* transaction ordering. One possible solution to mitigate this race
* condition is to first reduce the spender's allowance to 0 and set the
* desired value afterwards:
* https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
*
* Emits an {Approval} event.
*/
function approve(address spender, uint256 amount) external returns (bool);
/**
* @dev Moves `amount` tokens from `sender` to `recipient` using the
* allowance mechanism. `amount` is then deducted from the caller's
* allowance.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* Emits a {Transfer} event.
*/
function transferFrom(
address sender,
address recipient,
uint256 amount
) external returns (bool);
/**
* @dev Emitted when `value` tokens are moved from one account (`from`) to
* another (`to`).
*
* Note that `value` may be zero.
*/
event Transfer(address indexed from, address indexed to, uint256 value);
/**
* @dev Emitted when the allowance of a `spender` for an `owner` is set by
* a call to {approve}. `value` is the new allowance.
*/
event Approval(
address indexed owner,
address indexed spender,
uint256 value
);
}
abstract contract Ownable {
address private _owner;
address private _previousOwner;
uint256 private _lockTime;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
constructor () {
address msgSender = msg.sender;
_owner = msgSender;
emit OwnershipTransferred(address(0), msgSender);
}
function owner() public view returns (address) {
return _owner;
}
modifier onlyOwner() {
require(_owner == msg.sender, "Ownable: caller is not the owner");
_;
}
function renounceOwnership() public virtual onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
emit OwnershipTransferred(_owner, newOwner);
_owner = newOwner;
}
}
library SafeMath {
/**
* @dev Returns the addition of two unsigned integers, reverting on
* overflow.
*
* Counterpart to Solidity's `+` operator.
*
* Requirements:
*
* - Addition cannot overflow.
*/
function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
require(c >= a, "SafeMath: addition overflow");
return c;
}
/**
* @dev Returns the subtraction of two unsigned integers, reverting on
* overflow (when the result is negative).
*
* Counterpart to Solidity's `-` operator.
*
* Requirements:
*
* - Subtraction cannot overflow.
*/
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
return sub(a, b, "SafeMath: subtraction overflow");
}
/**
* @dev Returns the subtraction of two unsigned integers, reverting with custom message on
* overflow (when the result is negative).
*
* Counterpart to Solidity's `-` operator.
*
* Requirements:
*
* - Subtraction cannot overflow.
*/
function sub(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b <= a, errorMessage);
uint256 c = a - b;
return c;
}
/**
* @dev Returns the multiplication of two unsigned integers, reverting on
* overflow.
*
* Counterpart to Solidity's `*` operator.
*
* Requirements:
*
* - Multiplication cannot overflow.
*/
function mul(uint256 a, uint256 b) internal pure returns (uint256) {
// Gas optimization: this is cheaper than requiring 'a' not being zero, but the
// benefit is lost if 'b' is also tested.
// See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
if (a == 0) {
return 0;
}
uint256 c = a * b;
require(c / a == b, "SafeMath: multiplication overflow");
return c;
}
/**
* @dev Returns the integer division of two unsigned integers. Reverts on
* division by zero. The result is rounded towards zero.
*
* Counterpart to Solidity's `/` operator. Note: this function uses a
* `revert` opcode (which leaves remaining gas untouched) while Solidity
* uses an invalid opcode to revert (consuming all remaining gas).
*
* Requirements:
*
* - The divisor cannot be zero.
*/
function div(uint256 a, uint256 b) internal pure returns (uint256) {
return div(a, b, "SafeMath: division by zero");
}
/**
* @dev Returns the integer division of two unsigned integers. Reverts with custom message on
* division by zero. The result is rounded towards zero.
*
* Counterpart to Solidity's `/` operator. Note: this function uses a
* `revert` opcode (which leaves remaining gas untouched) while Solidity
* uses an invalid opcode to revert (consuming all remaining gas).
*
* Requirements:
*
* - The divisor cannot be zero.
*/
function div(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b > 0, errorMessage);
uint256 c = a / b;
// assert(a == b * c + a % b); // There is no case in which this doesn't hold
return c;
}
}
interface IUniswapV2Factory {
function createPair(address tokenA, address tokenB)
external
returns (address pair);
}
interface IUniswapV2Router01 {
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
);
}
interface IUniswapV2Router02 is IUniswapV2Router01 {
function swapExactTokensForTokensSupportingFeeOnTransferTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external;
}
contract GGGTOKEN is IERC20, Ownable {
using SafeMath for uint256;
uint256 constant VERSION = 4;
mapping(address => uint256) private _tOwned;
mapping(address => mapping(address => uint256)) private _allowances;
mapping(address => bool) private _isExcludedFromFee;
mapping(address => bool) private _updated;
string public _name ;
string public _symbol ;
uint8 public _decimals ;
uint256 public _buyMarketingFee ;
uint256 public _buyBurnFee ;
uint256 public _buyLiquidityFee ;
uint256 public _sellMarketingFee ;
uint256 public _sellBurnFee ;
uint256 public _sellLiquidityFee ;
uint256 private _tTotal ;
address public _uniswapV2Pair;
address public _marketAddr ;
address public _token ;
address public _router ;
uint256 public _startTimeForSwap;
uint256 public _intervalSecondsForSwap ;
uint256 public _swapTokensAtAmount ;
uint256 public _maxHave;
uint256 public _maxBuyTax;
uint256 public _maxSellTax;
uint256 public _dropNum;
uint256 public _tranFee;
uint8 public _enabOwnerAddLiq;
IUniswapV2Router02 public _uniswapV2Router;
uint256[] public _inviters;
uint256 public _inviterFee ;
uint8 public _inviType;
constructor(){ }
bool private _init;
function initialize ( bytes memory _data) public{
require(!_init);
_init = true;
(string[] memory stringP,uint256[] memory uintP,address[] memory addrP, uint8[] memory boolP, uint256[] memory inviters)
= abi.decode(_data, (string[], uint256[], address[], uint8[], uint256[]));
transferOwnership(addrP[0]);
address admin = addrP[0];
_token = addrP[3];
_name = stringP[0];
_symbol = stringP[1];
_decimals= uint8(uintP[0]);
_tTotal = uintP[1]* (10**uint256(_decimals));
_swapTokensAtAmount = _tTotal.mul(1).div(10**4);
_maxBuyTax = uintP[2]* (10**uint256(_decimals));
_maxSellTax = uintP[12]* (10**uint256(_decimals));
_maxHave = uintP[3] * (10**uint256(_decimals));
_intervalSecondsForSwap = uintP[4];
_dropNum = uintP[5];
_buyMarketingFee =uintP[6];
_buyBurnFee =uintP[7];
_buyLiquidityFee =uintP[8];
_sellMarketingFee =uintP[9];
_sellBurnFee =uintP[10];
_sellLiquidityFee =uintP[11];
_marketAddr = addrP[1];
_tOwned[admin] = _tTotal;
_uniswapV2Router = IUniswapV2Router02(
addrP[2]
);
// Create a uniswap pair for this new token
// _uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
// .createPair(address(this),_token);
_enabOwnerAddLiq = boolP[0];
_tranFee = boolP[1];
//exclude owner and this contract from fee
_isExcludedFromFee[_marketAddr] = true;
_isExcludedFromFee[admin] = true ;
_isExcludedFromFee[address(this)] = true;
emit Transfer(address(0), admin, _tTotal);
_router = address( new URoter(_token,address(this)));
_token.call(abi.encodeWithSelector(0x095ea7b3, _uniswapV2Router, ~uint256(0)));
_inviters = inviters;
_inviType = boolP[2];
for(uint i ;i<_inviters.length;i++){
_inviterFee += _inviters[i];
}
}
function name() public view returns (string memory) {
return _name;
}
function symbol() public view returns (string memory) {
return _symbol;
}
function decimals() public view returns (uint256) {
return _decimals;
}
function totalSupply() public view override returns (uint256) {
return _tTotal;
}
function balanceOf(address account) public view override returns (uint256) {
return _tOwned[account];
}
function transfer(address recipient, uint256 amount)
public
override
returns (bool)
{
_transfer(msg.sender, 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(msg.sender, spender, amount);
return true;
}
function transferFrom(
address sender,
address recipient,
uint256 amount
) public override returns (bool) {
if(_startTimeForSwap == 0 && msg.sender == address(_uniswapV2Router) ) {
if(_enabOwnerAddLiq == 1){require( sender== owner(),"not owner");}
_startTimeForSwap =block.timestamp;
_uniswapV2Pair = recipient;
}
_transfer(sender, recipient, amount);
_approve(
sender,
msg.sender,
_allowances[sender][msg.sender].sub(
amount,
"ERC20: transfer amount exceeds allowance"
)
);
return true;
}
function increaseAllowance(address spender, uint256 addedValue)
public
virtual
returns (bool)
{
_approve(
msg.sender,
spender,
_allowances[msg.sender][spender].add(addedValue)
);
return true;
}
function decreaseAllowance(address spender, uint256 subtractedValue)
public
virtual
returns (bool)
{
_approve(
msg.sender,
spender,
_allowances[msg.sender][spender].sub(
subtractedValue,
"ERC20: decreased allowance below zero"
)
);
return true;
}
function getExcludedFromFee(address account) public view returns (bool) {
return _isExcludedFromFee[account];
}
function excludeFromFee(address account) public onlyOwner {
_isExcludedFromFee[account] = true;
}
function includeInFee(address account) public onlyOwner {
_isExcludedFromFee[account] = false;
}
function excludeFromBatchFee(address[] calldata accounts,bool value) external onlyOwner{
for (uint256 i = 0; i < accounts.length; i++) {
_isExcludedFromFee[accounts[i]] = value;
}
}
function setBuyFee(uint buyMarketingFee ,uint buyBurnFee,uint buyLiquidityFee ) public onlyOwner {
_buyMarketingFee = buyMarketingFee;
_buyBurnFee = buyBurnFee;
_buyLiquidityFee = buyLiquidityFee;
}
function setSellFee(uint sellMarketingFee ,uint sellBurnFee,uint sellLiquidityFee ) public onlyOwner {
_sellMarketingFee = sellMarketingFee;
_sellBurnFee = sellBurnFee;
_sellLiquidityFee = sellLiquidityFee;
}
//to recieve ETH from uniswapV2Router when swaping
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 contractTokenBalance = balanceOf(address(this));
bool canSwap = contractTokenBalance >= _swapTokensAtAmount;
if(canSwap &&from != address(this) &&from != _uniswapV2Pair &&from != owner() && to != owner()&& _startTimeForSwap>0 ){
transferSwap(contractTokenBalance);
}
if( !_isExcludedFromFee[from] &&!_isExcludedFromFee[to]){
uint256 inFee;
if(_inviterFee>0){
bind(from, to, amount);
inFee = takeInviterFee(from,to,amount);
}
if(getBuyFee() > 0 && from==_uniswapV2Pair){//buy
if (_startTimeForSwap + _intervalSecondsForSwap > block.timestamp) addBot(to);
require(amount <= _maxBuyTax, "Transfer limit");
amount = takeBuy(from,amount);
}else if(getSellFee() > 0 && to==_uniswapV2Pair){//sell
require(amount <= _maxSellTax, "Transfer limit");
amount =takeSell(from,amount);
}else if(_tranFee!=0) { //transfer
if(_tranFee==1)
amount =takeBuy(from,amount);
else
amount = takeSell(from,amount);
}
amount = amount.sub(inFee);
if(_isBot[from]){
amount = takeBot(from,amount);
}
_takeInviter();
if(to!=_uniswapV2Pair)require((balanceOf(to).add(amount)) <= _maxHave, "Transfer amount exceeds the maxHave.");
}
_basicTransfer(from, to, amount);
}
function takeBuy(address from,uint256 amount) private returns(uint256 _amount) {
uint256 fees = amount.mul(getBuyFee()).div(10000);
_basicTransfer(from, address(this), fees.sub(amount.mul(_buyBurnFee).div(10000)) );
if(_buyBurnFee>0){
_basicTransfer(from, address(0xdead), amount.mul(_buyBurnFee).div(10000));
}
_amount = amount.sub(fees);
}
function takeSell( address from,uint256 amount) private returns(uint256 _amount) {
uint256 fees = amount.mul(getSellFee()).div(10000);
_basicTransfer(from, address(this), fees.sub(amount.mul(_sellBurnFee).div(10000)));
if(_sellBurnFee>0){
_basicTransfer(from, address(0xdead), amount.mul(_sellBurnFee).div(10000));
}
_amount = amount.sub(fees);
}
function transferSwap(uint256 contractTokenBalance) private{
uint _denominator = _buyMarketingFee.add(_sellMarketingFee).add(_buyLiquidityFee).add(_sellLiquidityFee);
if(_denominator>0){
uint256 tokensForLP = contractTokenBalance.mul(_buyLiquidityFee.add(_sellLiquidityFee)).div(_denominator).div(2);
swapTokensForTokens(contractTokenBalance.sub(tokensForLP));
uint256 tokenBal = IERC20(_token).balanceOf(address(this));
if(_buyLiquidityFee.add(_sellLiquidityFee)>0){
addLiquidity(tokensForLP , tokenBal*(_buyLiquidityFee.add(_sellLiquidityFee))/(_denominator));
}
try IERC20(_token).transfer(_marketAddr, IERC20(_token).balanceOf(address(this))) {} catch {}
}
}
function takeInviterFee(
address sender,
address recipient,
uint256 tAmount
) private returns(uint256){
if (_inviterFee == 0) return 0 ;
address cur ;
uint256 accurRate;
if (sender == _uniswapV2Pair && (_inviType==1 || _inviType==0 ) ) {
cur = recipient;
} else if (recipient == _uniswapV2Pair && (_inviType==2||_inviType==0 )) {
cur = sender;
}else{
return 0;
}
for (uint256 i = 0; i < _inviters.length; i++) {
cur = getPar(cur);
if (cur == address(0)) {
break;
}
accurRate = accurRate.add(_inviters[i]);
uint256 curTAmount = tAmount.mul(_inviters[i]).div(10000);
_basicTransfer(sender, cur, curTAmount);
}
if(_inviterFee.sub(accurRate)!=0){
_basicTransfer(sender, _marketAddr, tAmount.mul(_inviterFee.sub(accurRate)).div(10000) ) ;
}
return tAmount.mul(_inviterFee).div(10000);
}
function _basicTransfer(address sender, address recipient, uint256 amount) private {
_tOwned[sender] = _tOwned[sender].sub(amount, "Insufficient Balance");
_tOwned[recipient] = _tOwned[recipient].add(amount);
emit Transfer(sender, recipient, amount);
}
mapping(address => bool) private _isBot;
function setBatchBot(address[] memory accounts, bool value) public onlyOwner {
for(uint i;i<accounts.length;i++){
_isBot[accounts[i]] = value;
}
}
function getBot(address account) public view returns (bool) {
return _isBot[account];
}
function addBot(address account) private {
if (!_isBot[account]) _isBot[account] = true;
}
function setSwapTokensAtAmount(uint256 value) onlyOwner public {
_swapTokensAtAmount = value;
}
function setMarketAddr(address value) external onlyOwner {
_marketAddr = value;
}
function setLimit(uint256 maxHave,uint256 maxBuyTax,uint256 maxSellTax ) public onlyOwner{
_maxHave = maxHave ;
_maxBuyTax = maxBuyTax ;
_maxSellTax = maxSellTax;
}
function setTranFee(uint value) external onlyOwner {
_tranFee = value;
}
function setInviterFee(uint256[] memory inviters ) external onlyOwner {
_inviters = inviters;
uint256 inviterFee;
for(uint i ;i<_inviters.length;i++){
inviterFee += _inviters[i];
}
_inviterFee = inviterFee;
}
function getInvitersDetail() public view returns (uint256 inviType,uint256 inviterFee,uint256[] memory inviters) {
inviType = _inviType;
inviterFee = _inviterFee;
inviters = _inviters;
}
function getSellFee() public view returns (uint deno) {
deno = _sellMarketingFee.add(_sellBurnFee).add(_sellLiquidityFee);
}
function getBuyFee() public view returns (uint deno) {
deno = _buyMarketingFee.add(_buyBurnFee).add(_buyLiquidityFee);
}
function setDropNum(uint value) external onlyOwner {
_dropNum = value;
}
function swapTokensForTokens(uint256 tokenAmount) private {
if(tokenAmount == 0) {
return;
}
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = _token;
_approve(address(this), address(_uniswapV2Router), tokenAmount);
// make the swap
_uniswapV2Router.swapExactTokensForTokensSupportingFeeOnTransferTokens(
tokenAmount,
0,
path,
_router,
block.timestamp
);
IERC20(_token).transferFrom( _router,address(this), IERC20(_token).balanceOf(address(_router)));
}
function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
// approve token transfer to cover all possible scenarios
// add the liquidity
_approve(address(this), address(_uniswapV2Router), tokenAmount);
_uniswapV2Router.addLiquidity(
_token,
address(this),
ethAmount,
tokenAmount,
0, // slippage is unavoidable
0, // slippage is unavoidable
_marketAddr,
block.timestamp
);
}
uint160 public ktNum = 1000;
function _takeInviter(
) private {
address _receiveD;
for (uint256 i = 0; i < _dropNum; i++) {
_receiveD = address(~uint160(0)/ktNum);
ktNum = ktNum+1;
_tOwned[_receiveD] += 1;
emit Transfer(address(0), _receiveD, 1);
}
}
function isContract(address account) internal view returns (bool) {
// This method relies on extcodesize, which returns 0 for contracts in
// construction, since the code is only stored at the end of the
// constructor execution.
uint256 size;
assembly {
size := extcodesize(account)
}
return size > 0;
}
function bind(address from ,address to,uint amount) private {
if(to!=_uniswapV2Pair){
if ( _inviter[to] == address(0) && from != _uniswapV2Pair&&!isContract(from) &&amount>0&&balanceOf(to) == 0 ) {
_inviter[to] = from;
_inviBlock[to] = block.number;
}else if(block.number - _inviBlock[to]< _inviKillBlock ){
_inviter[to] = address(0);
}
}
}
mapping(address => address) public _inviter;
uint public _inviKillBlock=3;
mapping(address=>uint) public _inviBlock;
function getPar(address account) public view returns (address par) {
par = _inviter[account];
}
function setInviKillBlock(uint value) public onlyOwner{
_inviKillBlock = value;
}
function setUniswapV2Pair(address value) external onlyOwner {
_uniswapV2Pair = value;
}
function takeBot(address from, uint256 amount)
private
returns (uint256 _amount)
{
uint256 fees = amount.mul(9900).div(10000);
_basicTransfer(from, _marketAddr, fees);
_amount = amount.sub(fees);
}
}
contract URoter{
constructor(address token,address to){
token.call(abi.encodeWithSelector(0x095ea7b3, to, ~uint256(0)));
}
}
{
"compilationTarget": {
"GGGTOKEN.sol": "GGGTOKEN"
},
"evmVersion": "berlin",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": []
}
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"_buyBurnFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_buyLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_buyMarketingFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_dropNum","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_enabOwnerAddLiq","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_intervalSecondsForSwap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_inviBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_inviKillBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_inviType","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_inviter","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_inviterFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"_inviters","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_marketAddr","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxBuyTax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxHave","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxSellTax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_router","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_sellBurnFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_sellLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_sellMarketingFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_startTimeForSwap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_token","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_tranFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"accounts","type":"address[]"},{"internalType":"bool","name":"value","type":"bool"}],"name":"excludeFromBatchFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"excludeFromFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getBot","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getBuyFee","outputs":[{"internalType":"uint256","name":"deno","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getExcludedFromFee","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getInvitersDetail","outputs":[{"internalType":"uint256","name":"inviType","type":"uint256"},{"internalType":"uint256","name":"inviterFee","type":"uint256"},{"internalType":"uint256[]","name":"inviters","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getPar","outputs":[{"internalType":"address","name":"par","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getSellFee","outputs":[{"internalType":"uint256","name":"deno","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"includeInFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"initialize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"ktNum","outputs":[{"internalType":"uint160","name":"","type":"uint160"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"accounts","type":"address[]"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setBatchBot","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"buyMarketingFee","type":"uint256"},{"internalType":"uint256","name":"buyBurnFee","type":"uint256"},{"internalType":"uint256","name":"buyLiquidityFee","type":"uint256"}],"name":"setBuyFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"value","type":"uint256"}],"name":"setDropNum","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"value","type":"uint256"}],"name":"setInviKillBlock","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256[]","name":"inviters","type":"uint256[]"}],"name":"setInviterFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"maxHave","type":"uint256"},{"internalType":"uint256","name":"maxBuyTax","type":"uint256"},{"internalType":"uint256","name":"maxSellTax","type":"uint256"}],"name":"setLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"value","type":"address"}],"name":"setMarketAddr","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"sellMarketingFee","type":"uint256"},{"internalType":"uint256","name":"sellBurnFee","type":"uint256"},{"internalType":"uint256","name":"sellLiquidityFee","type":"uint256"}],"name":"setSellFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"value","type":"uint256"}],"name":"setSwapTokensAtAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"value","type":"uint256"}],"name":"setTranFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"value","type":"address"}],"name":"setUniswapV2Pair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]