// SPDX-License-Identifier: UNLICENSE
/**
About TattooMoney DeFi & NFT project:
Tattooing is a timeless phenomenon. The first human to be tattooed was Ötzi the Iceman when archaeologists discovered his body dating between 3,370 and 3,100 BC, or more than 5,000 years ago.
We bring tattoos to the cryptographic space...
https://app.TattooMoney.io/ - Our App
https://TattooMoney.io/ - Info about Project
*/
// ------------------------------------------------------------------------------------
// 'TattooMoneyV2' Token Contract
//
// Symbol : TAT2
// Name : TattooMoney
// Total Supply: 1,000,000,000 TAT2
// Decimals : 18
//
// © By 'TattooMoney Co LTD' With 'TAT2' Symbol since 2019.
//
// This is upgrade of token 0x960773318c1aeab5da6605c49266165af56435fa
//
// ------------------------------------------------------------------------------------
import "./owned.sol";
import "./dao.sol";
import "./interfaces.sol";
pragma solidity 0.8.7;
contract TattooMoneyV2 is IERC20, Owned, DAO {
constructor(address _owner) {
balances[_owner] = INITIAL_SUPPLY;
emit Transfer(ZERO, _owner, INITIAL_SUPPLY);
owner = _owner;
dao = 0x1e3d5272aa13f0c6d911866DBEF3C5979d9B7b40;
setfeesfree();
}
string public constant name = "TattooMoney";
string public constant symbol = "TAT2";
uint8 public constant decimals = 18;
uint256 private constant INITIAL_SUPPLY = 1_000_000_000 * (10**decimals);
uint256 private constant maxFee = 10;
uint256 private _totalSupply = INITIAL_SUPPLY;
uint256 private FeeTotalCollected;
uint256 private FeeTotalCollectedBurned;
address private constant ZERO = address(0);
mapping(address => uint256) private balances;
mapping(address => mapping(address => uint256)) public override allowance;
mapping(address => bool) public isFeeFreeSender;
mapping(address => bool) public isFeeFreeRecipient;
mapping(address => bool) public frozenAccount;
uint256 public totalFee = 2; // Total procent fee deductet from transaction
uint256 public burnFees = 40; // fee taken and burned
uint256 public charityFees = 20; // fee taken and added to the charity
address public charityaddress = 0xA48E5C39c9AF0f3B1A948a63F44d63AB777CB684;
uint256 public rewardsFees = 20; // fee taken and added to rewards
address public rewardsaddress = 0x2794F6a795823EDebC41D1799c0829EcD36821d2;
uint256 public systemFees = 0; // fee taken and added to system
address public systemaddress = 0x705E0d5120511d823b813b9e24e5E34a58616C3A;
uint256 public stakingFees = 20; // fee taken and added to staking pool
address public stakingaddress = 0xEDC46D5dDb981b7Da1A743b2739e69e44c4FBCE7;
uint256 public minTotalSupply =0; // min amount of tokens total supply
/**
* @dev Update charity address
* @param _charityaddress new charity address
*/
function updateCharityAddress( address _charityaddress ) external onlyDAO {
charityaddress = _charityaddress;
emit updateedCharityAddress( charityaddress );
}
/**
* @dev Update rewards address
* @param _rewardsaddress new charity address
*/
function updateRewardsAddress( address _rewardsaddress ) external onlyDAO {
rewardsaddress = _rewardsaddress;
emit updateedRewardsAddress( rewardsaddress );
}
/**
* @dev Update rewards address
* @param _systemaddress new charity address
*/
function updateSystemAddress( address _systemaddress ) external onlyDAO {
systemaddress = _systemaddress;
emit updateedSystemAddress( systemaddress );
}
/**
* @dev Update staking address
* @param _stakingaddress new charity address
*/
function updateStakingAddress( address _stakingaddress ) external onlyDAO {
stakingaddress = _stakingaddress;
emit updateedStakingAddress( stakingaddress );
}
/**
* @dev Updates fees
* @param _totalFee total taken fee
* @param _burnFees burn fees
* @param _charityFees liquidity pool fees
* @param _rewardsFees rewards fees
*/
function updateFees( uint256 _totalFee, uint256 _burnFees, uint256 _charityFees, uint256 _rewardsFees, uint256 _systemFees, uint256 _stakingFees ) external onlyDAO {
require( _totalFee <= maxFee, "VERIFY FEE: TOO BIG FEE" );
require( _verifyFees(_burnFees, _charityFees, _rewardsFees, _systemFees, _stakingFees), "VERIFY FEE: SUM DO NOT MATCH");
totalFee = _totalFee;
burnFees = _burnFees;
charityFees = _charityFees;
rewardsFees = _rewardsFees;
systemFees = _systemFees;
stakingFees = _stakingFees;
emit FeesUpdated( totalFee, burnFees, charityFees, rewardsFees, systemFees, stakingFees );
}
/**
* @dev verify fees
* @param _burnFees liquidity pool fees
* @param _charityFees charity fees
* @param _rewardsFees rewards fees
* @param _systemFees system fees
* @param _stakingFees staking fees
*/
function _verifyFees( uint256 _burnFees, uint256 _charityFees, uint256 _rewardsFees, uint256 _systemFees, uint256 _stakingFees) private pure returns (bool){
uint256 _totalFees = _burnFees + _charityFees + _rewardsFees + _systemFees + _stakingFees;
if(_totalFees == 100){
return true;
} else {
return false;
}
}
/**
* @dev Emitted when dao is updated
* @param dao dao address
*/
event DAOUpdated(
address dao
);
// ERC20 totalSupply
function totalSupply() external view override returns (uint256) {
return _totalSupply - balances[ZERO];
}
/// Total fees collected
function FeesCollected() external view returns (uint256) {
return FeeTotalCollected;
}
/// Total fees collected burned
function FeesCollectedBurned() external view returns (uint256) {
return FeeTotalCollectedBurned;
}
// ERC20 balanceOf
function balanceOf(address account)
external
view
override
returns (uint256)
{
return balances[account];
}
// ERC20 transfer
function transfer(address recipient, uint256 amount)
external
override
returns (bool)
{
_transfer(msg.sender, recipient, amount);
return true;
}
// ERC20 approve
function approve(address spender, uint256 amount)
external
override
returns (bool)
{
_approve(msg.sender, spender, amount);
return true;
}
// ERC20 transferFrom
function transferFrom( address sender, address recipient, uint256 amount ) external override returns (bool) {
uint256 amt = allowance[sender][msg.sender];
require(amt >= amount, "ERC20: transfer amount exceeds allowance");
// reduce only if not permament allowance (uniswap etc)
allowance[sender][msg.sender] -= amount;
_transfer(sender, recipient, amount);
return true;
}
// ERC20 increaseAllowance
function increaseAllowance(address spender, uint256 addedValue) external returns (bool) {
_approve( msg.sender, spender, allowance[msg.sender][spender] + addedValue );
return true;
}
// ERC20 decreaseAllowance
function decreaseAllowance(address spender, uint256 subtractedValue) external returns (bool) {
require( allowance[msg.sender][spender] >= subtractedValue, "ERC20: decreased allowance below zero" );
_approve( msg.sender, spender, allowance[msg.sender][spender] - subtractedValue );
return true;
}
// ERC20 burn
function burn(uint256 amount) external {
require(msg.sender != ZERO, "ERC20: burn from the zero address");
_burn(msg.sender, amount);
}
// ERC20 burnFrom
function burnFrom(address account, uint256 amount) external {
require(account != ZERO, "ERC20: burn from the zero address");
require(allowance[account][msg.sender] >= amount, "ERC20: burn amount exceeds allowance");
allowance[account][msg.sender] -= amount;
_burn(account, amount);
}
function _calcTransferFees( uint256 amount ) private view returns ( uint256 _FeesToTake, uint256 _toburn, uint256 _tocharity, uint256 _toreward, uint256 _tosystem, uint256 _tostaking )
{
_FeesToTake = amount * totalFee / 100;
if((_totalSupply - balances[ZERO]) > minTotalSupply){
_toburn = _FeesToTake * burnFees / 100;
} else {
_toburn = 0;
}
_tocharity = _FeesToTake * charityFees / 100;
_toreward = _FeesToTake * rewardsFees / 100;
_tosystem = _FeesToTake * systemFees / 100;
_tostaking = _FeesToTake * stakingFees / 100;
_FeesToTake = _toburn + _tocharity + _toreward + _tosystem + _tostaking;
}
/**
Internal approve function, emit Approval event
@param _owner approving address
@param spender delegated spender
@param amount amount of tokens
*/
function _approve( address _owner, address spender, uint256 amount ) private {
require(_owner != ZERO, "ERC20: approve from the zero address");
require(spender != ZERO, "ERC20: approve to the zero address");
allowance[_owner][spender] = amount;
emit Approval(_owner, spender, amount);
}
/**
Internal transfer function, calling feeFree if needed
@param sender sender address
@param recipient destination address
@param Amount transfer amount
*/
function _transfer( address sender, address recipient, uint256 Amount ) private {
require(sender != ZERO, "ERC20: transfer from the zero address");
require(recipient != ZERO, "ERC20: transfer to the zero address");
require(!frozenAccount[sender], "DAO: transfer from this address frozen");
require(!frozenAccount[recipient], "DAO: transfer to this address frozen");
if (Amount > 0) {
if (isFeeFreeSender[sender]){
_feeFreeTransfer(sender, recipient, Amount);
} else if(isFeeFreeRecipient[recipient]){
_feeFreeTransfer(sender, recipient, Amount);
} else {
( uint256 _FeesToTake, uint256 _toburn, uint256 _tocharity, uint256 _toreward, uint256 _tosystem, uint256 _tostaking ) = _calcTransferFees( Amount );
uint256 _totransfer = Amount - _FeesToTake;
uint256 _takefromsender = Amount - _toburn;
FeeTotalCollected += _FeesToTake;
balances[sender] -= _takefromsender;
balances[recipient] += _totransfer;
if(_toburn>0){
_burn(sender, _toburn);
FeeTotalCollectedBurned += _toburn;
emit Transfer(sender, ZERO, _toburn);
}
if(_tocharity>0){
balances[charityaddress] += _tocharity;
emit Transfer(sender, charityaddress, _tocharity);
}
if(_toreward>0){
balances[rewardsaddress] += _toreward;
emit Transfer(sender, rewardsaddress, _toreward);
}
if(_tosystem>0){
balances[systemaddress] += _tosystem;
emit Transfer(sender, systemaddress, _tosystem);
}
if(_tostaking>0){
balances[stakingaddress] += _tostaking;
emit Transfer(sender, stakingaddress, _tostaking);
}
emit Transfer(sender, recipient, _totransfer);
}
} else emit Transfer(sender, recipient, 0);
}
/**
Function provide fee-free transfer for selected addresses
@param sender sender address
@param recipient destination address
@param Amount transfer amount
*/
function _feeFreeTransfer( address sender, address recipient, uint256 Amount ) private {
balances[sender] -= Amount;
balances[recipient] += Amount;
emit Transfer(sender, recipient, Amount);
}
/// internal burn function
function _burn(address account, uint256 Amount) private {
require( balances[account] >= Amount, "ERC20: burn amount exceeds balance" );
balances[account] -= Amount;
_totalSupply -= Amount;
}
/**
* @dev Freez Account
* @param _address adress to feez/unfreez
* @param _freeze set state
*/
function freezeAccount(address _address, bool _freeze) public onlyDAO {
frozenAccount[_address] = _freeze;
}
/**
* @dev Update charity address
* @param _minTotalSupply new charity address
*/
function updateminTotalSupply( uint256 _minTotalSupply ) external onlyDAO {
minTotalSupply = _minTotalSupply;
emit updatedminTotalSupply( minTotalSupply );
}
function setfeesfree() private{
isFeeFreeSender[owner] = true;
isFeeFreeSender[dao] = true;
isFeeFreeSender[charityaddress] = true;
isFeeFreeSender[rewardsaddress] = true;
isFeeFreeSender[systemaddress] = true;
isFeeFreeSender[stakingaddress] = true;
isFeeFreeRecipient[charityaddress] = true;
}
/**
* @dev Emitted when fees are updated
* @param totalFee burn fees
* @param burnFees liquidity pool fees
* @param charityFees charity fees
* @param rewardsFees rewards fees
* @param systemFees system fees
* @param stakingFees staking fees
*/
event FeesUpdated( uint256 totalFee, uint256 burnFees, uint256 charityFees, uint256 rewardsFees, uint256 systemFees, uint256 stakingFees );
/**
* @dev Emitted when staking is updated
* @param stakingaddress burn fees
*/
event updateedStakingAddress( address stakingaddress );
/**
* @dev Emitted when system is updated
* @param systemaddress burn fees
*/
event updateedSystemAddress( address systemaddress );
/**
* @dev Emitted when rewards is updated
* @param rewardsaddress burn fees
*/
event updateedRewardsAddress( address rewardsaddress );
/**
* @dev Emitted when charity is updated
* @param charityaddress burn fees
*/
event updateedCharityAddress( address charityaddress );
/**
* @dev Emitted when minTotalSupply is updated
* @param minTotalSupply burn fees
*/
event updatedminTotalSupply( uint256 minTotalSupply );
//
// Hard Ride
//
/**
Add address that will not pay transfer fees
@param user address to mark as fee-free
*/
function addFeeFree(address user) external onlyDAO {
isFeeFreeSender[user] = true;
}
/**
Remove address form privileged list
@param user user to remove
*/
function removeFeeFree(address user) external onlyDAO {
isFeeFreeSender[user] = false;
}
/**
Add address that will recive tokens without fee
@param user address to mark as fee-free
*/
function addFeeFreeRecipient(address user) external onlyDAO {
isFeeFreeRecipient[user] = true;
}
/**
Remove address form privileged list
@param user user to remove
*/
function removeFeeFreeRecipient(address user) external onlyDAO {
isFeeFreeRecipient[user] = false;
}
/**
Take ETH accidentally send to contract
*/
function withdrawEth() external onlyOwner {
payable(owner).transfer(address(this).balance);
}
/**
Take any ERC20 sent to contract
@param token token address
*/
function withdrawErc20(address token) external onlyOwner {
uint256 balance = IERC20(token).balanceOf(address(this));
require(balance > 0, "Nothing to withdraw");
// use broken IERC20
INterfacesNoR(token).transfer(owner, balance);
}
}
//by Patrick
// SPDX-License-Identifier: UNLICENSE
pragma solidity ^0.8.7;
contract DAO {
address public dao;
event DAOChanged(address from, address to);
constructor() {
dao = msg.sender;
emit DAOChanged(address(0), msg.sender);
}
modifier onlyDAO() {
require(msg.sender == dao, "Only DAO");
_;
}
function changeDAO(address _dao) external onlyDAO {
require(_dao != address(0), "DAO to ZERO");
address olddao = dao;
dao = _dao;
emit DAOChanged(olddao, dao);
}
}
// SPDX-License-Identifier: UNLICENSE
pragma solidity ^0.8.7;
/**
* @dev Interface of the ERC20 standard as defined in the EIP.
*/
interface IERC20 {
/**
* @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 `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
);
}
// Interfaces for contract interaction
interface INterfaces {
function balanceOf(address) external returns (uint256);
function transfer(address, uint256) external returns (bool);
function transferFrom(
address,
address,
uint256
) external returns (bool);
}
// For tokens that do not return true on transfers eg. USDT
interface INterfacesNoR {
function transfer(address, uint256) external;
function transferFrom(
address,
address,
uint256
) external;
}
// SPDX-License-Identifier: UNLICENSE
pragma solidity ^0.8.7;
contract Owned {
address public owner;
address public newOwner;
event OwnershipChanged(address from, address to);
constructor() {
owner = msg.sender;
emit OwnershipChanged(address(0), msg.sender);
}
modifier onlyOwner() {
require(msg.sender == owner, "Only owner");
_;
}
// owner can give super-rights to someone
function giveOwnership(address user) external onlyOwner {
require(user != address(0), "User renounceOwnership");
newOwner = user;
}
// new owner need to accept
function acceptOwnership() external {
require(msg.sender == newOwner, "Only NewOwner");
emit OwnershipChanged(owner, newOwner);
owner = msg.sender;
delete newOwner;
}
}
{
"compilationTarget": {
"TattooMoneyV2.sol": "TattooMoneyV2"
},
"evmVersion": "london",
"libraries": {},
"metadata": {
"bytecodeHash": "ipfs"
},
"optimizer": {
"enabled": false,
"runs": 200
},
"remappings": []
}
[{"inputs":[{"internalType":"address","name":"_owner","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":false,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"address","name":"to","type":"address"}],"name":"DAOChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"dao","type":"address"}],"name":"DAOUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"totalFee","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"burnFees","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"charityFees","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"rewardsFees","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"systemFees","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"stakingFees","type":"uint256"}],"name":"FeesUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"address","name":"to","type":"address"}],"name":"OwnershipChanged","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"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"minTotalSupply","type":"uint256"}],"name":"updatedminTotalSupply","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"charityaddress","type":"address"}],"name":"updateedCharityAddress","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"rewardsaddress","type":"address"}],"name":"updateedRewardsAddress","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"stakingaddress","type":"address"}],"name":"updateedStakingAddress","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"systemaddress","type":"address"}],"name":"updateedSystemAddress","type":"event"},{"inputs":[],"name":"FeesCollected","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"FeesCollectedBurned","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"acceptOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"addFeeFree","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"addFeeFreeRecipient","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","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":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"burnFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burnFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_dao","type":"address"}],"name":"changeDAO","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"charityFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"charityaddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"dao","outputs":[{"internalType":"address","name":"","type":"address"}],"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":[{"internalType":"address","name":"_address","type":"address"},{"internalType":"bool","name":"_freeze","type":"bool"}],"name":"freezeAccount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"frozenAccount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"giveOwnership","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":"address","name":"","type":"address"}],"name":"isFeeFreeRecipient","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isFeeFreeSender","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"minTotalSupply","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":"newOwner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"removeFeeFree","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"removeFeeFreeRecipient","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"rewardsFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rewardsaddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"stakingFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"stakingaddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"systemFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"systemaddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":"_charityaddress","type":"address"}],"name":"updateCharityAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_totalFee","type":"uint256"},{"internalType":"uint256","name":"_burnFees","type":"uint256"},{"internalType":"uint256","name":"_charityFees","type":"uint256"},{"internalType":"uint256","name":"_rewardsFees","type":"uint256"},{"internalType":"uint256","name":"_systemFees","type":"uint256"},{"internalType":"uint256","name":"_stakingFees","type":"uint256"}],"name":"updateFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_rewardsaddress","type":"address"}],"name":"updateRewardsAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_stakingaddress","type":"address"}],"name":"updateStakingAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_systemaddress","type":"address"}],"name":"updateSystemAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_minTotalSupply","type":"uint256"}],"name":"updateminTotalSupply","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"}],"name":"withdrawErc20","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawEth","outputs":[],"stateMutability":"nonpayable","type":"function"}]