Forkchoice Ethereum Mainnet

Address Contract Partially Verified

Address 0xe8Cb87fE247564670797c4aFdbeccE4160168b51
Balance 0 ETH
Nonce 1
Code Size 6351 bytes
Indexed Transactions 0 (1 on-chain, 0% indexed)
External Etherscan · Sourcify

Contract Bytecode

6351 bytes
0x6080604052600436106100ec5760003560e01c8063715018a61161008a578063a9059cbb11610059578063a9059cbb14610284578063c3c8cd80146102a4578063c9567bf9146102b9578063dd62ed3e146102ce57600080fd5b8063715018a614610204578063751039fc146102195780638da5cb5b1461022e57806395d89b411461025657600080fd5b806323b872dd116100c657806323b872dd14610191578063313ce567146101b15780636fc3eaec146101cd57806370a08231146101e457600080fd5b806306fdde03146100f8578063095ea7b31461013e57806318160ddd1461016e57600080fd5b366100f357005b600080fd5b34801561010457600080fd5b5060408051808201909152600b81526a111959d95b88151c9bdb1b60aa1b60208201525b604051610135919061148b565b60405180910390f35b34801561014a57600080fd5b5061015e6101593660046114f5565b610314565b6040519015158152602001610135565b34801561017a57600080fd5b5061018361032b565b604051908152602001610135565b34801561019d57600080fd5b5061015e6101ac366004611521565b61034c565b3480156101bd57600080fd5b5060405160128152602001610135565b3480156101d957600080fd5b506101e26103b5565b005b3480156101f057600080fd5b506101836101ff366004611562565b6103e2565b34801561021057600080fd5b506101e2610404565b34801561022557600080fd5b506101e2610481565b34801561023a57600080fd5b506000546040516001600160a01b039091168152602001610135565b34801561026257600080fd5b50604080518082019091526005815264151493d31360da1b6020820152610128565b34801561029057600080fd5b5061015e61029f3660046114f5565b6104e8565b3480156102b057600080fd5b506101e26104f5565b3480156102c557600080fd5b506101e261052b565b3480156102da57600080fd5b506101836102e936600461157f565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b60006103213384846108a6565b5060015b92915050565b60006103396012600a6116b2565b610347906301312d006116c1565b905090565b60006103598484846109ca565b6103ab84336103a685604051806060016040528060288152602001611872602891396001600160a01b038a1660009081526004602090815260408083203384529091529020549190610d6f565b6108a6565b5060019392505050565b600f546001600160a01b0316336001600160a01b0316146103d557600080fd5b476103df81610da9565b50565b6001600160a01b03811660009081526002602052604081205461032590610de3565b6000546001600160a01b031633146104375760405162461bcd60e51b815260040161042e906116e0565b60405180910390fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031633146104ab5760405162461bcd60e51b815260040161042e906116e0565b6104b76012600a6116b2565b6104c5906301312d006116c1565b60129081556104d590600a6116b2565b6104e3906301312d006116c1565b601355565b60006103213384846109ca565b600f546001600160a01b0316336001600160a01b03161461051557600080fd5b6000610520306103e2565b90506103df81610e67565b6000546001600160a01b031633146105555760405162461bcd60e51b815260040161042e906116e0565b601154600160a01b900460ff16156105af5760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e000000000000000000604482015260640161042e565b601080546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556105f730826105e96012600a6116b2565b6103a6906301312d006116c1565b806001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610635573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106599190611715565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156106a6573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106ca9190611715565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610717573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061073b9190611715565b601180546001600160a01b0319166001600160a01b039283161790556010541663f305d719473061076b816103e2565b6000806107806000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156107e8573d6000803e3d6000fd5b50505050506040513d601f19601f8201168201806040525081019061080d9190611732565b50506011805463ffff00ff60a01b198116630101000160a01b1790915560105460405163095ea7b360e01b81526001600160a01b03918216600482015260001960248201529116915063095ea7b3906044016020604051808303816000875af115801561087e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108a29190611760565b5050565b6001600160a01b0383166109085760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161042e565b6001600160a01b0382166109695760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161042e565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610a2e5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161042e565b6001600160a01b038216610a905760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161042e565b60008111610af25760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b606482015260840161042e565b6000546001600160a01b03848116911614801590610b1e57506000546001600160a01b03838116911614155b15610d54576001600160a01b03831660009081526006602052604090205460ff16158015610b6557506001600160a01b03821660009081526006602052604090205460ff16155b610b6e57600080fd5b6000600a55600e5415610b8357600c54610b87565b600d545b600b556011546001600160a01b038481169116148015610bb557506010546001600160a01b03838116911614155b8015610bda57506001600160a01b03821660009081526005602052604090205460ff16155b8015610bef5750601154600160b81b900460ff165b15610cc957601254811115610c465760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e00000000000000604482015260640161042e565b60135481610c53846103e2565b610c5d9190611782565b1115610cab5760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e000000000000604482015260640161042e565b600e5415610cc957600e8054906000610cc38361179a565b91905055505b6000610cd4306103e2565b601154909150600160a81b900460ff16158015610cff57506011546001600160a01b03858116911614155b8015610d145750601154600160b01b900460ff165b8015610d205750600081115b8015610d2e5750601e600e54105b15610d4e57610d3c81610e67565b478015610d4c57610d4c47610da9565b505b50610d5f565b6000600a819055600b555b610d6a838383610fe1565b505050565b60008184841115610d935760405162461bcd60e51b815260040161042e919061148b565b506000610da084866117b1565b95945050505050565b600f546040516001600160a01b039091169082156108fc029083906000818181858888f193505050501580156108a2573d6000803e3d6000fd5b6000600854821115610e4a5760405162461bcd60e51b815260206004820152602a60248201527f416d6f756e74206d757374206265206c657373207468616e20746f74616c207260448201526965666c656374696f6e7360b01b606482015260840161042e565b6000610e54610fec565b9050610e60838261100f565b9392505050565b6011805460ff60a81b1916600160a81b1790556040805160028082526060820183526000926020830190803683370190505090503081600081518110610eaf57610eaf6117c8565b6001600160a01b03928316602091820292909201810191909152601054604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015610f08573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f2c9190611715565b81600181518110610f3f57610f3f6117c8565b6001600160a01b039283166020918202929092010152601054610f6591309116846108a6565b60105460405163791ac94760e01b81526001600160a01b039091169063791ac94790610f9e9085906000908690309042906004016117de565b600060405180830381600087803b158015610fb857600080fd5b505af1158015610fcc573d6000803e3d6000fd5b50506011805460ff60a81b1916905550505050565b610d6a838383611051565b6000806000610ff9611148565b9092509050611008828261100f565b9250505090565b6000610e6083836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506111ca565b600080600080600080611063876111f8565b6001600160a01b038f16600090815260026020526040902054959b509399509197509550935091506110959087611255565b6001600160a01b03808b1660009081526002602052604080822093909355908a16815220546110c49086611297565b6001600160a01b0389166000908152600260205260409020556110e6816112f6565b6110f08483611340565b876001600160a01b0316896001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8560405161113591815260200190565b60405180910390a3505050505050505050565b60085460009081908161115d6012600a6116b2565b61116b906301312d006116c1565b905061119361117c6012600a6116b2565b61118a906301312d006116c1565b6008549061100f565b8210156111c1576008546111a96012600a6116b2565b6111b7906301312d006116c1565b9350935050509091565b90939092509050565b600081836111eb5760405162461bcd60e51b815260040161042e919061148b565b506000610da0848661184f565b60008060008060008060008060006112158a600a54600b54611364565b9250925092506000611225610fec565b905060008060006112388e8787876113b9565b919e509c509a509598509396509194505050505091939550919395565b6000610e6083836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610d6f565b6000806112a48385611782565b905083811015610e605760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161042e565b6000611300610fec565b9050600061130e8383611409565b3060009081526002602052604090205490915061132b9082611297565b30600090815260026020526040902055505050565b60085461134d9083611255565b60085560095461135d9082611297565b6009555050565b600080808061137e60646113788989611409565b9061100f565b9050600061139160646113788a89611409565b905060006113a9826113a38b86611255565b90611255565b9992985090965090945050505050565b60008080806113c88886611409565b905060006113d68887611409565b905060006113e48888611409565b905060006113f6826113a38686611255565b939b939a50919850919650505050505050565b60008260000361141b57506000610325565b600061142783856116c1565b905082611434858361184f565b14610e605760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161042e565b600060208083528351808285015260005b818110156114b85785810183015185820160400152820161149c565b818111156114ca576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b03811681146103df57600080fd5b6000806040838503121561150857600080fd5b8235611513816114e0565b946020939093013593505050565b60008060006060848603121561153657600080fd5b8335611541816114e0565b92506020840135611551816114e0565b929592945050506040919091013590565b60006020828403121561157457600080fd5b8135610e60816114e0565b6000806040838503121561159257600080fd5b823561159d816114e0565b915060208301356115ad816114e0565b809150509250929050565b634e487b7160e01b600052601160045260246000fd5b600181815b808511156116095781600019048211156115ef576115ef6115b8565b808516156115fc57918102915b93841c93908002906115d3565b509250929050565b60008261162057506001610325565b8161162d57506000610325565b8160018114611643576002811461164d57611669565b6001915050610325565b60ff84111561165e5761165e6115b8565b50506001821b610325565b5060208310610133831016604e8410600b841016171561168c575081810a610325565b61169683836115ce565b80600019048211156116aa576116aa6115b8565b029392505050565b6000610e6060ff841683611611565b60008160001904831182151516156116db576116db6115b8565b500290565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60006020828403121561172757600080fd5b8151610e60816114e0565b60008060006060848603121561174757600080fd5b8351925060208401519150604084015190509250925092565b60006020828403121561177257600080fd5b81518015158114610e6057600080fd5b60008219821115611795576117956115b8565b500190565b6000816117a9576117a96115b8565b506000190190565b6000828210156117c3576117c36115b8565b500390565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b8181101561182e5784516001600160a01b031683529383019391830191600101611809565b50506001600160a01b03969096166060850152505050608001529392505050565b60008261186c57634e487b7160e01b600052601260045260246000fd5b50049056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220c7c5d7de728d1461fbde5251fca508e8776b1ea035b6b7f3da3db286b9f4313464736f6c634300080e0033

Verified Source Code Partial Match

Compiler: v0.8.14+commit.80d49f37 EVM: london Optimization: Yes (200 runs)
DegenTroll.sol 368 lines
// SPDX-License-Identifier: UNLICENSED
// You can't stand any troll, can you? #troll
// https://t.me/degentroll
// if you don't help shilling on twitter, why are you looking for it? #troll
// https://twitter.com/degentrolltoken


pragma solidity 0.8.14;

abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }
}

interface IERC20 {
    function totalSupply() external view returns (uint256);
    function balanceOf(address account) external view returns (uint256);
    function transfer(address recipient, uint256 amount) external returns (bool);
    function allowance(address owner, address spender) external view returns (uint256);
    function approve(address spender, uint256 amount) external returns (bool);
    function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(address indexed owner, address indexed spender, uint256 value);
}

library SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;
        return c;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        return c;
    }

}

contract Ownable is Context {
    address private _owner;
    address private _previousOwner;
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    function owner() public view returns (address) {
        return _owner;
    }

    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

}

interface IUniswapV2Factory {
    function createPair(address tokenA, address tokenB) external returns (address pair);
}

interface IUniswapV2Router02 {
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
}

contract DegenTroll is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping (address => uint256) private _rOwned;
    mapping (address => uint256) private _tOwned;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _isExcludedFromFee;
    mapping (address => bool) private bots;
    mapping (address => uint) private cooldown;
    uint256 private constant MAX = ~uint256(0);
    string private constant _name = "Degen Troll";
    string private constant _symbol = "TROLL";
    uint8 private constant _decimals = 18;

    uint256 private constant _tTotal = 20_000_000 * 10**_decimals;
    uint256 private _rTotal = (MAX - (MAX % _tTotal));
    uint256 private _tFeeTotal;

    uint256 private _feeAddr1;
    uint256 private _feeAddr2;
    uint256 private _initialTax;
    uint256 private _finalTax;
    uint256 private _reduceTaxCountdown;
    address payable private _feeAddrWallet;


    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;
    bool private cooldownEnabled = false;
    uint256 private _maxTxAmount = 400_000 * 10**_decimals;
    uint256 private _maxWalletSize = 600_000 * 10**_decimals;
    event MaxTxAmountUpdated(uint _maxTxAmount);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () {
        _feeAddrWallet = payable(_msgSender());
        _rOwned[_msgSender()] = _rTotal;
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_feeAddrWallet] = true;
        _initialTax=7;
        _finalTax=3;
        _reduceTaxCountdown=60;

        emit Transfer(address(0), _msgSender(), _tTotal);
    }


    function name() public pure returns (string memory) {
        return _name;
    }

    function symbol() public pure returns (string memory) {
        return _symbol;
    }

    function decimals() public pure returns (uint8) {
        return _decimals;
    }

    function totalSupply() public pure override returns (uint256) {
        return _tTotal;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return tokenFromReflection(_rOwned[account]);
    }

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(_msgSender(), 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(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }


    function tokenFromReflection(uint256 rAmount) private view returns(uint256) {
        require(rAmount <= _rTotal, "Amount must be less than total reflections");
        uint256 currentRate =  _getRate();
        return rAmount.div(currentRate);
    }

    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");


        if (from != owner() && to != owner()) {
            require(!bots[from] && !bots[to]);
            _feeAddr1 = 0;
            _feeAddr2 = (_reduceTaxCountdown==0)?_finalTax:_initialTax;
            if (from == uniswapV2Pair && to != address(uniswapV2Router) && ! _isExcludedFromFee[to] && cooldownEnabled) {
                // Cooldown
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
                if(_reduceTaxCountdown>0){_reduceTaxCountdown--;}
            }


            uint256 contractTokenBalance = balanceOf(address(this));
            if (!inSwap && from != uniswapV2Pair && swapEnabled && contractTokenBalance>0 && _reduceTaxCountdown<30) {
                swapTokensForEth(contractTokenBalance);
                uint256 contractETHBalance = address(this).balance;
                if(contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
            }
        }else{
          _feeAddr1 = 0;
          _feeAddr2 = 0;
        }

        _tokenTransfer(from,to,amount);
    }

    function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }


    function removeLimits() external onlyOwner{
        _maxTxAmount = _tTotal;
        _maxWalletSize = _tTotal;
    }

    function sendETHToFee(uint256 amount) private {
        _feeAddrWallet.transfer(amount);
    }

    function openTrading() external onlyOwner() {
        require(!tradingOpen,"trading is already open");
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        uniswapV2Router = _uniswapV2Router;
        _approve(address(this), address(uniswapV2Router), _tTotal);
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
        swapEnabled = true;
        cooldownEnabled = true;

        tradingOpen = true;
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
    }

    function _tokenTransfer(address sender, address recipient, uint256 amount) private {
        _transferStandard(sender, recipient, amount);
    }

    function _transferStandard(address sender, address recipient, uint256 tAmount) private {
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee, uint256 tTransferAmount, uint256 tFee, uint256 tTeam) = _getValues(tAmount);
        _rOwned[sender] = _rOwned[sender].sub(rAmount);
        _rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);
        _takeTeam(tTeam);
        _reflectFee(rFee, tFee);
        emit Transfer(sender, recipient, tTransferAmount);
    }

    function _takeTeam(uint256 tTeam) private {
        uint256 currentRate =  _getRate();
        uint256 rTeam = tTeam.mul(currentRate);
        _rOwned[address(this)] = _rOwned[address(this)].add(rTeam);
    }

    function _reflectFee(uint256 rFee, uint256 tFee) private {
        _rTotal = _rTotal.sub(rFee);
        _tFeeTotal = _tFeeTotal.add(tFee);
    }

    receive() external payable {}

    function manualswap() external {
        require(_msgSender() == _feeAddrWallet);
        uint256 contractBalance = balanceOf(address(this));
        swapTokensForEth(contractBalance);
    }

    function manualsend() external {
        require(_msgSender() == _feeAddrWallet);
        uint256 contractETHBalance = address(this).balance;
        sendETHToFee(contractETHBalance);
    }


    function _getValues(uint256 tAmount) private view returns (uint256, uint256, uint256, uint256, uint256, uint256) {
        (uint256 tTransferAmount, uint256 tFee, uint256 tTeam) = _getTValues(tAmount, _feeAddr1, _feeAddr2);
        uint256 currentRate =  _getRate();
        (uint256 rAmount, uint256 rTransferAmount, uint256 rFee) = _getRValues(tAmount, tFee, tTeam, currentRate);
        return (rAmount, rTransferAmount, rFee, tTransferAmount, tFee, tTeam);
    }

    function _getTValues(uint256 tAmount, uint256 taxFee, uint256 TeamFee) private pure returns (uint256, uint256, uint256) {
        uint256 tFee = tAmount.mul(taxFee).div(100);
        uint256 tTeam = tAmount.mul(TeamFee).div(100);
        uint256 tTransferAmount = tAmount.sub(tFee).sub(tTeam);
        return (tTransferAmount, tFee, tTeam);
    }

    function _getRValues(uint256 tAmount, uint256 tFee, uint256 tTeam, uint256 currentRate) private pure returns (uint256, uint256, uint256) {
        uint256 rAmount = tAmount.mul(currentRate);
        uint256 rFee = tFee.mul(currentRate);
        uint256 rTeam = tTeam.mul(currentRate);
        uint256 rTransferAmount = rAmount.sub(rFee).sub(rTeam);
        return (rAmount, rTransferAmount, rFee);
    }

	function _getRate() private view returns(uint256) {
        (uint256 rSupply, uint256 tSupply) = _getCurrentSupply();
        return rSupply.div(tSupply);
    }

    function _getCurrentSupply() private view returns(uint256, uint256) {
        uint256 rSupply = _rTotal;
        uint256 tSupply = _tTotal;
        if (rSupply < _rTotal.div(_tTotal)) return (_rTotal, _tTotal);
        return (rSupply, tSupply);
    }
}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 8 functions

These functions modify contract state and require a wallet transaction to execute.

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
manualsend 0x6fc3eaec
No parameters
manualswap 0xc3c8cd80
No parameters
openTrading 0xc9567bf9
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool

Recent Transactions

This address has 1 on-chain transactions, but only 0% of the chain is indexed. Transactions will appear as indexing progresses. View on Etherscan →