/**
8888888b. 8888888888 8888888888 8888888b. 888 888 .d8888b. 888888b.
888 "Y88b 888 888 888 Y88b 888 o 888 d88P Y88b 888 "88b
888 888 888 888 888 888 888 d8b 888 .d88P 888 .88P
888 888 8888888 8888888 888 d88P 888 d888b 888 8888" 8888888K.
888 888 888 888 8888888P" 888d88888b888 "Y8b. 888 "Y88b
888 888 888 888 888 88888P Y88888 888 888 888 888
888 .d88P 888 888 888 8888P Y8888 Y88b d88P 888 d88P
8888888P" 8888888888 8888888888 888 888P Y888 "Y8888P" 8888888P"
--------------------------------------------------------
CONTRACT AUDITED: https://deepw3b.com/api/static/deepw3b_contract_audit.pdf
--------------------------------------------------------
WEB: deepw3b.com
TELEGRAM: https://t.me/Deepw3b_com
TWITTER: https://twitter.com/deepw3b_
YOUTUBE: https://www.youtube.com/@deepw3b_/
IG: https://www.instagram.com/deepw3b_com/
TIKTOK: https://www.tiktok.com/@deepw3b_com
*/
// SPDX-License-Identifier: Unlicensed
pragma solidity >=0.6.0 <0.9.0;
interface IERC20 {
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
);
}
interface IFactoryV2 {
event PairCreated(
address indexed token0,
address indexed token1,
address lpPair,
uint256
);
function getPair(address tokenA, address tokenB)
external
view
returns (address lpPair);
function createPair(address tokenA, address tokenB)
external
returns (address lpPair);
}
interface IV2Pair {
function factory() external view returns (address);
function getReserves()
external
view
returns (
uint112 reserve0,
uint112 reserve1,
uint32 blockTimestampLast
);
function sync() external;
}
interface IRouter01 {
function factory() external pure returns (address);
function WETH() external pure returns (address);
function addLiquidityETH(
address token,
uint256 amountTokenDesired,
uint256 amountTokenMin,
uint256 amountETHMin,
address to,
uint256 deadline
)
external
payable
returns (
uint256 amountToken,
uint256 amountETH,
uint256 liquidity
);
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 swapExactETHForTokens(
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external payable returns (uint256[] memory amounts);
function getAmountsOut(uint256 amountIn, address[] calldata path)
external
view
returns (uint256[] memory amounts);
function getAmountsIn(uint256 amountOut, address[] calldata path)
external
view
returns (uint256[] memory amounts);
}
interface IRouter02 is IRouter01 {
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external;
function swapExactETHForTokensSupportingFeeOnTransferTokens(
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external payable;
function swapExactTokensForTokensSupportingFeeOnTransferTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external;
function swapExactTokensForTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external returns (uint256[] memory amounts);
}
contract DEEPW3B is IERC20 {
mapping(address => uint256) private _tOwned;
mapping(address => bool) lpPairs;
uint256 private timeSinceLastPair = 0;
mapping(address => mapping(address => uint256)) private _allowances;
mapping(address => bool) private _liquidityHolders;
mapping(address => bool) private _isExcludedFromFees;
mapping(address => bool) private _isExcludedFromLimits;
uint256 private constant startingSupply = 100_000_000;
string private constant _name = "Deepw3b";
string private constant _symbol = "DW3B";
uint8 private constant _decimals = 18;
uint256 private _tTotal = startingSupply * 10**_decimals;
struct Fees {
uint16 buyFee;
uint16 sellFee;
uint16 transferFee;
}
struct Ratios {
uint16 liquidity;
uint16 operations;
uint16 burn;
uint16 totalSwap;
}
Fees public _taxRates = Fees({buyFee: 600, sellFee: 600, transferFee: 600});
Ratios public _ratios =
Ratios({liquidity: 100, operations: 500, burn: 0, totalSwap: 600});
uint256 public constant maxTransferTaxes = 600;
uint256 public constant maxBuyTaxes = 600;
uint256 public constant maxSellTaxes = 600;
uint256 constant masterTaxDivisor = 10000;
bool public taxesAreLocked;
bool public maxDisabled;
IRouter02 public dexRouter;
address public lpPair;
address public liquidityAddress;
address public constant DEAD = 0x000000000000000000000000000000000000dEaD;
struct TaxWallets {
address payable operations;
}
TaxWallets public _taxWallets =
TaxWallets({
operations: payable(0x50800A8799aE012f18a609eb2bB485981F82D9c0)
});
bool inSwap;
bool public contractSwapEnabled = false;
uint256 public swapThreshold;
uint256 public swapAmount;
bool public piContractSwapsEnabled;
uint256 public piSwapPercent = 10;
uint256 private _maxTxAmount = (_tTotal * 205) / 10000;
uint256 private _maxWalletSize = (_tTotal * 205) / 10000;
bool public tradingEnabled = false;
bool public _hasLiqBeenAdded = false;
event ContractSwapEnabledUpdated(bool enabled);
event AutoLiquify(uint256 amountCurrency, uint256 amountTokens);
modifier inSwapFlag() {
inSwap = true;
_;
inSwap = false;
}
constructor() payable {
_owner = msg.sender;
originalDeployer = msg.sender;
_tOwned[_owner] = _tTotal;
emit Transfer(address(0), _owner, _tTotal);
dexRouter = IRouter02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
lpPair = IFactoryV2(dexRouter.factory()).createPair(
dexRouter.WETH(),
address(this)
);
lpPairs[lpPair] = true;
_approve(_owner, address(dexRouter), type(uint256).max);
_approve(address(this), address(dexRouter), type(uint256).max);
_isExcludedFromFees[_owner] = true;
_isExcludedFromFees[0x50800A8799aE012f18a609eb2bB485981F82D9c0] = true;
_isExcludedFromFees[address(this)] = true;
_isExcludedFromFees[DEAD] = true;
_liquidityHolders[_owner] = true;
liquidityAddress = _owner;
}
receive() external payable {}
address private _owner;
modifier onlyOwner() {
require(_owner == msg.sender, "Caller =/= owner.");
_;
}
event OwnershipTransferred(
address indexed previousOwner,
address indexed newOwner
);
function transferOwner(address newOwner) external onlyOwner {
require(
newOwner != address(0),
"Call renounceOwnership to transfer owner to the zero address."
);
require(
newOwner != DEAD,
"Call renounceOwnership to transfer owner to the zero address."
);
setExcludedFromFees(_owner, false);
setExcludedFromFees(newOwner, true);
if (balanceOf(_owner) > 0) {
finalizeTransfer(
_owner,
newOwner,
balanceOf(_owner),
false,
false,
true
);
}
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
function renounceOwnership() external onlyOwner {
setExcludedFromFees(_owner, false);
address oldOwner = _owner;
_owner = address(0);
emit OwnershipTransferred(oldOwner, address(0));
}
address public originalDeployer;
address public operator;
function setOperator(address newOperator) public {
require(
msg.sender == originalDeployer,
"Can only be called by original deployer."
);
address oldOperator = operator;
if (oldOperator != address(0)) {
_liquidityHolders[oldOperator] = false;
setExcludedFromFees(oldOperator, false);
}
operator = newOperator;
_liquidityHolders[newOperator] = true;
setExcludedFromFees(newOperator, true);
}
function renounceOriginalDeployer() external {
require(
msg.sender == originalDeployer,
"Can only be called by original deployer."
);
setOperator(address(0));
originalDeployer = address(0);
}
function totalSupply() external view override returns (uint256) {
if (_tTotal == 0) {
revert();
}
return _tTotal;
}
function decimals() external view override returns (uint8) {
if (_tTotal == 0) {
revert();
}
return _decimals;
}
function symbol() external pure override returns (string memory) {
return _symbol;
}
function name() external pure override returns (string memory) {
return _name;
}
function getOwner() external view override returns (address) {
return _owner;
}
function allowance(address holder, address spender)
external
view
override
returns (uint256)
{
return _allowances[holder][spender];
}
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 approve(address spender, uint256 amount)
external
override
returns (bool)
{
_approve(msg.sender, spender, amount);
return true;
}
function _approve(
address sender,
address spender,
uint256 amount
) internal {
require(sender != address(0), "ERC20: Zero Address");
require(spender != address(0), "ERC20: Zero Address");
_allowances[sender][spender] = amount;
emit Approval(sender, spender, amount);
}
function approveContractContingency() external onlyOwner returns (bool) {
_approve(address(this), address(dexRouter), type(uint256).max);
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] -= amount;
}
return _transfer(sender, recipient, amount);
}
function setNewRouter(address newRouter) external onlyOwner {
require(!_hasLiqBeenAdded, "Cannot change after liquidity.");
IRouter02 _newRouter = IRouter02(newRouter);
address get_pair = IFactoryV2(_newRouter.factory()).getPair(
address(this),
_newRouter.WETH()
);
lpPairs[lpPair] = false;
if (get_pair == address(0)) {
lpPair = IFactoryV2(_newRouter.factory()).createPair(
address(this),
_newRouter.WETH()
);
} else {
lpPair = get_pair;
}
dexRouter = _newRouter;
lpPairs[lpPair] = true;
_approve(address(this), address(dexRouter), type(uint256).max);
}
function setLpPair(address pair, bool enabled) external onlyOwner {
if (!enabled) {
lpPairs[pair] = false;
} else {
if (timeSinceLastPair != 0) {
require(
block.timestamp - timeSinceLastPair > 3 days,
"3 Day cooldown."
);
}
require(!lpPairs[pair], "Pair already added to list.");
lpPairs[pair] = true;
timeSinceLastPair = block.timestamp;
}
}
function isExcludedFromLimits(address account)
external
view
returns (bool)
{
return _isExcludedFromLimits[account];
}
function setExcludedFromLimits(address account, bool enabled)
external
onlyOwner
{
_isExcludedFromLimits[account] = enabled;
}
function isExcludedFromFees(address account) external view returns (bool) {
return _isExcludedFromFees[account];
}
function setExcludedFromFees(address account, bool enabled)
public
onlyOwner
{
_isExcludedFromFees[account] = enabled;
}
function lockTaxes() external onlyOwner {
taxesAreLocked = true;
}
function disableMax() external onlyOwner {
maxDisabled = true;
}
function setTaxes(
uint16 buyFee,
uint16 sellFee,
uint16 transferFee
) external onlyOwner {
require(!taxesAreLocked, "Taxes are locked.");
require(
buyFee <= maxBuyTaxes &&
sellFee <= maxSellTaxes &&
transferFee <= maxTransferTaxes,
"Cannot exceed maximums."
);
_taxRates.buyFee = buyFee;
_taxRates.sellFee = sellFee;
_taxRates.transferFee = transferFee;
}
function setRatios(
uint16 liquidity,
uint16 operations,
uint16 burn
) external onlyOwner {
_ratios.liquidity = liquidity;
_ratios.operations = operations;
_ratios.burn = burn;
_ratios.totalSwap = liquidity + operations;
uint256 total = _taxRates.buyFee + _taxRates.sellFee;
require(
_ratios.totalSwap + _ratios.burn <= total,
"Cannot exceed sum of buy and sell fees."
);
}
function setWallets(address payable operations) external onlyOwner {
require(operations != address(0), "Cannot be zero address.");
_taxWallets.operations = payable(operations);
}
function setLiquidityAddress(address _liquidityAddress) external onlyOwner {
require(_liquidityAddress != address(0), "Cannot be zero address.");
liquidityAddress = _liquidityAddress;
}
function setMaxTxAmount(uint256 percent, uint256 divisor)
external
onlyOwner
{
require(!maxDisabled, "Max amount is disabled.");
require(
(_tTotal * percent) / divisor >= ((_tTotal * 5) / 1000),
"Max Transaction amt must be above 0.5% of total supply."
);
_maxTxAmount = (_tTotal * percent) / divisor;
}
function setMaxWalletSize(uint256 percent, uint256 divisor)
external
onlyOwner
{
require(!maxDisabled, "Max wallet is disabled.");
require(
(_tTotal * percent) / divisor >= (_tTotal / 100),
"Max Wallet amt must be above 1% of total supply."
);
_maxWalletSize = (_tTotal * percent) / divisor;
}
function getTokenAmountAtPriceImpact(uint256 priceImpactInHundreds)
external
view
returns (uint256)
{
return ((balanceOf(lpPair) * priceImpactInHundreds) / masterTaxDivisor);
}
function setSwapSettings(
uint256 thresholdPercent,
uint256 thresholdDivisor,
uint256 amountPercent,
uint256 amountDivisor
) external onlyOwner {
swapThreshold = (_tTotal * thresholdPercent) / thresholdDivisor;
swapAmount = (_tTotal * amountPercent) / amountDivisor;
require(
swapThreshold <= swapAmount,
"Threshold cannot be above amount."
);
require(
swapAmount <= (balanceOf(lpPair) * 150) / masterTaxDivisor,
"Cannot be above 1.5% of current PI."
);
require(
swapAmount >= _tTotal / 1_000_000,
"Cannot be lower than 0.00001% of total supply."
);
require(
swapThreshold >= _tTotal / 1_000_000,
"Cannot be lower than 0.00001% of total supply."
);
}
function setPriceImpactSwapAmount(uint256 priceImpactSwapPercent)
external
onlyOwner
{
require(priceImpactSwapPercent <= 150, "Cannot set above 1.5%.");
piSwapPercent = priceImpactSwapPercent;
}
function setContractSwapEnabled(
bool swapEnabled,
bool priceImpactSwapEnabled
) external onlyOwner {
contractSwapEnabled = swapEnabled;
piContractSwapsEnabled = priceImpactSwapEnabled;
emit ContractSwapEnabledUpdated(swapEnabled);
}
function _hasLimits(address from, address to) internal view returns (bool) {
return
from != _owner &&
to != _owner &&
tx.origin != _owner &&
!_liquidityHolders[to] &&
!_liquidityHolders[from] &&
to != DEAD &&
to != address(0) &&
from != address(this);
}
function _transfer(
address from,
address to,
uint256 amount
) internal returns (bool) {
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");
bool buy = false;
bool sell = false;
bool other = false;
if (lpPairs[from]) {
buy = true;
} else if (lpPairs[to]) {
sell = true;
} else {
other = true;
}
if (_hasLimits(from, to)) {
if (!tradingEnabled) {
revert("Trading not yet enabled!");
}
if (buy || sell) {
if (
!_isExcludedFromLimits[from] && !_isExcludedFromLimits[to] && !maxDisabled
) {
require(
amount <= _maxTxAmount,
"Transfer amount exceeds the maxTxAmount."
);
}
}
if (to != address(dexRouter) && !sell) {
if (!_isExcludedFromLimits[to] && !maxDisabled) {
require(
balanceOf(to) + amount <= _maxWalletSize,
"Transfer amount exceeds the maxWalletSize."
);
}
}
}
if (sell) {
if (!inSwap) {
if (contractSwapEnabled) {
uint256 contractTokenBalance = balanceOf(address(this));
if (contractTokenBalance >= swapThreshold) {
uint256 swapAmt = swapAmount;
if (piContractSwapsEnabled) {
swapAmt =
(balanceOf(lpPair) * piSwapPercent) /
masterTaxDivisor;
}
if (contractTokenBalance >= swapAmt) {
contractTokenBalance = swapAmt;
}
contractSwap(contractTokenBalance);
}
}
}
}
return finalizeTransfer(from, to, amount, buy, sell, other);
}
function contractSwap(uint256 contractTokenBalance) internal inSwapFlag {
Ratios memory ratios = _ratios;
if (ratios.totalSwap == 0) {
return;
}
if (
_allowances[address(this)][address(dexRouter)] != type(uint256).max
) {
_allowances[address(this)][address(dexRouter)] = type(uint256).max;
}
uint256 toLiquify = ((contractTokenBalance * ratios.liquidity) /
ratios.totalSwap) / 2;
uint256 swapAmt = contractTokenBalance - toLiquify;
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = dexRouter.WETH();
try
dexRouter.swapExactTokensForETHSupportingFeeOnTransferTokens(
swapAmt,
0,
path,
address(this),
block.timestamp
)
{} catch {
return;
}
uint256 amtBalance = address(this).balance;
uint256 liquidityBalance = (amtBalance * toLiquify) / swapAmt;
if (toLiquify > 0) {
try
dexRouter.addLiquidityETH{value: liquidityBalance}(
address(this),
toLiquify,
0,
0,
liquidityAddress,
block.timestamp
)
{
emit AutoLiquify(liquidityBalance, toLiquify);
} catch {
return;
}
}
amtBalance -= liquidityBalance;
ratios.totalSwap -= ratios.liquidity;
bool success;
uint256 operationsBalance = (amtBalance * ratios.operations) /
ratios.totalSwap;
if (ratios.operations > 0) {
(success, ) = _taxWallets.operations.call{
value: operationsBalance,
gas: 55000
}("");
}
}
function _checkLiquidityAdd(address from, address to) internal {
require(!_hasLiqBeenAdded, "Liquidity already added and marked.");
if (!_hasLimits(from, to) && to == lpPair) {
_liquidityHolders[from] = true;
_isExcludedFromFees[from] = true;
_hasLiqBeenAdded = true;
contractSwapEnabled = true;
emit ContractSwapEnabledUpdated(true);
}
}
function enableTrading() public onlyOwner {
require(!tradingEnabled, "Trading already enabled!");
require(_hasLiqBeenAdded, "Liquidity must be added.");
tradingEnabled = true;
swapThreshold = (balanceOf(lpPair) * 10) / 10000;
swapAmount = (balanceOf(lpPair) * 30) / 10000;
}
function sweepContingency() external onlyOwner {
payable(_owner).transfer(address(this).balance);
}
function sweepExternalTokens(address token) external onlyOwner {
IERC20 TOKEN = IERC20(token);
TOKEN.transfer(_owner, TOKEN.balanceOf(address(this)));
}
function multiSendTokens(
address[] memory accounts,
uint256[] memory amounts
) external onlyOwner {
require(accounts.length == amounts.length, "Lengths do not match.");
for (uint16 i = 0; i < accounts.length; i++) {
require(
balanceOf(msg.sender) >= amounts[i] * 10**_decimals,
"Not enough tokens."
);
finalizeTransfer(
msg.sender,
accounts[i],
amounts[i] * 10**_decimals,
false,
false,
true
);
}
}
function finalizeTransfer(
address from,
address to,
uint256 amount,
bool buy,
bool sell,
bool other
) internal returns (bool) {
bool takeFee = true;
if (_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
takeFee = false;
}
_tOwned[from] -= amount;
uint256 amountReceived = (takeFee)
? takeTaxes(from, buy, sell, amount)
: amount;
_tOwned[to] += amountReceived;
emit Transfer(from, to, amountReceived);
if (!_hasLiqBeenAdded) {
_checkLiquidityAdd(from, to);
if (!_hasLiqBeenAdded && _hasLimits(from, to) && !other) {
revert("Pre-liquidity transfer protection.");
}
}
return true;
}
function takeTaxes(
address from,
bool buy,
bool sell,
uint256 amount
) internal returns (uint256) {
Ratios memory ratios = _ratios;
uint256 total = ratios.burn + ratios.totalSwap;
uint256 currentFee;
if (buy) {
currentFee = _taxRates.buyFee;
} else if (sell) {
currentFee = _taxRates.sellFee;
} else {
currentFee = _taxRates.transferFee;
}
if (currentFee == 0 || total == 0) {
return amount;
}
uint256 feeAmount = (amount * currentFee) / masterTaxDivisor;
uint256 burnAmt = (feeAmount * ratios.burn) / total;
uint256 swapAmt = feeAmount - burnAmt;
if (swapAmt > 0) {
_tOwned[address(this)] += swapAmt;
emit Transfer(from, address(this), swapAmt);
}
if (burnAmt > 0) {
_tTotal -= burnAmt;
emit Transfer(from, address(0), burnAmt);
}
return amount - feeAmount;
}
}
{
"compilationTarget": {
"DEEPW3B.sol": "DEEPW3B"
},
"evmVersion": "paris",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": true,
"runs": 200
},
"remappings": []
}
[{"inputs":[],"stateMutability":"payable","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":false,"internalType":"uint256","name":"amountCurrency","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amountTokens","type":"uint256"}],"name":"AutoLiquify","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bool","name":"enabled","type":"bool"}],"name":"ContractSwapEnabledUpdated","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":"DEAD","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_hasLiqBeenAdded","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_ratios","outputs":[{"internalType":"uint16","name":"liquidity","type":"uint16"},{"internalType":"uint16","name":"operations","type":"uint16"},{"internalType":"uint16","name":"burn","type":"uint16"},{"internalType":"uint16","name":"totalSwap","type":"uint16"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_taxRates","outputs":[{"internalType":"uint16","name":"buyFee","type":"uint16"},{"internalType":"uint16","name":"sellFee","type":"uint16"},{"internalType":"uint16","name":"transferFee","type":"uint16"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_taxWallets","outputs":[{"internalType":"address payable","name":"operations","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"holder","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":[],"name":"approveContractContingency","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":"contractSwapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"dexRouter","outputs":[{"internalType":"contract IRouter02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"disableMax","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getOwner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"priceImpactInHundreds","type":"uint256"}],"name":"getTokenAmountAtPriceImpact","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromLimits","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"liquidityAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lockTaxes","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"lpPair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxBuyTaxes","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxDisabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxSellTaxes","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTransferTaxes","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"accounts","type":"address[]"},{"internalType":"uint256[]","name":"amounts","type":"uint256[]"}],"name":"multiSendTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"operator","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"originalDeployer","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"piContractSwapsEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"piSwapPercent","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOriginalDeployer","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"swapEnabled","type":"bool"},{"internalType":"bool","name":"priceImpactSwapEnabled","type":"bool"}],"name":"setContractSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"enabled","type":"bool"}],"name":"setExcludedFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"enabled","type":"bool"}],"name":"setExcludedFromLimits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_liquidityAddress","type":"address"}],"name":"setLiquidityAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"enabled","type":"bool"}],"name":"setLpPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"percent","type":"uint256"},{"internalType":"uint256","name":"divisor","type":"uint256"}],"name":"setMaxTxAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"percent","type":"uint256"},{"internalType":"uint256","name":"divisor","type":"uint256"}],"name":"setMaxWalletSize","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newRouter","type":"address"}],"name":"setNewRouter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOperator","type":"address"}],"name":"setOperator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"priceImpactSwapPercent","type":"uint256"}],"name":"setPriceImpactSwapAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint16","name":"liquidity","type":"uint16"},{"internalType":"uint16","name":"operations","type":"uint16"},{"internalType":"uint16","name":"burn","type":"uint16"}],"name":"setRatios","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"thresholdPercent","type":"uint256"},{"internalType":"uint256","name":"thresholdDivisor","type":"uint256"},{"internalType":"uint256","name":"amountPercent","type":"uint256"},{"internalType":"uint256","name":"amountDivisor","type":"uint256"}],"name":"setSwapSettings","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint16","name":"buyFee","type":"uint16"},{"internalType":"uint16","name":"sellFee","type":"uint16"},{"internalType":"uint16","name":"transferFee","type":"uint16"}],"name":"setTaxes","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address payable","name":"operations","type":"address"}],"name":"setWallets","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapThreshold","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sweepContingency","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"sweepExternalTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"taxesAreLocked","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"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":"transferOwner","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]