Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x251824E7F938260412E825185CEcfe3903e4cf34
Balance 0 ETH
Nonce 1
Code Size 7180 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

7180 bytes
0x6080604052600436106101235760003560e01c806370a08231116100a0578063a9059cbb11610064578063a9059cbb14610341578063b87f137a14610361578063c3c8cd8014610381578063c9567bf914610396578063dd62ed3e146103ab57600080fd5b806370a08231146102a3578063715018a6146102c3578063751039fc146102d85780638da5cb5b146102ed57806395d89b411461031557600080fd5b8063273123b7116100e7578063273123b714610212578063313ce567146102325780635932ead11461024e578063677daa571461026e5780636fc3eaec1461028e57600080fd5b806306fdde031461012f578063095ea7b31461017b57806318160ddd146101ab5780631b3f71ae146101d057806323b872dd146101f257600080fd5b3661012a57005b600080fd5b34801561013b57600080fd5b506040805180820190915260118152704676636b20426561722043756c7475726560781b60208201525b60405161017291906119c3565b60405180910390f35b34801561018757600080fd5b5061019b61019636600461184a565b6103f1565b6040519015158152602001610172565b3480156101b757600080fd5b50670de0b6b3a76400005b604051908152602001610172565b3480156101dc57600080fd5b506101f06101eb366004611876565b610408565b005b3480156101fe57600080fd5b5061019b61020d366004611809565b6104a7565b34801561021e57600080fd5b506101f061022d366004611796565b610510565b34801561023e57600080fd5b5060405160098152602001610172565b34801561025a57600080fd5b506101f0610269366004611942565b61055b565b34801561027a57600080fd5b506101f061028936600461197c565b6105a3565b34801561029a57600080fd5b506101f06105fd565b3480156102af57600080fd5b506101c26102be366004611796565b61062a565b3480156102cf57600080fd5b506101f061064c565b3480156102e457600080fd5b506101f06106c0565b3480156102f957600080fd5b506000546040516001600160a01b039091168152602001610172565b34801561032157600080fd5b5060408051808201909152600381526246424360e81b6020820152610165565b34801561034d57600080fd5b5061019b61035c36600461184a565b6106fd565b34801561036d57600080fd5b506101f061037c36600461197c565b61070a565b34801561038d57600080fd5b506101f061075e565b3480156103a257600080fd5b506101f0610794565b3480156103b757600080fd5b506101c26103c63660046117d0565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b60006103fe338484610b8f565b5060015b92915050565b6000546001600160a01b0316331461043b5760405162461bcd60e51b815260040161043290611a18565b60405180910390fd5b60005b81518110156104a35760016006600084848151811061045f5761045f611b5f565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff19169115159190911790558061049b81611b2e565b91505061043e565b5050565b60006104b4848484610cb3565b610506843361050185604051806060016040528060288152602001611baf602891396001600160a01b038a16600090815260046020908152604080832033845290915290205491906110a6565b610b8f565b5060019392505050565b6000546001600160a01b0316331461053a5760405162461bcd60e51b815260040161043290611a18565b6001600160a01b03166000908152600660205260409020805460ff19169055565b6000546001600160a01b031633146105855760405162461bcd60e51b815260040161043290611a18565b600e8054911515600160b81b0260ff60b81b19909216919091179055565b6000546001600160a01b031633146105cd5760405162461bcd60e51b815260040161043290611a18565b600081116105da57600080fd5b6105f760646105f1670de0b6b3a7640000846110e0565b90611166565b600f5550565b600c546001600160a01b0316336001600160a01b03161461061d57600080fd5b47610627816111a8565b50565b6001600160a01b038116600090815260026020526040812054610402906111e2565b6000546001600160a01b031633146106765760405162461bcd60e51b815260040161043290611a18565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031633146106ea5760405162461bcd60e51b815260040161043290611a18565b670de0b6b3a7640000600f819055601055565b60006103fe338484610cb3565b6000546001600160a01b031633146107345760405162461bcd60e51b815260040161043290611a18565b6000811161074157600080fd5b61075860646105f1670de0b6b3a7640000846110e0565b60105550565b600c546001600160a01b0316336001600160a01b03161461077e57600080fd5b60006107893061062a565b90506106278161125f565b6000546001600160a01b031633146107be5760405162461bcd60e51b815260040161043290611a18565b600e54600160a01b900460ff16156108185760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e0000000000000000006044820152606401610432565b600d80546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556108543082670de0b6b3a7640000610b8f565b806001600160a01b031663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b15801561088d57600080fd5b505afa1580156108a1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108c591906117b3565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561090d57600080fd5b505afa158015610921573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061094591906117b3565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381600087803b15801561098d57600080fd5b505af11580156109a1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109c591906117b3565b600e80546001600160a01b0319166001600160a01b03928316179055600d541663f305d71947306109f58161062a565b600080610a0a6000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c4016060604051808303818588803b158015610a6d57600080fd5b505af1158015610a81573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610aa69190611995565b5050600e805461ffff60b01b191661010160b01b17905550610ad660646105f1670de0b6b3a764000060026110e0565b600f55610af160646105f1670de0b6b3a764000060036110e0565b601055600e8054600160a01b60ff60a01b19821617909155600d5460405163095ea7b360e01b81526001600160a01b039182166004820152600019602482015291169063095ea7b390604401602060405180830381600087803b158015610b5757600080fd5b505af1158015610b6b573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906104a3919061195f565b6001600160a01b038316610bf15760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610432565b6001600160a01b038216610c525760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610432565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610d175760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610432565b6001600160a01b038216610d795760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610432565b60008111610ddb5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610432565b6000600a818155600b55546001600160a01b03848116911614801590610e0f57506000546001600160a01b03838116911614155b15611096576001600160a01b03831660009081526006602052604090205460ff16158015610e5657506001600160a01b03821660009081526006602052604090205460ff16155b610e5f57600080fd5b600e546001600160a01b038481169116148015610e8a5750600d546001600160a01b03838116911614155b8015610eaf57506001600160a01b03821660009081526005602052604090205460ff16155b8015610ec45750600e54600160b81b900460ff165b15610fc957600f54811115610f1b5760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e000000000000006044820152606401610432565b60105481610f288461062a565b610f329190611abe565b1115610f805760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e0000000000006044820152606401610432565b6001600160a01b0382166000908152600760205260409020544211610fa457600080fd5b610faf42601e611abe565b6001600160a01b0383166000908152600760205260409020555b600e546001600160a01b038381169116148015610ff45750600d546001600160a01b03848116911614155b801561101957506001600160a01b03831660009081526005602052604090205460ff16155b15611029576000600a908155600b555b60006110343061062a565b600e54909150600160a81b900460ff1615801561105f5750600e546001600160a01b03858116911614155b80156110745750600e54600160b01b900460ff165b15611094576110828161125f565b47801561109257611092476111a8565b505b505b6110a18383836113e8565b505050565b600081848411156110ca5760405162461bcd60e51b815260040161043291906119c3565b5060006110d78486611b17565b95945050505050565b6000826110ef57506000610402565b60006110fb8385611af8565b9050826111088583611ad6565b1461115f5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610432565b9392505050565b600061115f83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506113f3565b600c546040516001600160a01b039091169082156108fc029083906000818181858888f193505050501580156104a3573d6000803e3d6000fd5b60006008548211156112495760405162461bcd60e51b815260206004820152602a60248201527f416d6f756e74206d757374206265206c657373207468616e20746f74616c207260448201526965666c656374696f6e7360b01b6064820152608401610432565b6000611253611421565b905061115f8382611166565b600e805460ff60a81b1916600160a81b17905560408051600280825260608201835260009260208301908036833701905050905030816000815181106112a7576112a7611b5f565b6001600160a01b03928316602091820292909201810191909152600d54604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b1580156112fb57600080fd5b505afa15801561130f573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061133391906117b3565b8160018151811061134657611346611b5f565b6001600160a01b039283166020918202929092010152600d5461136c9130911684610b8f565b600d5460405163791ac94760e01b81526001600160a01b039091169063791ac947906113a5908590600090869030904290600401611a4d565b600060405180830381600087803b1580156113bf57600080fd5b505af11580156113d3573d6000803e3d6000fd5b5050600e805460ff60a81b1916905550505050565b6110a1838383611444565b600081836114145760405162461bcd60e51b815260040161043291906119c3565b5060006110d78486611ad6565b600080600061142e61153b565b909250905061143d8282611166565b9250505090565b6000806000806000806114568761157b565b6001600160a01b038f16600090815260026020526040902054959b5093995091975095509350915061148890876115d8565b6001600160a01b03808b1660009081526002602052604080822093909355908a16815220546114b7908661161a565b6001600160a01b0389166000908152600260205260409020556114d981611679565b6114e384836116c3565b876001600160a01b0316896001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8560405161152891815260200190565b60405180910390a3505050505050505050565b6008546000908190670de0b6b3a76400006115568282611166565b82101561157257505060085492670de0b6b3a764000092509050565b90939092509050565b60008060008060008060008060006115988a600a54600b546116e7565b92509250925060006115a8611421565b905060008060006115bb8e878787611736565b919e509c509a509598509396509194505050505091939550919395565b600061115f83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506110a6565b6000806116278385611abe565b90508381101561115f5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610432565b6000611683611421565b9050600061169183836110e0565b306000908152600260205260409020549091506116ae908261161a565b30600090815260026020526040902055505050565b6008546116d090836115d8565b6008556009546116e0908261161a565b6009555050565b60008080806116fb60646105f189896110e0565b9050600061170e60646105f18a896110e0565b90506000611726826117208b866115d8565b906115d8565b9992985090965090945050505050565b600080808061174588866110e0565b9050600061175388876110e0565b9050600061176188886110e0565b905060006117738261172086866115d8565b939b939a50919850919650505050505050565b803561179181611b8b565b919050565b6000602082840312156117a857600080fd5b813561115f81611b8b565b6000602082840312156117c557600080fd5b815161115f81611b8b565b600080604083850312156117e357600080fd5b82356117ee81611b8b565b915060208301356117fe81611b8b565b809150509250929050565b60008060006060848603121561181e57600080fd5b833561182981611b8b565b9250602084013561183981611b8b565b929592945050506040919091013590565b6000806040838503121561185d57600080fd5b823561186881611b8b565b946020939093013593505050565b6000602080838503121561188957600080fd5b823567ffffffffffffffff808211156118a157600080fd5b818501915085601f8301126118b557600080fd5b8135818111156118c7576118c7611b75565b8060051b604051601f19603f830116810181811085821117156118ec576118ec611b75565b604052828152858101935084860182860187018a101561190b57600080fd5b600095505b838610156119355761192181611786565b855260019590950194938601938601611910565b5098975050505050505050565b60006020828403121561195457600080fd5b813561115f81611ba0565b60006020828403121561197157600080fd5b815161115f81611ba0565b60006020828403121561198e57600080fd5b5035919050565b6000806000606084860312156119aa57600080fd5b8351925060208401519150604084015190509250925092565b600060208083528351808285015260005b818110156119f0578581018301518582016040015282016119d4565b81811115611a02576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611a9d5784516001600160a01b031683529383019391830191600101611a78565b50506001600160a01b03969096166060850152505050608001529392505050565b60008219821115611ad157611ad1611b49565b500190565b600082611af357634e487b7160e01b600052601260045260246000fd5b500490565b6000816000190483118215151615611b1257611b12611b49565b500290565b600082821015611b2957611b29611b49565b500390565b6000600019821415611b4257611b42611b49565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160a01b038116811461062757600080fd5b801515811461062757600080fdfe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220d55ed3b03e58101842aa7eb521b0b76dd9a4f68e7296bf79e21068b1d379065964736f6c63430008070033

Verified Source Code Partial Match

Compiler: v0.8.7+commit.e28d00a7 EVM: london Optimization: Yes (200 runs)
FvckBearCulture.sol 391 lines
/**


███████╗██████╗░░█████╗░
██╔════╝██╔══██╗██╔══██╗
█████╗░░██████╦╝██║░░╚═╝
██╔══╝░░██╔══██╗██║░░██╗
██║░░░░░██████╦╝╚█████╔╝
╚═╝░░░░░╚═════╝░░╚════╝░

Fvck Bears

Telegram: https://t.me/FvckBearCulture

*/

pragma solidity ^0.8.4;
// SPDX-License-Identifier: UNLICENSED
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 FvckBearCulture 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);
    uint256 private constant _tTotal = 1000000000 * 10**9;
    uint256 private _rTotal = (MAX - (MAX % _tTotal));
    uint256 private _tFeeTotal;
    
    uint256 private _feeAddr1;
    uint256 private _feeAddr2;
    address payable private _feeAddrWallet;
    
    string private constant _name = "Fvck Bear Culture";
    string private constant _symbol = "FBC";
    uint8 private constant _decimals = 9;
    
    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;
    bool private cooldownEnabled = false;
    uint256 private _maxTxAmount = _tTotal;
    uint256 private _maxWalletSize = _tTotal;
    event MaxTxAmountUpdated(uint _maxTxAmount);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () {
        _feeAddrWallet = payable(0xC63eCC3f2824FC8447d1c7dAF22cA8420bADfBa0);
        _rOwned[_msgSender()] = _rTotal;
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[_feeAddrWallet] = true;
        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 setCooldownEnabled(bool onoff) external onlyOwner() {
        cooldownEnabled = onoff;
    }

    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");
        _feeAddr1 = 0;
        _feeAddr2 = 10;
        if (from != owner() && to != owner()) {
            require(!bots[from] && !bots[to]);
            if (from == uniswapV2Pair && to != address(uniswapV2Router) && ! _isExcludedFromFee[to] && cooldownEnabled) {
                // Cooldown
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
                require(cooldown[to] < block.timestamp);
                cooldown[to] = block.timestamp + (30 seconds);
            }
            
            
            if (to == uniswapV2Pair && from != address(uniswapV2Router) && ! _isExcludedFromFee[from]) {
                _feeAddr1 = 0;
                _feeAddr2 = 10;
            }
            uint256 contractTokenBalance = balanceOf(address(this));
            if (!inSwap && from != uniswapV2Pair && swapEnabled) {
                swapTokensForEth(contractTokenBalance);
                uint256 contractETHBalance = address(this).balance;
                if(contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
            }
        }
		
        _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 changeMaxTxAmount(uint256 percentage) external onlyOwner{
        require(percentage>0);
        _maxTxAmount = _tTotal.mul(percentage).div(100);
    }

    function changeMaxWalletSize(uint256 percentage) external onlyOwner{
        require(percentage>0);
        _maxWalletSize = _tTotal.mul(percentage).div(100);
    }
        
    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;
        _maxTxAmount = _tTotal.mul(2).div(100);
        _maxWalletSize = _tTotal.mul(3).div(100);
        tradingOpen = true;
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
    }
    
    function nonosquare(address[] memory bots_) public onlyOwner {
        for (uint i = 0; i < bots_.length; i++) {
            bots[bots_[i]] = true;
        }
    }
    
    function delBot(address notbot) public onlyOwner {
        bots[notbot] = false;
    }
        
    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 13 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
changeMaxTxAmount 0x677daa57
uint256 percentage
changeMaxWalletSize 0xb87f137a
uint256 percentage
delBot 0x273123b7
address notbot
manualsend 0x6fc3eaec
No parameters
manualswap 0xc3c8cd80
No parameters
nonosquare 0x1b3f71ae
address[] bots_
openTrading 0xc9567bf9
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
setCooldownEnabled 0x5932ead1
bool onoff
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool

Recent Transactions

No transactions found for this address