ETH Price: $2,684.80 (-2.26%)

Token

Proof of Life (H2.0)
 

Overview

Max Total Supply

1,000,000,000 H2.0

Holders

35

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
17,977,940.065016877896201344 H2.0

Value
$0.00
0x99645a9761da8586e134af9827cd06ce78e25be3
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
ProofOfLifeH20

Compiler Version
v0.8.13+commit.abaa5c0e

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion
File 1 of 2 : proofoflifeh20.sol
/**
    Website ~ https://proofoflife.web.app/
    Telegram ~ https://t.me/proofoflifeh20
*/

// SPDX-License-Identifier: MIT

pragma solidity 0.8.13;         

// OpenZeppelin Contracts - https://www.openzeppelin.com/
import "@openzeppelin/contracts/utils/math/SafeMath.sol";  

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

    function _msgData() internal view virtual returns (bytes calldata) {
        this;           // silence state mutability warning without generating bytecode - see https: //github.com/ethereum/solidity/issues/2691
        return msg.data;         
    }
}

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

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 cal ler's tokens.
     *
     * Returns a boolean value indicating whether the op eration succeeded.
     *
     * IMPORTANT: Beware that changing an allowan ce 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 spe nder's allowance to 0 and set the
     * desired valu  afterwards:
     * https: //github.co m/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);         

    /**
     * @dev Moves `amount` toke ns from `sender` to `recipient` using the
     * allowance mechanism. `am ount` 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 `v alue` tokens are moved from one account (`from`) to
     * anot her (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);         

    /**
     * @dev Emitted when the all owance of a `spender` for an `owner` is set by
     * a call to {approve}. `va lue` is the new allowance.
     */
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );         
}

interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);         

    /**
     * @dev Returns the symbol of the token.
     */
    function symbol() external view returns (string memory);         

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);         
}

contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping(address => uint256) private _balances;         

    mapping(address => mapping(address => uint256)) private _allowances;         

    uint256 private _totalSupply;         

    string private _name;         
    string private _symbol;         

    constructor(string memory name_, string memory symbol_) {
        _name = name_;         
        _symbol = symbol_;         
    }

    function name() public view virtual override returns (string memory) {
        return _name;         
    }

    function symbol() public view virtual override returns (string memory) {
        return _symbol;         
    }

    function decimals() public view virtual override returns (uint8) {
        return 18;         
    }

    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;         
    }

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

    function transfer(address recipient, uint256 amount)
        public
        virtual
        override
        returns (bool)
    {
        _transfer(_msgSender(), recipient, amount);         
        return true;         
    }

    function allowance(address owner, address spender)
        public
        view
        virtual
        override
        returns (uint256)
    {
        return _allowances[owner][spender];         
    }

    function approve(address spender, uint256 amount)
        public
        virtual
        override
        returns (bool)
    {
        _approve(_msgSender(), spender, amount);         
        return true;         
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);         

        uint256 currentAllowance = _allowances[sender][_msgSender()];         
        require(
            currentAllowance >= amount,
            "ERC20: transfer amount exceeds allowance"
        );         
        unchecked {
            _approve(sender, _msgSender(), currentAllowance - amount);         
        }

        return true;         
    }

    function increaseAllowance(address spender, uint256 addedValue)
        public
        virtual
        returns (bool)
    {
        _approve(
            _msgSender(),
            spender,
            _allowances[_msgSender()][spender] + addedValue
        );         
        return true;         
    }

    function decreaseAllowance(address spender, uint256 subtractedValue)
        public
        virtual
        returns (bool)
    {
        uint256 currentAllowance = _allowances[_msgSender()][spender];         
        require(
            currentAllowance >= subtractedValue,
            "ERC20: decreased allowance below zero"
        );         
        unchecked {
            _approve(_msgSender(), spender, currentAllowance - subtractedValue);         
        }

        return true;         
    }

    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");         
        require(recipient != address(0), "ERC20: transfer to the zero address");         

        uint256 senderBalance = _balances[sender];         
        require(
            senderBalance >= amount,
            "ERC20: transfer amount exceeds balance"
        );         
        unchecked {
            _balances[sender] = senderBalance - amount;         
        }
        _balances[recipient] += amount;         

        emit Transfer(sender, recipient, amount);         
    }

    function _createInitialSupply(address account, uint256 amount)
        internal
        virtual
    {
        require(account != address(0), "ERC20: mint to the zero address");         
        _totalSupply += amount;         
        _balances[account] += amount;         
        emit Transfer(address(0), account, amount);         
    }

    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        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);         
    }
}


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() {
        address msgSender = _msgSender();         
        _owner = msgSender;         
        emit OwnershipTransferred(address(0), msgSender);         
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view returns (address) {
        return _owner;         
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");         
        _;         
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));         
        _owner = 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"
        );         
        emit OwnershipTransferred(_owner, newOwner);         
        _owner = newOwner;         
    }
}

library SafeMathInt {
    int256 private constant MIN_INT256 = int256(1) << 255;         
    int256 private constant MAX_INT256 = ~(int256(1) << 255);         

    /**
     * @dev Multiplies two int256 variables and fails on overflow.
     */
    function mul(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a * b;         

         // Detect overflow when multiplying MIN_INT256 with -1
        require(c != MIN_INT256 || (a & MIN_INT256) != (b & MIN_INT256));         
        require((b == 0) || (c / b == a));         
        return c;         
    }

    /**
     * @dev Division of two int256 variables and fails on overflow.
     */
    function div(int256 a, int256 b) internal pure returns (int256) {
         // Prevent overflow when dividing MIN_INT256 by -1
        require(b != -1 || a != MIN_INT256);         

         // Solidity already throws when dividing by 0.
        return a / b;         
    }

    /**
     * @dev Subtracts two int256 variables and fails on overflow.
     */
    function sub(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a - b;         
        require((b >= 0 && c <= a) || (b < 0 && c > a));         
        return c;         
    }

    /**
     * @dev Adds two int256 variables and fails on overflow.
     */
    function add(int256 a, int256 b) internal pure returns (int256) {
        int256 c = a + b;         
        require((b >= 0 && c >= a) || (b < 0 && c < a));         
        return c;         
    }

    /**
     * @dev Converts to absolute value, and fails on overflow.
     */
    function abs(int256 a) internal pure returns (int256) {
        require(a != MIN_INT256);         
        return a < 0 ? -a : a;         
    }

    function toUint256Safe(int256 a) internal pure returns (uint256) {
        require(a >= 0);         
        return uint256(a);         
    }
}

library SafeMathUint {
    function toInt256Safe(uint256 a) internal pure returns (int256) {
        int256 b = int256(a);         
        require(b >= 0);         
        return b;         
    }
}

interface IUniswapV2Router01 {
    function factory() external pure returns (address);         

    function WETH() external pure returns (address);         

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    )
        external
        returns (
            uint256 amountA,
            uint256 amountB,
            uint256 liquidity
        );         

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );         

    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint256 liquidity,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountA, uint256 amountB);         

    function removeLiquidityETH(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountToken, uint256 amountETH);         

    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint256 liquidity,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountA, uint256 amountB);         

    function removeLiquidityETHWithPermit(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountToken, uint256 amountETH);         

    function swapExactTokensForTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);         

    function swapTokensForExactTokens(
        uint256 amountOut,
        uint256 amountInMax,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);         

    function swapExactETHForTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable returns (uint256[] memory amounts);         

    function swapTokensForExactETH(
        uint256 amountOut,
        uint256 amountInMax,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);         

    function swapExactTokensForETH(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external returns (uint256[] memory amounts);         

    function swapETHForExactTokens(
        uint256 amountOut,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable returns (uint256[] memory amounts);         

    function quote(
        uint256 amountA,
        uint256 reserveA,
        uint256 reserveB
    ) external pure returns (uint256 amountB);         

    function getAmountOut(
        uint256 amountIn,
        uint256 reserveIn,
        uint256 reserveOut
    ) external pure returns (uint256 amountOut);         

    function getAmountIn(
        uint256 amountOut,
        uint256 reserveIn,
        uint256 reserveOut
    ) external pure returns (uint256 amountIn);         

    function getAmountsOut(uint256 amountIn, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);         

    function getAmountsIn(uint256 amountOut, address[] calldata path)
        external
        view
        returns (uint256[] memory amounts);         
}

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountETH);         

    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint256 liquidity,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint256 amountETH);         

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;         

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable;         

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;         
}

contract ProofOfLifeH20 is ERC20, Ownable {
    using SafeMath for uint256;         

    IUniswapV2Router02 public uniswapV2Router;         
    address public uniswapV2Pair;         

    bool private swapping;         

    uint256 public swapTokensAtAmount;         
    uint256 public maxTransactionAmount;         

    uint256 public liquidityActiveBlock = 0;           // 0 means liquidity is not active yet
    uint256 public tradingActiveBlock = 0;           // 0 means trading is not active

    bool public tradingActive = false;         
    bool public limitsInEffect = true;         
    bool public swapEnabled = false;         

    address public constant burnWallet =
        0x000000000000000000000000000000000000dEaD;         
    address public marketingWallet = 0xB46eafdd84196Bc817720058CB1e8D554A54134b;         

    uint256 public constant feeDivisor = 1000;         

    uint256 public marketingBuysFee;         
    uint256 public totalBuyFees;         

    uint256 public marketingSellsFee;         
    uint256 public totalSellsFees;         

    uint256 public tokensForFees;         
    uint256 public tokensForMarketing;         

    bool public transferDelayEnabled = true;         
    uint256 public maxWallet;         

    mapping(address => bool) private _isExcludedFromFees;         
    mapping(address => bool) public _isExcludedMaxTransactionAmount;         

    mapping(address => bool) public automatedMarketMakerPairs;         

    mapping(address => uint256) public _earlyBuyer;         

    event ExcludeFromFees(address indexed account, bool isExcluded);         
    event ExcludeMultipleAccountsFromFees(address[] accounts, bool isExcluded);         

    event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);         

    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );         

    constructor() ERC20("Proof of Life", "H2.0") {
        uint256 totalSupply = 1 * 1e9 * 1e18;         

        swapTokensAtAmount = (totalSupply * 1) / 10000;           // 0.01% swap tokens amount
        maxTransactionAmount = (totalSupply * 20) / 1000;           // 1% maxTransactionAmountTxn
        maxWallet = (totalSupply * 20) / 1000;           // 2% maxWallet

        marketingBuysFee = 40;           // 4%
        totalBuyFees = marketingBuysFee;         

        marketingSellsFee = 40;           // 4%
        totalSellsFees = marketingSellsFee;         


        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );         

         // Create a uniswap pair for this new token
        address _uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
            .createPair(address(this), _uniswapV2Router.WETH());         

        uniswapV2Router = _uniswapV2Router;         
        uniswapV2Pair = _uniswapV2Pair;         

        _setAutomatedMarketMakerPair(_uniswapV2Pair, true);         

         // exclude from paying fees or having max transaction amount
        excludeFromFees(owner(), true);         
        excludeFromFees(address(this), true);         
        excludeFromFees(address(0xdead), true);         
        excludeFromFees(address(_uniswapV2Router), true);         
        excludeFromFees(address(marketingWallet), true);         

        excludeFromMaxTransaction(owner(), true);         
        excludeFromMaxTransaction(address(this), true);         
        excludeFromMaxTransaction(address(0xdead), true);         
        excludeFromMaxTransaction(address(marketingWallet), true);         

        _createInitialSupply(address(owner()), totalSupply);         
    }

    receive() external payable {}

    function enableTrading() external onlyOwner {
        require(!tradingActive, "Cannot re-enable trading");         
        tradingActive = true;         
        swapEnabled = true;         
        tradingActiveBlock = block.number;         
    }

    function updateMaxTxnAmount(uint256 newNum) external onlyOwner {
        require(
            newNum >= ((totalSupply() * 20) / 1000) / 1e18,
            "Cannot set maxTransactionAmount lower than 2.0%"
        );         
        maxTransactionAmount = newNum * (10**18);         
    }

    function updateMaxWalletAmount(uint256 newNum) external onlyOwner {
        require(
            newNum >= ((totalSupply() * 40) / 1000) / 1e18,
            "Cannot set maxWallet lower than 4.0%"
        );         
        maxWallet = newNum * (10**18);         
    }

    function excludeFromMaxTransaction(address updAds, bool isEx)
        public
        onlyOwner
    {
        _isExcludedMaxTransactionAmount[updAds] = isEx;         
    }

     // only use to disable contract sales if absolutely necessary (emergency use only)
    function updateSwapEnabled(bool enabled) external onlyOwner {
        swapEnabled = enabled;         
    }

    function updateSellFees(uint256 _marketingSellsFee) external onlyOwner {
        marketingSellsFee = _marketingSellsFee;         
        totalSellsFees = marketingSellsFee;         
        require(totalSellsFees <= 100, "Must keep fees at 10% or less");         
    }

    function updateBuyFees(uint256 _marketingBuysFee) external onlyOwner {
        marketingBuysFee = _marketingBuysFee;         
        totalBuyFees = marketingBuysFee;         
        require(totalSellsFees <= 100, "Must keep fees at 10% or less");         
    }

    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;         

        emit ExcludeFromFees(account, excluded);         
    }

    function excludeMultipleAccountsFromFees(
        address[] calldata accounts,
        bool excluded
    ) external onlyOwner {
        for (uint256 i = 0;          i < accounts.length;          i++) {
            _isExcludedFromFees[accounts[i]] = excluded;         
        }

        emit ExcludeMultipleAccountsFromFees(accounts, excluded);         
    }

    function setAutomatedMarketMakerPair(address pair, bool value)
        external
        onlyOwner
    {
        require(
            pair != uniswapV2Pair,
            "The Uniswap pair cannot be removed from automatedMarketMakerPairs"
        );         

        _setAutomatedMarketMakerPair(pair, value);         
    }

    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        automatedMarketMakerPairs[pair] = value;         
        emit SetAutomatedMarketMakerPair(pair, value);         
    }

    function isExcludedFromFees(address account) external view returns (bool) {
        return _isExcludedFromFees[account];         
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        require(from != address(0), "ERC20: transfer from the zero address");         
        require(to != address(0), "ERC20: transfer to the zero address");         


        if (amount == 0) {
            super._transfer(from, to, 0);         
            return;         
        }

        if (!tradingActive) {
            require(
                _isExcludedFromFees[from] || _isExcludedFromFees[to],
                "Trading is not active yet."
            );         
        }

        if (limitsInEffect) {
            if (
                from != owner() &&
                to != owner() &&
                to != address(0) &&
                to != address(0xdead) &&
                !swapping
            ) {
                if (!tradingActive) {
                    require(
                        _isExcludedFromFees[from] || _isExcludedFromFees[to],
                        "Trading is not active."
                    );         
                }

                 //when buy
                if (
                    automatedMarketMakerPairs[from] &&
                    !_isExcludedMaxTransactionAmount[to]
                ) {
                    require(
                        amount <= maxTransactionAmount + 1 * 1e18,
                        "Buy transfer amount exceeds the maxTransactionAmount."
                    );         
                    require(
                        amount + balanceOf(to) <= maxWallet,
                        "Max wallet exceeded"
                    );         
                }
                 //when sell
                else if (
                    automatedMarketMakerPairs[to] &&
                    !_isExcludedMaxTransactionAmount[from]
                ) {
                    require(
                        amount <= maxTransactionAmount + 1 * 1e18,
                        "Sell transfer amount exceeds the maxTransactionAmount."
                    );         
                } else if (!_isExcludedMaxTransactionAmount[to]) {
                    require(
                        amount + balanceOf(to) <= maxWallet,
                        "Max wallet exceeded"
                    );         
                }
            }
        }

        uint256 contractTokenBalance = balanceOf(address(this));         
        bool canSwap = contractTokenBalance >= swapTokensAtAmount;         

        if (
            canSwap &&
            swapEnabled &&
            !swapping &&
            !automatedMarketMakerPairs[from] &&
            !_isExcludedFromFees[from] &&
            !_isExcludedFromFees[to]
        ) {
            swapping = true;         
            swapBack();         
            swapping = false;         
        }

        bool takeFee = !swapping;         

         // if any account belongs to _isExcludedFromFee account then remove the fee
        if (_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;         
        }

        uint256 fees = 0;         

         // no taxes on transfers (non buys/sells)
        if (takeFee) {
             // on sell take fees, purchase token and burn it
            if (automatedMarketMakerPairs[to] && totalSellsFees > 0) {
                fees = amount.mul(totalSellsFees).div(feeDivisor);         
                tokensForFees += fees;         
                tokensForMarketing += (fees * marketingSellsFee) / totalSellsFees;         
            }
             // on buy
            else if (automatedMarketMakerPairs[from]) {
                fees = amount.mul(totalBuyFees).div(feeDivisor);         
                tokensForFees += fees;         
                tokensForMarketing += (fees * marketingBuysFee) / totalBuyFees;         
            }

            if (fees > 0) {
                super._transfer(from, address(this), fees);         
            }

            amount -= fees;         
        }


        super._transfer(from, to, amount);         
    }

    function swapTokensForEth(uint256 tokenAmount) private {
         // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);         
        path[0] = address(this);         
        path[1] = uniswapV2Router.WETH();         

        _approve(address(this), address(uniswapV2Router), tokenAmount);         

         // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,  // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );         
    }

    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
         // approve token transfer to cover all possible scenarios
        _approve(address(this), address(uniswapV2Router), tokenAmount);         

         // add the liquidity
        uniswapV2Router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0,  // slippage is unavoidable
            0,  // slippage is unavoidable
            address(0xdead),
            block.timestamp
        );         
    }

    function manualSwap() external onlyOwner {
        uint256 contractBalance = balanceOf(address(this));         
        swapTokensForEth(contractBalance);         
    }

     // remove limits after token is stable
    function removeLimits() external onlyOwner returns (bool) {
        limitsInEffect = false;         
        return true;         
    }

    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));         
        uint256 totalTokensToSwap = tokensForMarketing;         
        bool success;         

        if (contractBalance == 0 || totalTokensToSwap == 0) {
            return;         
        }

        uint256 amountToSwapForETH = contractBalance;         
        swapTokensForEth(amountToSwapForETH);         

        (success, ) = address(marketingWallet).call{
            value: address(this).balance
        }("");         

        tokensForMarketing = 0;         
        tokensForFees = 0;         
    }



    function withdrawStuckEth() external onlyOwner {
        (bool success, ) = address(msg.sender).call{
            value: address(this).balance
        }("");         
        require(success, "failed to withdraw");         
    }
}

File 2 of 2 : SafeMath.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.6.0) (utils/math/SafeMath.sol)

pragma solidity ^0.8.0;

// CAUTION
// This version of SafeMath should only be used with Solidity 0.8 or later,
// because it relies on the compiler's built in overflow checks.

/**
 * @dev Wrappers over Solidity's arithmetic operations.
 *
 * NOTE: `SafeMath` is generally not needed starting with Solidity 0.8, since the compiler
 * now has built in overflow checking.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
            // benefit is lost if 'b' is also tested.
            // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
            if (a == 0) return (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        return a + b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return a - b;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator.
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return a % b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting with custom message when dividing by zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryMod}.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}

Settings
{
  "optimizer": {
    "enabled": true,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"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":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address[]","name":"accounts","type":"address[]"},{"indexed":false,"internalType":"bool","name":"isExcluded","type":"bool"}],"name":"ExcludeMultipleAccountsFromFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pair","type":"address"},{"indexed":true,"internalType":"bool","name":"value","type":"bool"}],"name":"SetAutomatedMarketMakerPair","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiqudity","type":"uint256"}],"name":"SwapAndLiquify","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":"","type":"address"}],"name":"_earlyBuyer","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"_isExcludedMaxTransactionAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"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":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"automatedMarketMakerPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"burnWallet","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":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"updAds","type":"address"},{"internalType":"bool","name":"isEx","type":"bool"}],"name":"excludeFromMaxTransaction","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"accounts","type":"address[]"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeMultipleAccountsFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"feeDivisor","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":"account","type":"address"}],"name":"isExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"limitsInEffect","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"liquidityActiveBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"manualSwap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"marketingBuysFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"marketingSellsFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"marketingWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTransactionAmount","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":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapTokensAtAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForMarketing","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalBuyFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSellsFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingActiveBlock","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":[],"name":"transferDelayEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_marketingBuysFee","type":"uint256"}],"name":"updateBuyFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newNum","type":"uint256"}],"name":"updateMaxTxnAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newNum","type":"uint256"}],"name":"updateMaxWalletAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_marketingSellsFee","type":"uint256"}],"name":"updateSellFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enabled","type":"bool"}],"name":"updateSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawStuckEth","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60806040526000600a819055600b55600c80546001600160b81b03191676b46eafdd84196bc817720058cb1e8d554a54134b0001001790556013805460ff191660011790553480156200005157600080fd5b50604080518082018252600d81526c50726f6f66206f66204c69666560981b602080830191825283518085019094526004845263048322e360e41b908401528151919291620000a39160039162000688565b508051620000b990600490602084019062000688565b5050506000620000ce6200042760201b60201c565b600580546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506b033b2e3c9fd0803ce80000006127106200013982600162000744565b62000145919062000766565b6008556103e86200015882601462000744565b62000164919062000766565b6009556103e86200017782601462000744565b62000183919062000766565b6014556028600d819055600e819055600f8190556010556040805163c45a015560e01b81529051737a250d5630b4cf539739df2c5dacb4c659f2488d91600091839163c45a01559160048281019260209291908290030181865afa158015620001f0573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000216919062000789565b6001600160a01b031663c9c6539630846001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000264573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200028a919062000789565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015620002d8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620002fe919062000789565b600680546001600160a01b038086166001600160a01b031992831617909255600780549284169290911691909117905590506200033d8160016200042b565b6200035c620003546005546001600160a01b031690565b60016200047f565b620003693060016200047f565b6200037861dead60016200047f565b620003858260016200047f565b600c54620003a590630100000090046001600160a01b031660016200047f565b620003c4620003bc6005546001600160a01b031690565b60016200052d565b620003d13060016200052d565b620003e061dead60016200052d565b600c546200040090630100000090046001600160a01b031660016200052d565b6200041e620004176005546001600160a01b031690565b84620005a3565b50505062000812565b3390565b6001600160a01b038216600081815260176020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6005546001600160a01b03163314620004ce5760405162461bcd60e51b8152602060048201819052602482015260008051602062002d5c83398151915260448201526064015b60405180910390fd5b6001600160a01b038216600081815260156020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314620005785760405162461bcd60e51b8152602060048201819052602482015260008051602062002d5c8339815191526044820152606401620004c5565b6001600160a01b03919091166000908152601660205260409020805460ff1916911515919091179055565b6001600160a01b038216620005fb5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401620004c5565b80600260008282546200060f9190620007bb565b90915550506001600160a01b038216600090815260208190526040812080548392906200063e908490620007bb565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b8280546200069690620007d6565b90600052602060002090601f016020900481019282620006ba576000855562000705565b82601f10620006d557805160ff191683800117855562000705565b8280016001018555821562000705579182015b8281111562000705578251825591602001919060010190620006e8565b506200071392915062000717565b5090565b5b8082111562000713576000815560010162000718565b634e487b7160e01b600052601160045260246000fd5b60008160001904831182151516156200076157620007616200072e565b500290565b6000826200078457634e487b7160e01b600052601260045260246000fd5b500490565b6000602082840312156200079c57600080fd5b81516001600160a01b0381168114620007b457600080fd5b9392505050565b60008219821115620007d157620007d16200072e565b500190565b600181811c90821680620007eb57607f821691505b6020821081036200080c57634e487b7160e01b600052602260045260246000fd5b50919050565b61253a80620008226000396000f3fe6080604052600436106102e85760003560e01c806375f0a87411610190578063bbc0c742116100dc578063dd62ed3e11610095578063ee40166e1161006f578063ee40166e146108d8578063f2fde38b146108ee578063f8afa9511461090e578063f8b45b051461092457600080fd5b8063dd62ed3e1461085c578063e2f45605146108a2578063eba4c333146108b857600080fd5b8063bbc0c742146107b2578063c0246668146107cc578063c18bc195146107ec578063c492f0461461080c578063c876d0b91461082c578063c8c8ebe41461084657600080fd5b806397b1406111610149578063a457c2d711610123578063a457c2d71461072c578063a9059cbb1461074c578063b62496f51461076c578063b9e937001461079c57600080fd5b806397b14061146106e05780639a36f932146106f65780639a7a23d61461070c57600080fd5b806375f0a8741461063c5780637fa787ba146106635780638a8c523c146106785780638da5cb5b1461068d578063924de9b7146106ab57806395d89b41146106cb57600080fd5b8063395093511161024f57806351bc3c8511610208578063715018a6116101e2578063715018a6146105d257806371fc4688146105e7578063751039fc146106075780637571336a1461061c57600080fd5b806351bc3c85146105675780636ddd17131461057c57806370a082311461059c57600080fd5b806339509351146104a35780633f8a6204146104c357806349bd5a5e146104d95780634a62bb65146104f95780634eed1183146105185780634fbee1931461052e57600080fd5b806318160ddd116102a157806318160ddd146103ed5780631f3fed8f14610402578063203e727e1461041857806323b872dd1461043a5780632a3de72e1461045a578063313ce5671461048757600080fd5b806306228749146102f457806306fdde0314610327578063095ea7b3146103495780630f4432e31461037957806310d5de531461039d5780631694505e146103cd57600080fd5b366102ef57005b600080fd5b34801561030057600080fd5b5061030a61dead81565b6040516001600160a01b0390911681526020015b60405180910390f35b34801561033357600080fd5b5061033c61093a565b60405161031e9190612042565b34801561035557600080fd5b506103696103643660046120ac565b6109cc565b604051901515815260200161031e565b34801561038557600080fd5b5061038f600a5481565b60405190815260200161031e565b3480156103a957600080fd5b506103696103b83660046120d8565b60166020526000908152604090205460ff1681565b3480156103d957600080fd5b5060065461030a906001600160a01b031681565b3480156103f957600080fd5b5060025461038f565b34801561040e57600080fd5b5061038f60125481565b34801561042457600080fd5b506104386104333660046120f5565b6109e2565b005b34801561044657600080fd5b5061036961045536600461210e565b610ac8565b34801561046657600080fd5b5061038f6104753660046120d8565b60186020526000908152604090205481565b34801561049357600080fd5b506040516012815260200161031e565b3480156104af57600080fd5b506103696104be3660046120ac565b610b72565b3480156104cf57600080fd5b5061038f60115481565b3480156104e557600080fd5b5060075461030a906001600160a01b031681565b34801561050557600080fd5b50600c5461036990610100900460ff1681565b34801561052457600080fd5b5061038f60105481565b34801561053a57600080fd5b506103696105493660046120d8565b6001600160a01b031660009081526015602052604090205460ff1690565b34801561057357600080fd5b50610438610bae565b34801561058857600080fd5b50600c546103699062010000900460ff1681565b3480156105a857600080fd5b5061038f6105b73660046120d8565b6001600160a01b031660009081526020819052604090205490565b3480156105de57600080fd5b50610438610bf4565b3480156105f357600080fd5b506104386106023660046120f5565b610c68565b34801561061357600080fd5b50610369610cef565b34801561062857600080fd5b50610438610637366004612164565b610d2d565b34801561064857600080fd5b50600c5461030a90630100000090046001600160a01b031681565b34801561066f57600080fd5b50610438610d82565b34801561068457600080fd5b50610438610e39565b34801561069957600080fd5b506005546001600160a01b031661030a565b3480156106b757600080fd5b506104386106c6366004612199565b610ecd565b3480156106d757600080fd5b5061033c610f13565b3480156106ec57600080fd5b5061038f600f5481565b34801561070257600080fd5b5061038f6103e881565b34801561071857600080fd5b50610438610727366004612164565b610f22565b34801561073857600080fd5b506103696107473660046120ac565b610fe8565b34801561075857600080fd5b506103696107673660046120ac565b611081565b34801561077857600080fd5b506103696107873660046120d8565b60176020526000908152604090205460ff1681565b3480156107a857600080fd5b5061038f600e5481565b3480156107be57600080fd5b50600c546103699060ff1681565b3480156107d857600080fd5b506104386107e7366004612164565b61108e565b3480156107f857600080fd5b506104386108073660046120f5565b611117565b34801561081857600080fd5b506104386108273660046121b4565b6111e8565b34801561083857600080fd5b506013546103699060ff1681565b34801561085257600080fd5b5061038f60095481565b34801561086857600080fd5b5061038f610877366004612238565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156108ae57600080fd5b5061038f60085481565b3480156108c457600080fd5b506104386108d33660046120f5565b6112c4565b3480156108e457600080fd5b5061038f600b5481565b3480156108fa57600080fd5b506104386109093660046120d8565b611349565b34801561091a57600080fd5b5061038f600d5481565b34801561093057600080fd5b5061038f60145481565b60606003805461094990612271565b80601f016020809104026020016040519081016040528092919081815260200182805461097590612271565b80156109c25780601f10610997576101008083540402835291602001916109c2565b820191906000526020600020905b8154815290600101906020018083116109a557829003601f168201915b5050505050905090565b60006109d9338484611434565b50600192915050565b6005546001600160a01b03163314610a155760405162461bcd60e51b8152600401610a0c906122ab565b60405180910390fd5b670de0b6b3a76400006103e8610a2a60025490565b610a359060146122f6565b610a3f9190612315565b610a499190612315565b811015610ab05760405162461bcd60e51b815260206004820152602f60248201527f43616e6e6f7420736574206d61785472616e73616374696f6e416d6f756e742060448201526e6c6f776572207468616e20322e302560881b6064820152608401610a0c565b610ac281670de0b6b3a76400006122f6565b60095550565b6000610ad5848484611558565b6001600160a01b038416600090815260016020908152604080832033845290915290205482811015610b5a5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b6064820152608401610a0c565b610b678533858403611434565b506001949350505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916109d9918590610ba9908690612337565b611434565b6005546001600160a01b03163314610bd85760405162461bcd60e51b8152600401610a0c906122ab565b30600090815260208190526040902054610bf181611c81565b50565b6005546001600160a01b03163314610c1e5760405162461bcd60e51b8152600401610a0c906122ab565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610c925760405162461bcd60e51b8152600401610a0c906122ab565b600d819055600e81905560105460641015610bf15760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420313025206f72206c6573730000006044820152606401610a0c565b6005546000906001600160a01b03163314610d1c5760405162461bcd60e51b8152600401610a0c906122ab565b50600c805461ff0019169055600190565b6005546001600160a01b03163314610d575760405162461bcd60e51b8152600401610a0c906122ab565b6001600160a01b03919091166000908152601660205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610dac5760405162461bcd60e51b8152600401610a0c906122ab565b604051600090339047908381818185875af1925050503d8060008114610dee576040519150601f19603f3d011682016040523d82523d6000602084013e610df3565b606091505b5050905080610bf15760405162461bcd60e51b81526020600482015260126024820152716661696c656420746f20776974686472617760701b6044820152606401610a0c565b6005546001600160a01b03163314610e635760405162461bcd60e51b8152600401610a0c906122ab565b600c5460ff1615610eb65760405162461bcd60e51b815260206004820152601860248201527f43616e6e6f742072652d656e61626c652074726164696e6700000000000000006044820152606401610a0c565b600c805462ff00ff19166201000117905543600b55565b6005546001600160a01b03163314610ef75760405162461bcd60e51b8152600401610a0c906122ab565b600c8054911515620100000262ff000019909216919091179055565b60606004805461094990612271565b6005546001600160a01b03163314610f4c5760405162461bcd60e51b8152600401610a0c906122ab565b6007546001600160a01b0390811690831603610fda5760405162461bcd60e51b815260206004820152604160248201527f54686520556e697377617020706169722063616e6e6f742062652072656d6f7660448201527f65642066726f6d206175746f6d617465644d61726b65744d616b6572506169726064820152607360f81b608482015260a401610a0c565b610fe48282611ddb565b5050565b3360009081526001602090815260408083206001600160a01b03861684529091528120548281101561106a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610a0c565b6110773385858403611434565b5060019392505050565b60006109d9338484611558565b6005546001600160a01b031633146110b85760405162461bcd60e51b8152600401610a0c906122ab565b6001600160a01b038216600081815260156020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b031633146111415760405162461bcd60e51b8152600401610a0c906122ab565b670de0b6b3a76400006103e861115660025490565b6111619060286122f6565b61116b9190612315565b6111759190612315565b8110156111d05760405162461bcd60e51b8152602060048201526024808201527f43616e6e6f7420736574206d617857616c6c6574206c6f776572207468616e20604482015263342e302560e01b6064820152608401610a0c565b6111e281670de0b6b3a76400006122f6565b60145550565b6005546001600160a01b031633146112125760405162461bcd60e51b8152600401610a0c906122ab565b60005b828110156112835781601560008686858181106112345761123461234f565b905060200201602081019061124991906120d8565b6001600160a01b031681526020810191909152604001600020805460ff19169115159190911790558061127b81612365565b915050611215565b507f7fdaf542373fa84f4ee8d662c642f44e4c2276a217d7d29e548b6eb29a233b358383836040516112b79392919061237e565b60405180910390a1505050565b6005546001600160a01b031633146112ee5760405162461bcd60e51b8152600401610a0c906122ab565b600f81905560108190556064811115610bf15760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420313025206f72206c6573730000006044820152606401610a0c565b6005546001600160a01b031633146113735760405162461bcd60e51b8152600401610a0c906122ab565b6001600160a01b0381166113d85760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a0c565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0383166114965760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a0c565b6001600160a01b0382166114f75760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a0c565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b03831661157e5760405162461bcd60e51b8152600401610a0c906123d7565b6001600160a01b0382166115a45760405162461bcd60e51b8152600401610a0c9061241c565b806000036115bd576115b883836000611e2f565b505050565b600c5460ff16611652576001600160a01b03831660009081526015602052604090205460ff168061160657506001600160a01b03821660009081526015602052604090205460ff165b6116525760405162461bcd60e51b815260206004820152601a60248201527f54726164696e67206973206e6f7420616374697665207965742e0000000000006044820152606401610a0c565b600c54610100900460ff16156119ec576005546001600160a01b0384811691161480159061168e57506005546001600160a01b03838116911614155b80156116a257506001600160a01b03821615155b80156116b957506001600160a01b03821661dead14155b80156116cf5750600754600160a01b900460ff16155b156119ec57600c5460ff16611762576001600160a01b03831660009081526015602052604090205460ff168061171d57506001600160a01b03821660009081526015602052604090205460ff165b6117625760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610a0c565b6001600160a01b03831660009081526017602052604090205460ff1680156117a357506001600160a01b03821660009081526016602052604090205460ff16155b15611899576009546117bd90670de0b6b3a7640000612337565b81111561182a5760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610a0c565b6014546001600160a01b0383166000908152602081905260409020546118509083612337565b11156118945760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a0c565b6119ec565b6001600160a01b03821660009081526017602052604090205460ff1680156118da57506001600160a01b03831660009081526016602052604090205460ff16155b15611962576009546118f490670de0b6b3a7640000612337565b8111156118945760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610a0c565b6001600160a01b03821660009081526016602052604090205460ff166119ec576014546001600160a01b0383166000908152602081905260409020546119a89083612337565b11156119ec5760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a0c565b3060009081526020819052604090205460085481108015908190611a185750600c5462010000900460ff165b8015611a2e5750600754600160a01b900460ff16155b8015611a5357506001600160a01b03851660009081526017602052604090205460ff16155b8015611a7857506001600160a01b03851660009081526015602052604090205460ff16155b8015611a9d57506001600160a01b03841660009081526015602052604090205460ff16155b15611acb576007805460ff60a01b1916600160a01b179055611abd611f84565b6007805460ff60a01b191690555b6007546001600160a01b03861660009081526015602052604090205460ff600160a01b909204821615911680611b1957506001600160a01b03851660009081526015602052604090205460ff165b15611b22575060005b60008115611c6d576001600160a01b03861660009081526017602052604090205460ff168015611b5457506000601054115b15611bc957611b7a6103e8611b746010548861202390919063ffffffff16565b90612036565b90508060116000828254611b8e9190612337565b9091555050601054600f54611ba390836122f6565b611bad9190612315565b60126000828254611bbe9190612337565b90915550611c4f9050565b6001600160a01b03871660009081526017602052604090205460ff1615611c4f57611c056103e8611b74600e548861202390919063ffffffff16565b90508060116000828254611c199190612337565b9091555050600e54600d54611c2e90836122f6565b611c389190612315565b60126000828254611c499190612337565b90915550505b8015611c6057611c60873083611e2f565b611c6a818661245f565b94505b611c78878787611e2f565b50505050505050565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611cb657611cb661234f565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611d0f573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d339190612476565b81600181518110611d4657611d4661234f565b6001600160a01b039283166020918202929092010152600654611d6c9130911684611434565b60065460405163791ac94760e01b81526001600160a01b039091169063791ac94790611da5908590600090869030904290600401612493565b600060405180830381600087803b158015611dbf57600080fd5b505af1158015611dd3573d6000803e3d6000fd5b505050505050565b6001600160a01b038216600081815260176020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b038316611e555760405162461bcd60e51b8152600401610a0c906123d7565b6001600160a01b038216611e7b5760405162461bcd60e51b8152600401610a0c9061241c565b6001600160a01b03831660009081526020819052604090205481811015611ef35760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610a0c565b6001600160a01b03808516600090815260208190526040808220858503905591851681529081208054849290611f2a908490612337565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611f7691815260200190565b60405180910390a350505050565b306000908152602081905260408120546012549091821580611fa4575081155b15611fae57505050565b82611fb881611c81565b600c5460405163010000009091046001600160a01b0316904790600081818185875af1925050503d806000811461200b576040519150601f19603f3d011682016040523d82523d6000602084013e612010565b606091505b5050600060128190556011555050505050565b600061202f82846122f6565b9392505050565b600061202f8284612315565b600060208083528351808285015260005b8181101561206f57858101830151858201604001528201612053565b81811115612081576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610bf157600080fd5b600080604083850312156120bf57600080fd5b82356120ca81612097565b946020939093013593505050565b6000602082840312156120ea57600080fd5b813561202f81612097565b60006020828403121561210757600080fd5b5035919050565b60008060006060848603121561212357600080fd5b833561212e81612097565b9250602084013561213e81612097565b929592945050506040919091013590565b8035801515811461215f57600080fd5b919050565b6000806040838503121561217757600080fd5b823561218281612097565b91506121906020840161214f565b90509250929050565b6000602082840312156121ab57600080fd5b61202f8261214f565b6000806000604084860312156121c957600080fd5b833567ffffffffffffffff808211156121e157600080fd5b818601915086601f8301126121f557600080fd5b81358181111561220457600080fd5b8760208260051b850101111561221957600080fd5b60209283019550935061222f918601905061214f565b90509250925092565b6000806040838503121561224b57600080fd5b823561225681612097565b9150602083013561226681612097565b809150509250929050565b600181811c9082168061228557607f821691505b6020821081036122a557634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b6000816000190483118215151615612310576123106122e0565b500290565b60008261233257634e487b7160e01b600052601260045260246000fd5b500490565b6000821982111561234a5761234a6122e0565b500190565b634e487b7160e01b600052603260045260246000fd5b600060018201612377576123776122e0565b5060010190565b6040808252810183905260008460608301825b868110156123c15782356123a481612097565b6001600160a01b0316825260209283019290910190600101612391565b5080925050508215156020830152949350505050565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015612471576124716122e0565b500390565b60006020828403121561248857600080fd5b815161202f81612097565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156124e35784516001600160a01b0316835293830193918301916001016124be565b50506001600160a01b0396909616606085015250505060800152939250505056fea264697066735822122084a26197bda9c28ee2697f9bbdd1c8a4577ad5bbef8f961c3d7ee690e777ff5564736f6c634300080d00334f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572

Deployed Bytecode

0x6080604052600436106102e85760003560e01c806375f0a87411610190578063bbc0c742116100dc578063dd62ed3e11610095578063ee40166e1161006f578063ee40166e146108d8578063f2fde38b146108ee578063f8afa9511461090e578063f8b45b051461092457600080fd5b8063dd62ed3e1461085c578063e2f45605146108a2578063eba4c333146108b857600080fd5b8063bbc0c742146107b2578063c0246668146107cc578063c18bc195146107ec578063c492f0461461080c578063c876d0b91461082c578063c8c8ebe41461084657600080fd5b806397b1406111610149578063a457c2d711610123578063a457c2d71461072c578063a9059cbb1461074c578063b62496f51461076c578063b9e937001461079c57600080fd5b806397b14061146106e05780639a36f932146106f65780639a7a23d61461070c57600080fd5b806375f0a8741461063c5780637fa787ba146106635780638a8c523c146106785780638da5cb5b1461068d578063924de9b7146106ab57806395d89b41146106cb57600080fd5b8063395093511161024f57806351bc3c8511610208578063715018a6116101e2578063715018a6146105d257806371fc4688146105e7578063751039fc146106075780637571336a1461061c57600080fd5b806351bc3c85146105675780636ddd17131461057c57806370a082311461059c57600080fd5b806339509351146104a35780633f8a6204146104c357806349bd5a5e146104d95780634a62bb65146104f95780634eed1183146105185780634fbee1931461052e57600080fd5b806318160ddd116102a157806318160ddd146103ed5780631f3fed8f14610402578063203e727e1461041857806323b872dd1461043a5780632a3de72e1461045a578063313ce5671461048757600080fd5b806306228749146102f457806306fdde0314610327578063095ea7b3146103495780630f4432e31461037957806310d5de531461039d5780631694505e146103cd57600080fd5b366102ef57005b600080fd5b34801561030057600080fd5b5061030a61dead81565b6040516001600160a01b0390911681526020015b60405180910390f35b34801561033357600080fd5b5061033c61093a565b60405161031e9190612042565b34801561035557600080fd5b506103696103643660046120ac565b6109cc565b604051901515815260200161031e565b34801561038557600080fd5b5061038f600a5481565b60405190815260200161031e565b3480156103a957600080fd5b506103696103b83660046120d8565b60166020526000908152604090205460ff1681565b3480156103d957600080fd5b5060065461030a906001600160a01b031681565b3480156103f957600080fd5b5060025461038f565b34801561040e57600080fd5b5061038f60125481565b34801561042457600080fd5b506104386104333660046120f5565b6109e2565b005b34801561044657600080fd5b5061036961045536600461210e565b610ac8565b34801561046657600080fd5b5061038f6104753660046120d8565b60186020526000908152604090205481565b34801561049357600080fd5b506040516012815260200161031e565b3480156104af57600080fd5b506103696104be3660046120ac565b610b72565b3480156104cf57600080fd5b5061038f60115481565b3480156104e557600080fd5b5060075461030a906001600160a01b031681565b34801561050557600080fd5b50600c5461036990610100900460ff1681565b34801561052457600080fd5b5061038f60105481565b34801561053a57600080fd5b506103696105493660046120d8565b6001600160a01b031660009081526015602052604090205460ff1690565b34801561057357600080fd5b50610438610bae565b34801561058857600080fd5b50600c546103699062010000900460ff1681565b3480156105a857600080fd5b5061038f6105b73660046120d8565b6001600160a01b031660009081526020819052604090205490565b3480156105de57600080fd5b50610438610bf4565b3480156105f357600080fd5b506104386106023660046120f5565b610c68565b34801561061357600080fd5b50610369610cef565b34801561062857600080fd5b50610438610637366004612164565b610d2d565b34801561064857600080fd5b50600c5461030a90630100000090046001600160a01b031681565b34801561066f57600080fd5b50610438610d82565b34801561068457600080fd5b50610438610e39565b34801561069957600080fd5b506005546001600160a01b031661030a565b3480156106b757600080fd5b506104386106c6366004612199565b610ecd565b3480156106d757600080fd5b5061033c610f13565b3480156106ec57600080fd5b5061038f600f5481565b34801561070257600080fd5b5061038f6103e881565b34801561071857600080fd5b50610438610727366004612164565b610f22565b34801561073857600080fd5b506103696107473660046120ac565b610fe8565b34801561075857600080fd5b506103696107673660046120ac565b611081565b34801561077857600080fd5b506103696107873660046120d8565b60176020526000908152604090205460ff1681565b3480156107a857600080fd5b5061038f600e5481565b3480156107be57600080fd5b50600c546103699060ff1681565b3480156107d857600080fd5b506104386107e7366004612164565b61108e565b3480156107f857600080fd5b506104386108073660046120f5565b611117565b34801561081857600080fd5b506104386108273660046121b4565b6111e8565b34801561083857600080fd5b506013546103699060ff1681565b34801561085257600080fd5b5061038f60095481565b34801561086857600080fd5b5061038f610877366004612238565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b3480156108ae57600080fd5b5061038f60085481565b3480156108c457600080fd5b506104386108d33660046120f5565b6112c4565b3480156108e457600080fd5b5061038f600b5481565b3480156108fa57600080fd5b506104386109093660046120d8565b611349565b34801561091a57600080fd5b5061038f600d5481565b34801561093057600080fd5b5061038f60145481565b60606003805461094990612271565b80601f016020809104026020016040519081016040528092919081815260200182805461097590612271565b80156109c25780601f10610997576101008083540402835291602001916109c2565b820191906000526020600020905b8154815290600101906020018083116109a557829003601f168201915b5050505050905090565b60006109d9338484611434565b50600192915050565b6005546001600160a01b03163314610a155760405162461bcd60e51b8152600401610a0c906122ab565b60405180910390fd5b670de0b6b3a76400006103e8610a2a60025490565b610a359060146122f6565b610a3f9190612315565b610a499190612315565b811015610ab05760405162461bcd60e51b815260206004820152602f60248201527f43616e6e6f7420736574206d61785472616e73616374696f6e416d6f756e742060448201526e6c6f776572207468616e20322e302560881b6064820152608401610a0c565b610ac281670de0b6b3a76400006122f6565b60095550565b6000610ad5848484611558565b6001600160a01b038416600090815260016020908152604080832033845290915290205482811015610b5a5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b6064820152608401610a0c565b610b678533858403611434565b506001949350505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916109d9918590610ba9908690612337565b611434565b6005546001600160a01b03163314610bd85760405162461bcd60e51b8152600401610a0c906122ab565b30600090815260208190526040902054610bf181611c81565b50565b6005546001600160a01b03163314610c1e5760405162461bcd60e51b8152600401610a0c906122ab565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610c925760405162461bcd60e51b8152600401610a0c906122ab565b600d819055600e81905560105460641015610bf15760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420313025206f72206c6573730000006044820152606401610a0c565b6005546000906001600160a01b03163314610d1c5760405162461bcd60e51b8152600401610a0c906122ab565b50600c805461ff0019169055600190565b6005546001600160a01b03163314610d575760405162461bcd60e51b8152600401610a0c906122ab565b6001600160a01b03919091166000908152601660205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610dac5760405162461bcd60e51b8152600401610a0c906122ab565b604051600090339047908381818185875af1925050503d8060008114610dee576040519150601f19603f3d011682016040523d82523d6000602084013e610df3565b606091505b5050905080610bf15760405162461bcd60e51b81526020600482015260126024820152716661696c656420746f20776974686472617760701b6044820152606401610a0c565b6005546001600160a01b03163314610e635760405162461bcd60e51b8152600401610a0c906122ab565b600c5460ff1615610eb65760405162461bcd60e51b815260206004820152601860248201527f43616e6e6f742072652d656e61626c652074726164696e6700000000000000006044820152606401610a0c565b600c805462ff00ff19166201000117905543600b55565b6005546001600160a01b03163314610ef75760405162461bcd60e51b8152600401610a0c906122ab565b600c8054911515620100000262ff000019909216919091179055565b60606004805461094990612271565b6005546001600160a01b03163314610f4c5760405162461bcd60e51b8152600401610a0c906122ab565b6007546001600160a01b0390811690831603610fda5760405162461bcd60e51b815260206004820152604160248201527f54686520556e697377617020706169722063616e6e6f742062652072656d6f7660448201527f65642066726f6d206175746f6d617465644d61726b65744d616b6572506169726064820152607360f81b608482015260a401610a0c565b610fe48282611ddb565b5050565b3360009081526001602090815260408083206001600160a01b03861684529091528120548281101561106a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610a0c565b6110773385858403611434565b5060019392505050565b60006109d9338484611558565b6005546001600160a01b031633146110b85760405162461bcd60e51b8152600401610a0c906122ab565b6001600160a01b038216600081815260156020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b031633146111415760405162461bcd60e51b8152600401610a0c906122ab565b670de0b6b3a76400006103e861115660025490565b6111619060286122f6565b61116b9190612315565b6111759190612315565b8110156111d05760405162461bcd60e51b8152602060048201526024808201527f43616e6e6f7420736574206d617857616c6c6574206c6f776572207468616e20604482015263342e302560e01b6064820152608401610a0c565b6111e281670de0b6b3a76400006122f6565b60145550565b6005546001600160a01b031633146112125760405162461bcd60e51b8152600401610a0c906122ab565b60005b828110156112835781601560008686858181106112345761123461234f565b905060200201602081019061124991906120d8565b6001600160a01b031681526020810191909152604001600020805460ff19169115159190911790558061127b81612365565b915050611215565b507f7fdaf542373fa84f4ee8d662c642f44e4c2276a217d7d29e548b6eb29a233b358383836040516112b79392919061237e565b60405180910390a1505050565b6005546001600160a01b031633146112ee5760405162461bcd60e51b8152600401610a0c906122ab565b600f81905560108190556064811115610bf15760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420313025206f72206c6573730000006044820152606401610a0c565b6005546001600160a01b031633146113735760405162461bcd60e51b8152600401610a0c906122ab565b6001600160a01b0381166113d85760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a0c565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0383166114965760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a0c565b6001600160a01b0382166114f75760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a0c565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b03831661157e5760405162461bcd60e51b8152600401610a0c906123d7565b6001600160a01b0382166115a45760405162461bcd60e51b8152600401610a0c9061241c565b806000036115bd576115b883836000611e2f565b505050565b600c5460ff16611652576001600160a01b03831660009081526015602052604090205460ff168061160657506001600160a01b03821660009081526015602052604090205460ff165b6116525760405162461bcd60e51b815260206004820152601a60248201527f54726164696e67206973206e6f7420616374697665207965742e0000000000006044820152606401610a0c565b600c54610100900460ff16156119ec576005546001600160a01b0384811691161480159061168e57506005546001600160a01b03838116911614155b80156116a257506001600160a01b03821615155b80156116b957506001600160a01b03821661dead14155b80156116cf5750600754600160a01b900460ff16155b156119ec57600c5460ff16611762576001600160a01b03831660009081526015602052604090205460ff168061171d57506001600160a01b03821660009081526015602052604090205460ff165b6117625760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610a0c565b6001600160a01b03831660009081526017602052604090205460ff1680156117a357506001600160a01b03821660009081526016602052604090205460ff16155b15611899576009546117bd90670de0b6b3a7640000612337565b81111561182a5760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610a0c565b6014546001600160a01b0383166000908152602081905260409020546118509083612337565b11156118945760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a0c565b6119ec565b6001600160a01b03821660009081526017602052604090205460ff1680156118da57506001600160a01b03831660009081526016602052604090205460ff16155b15611962576009546118f490670de0b6b3a7640000612337565b8111156118945760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610a0c565b6001600160a01b03821660009081526016602052604090205460ff166119ec576014546001600160a01b0383166000908152602081905260409020546119a89083612337565b11156119ec5760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610a0c565b3060009081526020819052604090205460085481108015908190611a185750600c5462010000900460ff165b8015611a2e5750600754600160a01b900460ff16155b8015611a5357506001600160a01b03851660009081526017602052604090205460ff16155b8015611a7857506001600160a01b03851660009081526015602052604090205460ff16155b8015611a9d57506001600160a01b03841660009081526015602052604090205460ff16155b15611acb576007805460ff60a01b1916600160a01b179055611abd611f84565b6007805460ff60a01b191690555b6007546001600160a01b03861660009081526015602052604090205460ff600160a01b909204821615911680611b1957506001600160a01b03851660009081526015602052604090205460ff165b15611b22575060005b60008115611c6d576001600160a01b03861660009081526017602052604090205460ff168015611b5457506000601054115b15611bc957611b7a6103e8611b746010548861202390919063ffffffff16565b90612036565b90508060116000828254611b8e9190612337565b9091555050601054600f54611ba390836122f6565b611bad9190612315565b60126000828254611bbe9190612337565b90915550611c4f9050565b6001600160a01b03871660009081526017602052604090205460ff1615611c4f57611c056103e8611b74600e548861202390919063ffffffff16565b90508060116000828254611c199190612337565b9091555050600e54600d54611c2e90836122f6565b611c389190612315565b60126000828254611c499190612337565b90915550505b8015611c6057611c60873083611e2f565b611c6a818661245f565b94505b611c78878787611e2f565b50505050505050565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611cb657611cb661234f565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611d0f573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d339190612476565b81600181518110611d4657611d4661234f565b6001600160a01b039283166020918202929092010152600654611d6c9130911684611434565b60065460405163791ac94760e01b81526001600160a01b039091169063791ac94790611da5908590600090869030904290600401612493565b600060405180830381600087803b158015611dbf57600080fd5b505af1158015611dd3573d6000803e3d6000fd5b505050505050565b6001600160a01b038216600081815260176020526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b6001600160a01b038316611e555760405162461bcd60e51b8152600401610a0c906123d7565b6001600160a01b038216611e7b5760405162461bcd60e51b8152600401610a0c9061241c565b6001600160a01b03831660009081526020819052604090205481811015611ef35760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610a0c565b6001600160a01b03808516600090815260208190526040808220858503905591851681529081208054849290611f2a908490612337565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611f7691815260200190565b60405180910390a350505050565b306000908152602081905260408120546012549091821580611fa4575081155b15611fae57505050565b82611fb881611c81565b600c5460405163010000009091046001600160a01b0316904790600081818185875af1925050503d806000811461200b576040519150601f19603f3d011682016040523d82523d6000602084013e612010565b606091505b5050600060128190556011555050505050565b600061202f82846122f6565b9392505050565b600061202f8284612315565b600060208083528351808285015260005b8181101561206f57858101830151858201604001528201612053565b81811115612081576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610bf157600080fd5b600080604083850312156120bf57600080fd5b82356120ca81612097565b946020939093013593505050565b6000602082840312156120ea57600080fd5b813561202f81612097565b60006020828403121561210757600080fd5b5035919050565b60008060006060848603121561212357600080fd5b833561212e81612097565b9250602084013561213e81612097565b929592945050506040919091013590565b8035801515811461215f57600080fd5b919050565b6000806040838503121561217757600080fd5b823561218281612097565b91506121906020840161214f565b90509250929050565b6000602082840312156121ab57600080fd5b61202f8261214f565b6000806000604084860312156121c957600080fd5b833567ffffffffffffffff808211156121e157600080fd5b818601915086601f8301126121f557600080fd5b81358181111561220457600080fd5b8760208260051b850101111561221957600080fd5b60209283019550935061222f918601905061214f565b90509250925092565b6000806040838503121561224b57600080fd5b823561225681612097565b9150602083013561226681612097565b809150509250929050565b600181811c9082168061228557607f821691505b6020821081036122a557634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b6000816000190483118215151615612310576123106122e0565b500290565b60008261233257634e487b7160e01b600052601260045260246000fd5b500490565b6000821982111561234a5761234a6122e0565b500190565b634e487b7160e01b600052603260045260246000fd5b600060018201612377576123776122e0565b5060010190565b6040808252810183905260008460608301825b868110156123c15782356123a481612097565b6001600160a01b0316825260209283019290910190600101612391565b5080925050508215156020830152949350505050565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015612471576124716122e0565b500390565b60006020828403121561248857600080fd5b815161202f81612097565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156124e35784516001600160a01b0316835293830193918301916001016124be565b50506001600160a01b0396909616606085015250505060800152939250505056fea264697066735822122084a26197bda9c28ee2697f9bbdd1c8a4577ad5bbef8f961c3d7ee690e777ff5564736f6c634300080d0033

Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.