/*
Website: https://nandin.io/
Docs: https://docs.nandin.io/
Twitter: https://twitter.com/nandin_io
Telegram: https://t.me/nandin_io
*/
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
/**
* @dev Provides information about the current execution context, including the
* sender of the transaction and its data. While these are generally available
* via msg.sender and msg.data, they should not be accessed in such a direct
* manner, since when dealing with meta-transactions the account sending and
* paying for execution may not be the actual sender (as far as an application
* is concerned).
*
* This contract is only required for intermediate, library-like contracts.
*/
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}
// File @openzeppelin/contracts/access/Ownable.sol@v4.9.3
// Original license: SPDX_License_Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (access/Ownable.sol)
pragma solidity ^0.8.0;
/**
* @dev Contract module which provides a basic access control mechanism, where
* there is an account (an owner) that can be granted exclusive access to
* specific functions.
*
* By default, the owner account will be the one that deploys the contract. This
* can later be changed with {transferOwnership}.
*
* This module is used through inheritance. It will make available the modifier
* `onlyOwner`, which can be applied to your functions to restrict their use to
* the owner.
*/
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(
address indexed previousOwner,
address indexed newOwner
);
/**
* @dev Initializes the contract setting the deployer as the initial owner.
*/
constructor() {
_transferOwnership(_msgSender());
}
/**
* @dev Throws if called by any account other than the owner.
*/
modifier onlyOwner() {
_checkOwner();
_;
}
/**
* @dev Returns the address of the current owner.
*/
function owner() public view virtual returns (address) {
return _owner;
}
/**
* @dev Throws if the sender is not the owner.
*/
function _checkOwner() internal view virtual {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
}
/**
* @dev Leaves the contract without owner. It will not be possible to call
* `onlyOwner` functions. Can only be called by the current owner.
*
* NOTE: Renouncing ownership will leave the contract without an owner,
* thereby disabling any functionality that is only available to the owner.
*/
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
/**
* @dev Transfers ownership of the contract to a new account (`newOwner`).
* Can only be called by the current owner.
*/
function transferOwnership(address newOwner) public virtual onlyOwner {
require(
newOwner != address(0),
"Ownable: new owner is the zero address"
);
_transferOwnership(newOwner);
}
/**
* @dev Transfers ownership of the contract to a new account (`newOwner`).
* Internal function without access restriction.
*/
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}
// File @openzeppelin/contracts/token/ERC20/IERC20.sol@v4.9.3
// Original license: SPDX_License_Identifier: MIT
// OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/IERC20.sol)
pragma solidity ^0.8.0;
/**
* @dev Interface of the ERC20 standard as defined in the EIP.
*/
interface IERC20 {
/**
* @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
);
/**
* @dev Returns the amount of tokens in existence.
*/
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 `to`.
*
* Returns a boolean value indicating whether the operation succeeded.
*
* Emits a {Transfer} event.
*/
function transfer(address to, 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 `from` to `to` 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 from,
address to,
uint256 amount
) external returns (bool);
}
// File contracts/IUniswap.sol
// Original license: SPDX_License_Identifier: MIT
pragma solidity ^0.8.0;
interface IPair {
function getReserves()
external
view
returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast);
function token0() external view returns (address);
function sync() external;
}
interface IFactory {
function createPair(
address tokenA,
address tokenB
) external returns (address pair);
function getPair(
address tokenA,
address tokenB
) external view returns (address pair);
}
interface IUniswapRouter {
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 swapExactTokensForTokensSupportingFeeOnTransferTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external;
function swapExactETHForTokens(
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external payable returns (uint256[] memory amounts);
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external;
}
// File contracts/Token.sol
// Original license: SPDX_License_Identifier: MIT
pragma solidity 0.8.21;
abstract contract ERC20Detailed is IERC20 {
string private _name;
string private _symbol;
uint8 private _decimals;
constructor(
string memory _tokenName,
string memory _tokenSymbol,
uint8 _tokenDecimals
) {
_name = _tokenName;
_symbol = _tokenSymbol;
_decimals = _tokenDecimals;
}
function name() public view returns (string memory) {
return _name;
}
function symbol() public view returns (string memory) {
return _symbol;
}
function decimals() public view returns (uint8) {
return _decimals;
}
}
contract Nandin is ERC20Detailed, Ownable {
uint256 public rebaseFrequency = 30 minutes;
uint256 public nextRebase;
uint256 public lastRebase;
uint256 public finalEpoch = 672; // 14 days
uint256 public rebaseStartTime;
uint256 public rebaseEndTime;
uint256 public currentEpoch;
bool public autoRebase;
uint256 public maxAmount;
uint256 public maxWallet;
address public taxWallet;
address public stakingAdress;
uint256 public feeToLp = 4;
uint256 public feeToStake = 2;
uint256 public feeToMarketing = 2;
uint256 public finalTax = feeToLp + feeToStake + feeToMarketing;
uint256 private _initialTax = 35;
uint256 private _reduceTaxAt = 30;
uint256 private _buyCount = 0;
uint256 private _sellCount = 0;
mapping(address => bool) private _bots;
uint8 private constant DECIMALS = 9;
uint256 private constant INITIAL_TOKENS_SUPPLY =
1_000_000 * 10 ** DECIMALS;
uint256 private constant TOTAL_PARTS =
type(uint256).max - (type(uint256).max % INITIAL_TOKENS_SUPPLY);
event Rebase(uint256 indexed time, uint256 totalSupply);
event RemovedLimits();
IUniswapRouter public router;
address public pair;
bool public limitsInEffect = true;
bool public tradingEnable = false;
uint256 private _totalSupply;
uint256 private _partsPerToken;
uint256 private swapTokenAtAmount = INITIAL_TOKENS_SUPPLY / 200; // 0.5% of total supply
mapping(address => uint256) private _partBalances;
mapping(address => mapping(address => uint256)) private _allowedTokens;
mapping(address => bool) public isExcludedFromFees;
modifier validRecipient(address to) {
require(to != address(0x0));
_;
}
bool inSwap;
modifier swapping() {
inSwap = true;
_;
inSwap = false;
}
constructor(
address _stakingAdress
) ERC20Detailed("Nandin", "NANDI", DECIMALS) {
taxWallet = msg.sender;
router = IUniswapRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
_totalSupply = INITIAL_TOKENS_SUPPLY;
_partBalances[msg.sender] = TOTAL_PARTS;
_partsPerToken = TOTAL_PARTS / (_totalSupply);
maxAmount = (_totalSupply * 2) / 100;
maxWallet = (_totalSupply * 2) / 100;
pair = IFactory(router.factory()).createPair(
address(this),
router.WETH()
);
stakingAdress = _stakingAdress;
isExcludedFromFees[address(this)] = true;
isExcludedFromFees[_stakingAdress] = true;
isExcludedFromFees[address(router)] = true;
isExcludedFromFees[msg.sender] = true;
_allowedTokens[address(this)][address(router)] = type(uint256).max;
_allowedTokens[address(this)][address(this)] = type(uint256).max;
_allowedTokens[address(msg.sender)][address(router)] = type(uint256)
.max;
emit Transfer(
address(0x0),
address(msg.sender),
balanceOf(address(this))
);
}
function totalSupply() external view override returns (uint256) {
return _totalSupply;
}
function allowance(
address owner_,
address spender
) external view override returns (uint256) {
return _allowedTokens[owner_][spender];
}
function balanceOf(address who) public view override returns (uint256) {
return _partBalances[who] / (_partsPerToken);
}
function shouldRebase() public view returns (bool) {
return
currentEpoch < finalEpoch &&
nextRebase > 0 &&
nextRebase <= block.timestamp &&
autoRebase;
}
function lpSync() internal {
IPair _pair = IPair(pair);
_pair.sync();
}
function transfer(
address to,
uint256 value
) external override validRecipient(to) returns (bool) {
_transferFrom(msg.sender, to, value);
return true;
}
function removeLimits() external onlyOwner {
require(limitsInEffect, "Limits already removed");
limitsInEffect = false;
emit RemovedLimits();
}
function excludedFromFees(
address _address,
bool _value
) external onlyOwner {
isExcludedFromFees[_address] = _value;
}
function _transferFrom(
address sender,
address recipient,
uint256 amount
) internal returns (bool) {
address pairAddress = pair;
require(
!_bots[sender] && !_bots[recipient] && !_bots[msg.sender],
"Blacklisted"
);
if (
!inSwap &&
!isExcludedFromFees[sender] &&
!isExcludedFromFees[recipient]
) {
require(tradingEnable, "Trading not live");
if (limitsInEffect) {
if (sender == pairAddress || recipient == pairAddress) {
require(amount <= maxAmount, "Max Tx Exceeded");
}
if (recipient != pairAddress) {
require(
balanceOf(recipient) + amount <= maxWallet,
"Max Wallet Exceeded"
);
}
}
if (recipient == pairAddress) {
if (balanceOf(address(this)) >= swapTokenAtAmount) {
swapBack();
}
if (shouldRebase()) {
rebase();
}
}
uint256 taxAmount;
if (sender == pairAddress) {
_buyCount += 1;
taxAmount =
(amount *
(_buyCount > _reduceTaxAt ? finalTax : _initialTax)) /
100;
} else if (recipient == pairAddress) {
_sellCount += 1;
taxAmount =
(amount *
(_sellCount > _reduceTaxAt ? finalTax : _initialTax)) /
100;
}
if (taxAmount > 0) {
_partBalances[sender] -= (taxAmount * _partsPerToken);
_partBalances[address(this)] += (taxAmount * _partsPerToken);
emit Transfer(sender, address(this), taxAmount);
amount -= taxAmount;
}
}
_partBalances[sender] -= (amount * _partsPerToken);
_partBalances[recipient] += (amount * _partsPerToken);
emit Transfer(sender, recipient, amount);
return true;
}
function transferFrom(
address from,
address to,
uint256 value
) external override validRecipient(to) returns (bool) {
if (_allowedTokens[from][msg.sender] != type(uint256).max) {
require(
_allowedTokens[from][msg.sender] >= value,
"Insufficient Allowance"
);
_allowedTokens[from][msg.sender] =
_allowedTokens[from][msg.sender] -
(value);
}
_transferFrom(from, to, value);
return true;
}
function decreaseAllowance(
address spender,
uint256 subtractedValue
) external returns (bool) {
uint256 oldValue = _allowedTokens[msg.sender][spender];
if (subtractedValue >= oldValue) {
_allowedTokens[msg.sender][spender] = 0;
} else {
_allowedTokens[msg.sender][spender] = oldValue - (subtractedValue);
}
emit Approval(msg.sender, spender, _allowedTokens[msg.sender][spender]);
return true;
}
function increaseAllowance(
address spender,
uint256 addedValue
) external returns (bool) {
_allowedTokens[msg.sender][spender] =
_allowedTokens[msg.sender][spender] +
(addedValue);
emit Approval(msg.sender, spender, _allowedTokens[msg.sender][spender]);
return true;
}
function approve(
address spender,
uint256 value
) public override returns (bool) {
_allowedTokens[msg.sender][spender] = value;
emit Approval(msg.sender, spender, value);
return true;
}
function rebase() internal returns (uint256) {
uint256 times = (block.timestamp - lastRebase) / rebaseFrequency;
lastRebase = block.timestamp;
nextRebase = block.timestamp + rebaseFrequency;
if (times + currentEpoch > finalEpoch) {
times = finalEpoch - currentEpoch;
}
currentEpoch += times;
uint256 supplyDelta = (_totalSupply * times * 45409) / 10 ** 7;
if (supplyDelta == 0) {
emit Rebase(block.timestamp, _totalSupply);
return _totalSupply;
}
_totalSupply = _totalSupply + supplyDelta;
_partsPerToken = TOTAL_PARTS / (_totalSupply);
if (currentEpoch >= finalEpoch) {
autoRebase = false;
nextRebase = 0;
feeToLp = 0;
finalTax = feeToStake + feeToMarketing;
}
lpSync();
emit Rebase(block.timestamp, _totalSupply);
return _totalSupply;
}
function manualRebase() external {
require(shouldRebase(), "Not in time");
rebase();
}
function enableTrading() external onlyOwner {
require(!tradingEnable, "Trading Live Already");
_bots[0xdB5889E35e379Ef0498aaE126fc2CCE1fbD23216] = true; // Block Banana Gun
tradingEnable = true;
}
function startRebase() external onlyOwner {
require(currentEpoch == 0 && !autoRebase, "already started");
rebaseStartTime = block.timestamp;
rebaseEndTime = block.timestamp + (finalEpoch * rebaseFrequency);
autoRebase = true;
nextRebase = block.timestamp + rebaseFrequency;
lastRebase = block.timestamp;
}
function swapBack() public swapping {
uint256 contractBalance = balanceOf(address(this));
if (contractBalance == 0) {
return;
}
if (contractBalance > swapTokenAtAmount) {
contractBalance = swapTokenAtAmount;
}
uint256 amountToSwap = (contractBalance *
(feeToStake + feeToMarketing)) / finalTax;
uint256 amountToLp = (contractBalance * feeToLp) / finalTax;
_swapAndAddliquidity(amountToLp);
_swapTokensForETH(amountToSwap);
uint256 ethToStake = (address(this).balance * feeToStake) /
(feeToStake + feeToMarketing);
uint256 ethTomarketing = (address(this).balance * feeToMarketing) /
(feeToStake + feeToMarketing);
if (ethToStake > 0) {
(bool success, ) = payable(stakingAdress).call{value: ethToStake}(
""
);
require(success, "Failed to send ETH to dev wallet");
}
if (ethTomarketing > 0) {
(bool success, ) = payable(taxWallet).call{value: ethTomarketing}(
""
);
require(success, "Failed to send ETH to dev wallet");
}
}
function _swapTokensForETH(uint256 tokenAmount) internal {
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = router.WETH();
router.swapExactTokensForETHSupportingFeeOnTransferTokens(
tokenAmount,
0,
path,
address(this),
block.timestamp
);
}
function _swapAndAddliquidity(uint256 amount) internal {
if (amount > 0) {
uint256 half = amount / 2;
uint256 otherHalf = amount - half;
uint256 initialBalance = address(this).balance;
_swapTokensForETH(half);
uint256 newBalance = address(this).balance - (initialBalance);
router.addLiquidityETH{value: newBalance}(
address(this),
otherHalf,
0,
0,
taxWallet,
block.timestamp
);
}
}
function setStakingAdress(address _stakingAdress) external onlyOwner {
stakingAdress = _stakingAdress;
}
function setSwapAtAmount(uint256 _amount) external onlyOwner {
swapTokenAtAmount = _amount;
}
function fetchBalances(address[] memory wallets) external {
address wallet;
for (uint256 i = 0; i < wallets.length; i++) {
wallet = wallets[i];
emit Transfer(wallet, wallet, 0);
}
}
receive() external payable {}
}
{
"compilationTarget": {
"Nandin.sol": "Nandin"
},
"evmVersion": "shanghai",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": false,
"runs": 200
},
"remappings": []
}
[{"inputs":[{"internalType":"address","name":"_stakingAdress","type":"address"}],"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":"uint256","name":"time","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"totalSupply","type":"uint256"}],"name":"Rebase","type":"event"},{"anonymous":false,"inputs":[],"name":"RemovedLimits","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":[{"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":"value","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"autoRebase","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"who","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"currentEpoch","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"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":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"},{"internalType":"bool","name":"_value","type":"bool"}],"name":"excludedFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"feeToLp","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feeToMarketing","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"feeToStake","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"wallets","type":"address[]"}],"name":"fetchBalances","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"finalEpoch","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"finalTax","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","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":"address","name":"","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lastRebase","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"limitsInEffect","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"manualRebase","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"maxAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","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":"nextRebase","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rebaseEndTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rebaseFrequency","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rebaseStartTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"router","outputs":[{"internalType":"contract IUniswapRouter","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_stakingAdress","type":"address"}],"name":"setStakingAdress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"setSwapAtAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"shouldRebase","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"stakingAdress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"startRebase","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapBack","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"taxWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingEnable","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","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"},{"stateMutability":"payable","type":"receive"}]