ETH Price: $2,130.96 (+8.70%)

Token

Empire City (EMPC)
 

Overview

Max Total Supply

1,000,000 EMPC

Holders

5

Transfers

-
0

Market

Onchain Market Cap

-

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

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:
EmpireCity

Compiler Version
v0.8.20+commit.a1b79de6

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion
File 1 of 9 : empire.sol
/*
  ______                 _             _____ _ _         
 |  ____|               (_)           / ____(_) |        
 | |__   _ __ ___  _ __  _ _ __ ___  | |     _| |_ _   _ 
 |  __| | '_ ` _ \| '_ \| | '__/ _ \ | |    | | __| | | |
 | |____| | | | | | |_) | | | |  __/ | |____| | |_| |_| |
 |______|_| |_| |_| .__/|_|_|  \___|  \_____|_|\__|\__, |
                  | |                               __/ |
                  |_|                              |___/ 

● Revolutionary ERC-20
● Deflationary supply
● Fast games secured by Chainlink VRF

Website: https://empire-city.site/
Documentation: https://docs.empire-city.site/
Telegram: https://t.me/empirecityeth/
X (Twitter): https://x.com/empirecityeth/

*/

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

import {VRFConsumerBaseV2Plus} from "@chainlink/contracts@1.2.0/src/v0.8/vrf/dev/VRFConsumerBaseV2Plus.sol";
import {VRFV2PlusClient} from "@chainlink/contracts@1.2.0/src/v0.8/vrf/dev/libraries/VRFV2PlusClient.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 IUniswapV2Pair {
    event Approval(address indexed owner, address indexed spender, uint value);
    event Transfer(address indexed from, address indexed to, uint value);
    function name() external pure returns (string memory);
    function symbol() external pure returns (string memory);
    function decimals() external pure returns (uint8);
    function totalSupply() external view returns (uint);
    function balanceOf(address owner) external view returns (uint);
    function allowance(address owner, address spender) external view returns (uint);
    function approve(address spender, uint value) external returns (bool);
    function transfer(address to, uint value) external returns (bool);
    function transferFrom(address from, address to, uint value) external returns (bool);
    function DOMAIN_SEPARATOR() external view returns (bytes32);
    function PERMIT_TYPEHASH() external pure returns (bytes32);
    function nonces(address owner) external view returns (uint);
    function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;
    event Mint(address indexed sender, uint amount0, uint amount1);
    event Burn(address indexed sender, uint amount0, uint amount1, address indexed to);
    event Swap(
        address indexed sender,
        uint amount0In,
        uint amount1In,
        uint amount0Out,
        uint amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);
    function MINIMUM_LIQUIDITY() external pure returns (uint);
    function factory() external view returns (address);
    function token0() external view returns (address);
    function token1() external view returns (address);
    function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast);
    function price0CumulativeLast() external view returns (uint);
    function price1CumulativeLast() external view returns (uint);
    function kLast() external view returns (uint);
    function mint(address to) external returns (uint liquidity);
    function burn(address to) external returns (uint amount0, uint amount1);
    function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
    function skim(address to) external;
    function sync() external;
    function initialize(address, address) external;
}

interface IUniswapV2Factory {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);
    function feeTo() external view returns (address);
    function feeToSetter() external view returns (address);
    function getPair(address tokenA, address tokenB) external view returns (address pair);
    function allPairs(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);
    function createPair(address tokenA, address tokenB) external returns (address pair);
    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}

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

interface IERC20Metadata is IERC20 {
    function name() external view returns (string memory);
    function symbol() external view returns (string memory);
    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);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()] - 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) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] - 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");
        _beforeTokenTransfer(sender, recipient, amount);
        _balances[sender] = _balances[sender] - amount;
        _balances[recipient] = _balances[recipient] + amount;
        emit Transfer(sender, recipient, amount);
    }
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");
        _beforeTokenTransfer(address(0), account, amount);
        _totalSupply = _totalSupply + amount;
        _balances[account] = _balances[account] + amount;
        emit Transfer(address(0), account, amount);
    }
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");
        _beforeTokenTransfer(account, address(0), amount);
        _balances[account] = _balances[account] - amount;
        _totalSupply = _totalSupply - amount;
        emit Transfer(account, address(0), 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);
    }
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

contract Ownable is Context {
    address private _owner;
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }
    function owner() public view returns (address) {
        return _owner;
    }
    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }
    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

interface IUniswapV2Router01 {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);
    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountToken, uint amountETH);
    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);
    function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);
    function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
    function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
    function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
    function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
    function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);
    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountETH);
    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}

error Reentrancy();

abstract contract ReentrancyGuard {
  uint256 private locked = 1;
  modifier nonReentrant() {
    if (locked != 1) {
      revert Reentrancy();
    }
    locked = 2;
    _;
    locked = 1;
  }
}

contract EmpireCity is ERC20, ReentrancyGuard, VRFConsumerBaseV2Plus {
    uint256 private s_subscriptionId;
    bytes32 private keyHash;
    uint32 private callbackGasLimit = 2500000;
    uint16 private requestConfirmations = 3;
    uint32 private numWords =  1;

    mapping(uint256 => address) private requestIdToSender;
    mapping(address => uint256) public userIdFlip;
    mapping(address => uint256) public betsizeFlip;
    event betFlip(address indexed from, uint amount);
    event winFlip(address indexed from, uint roll, bool won, uint amount); 

    IUniswapV2Router02 public uniswapV2Router;
    address public constant deadAddress = address(0xdead);

    bool private swapping;

    address public devWallet;
    
    uint256 public maxTransactionAmount;
    uint256 public swapTokensAtAmount;
    uint256 public maxWallet;

    bool public limitsInEffect = true;
    bool public tradingActive = false;
    bool public swapEnabled = false;
    
    uint256 public buyTotalFees;
    uint256 public buyLiquidityFee;
    uint256 public buyDevFee;
    
    uint256 public sellTotalFees;
    uint256 public sellLiquidityFee;
    uint256 public sellDevFee;

    uint256 public VRFFee; 
    
    uint256 public tokensForLiquidity;
    uint256 public tokensForDev;
    
    // exlcude from fees and max transaction amount
    mapping (address => bool) private _isExcludedFromFees;
    mapping (address => bool) public _isExcludedMaxTransactionAmount;

    // store addresses that a automatic market maker pairs. Any transfer *to* these addresses
    // could be subject to a maximum transfer amount
    mapping (address => bool) public automatedMarketMakerPairs;

    event UpdateUniswapV2Router(address indexed newAddress, address indexed oldAddress);
    event ExcludeFromFees(address indexed account, bool isExcluded);
    event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);
    event devWalletUpdated(address indexed newWallet, address indexed oldWallet);
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiquidity
    );

    constructor(uint256 subscriptionId) ERC20("Empire City", "EMPC") VRFConsumerBaseV2Plus(0xD7f86b4b8Cae7D942340FF628F82735b7a20893a) {
        s_subscriptionId = subscriptionId;
        keyHash = 0x8077df514608a09f83e4e8d300645594e5d7234665448ba83f51a50f842bd3d9;

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x126CFc30e7eb867EE604bBC53Eb95733eF48C55e);
        
        excludeFromMaxTransaction(address(_uniswapV2Router), true);
        uniswapV2Router = _uniswapV2Router;
        
        uint256 _buyLiquidityFee = 0;
        uint256 _buyDevFee = 3;
        uint256 _sellLiquidityFee = 4;
        uint256 _sellDevFee = 3;

        uint256 _VRFFee = 0.01 ether;
        
        uint256 totalSupply = 1000000 * 1e18;
        
        maxTransactionAmount = totalSupply * 5 / 100; // 5% maxTransactionAmountTxn
        maxWallet = totalSupply * 5 / 100; // 5% maxWallet
        swapTokensAtAmount = totalSupply * 5 / 10000; // 0.05% swap wallet

        buyLiquidityFee = _buyLiquidityFee;
        buyDevFee = _buyDevFee;
        buyTotalFees = buyLiquidityFee + buyDevFee;
        
        sellLiquidityFee = _sellLiquidityFee;
        sellDevFee = _sellDevFee;
        sellTotalFees = sellLiquidityFee + sellDevFee;

        VRFFee = _VRFFee;
        
        devWallet = address(0x04273222eEb301d665b9E795C02F335f1BcD9dcC); // set as dev wallet

        // exclude from paying fees or having max transaction amount
        excludeFromFees(owner(), true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);
        
        excludeFromMaxTransaction(owner(), true);
        excludeFromMaxTransaction(address(this), true);
        excludeFromMaxTransaction(address(0xdead), true);
        
        _mint(msg.sender, totalSupply);
    }

    receive() external payable {}

    function flip(uint256 _amount) nonReentrant public payable {
        require(_amount <= totalSupply() / 100, "Can not flip more than 1% of the supply at a time");
        require(userIdFlip[msg.sender] == 0, "One flip at a time!");
        require(msg.value >= VRFFee, "Insufficient VRFFee");

        (bool sent, ) = devWallet.call{value: VRFFee}("");
        require(sent, "Failed to send VRFFee");

        _burn(msg.sender, _amount);

        uint256 requestId = s_vrfCoordinator.requestRandomWords(
            VRFV2PlusClient.RandomWordsRequest({
                keyHash: keyHash,
                subId: s_subscriptionId,
                requestConfirmations: requestConfirmations,
                callbackGasLimit: callbackGasLimit,
                numWords: numWords,
                extraArgs: VRFV2PlusClient._argsToBytes(
                    VRFV2PlusClient.ExtraArgsV1({
                        nativePayment: true
                    })
                )
            })
        );

        requestIdToSender[requestId] = msg.sender;
        userIdFlip[msg.sender] = requestId;
        betsizeFlip[msg.sender] = (_amount * 199 / 100);
        emit betFlip(msg.sender, _amount);
    }

    function fulfillRandomWords(uint256 requestId, uint256[] calldata randomWords) internal override {
        address user = requestIdToSender[requestId];
        require(user != address(0), "No game found for the user");

        uint256 randomNumber = randomWords[0];

        // Flip Game Logic
        if (userIdFlip[user] == requestId) {
            uint256 secretnum = randomNumber % 2;
            if (secretnum == 0){
                _mint(user, betsizeFlip[user]);
                emit winFlip(user, secretnum, true, betsizeFlip[user]);
            }
            else {
                emit winFlip(user, secretnum, false, betsizeFlip[user]);
            }
            delete betsizeFlip[user];
            delete userIdFlip[user];
        }
    }

    function dangerClearCacheFlip() public {
        delete betsizeFlip[msg.sender];
        delete userIdFlip[msg.sender];
    }

    function setRouter(address router) public onlyOwner{
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(router);
        
        excludeFromMaxTransaction(address(_uniswapV2Router), true);
        uniswapV2Router = _uniswapV2Router;
    }

    // once enabled, can never be turned off
    function enableTrading() external onlyOwner {
        tradingActive = true;
        swapEnabled = true;
    }
    
    function removeLimits() external onlyOwner returns (bool){
        limitsInEffect = false;
        return true;
    }
    
     // change the minimum amount of tokens to sell from fees
    function updateSwapTokensAtAmount(uint256 newAmount) external onlyOwner returns (bool){
  	    require(newAmount >= totalSupply() * 1 / 100000, "Swap amount cannot be lower than 0.001% total supply.");
  	    require(newAmount <= totalSupply() * 1 / 100, "Swap amount cannot be higher than 1% total supply.");
  	    swapTokensAtAmount = newAmount;
  	    return true;
  	}
    
    function updateMaxTxnAmount(uint256 newNum) external onlyOwner {
        require(newNum >= (totalSupply() * 1 / 1000)/1e18, "Cannot set maxTransactionAmount lower than 0.1%");
        maxTransactionAmount = newNum * (10**18);
    }

    function updateMaxWalletAmount(uint256 newNum) external onlyOwner {
        require(newNum >= (totalSupply() * 5 / 1000)/1e18, "Cannot set maxWallet lower than 0.5%");
        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 updateBuyFees(uint256 _liquidityFee, uint256 _devFee) external onlyOwner {
        buyLiquidityFee = _liquidityFee;
        buyDevFee = _devFee;
        buyTotalFees = buyLiquidityFee + buyDevFee;
        require(buyTotalFees <= 20, "Must keep fees at 20% or less");
    }
    
    function updateSellFees(uint256 _liquidityFee, uint256 _devFee) external onlyOwner {
        sellLiquidityFee = _liquidityFee;
        sellDevFee = _devFee;
        sellTotalFees = sellLiquidityFee + sellDevFee;
        require(sellTotalFees <= 25, "Must keep fees at 25% or less");
    }

    function updateVRFFee(uint256 _newFee) external onlyOwner {
        require(_newFee <= 0.1 ether, "Must keep VRF fee <= 0.1 ETH");
        VRFFee = _newFee;
    }

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

    function setAutomatedMarketMakerPair(address pair, bool value) public onlyOwner {
        _setAutomatedMarketMakerPair(pair, value);
    }

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

        emit SetAutomatedMarketMakerPair(pair, value);
    }
    
    function updateDevWallet(address newWallet) external onlyOwner {
        emit devWalletUpdated(newWallet, devWallet);
        devWallet = newWallet;
    }
    
    function isExcludedFromFees(address account) public 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(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, "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, "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;
        // only take fees on buys/sells, do not take on wallet transfers
        if(takeFee){
            // on sell
            if (automatedMarketMakerPairs[to] && sellTotalFees > 0){
                fees = amount * sellTotalFees / 100;
                tokensForLiquidity += fees * sellLiquidityFee / sellTotalFees;
                tokensForDev += fees * sellDevFee / sellTotalFees;
            }
            // on buy
            else if(automatedMarketMakerPairs[from] && buyTotalFees > 0) {
        	    fees = amount * buyTotalFees / 100;
        	    tokensForLiquidity += fees * buyLiquidityFee / buyTotalFees;
                tokensForDev += fees * buyDevFee / buyTotalFees;
            }     
            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
            devWallet,
            block.timestamp
        );
    }

    function swapBack() private {
        uint256 contractBalance = balanceOf(address(this));
        uint256 totalTokensToSwap = tokensForLiquidity + tokensForDev;
        bool success;
        
        if(contractBalance == 0 || totalTokensToSwap == 0) {return;}

        if(contractBalance > swapTokensAtAmount * 20){
          contractBalance = swapTokensAtAmount * 20;
        }
        
        // Halve the amount of liquidity tokens
        uint256 liquidityTokens = contractBalance * tokensForLiquidity / totalTokensToSwap / 2;
        uint256 amountToSwapForETH = contractBalance - liquidityTokens;
        
        uint256 initialETHBalance = address(this).balance;

        swapTokensForEth(amountToSwapForETH); 
        
        uint256 ethBalance = address(this).balance - initialETHBalance;
        
        uint256 ethForDev = ethBalance * tokensForDev / totalTokensToSwap;
        
        uint256 ethForLiquidity = ethBalance - ethForDev;
        
        tokensForLiquidity = 0;
        tokensForDev = 0;
        
        (success,) = address(devWallet).call{value: ethForDev}("");
        
        if(liquidityTokens > 0 && ethForLiquidity > 0){
            addLiquidity(liquidityTokens, ethForLiquidity);
            emit SwapAndLiquify(amountToSwapForETH, ethForLiquidity, tokensForLiquidity);
        }
        (success,) = address(devWallet).call{value: address(this).balance}("");
    }
    
    function payout() public onlyOwner {
        payable(msg.sender).transfer(address(this).balance);
    }

    function withdrawToken() public onlyOwner {
        this.approve(address(this), totalSupply());
        this.transferFrom(address(this), owner(), balanceOf(address(this)));  
    }
}

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.4;

// End consumer library.
library VRFV2PlusClient {
  // extraArgs will evolve to support new features
  bytes4 public constant EXTRA_ARGS_V1_TAG = bytes4(keccak256("VRF ExtraArgsV1"));
  struct ExtraArgsV1 {
    bool nativePayment;
  }

  struct RandomWordsRequest {
    bytes32 keyHash;
    uint256 subId;
    uint16 requestConfirmations;
    uint32 callbackGasLimit;
    uint32 numWords;
    bytes extraArgs;
  }

  function _argsToBytes(ExtraArgsV1 memory extraArgs) internal pure returns (bytes memory bts) {
    return abi.encodeWithSelector(EXTRA_ARGS_V1_TAG, extraArgs);
  }
}

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.4;

import {IVRFCoordinatorV2Plus} from "./interfaces/IVRFCoordinatorV2Plus.sol";
import {IVRFMigratableConsumerV2Plus} from "./interfaces/IVRFMigratableConsumerV2Plus.sol";
import {ConfirmedOwner} from "../../shared/access/ConfirmedOwner.sol";

/** ****************************************************************************
 * @notice Interface for contracts using VRF randomness
 * *****************************************************************************
 * @dev PURPOSE
 *
 * @dev Reggie the Random Oracle (not his real job) wants to provide randomness
 * @dev to Vera the verifier in such a way that Vera can be sure he's not
 * @dev making his output up to suit himself. Reggie provides Vera a public key
 * @dev to which he knows the secret key. Each time Vera provides a seed to
 * @dev Reggie, he gives back a value which is computed completely
 * @dev deterministically from the seed and the secret key.
 *
 * @dev Reggie provides a proof by which Vera can verify that the output was
 * @dev correctly computed once Reggie tells it to her, but without that proof,
 * @dev the output is indistinguishable to her from a uniform random sample
 * @dev from the output space.
 *
 * @dev The purpose of this contract is to make it easy for unrelated contracts
 * @dev to talk to Vera the verifier about the work Reggie is doing, to provide
 * @dev simple access to a verifiable source of randomness. It ensures 2 things:
 * @dev 1. The fulfillment came from the VRFCoordinatorV2Plus.
 * @dev 2. The consumer contract implements fulfillRandomWords.
 * *****************************************************************************
 * @dev USAGE
 *
 * @dev Calling contracts must inherit from VRFConsumerBaseV2Plus, and can
 * @dev initialize VRFConsumerBaseV2Plus's attributes in their constructor as
 * @dev shown:
 *
 * @dev   contract VRFConsumerV2Plus is VRFConsumerBaseV2Plus {
 * @dev     constructor(<other arguments>, address _vrfCoordinator, address _subOwner)
 * @dev       VRFConsumerBaseV2Plus(_vrfCoordinator, _subOwner) public {
 * @dev         <initialization with other arguments goes here>
 * @dev       }
 * @dev   }
 *
 * @dev The oracle will have given you an ID for the VRF keypair they have
 * @dev committed to (let's call it keyHash). Create a subscription, fund it
 * @dev and your consumer contract as a consumer of it (see VRFCoordinatorInterface
 * @dev subscription management functions).
 * @dev Call requestRandomWords(keyHash, subId, minimumRequestConfirmations,
 * @dev callbackGasLimit, numWords, extraArgs),
 * @dev see (IVRFCoordinatorV2Plus for a description of the arguments).
 *
 * @dev Once the VRFCoordinatorV2Plus has received and validated the oracle's response
 * @dev to your request, it will call your contract's fulfillRandomWords method.
 *
 * @dev The randomness argument to fulfillRandomWords is a set of random words
 * @dev generated from your requestId and the blockHash of the request.
 *
 * @dev If your contract could have concurrent requests open, you can use the
 * @dev requestId returned from requestRandomWords to track which response is associated
 * @dev with which randomness request.
 * @dev See "SECURITY CONSIDERATIONS" for principles to keep in mind,
 * @dev if your contract could have multiple requests in flight simultaneously.
 *
 * @dev Colliding `requestId`s are cryptographically impossible as long as seeds
 * @dev differ.
 *
 * *****************************************************************************
 * @dev SECURITY CONSIDERATIONS
 *
 * @dev A method with the ability to call your fulfillRandomness method directly
 * @dev could spoof a VRF response with any random value, so it's critical that
 * @dev it cannot be directly called by anything other than this base contract
 * @dev (specifically, by the VRFConsumerBaseV2Plus.rawFulfillRandomness method).
 *
 * @dev For your users to trust that your contract's random behavior is free
 * @dev from malicious interference, it's best if you can write it so that all
 * @dev behaviors implied by a VRF response are executed *during* your
 * @dev fulfillRandomness method. If your contract must store the response (or
 * @dev anything derived from it) and use it later, you must ensure that any
 * @dev user-significant behavior which depends on that stored value cannot be
 * @dev manipulated by a subsequent VRF request.
 *
 * @dev Similarly, both miners and the VRF oracle itself have some influence
 * @dev over the order in which VRF responses appear on the blockchain, so if
 * @dev your contract could have multiple VRF requests in flight simultaneously,
 * @dev you must ensure that the order in which the VRF responses arrive cannot
 * @dev be used to manipulate your contract's user-significant behavior.
 *
 * @dev Since the block hash of the block which contains the requestRandomness
 * @dev call is mixed into the input to the VRF *last*, a sufficiently powerful
 * @dev miner could, in principle, fork the blockchain to evict the block
 * @dev containing the request, forcing the request to be included in a
 * @dev different block with a different hash, and therefore a different input
 * @dev to the VRF. However, such an attack would incur a substantial economic
 * @dev cost. This cost scales with the number of blocks the VRF oracle waits
 * @dev until it calls responds to a request. It is for this reason that
 * @dev that you can signal to an oracle you'd like them to wait longer before
 * @dev responding to the request (however this is not enforced in the contract
 * @dev and so remains effective only in the case of unmodified oracle software).
 */
abstract contract VRFConsumerBaseV2Plus is IVRFMigratableConsumerV2Plus, ConfirmedOwner {
  error OnlyCoordinatorCanFulfill(address have, address want);
  error OnlyOwnerOrCoordinator(address have, address owner, address coordinator);
  error ZeroAddress();

  // s_vrfCoordinator should be used by consumers to make requests to vrfCoordinator
  // so that coordinator reference is updated after migration
  IVRFCoordinatorV2Plus public s_vrfCoordinator;

  /**
   * @param _vrfCoordinator address of VRFCoordinator contract
   */
  constructor(address _vrfCoordinator) ConfirmedOwner(msg.sender) {
    if (_vrfCoordinator == address(0)) {
      revert ZeroAddress();
    }
    s_vrfCoordinator = IVRFCoordinatorV2Plus(_vrfCoordinator);
  }

  /**
   * @notice fulfillRandomness handles the VRF response. Your contract must
   * @notice implement it. See "SECURITY CONSIDERATIONS" above for important
   * @notice principles to keep in mind when implementing your fulfillRandomness
   * @notice method.
   *
   * @dev VRFConsumerBaseV2Plus expects its subcontracts to have a method with this
   * @dev signature, and will call it once it has verified the proof
   * @dev associated with the randomness. (It is triggered via a call to
   * @dev rawFulfillRandomness, below.)
   *
   * @param requestId The Id initially returned by requestRandomness
   * @param randomWords the VRF output expanded to the requested number of words
   */
  // solhint-disable-next-line chainlink-solidity/prefix-internal-functions-with-underscore
  function fulfillRandomWords(uint256 requestId, uint256[] calldata randomWords) internal virtual;

  // rawFulfillRandomness is called by VRFCoordinator when it receives a valid VRF
  // proof. rawFulfillRandomness then calls fulfillRandomness, after validating
  // the origin of the call
  function rawFulfillRandomWords(uint256 requestId, uint256[] calldata randomWords) external {
    if (msg.sender != address(s_vrfCoordinator)) {
      revert OnlyCoordinatorCanFulfill(msg.sender, address(s_vrfCoordinator));
    }
    fulfillRandomWords(requestId, randomWords);
  }

  /**
   * @inheritdoc IVRFMigratableConsumerV2Plus
   */
  function setCoordinator(address _vrfCoordinator) external override onlyOwnerOrCoordinator {
    if (_vrfCoordinator == address(0)) {
      revert ZeroAddress();
    }
    s_vrfCoordinator = IVRFCoordinatorV2Plus(_vrfCoordinator);

    emit CoordinatorSet(_vrfCoordinator);
  }

  modifier onlyOwnerOrCoordinator() {
    if (msg.sender != owner() && msg.sender != address(s_vrfCoordinator)) {
      revert OnlyOwnerOrCoordinator(msg.sender, owner(), address(s_vrfCoordinator));
    }
    _;
  }
}

File 4 of 9 : ConfirmedOwner.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

import {ConfirmedOwnerWithProposal} from "./ConfirmedOwnerWithProposal.sol";

/// @title The ConfirmedOwner contract
/// @notice A contract with helpers for basic contract ownership.
contract ConfirmedOwner is ConfirmedOwnerWithProposal {
  constructor(address newOwner) ConfirmedOwnerWithProposal(newOwner, address(0)) {}
}

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

/// @notice The IVRFMigratableConsumerV2Plus interface defines the
/// @notice method required to be implemented by all V2Plus consumers.
/// @dev This interface is designed to be used in VRFConsumerBaseV2Plus.
interface IVRFMigratableConsumerV2Plus {
  event CoordinatorSet(address vrfCoordinator);

  /// @notice Sets the VRF Coordinator address
  /// @notice This method should only be callable by the coordinator or contract owner
  function setCoordinator(address vrfCoordinator) external;
}

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

import {VRFV2PlusClient} from "../libraries/VRFV2PlusClient.sol";
import {IVRFSubscriptionV2Plus} from "./IVRFSubscriptionV2Plus.sol";

// Interface that enables consumers of VRFCoordinatorV2Plus to be future-proof for upgrades
// This interface is supported by subsequent versions of VRFCoordinatorV2Plus
interface IVRFCoordinatorV2Plus is IVRFSubscriptionV2Plus {
  /**
   * @notice Request a set of random words.
   * @param req - a struct containing following fields for randomness request:
   * keyHash - Corresponds to a particular oracle job which uses
   * that key for generating the VRF proof. Different keyHash's have different gas price
   * ceilings, so you can select a specific one to bound your maximum per request cost.
   * subId  - The ID of the VRF subscription. Must be funded
   * with the minimum subscription balance required for the selected keyHash.
   * requestConfirmations - How many blocks you'd like the
   * oracle to wait before responding to the request. See SECURITY CONSIDERATIONS
   * for why you may want to request more. The acceptable range is
   * [minimumRequestBlockConfirmations, 200].
   * callbackGasLimit - How much gas you'd like to receive in your
   * fulfillRandomWords callback. Note that gasleft() inside fulfillRandomWords
   * may be slightly less than this amount because of gas used calling the function
   * (argument decoding etc.), so you may need to request slightly more than you expect
   * to have inside fulfillRandomWords. The acceptable range is
   * [0, maxGasLimit]
   * numWords - The number of uint256 random values you'd like to receive
   * in your fulfillRandomWords callback. Note these numbers are expanded in a
   * secure way by the VRFCoordinator from a single random value supplied by the oracle.
   * extraArgs - abi-encoded extra args
   * @return requestId - A unique identifier of the request. Can be used to match
   * a request to a response in fulfillRandomWords.
   */
  function requestRandomWords(VRFV2PlusClient.RandomWordsRequest calldata req) external returns (uint256 requestId);
}

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

/// @notice The IVRFSubscriptionV2Plus interface defines the subscription
/// @notice related methods implemented by the V2Plus coordinator.
interface IVRFSubscriptionV2Plus {
  /**
   * @notice Add a consumer to a VRF subscription.
   * @param subId - ID of the subscription
   * @param consumer - New consumer which can use the subscription
   */
  function addConsumer(uint256 subId, address consumer) external;

  /**
   * @notice Remove a consumer from a VRF subscription.
   * @param subId - ID of the subscription
   * @param consumer - Consumer to remove from the subscription
   */
  function removeConsumer(uint256 subId, address consumer) external;

  /**
   * @notice Cancel a subscription
   * @param subId - ID of the subscription
   * @param to - Where to send the remaining LINK to
   */
  function cancelSubscription(uint256 subId, address to) external;

  /**
   * @notice Accept subscription owner transfer.
   * @param subId - ID of the subscription
   * @dev will revert if original owner of subId has
   * not requested that msg.sender become the new owner.
   */
  function acceptSubscriptionOwnerTransfer(uint256 subId) external;

  /**
   * @notice Request subscription owner transfer.
   * @param subId - ID of the subscription
   * @param newOwner - proposed new owner of the subscription
   */
  function requestSubscriptionOwnerTransfer(uint256 subId, address newOwner) external;

  /**
   * @notice Create a VRF subscription.
   * @return subId - A unique subscription id.
   * @dev You can manage the consumer set dynamically with addConsumer/removeConsumer.
   * @dev Note to fund the subscription with LINK, use transferAndCall. For example
   * @dev  LINKTOKEN.transferAndCall(
   * @dev    address(COORDINATOR),
   * @dev    amount,
   * @dev    abi.encode(subId));
   * @dev Note to fund the subscription with Native, use fundSubscriptionWithNative. Be sure
   * @dev  to send Native with the call, for example:
   * @dev COORDINATOR.fundSubscriptionWithNative{value: amount}(subId);
   */
  function createSubscription() external returns (uint256 subId);

  /**
   * @notice Get a VRF subscription.
   * @param subId - ID of the subscription
   * @return balance - LINK balance of the subscription in juels.
   * @return nativeBalance - native balance of the subscription in wei.
   * @return reqCount - Requests count of subscription.
   * @return owner - owner of the subscription.
   * @return consumers - list of consumer address which are able to use this subscription.
   */
  function getSubscription(
    uint256 subId
  )
    external
    view
    returns (uint96 balance, uint96 nativeBalance, uint64 reqCount, address owner, address[] memory consumers);

  /*
   * @notice Check to see if there exists a request commitment consumers
   * for all consumers and keyhashes for a given sub.
   * @param subId - ID of the subscription
   * @return true if there exists at least one unfulfilled request for the subscription, false
   * otherwise.
   */
  function pendingRequestExists(uint256 subId) external view returns (bool);

  /**
   * @notice Paginate through all active VRF subscriptions.
   * @param startIndex index of the subscription to start from
   * @param maxCount maximum number of subscriptions to return, 0 to return all
   * @dev the order of IDs in the list is **not guaranteed**, therefore, if making successive calls, one
   * @dev should consider keeping the blockheight constant to ensure a holistic picture of the contract state
   */
  function getActiveSubscriptionIds(uint256 startIndex, uint256 maxCount) external view returns (uint256[] memory);

  /**
   * @notice Fund a subscription with native.
   * @param subId - ID of the subscription
   * @notice This method expects msg.value to be greater than or equal to 0.
   */
  function fundSubscriptionWithNative(uint256 subId) external payable;
}

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

import {IOwnable} from "../interfaces/IOwnable.sol";

/// @title The ConfirmedOwner contract
/// @notice A contract with helpers for basic contract ownership.
contract ConfirmedOwnerWithProposal is IOwnable {
  address private s_owner;
  address private s_pendingOwner;

  event OwnershipTransferRequested(address indexed from, address indexed to);
  event OwnershipTransferred(address indexed from, address indexed to);

  constructor(address newOwner, address pendingOwner) {
    // solhint-disable-next-line gas-custom-errors
    require(newOwner != address(0), "Cannot set owner to zero");

    s_owner = newOwner;
    if (pendingOwner != address(0)) {
      _transferOwnership(pendingOwner);
    }
  }

  /// @notice Allows an owner to begin transferring ownership to a new address.
  function transferOwnership(address to) public override onlyOwner {
    _transferOwnership(to);
  }

  /// @notice Allows an ownership transfer to be completed by the recipient.
  function acceptOwnership() external override {
    // solhint-disable-next-line gas-custom-errors
    require(msg.sender == s_pendingOwner, "Must be proposed owner");

    address oldOwner = s_owner;
    s_owner = msg.sender;
    s_pendingOwner = address(0);

    emit OwnershipTransferred(oldOwner, msg.sender);
  }

  /// @notice Get the current owner
  function owner() public view override returns (address) {
    return s_owner;
  }

  /// @notice validate, transfer ownership, and emit relevant events
  function _transferOwnership(address to) private {
    // solhint-disable-next-line gas-custom-errors
    require(to != msg.sender, "Cannot transfer to self");

    s_pendingOwner = to;

    emit OwnershipTransferRequested(s_owner, to);
  }

  /// @notice validate access
  function _validateOwnership() internal view {
    // solhint-disable-next-line gas-custom-errors
    require(msg.sender == s_owner, "Only callable by owner");
  }

  /// @notice Reverts if called by anyone other than the contract owner.
  modifier onlyOwner() {
    _validateOwnership();
    _;
  }
}

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

interface IOwnable {
  function owner() external returns (address);

  function transferOwnership(address recipient) external;

  function acceptOwnership() external;
}

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

Contract Security Audit

Contract ABI

API
[{"inputs":[{"internalType":"uint256","name":"subscriptionId","type":"uint256"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"have","type":"address"},{"internalType":"address","name":"want","type":"address"}],"name":"OnlyCoordinatorCanFulfill","type":"error"},{"inputs":[{"internalType":"address","name":"have","type":"address"},{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"coordinator","type":"address"}],"name":"OnlyOwnerOrCoordinator","type":"error"},{"inputs":[],"name":"Reentrancy","type":"error"},{"inputs":[],"name":"ZeroAddress","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"vrfCoordinator","type":"address"}],"name":"CoordinatorSet","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":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"}],"name":"OwnershipTransferRequested","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","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":"tokensIntoLiquidity","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"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newAddress","type":"address"},{"indexed":true,"internalType":"address","name":"oldAddress","type":"address"}],"name":"UpdateUniswapV2Router","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"betFlip","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"newWallet","type":"address"},{"indexed":true,"internalType":"address","name":"oldWallet","type":"address"}],"name":"devWalletUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"roll","type":"uint256"},{"indexed":false,"internalType":"bool","name":"won","type":"bool"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"winFlip","type":"event"},{"inputs":[],"name":"VRFFee","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":[],"name":"acceptOwnership","outputs":[],"stateMutability":"nonpayable","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":[{"internalType":"address","name":"","type":"address"}],"name":"betsizeFlip","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"dangerClearCacheFlip","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"deadAddress","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":"devWallet","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","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":"uint256","name":"_amount","type":"uint256"}],"name":"flip","outputs":[],"stateMutability":"payable","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":"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":"payout","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"requestId","type":"uint256"},{"internalType":"uint256[]","name":"randomWords","type":"uint256[]"}],"name":"rawFulfillRandomWords","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"s_vrfCoordinator","outputs":[{"internalType":"contract IVRFCoordinatorV2Plus","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellLiquidityFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellTotalFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pair","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"setAutomatedMarketMakerPair","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_vrfCoordinator","type":"address"}],"name":"setCoordinator","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"router","type":"address"}],"name":"setRouter","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":"tokensForDev","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensForLiquidity","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":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_liquidityFee","type":"uint256"},{"internalType":"uint256","name":"_devFee","type":"uint256"}],"name":"updateBuyFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newWallet","type":"address"}],"name":"updateDevWallet","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":"_liquidityFee","type":"uint256"},{"internalType":"uint256","name":"_devFee","type":"uint256"}],"name":"updateSellFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"enabled","type":"bool"}],"name":"updateSwapEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newAmount","type":"uint256"}],"name":"updateSwapTokensAtAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newFee","type":"uint256"}],"name":"updateVRFFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"userIdFlip","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdrawToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

608060405260016005819055600b80546001600160501b03191666010003002625a01790556014805462ffffff191690911790553480156200003f575f80fd5b50604051620037193803806200371983398101604081905262000062916200060d565b73d7f86b4b8cae7d942340ff628f82735b7a20893a33805f6040518060400160405280600b81526020016a456d70697265204369747960a81b81525060405180604001604052806004815260200163454d504360e01b8152508160039081620000cc9190620006c4565b506004620000db8282620006c4565b5050506001600160a01b0382166200013a5760405162461bcd60e51b815260206004820152601860248201527f43616e6e6f7420736574206f776e657220746f207a65726f000000000000000060448201526064015b60405180910390fd5b600680546001600160a01b0319166001600160a01b03848116919091179091558116156200016d576200016d816200037f565b5050506001600160a01b038116620001985760405163d92e233d60e01b815260040160405180910390fd5b600880546001600160a01b0319166001600160a01b039290921691909117905560098190557f8077df514608a09f83e4e8d300645594e5d7234665448ba83f51a50f842bd3d9600a5573126cfc30e7eb867ee604bbc53eb95733ef48c55e620002038160016200042a565b600f80546001600160a01b0319166001600160a01b0383161790555f6003600481662386f26fc1000069d3c21bcecceda1000000606462000246826005620007a0565b620002529190620007c0565b601155606462000264826005620007a0565b620002709190620007c0565b60135561271062000283826005620007a0565b6200028f9190620007c0565b60125560168690556017859055620002a88587620007e0565b6015556019849055601a839055620002c18385620007e0565b601855601b829055601080546001600160a01b0319167304273222eeb301d665b9e795c02f335f1bcd9dcc1790556200030e620003066006546001600160a01b031690565b60016200045e565b6200031b3060016200045e565b6200032a61dead60016200045e565b62000349620003416006546001600160a01b031690565b60016200042a565b620003563060016200042a565b6200036561dead60016200042a565b620003713382620004c6565b5050505050505050620007f6565b336001600160a01b03821603620003d95760405162461bcd60e51b815260206004820152601760248201527f43616e6e6f74207472616e7366657220746f2073656c66000000000000000000604482015260640162000131565b600780546001600160a01b0319166001600160a01b03838116918217909255600654604051919216907fed8889f560326eb138920d842192f0eb3dd22b4f139c87a2c57538e05bae1278905f90a350565b62000434620005aa565b6001600160a01b03919091165f908152601f60205260409020805460ff1916911515919091179055565b62000468620005aa565b6001600160a01b0382165f818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6001600160a01b0382166200051e5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640162000131565b806002546200052e9190620007e0565b6002556001600160a01b0382165f9081526020819052604090205462000556908290620007e0565b6001600160a01b0383165f81815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6006546001600160a01b03163314620006065760405162461bcd60e51b815260206004820152601660248201527f4f6e6c792063616c6c61626c65206279206f776e657200000000000000000000604482015260640162000131565b565b505050565b5f602082840312156200061e575f80fd5b5051919050565b634e487b7160e01b5f52604160045260245ffd5b600181811c908216806200064e57607f821691505b6020821081036200066d57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f82111562000608575f81815260208120601f850160051c810160208610156200069b5750805b601f850160051c820191505b81811015620006bc57828155600101620006a7565b505050505050565b81516001600160401b03811115620006e057620006e062000625565b620006f881620006f1845462000639565b8462000673565b602080601f8311600181146200072e575f8415620007165750858301515b5f19600386901b1c1916600185901b178555620006bc565b5f85815260208120601f198616915b828110156200075e578886015182559484019460019091019084016200073d565b50858210156200077c57878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b5f52601160045260245ffd5b8082028115828204841417620007ba57620007ba6200078c565b92915050565b5f82620007db57634e487b7160e01b5f52601260045260245ffd5b500490565b80820180821115620007ba57620007ba6200078c565b612f1580620008045f395ff3fe608060405260043610610374575f3560e01c80638da5cb5b116101c8578063b62496f5116100fd578063d257b34f1161009d578063f11a24d31161006d578063f11a24d314610a13578063f2fde38b14610a28578063f637434214610a47578063f8b45b0514610a5c575f80fd5b8063d257b34f14610986578063d85ba063146109a5578063dd62ed3e146109ba578063e2f45605146109fe575f80fd5b8063c0d78655116100d8578063c0d786551461091f578063c18bc1951461093e578063c8c8ebe41461095d578063ca628c7814610972575f80fd5b8063b62496f5146108b5578063bbc0c742146108e2578063c024666814610900575f80fd5b80639c3b4fdc11610168578063a0d82dc511610143578063a0d82dc514610837578063a457c2d71461084c578063a6b5717c1461086b578063a9059cbb14610896575f80fd5b80639c3b4fdc146107ee5780639eccacf6146108035780639fccce3214610822575f80fd5b8063924de9b7116101a3578063924de9b714610787578063935cbe15146107a657806395d89b41146107bb5780639a7a23d6146107cf575f80fd5b80638da5cb5b1461072c5780638ea5220f146107495780638ea9811714610768575f80fd5b80632aec3ab9116102a957806366ca9b8311610249578063751039fc11610219578063751039fc146106d15780637571336a146106e557806379ba5097146107045780638a8c523c14610718575f80fd5b806366ca9b831461064a5780636a486a8e146106695780636ddd17131461067e57806370a082311461069d575f80fd5b80634a62bb65116102845780634a62bb65146105bb5780634fbee193146105d45780635fb7a3021461060b57806363bd1d4a14610636575f80fd5b80632aec3ab914610562578063313ce56714610581578063395093511461059c575f80fd5b80631816467f11610314578063203e727e116102ef578063203e727e146104fc578063221e885d1461051b57806323b872dd1461052e57806327c8f8351461054d575f80fd5b80631816467f146104a95780631a8145bb146104c85780631fe543e3146104dd575f80fd5b806310d5de531161034f57806310d5de53146103f95780631694505e1461042757806316fd63021461045e57806318160ddd1461048b575f80fd5b806302dbd8f81461037f57806306fdde03146103a0578063095ea7b3146103ca575f80fd5b3661037b57005b5f80fd5b34801561038a575f80fd5b5061039e610399366004612a08565b610a71565b005b3480156103ab575f80fd5b506103b4610aeb565b6040516103c19190612a6b565b60405180910390f35b3480156103d5575f80fd5b506103e96103e4366004612a98565b610b7b565b60405190151581526020016103c1565b348015610404575f80fd5b506103e9610413366004612ac2565b601f6020525f908152604090205460ff1681565b348015610432575f80fd5b50600f54610446906001600160a01b031681565b6040516001600160a01b0390911681526020016103c1565b348015610469575f80fd5b5061039e335f908152600e60209081526040808320839055600d909152812055565b348015610496575f80fd5b506002545b6040519081526020016103c1565b3480156104b4575f80fd5b5061039e6104c3366004612ac2565b610b91565b3480156104d3575f80fd5b5061049b601c5481565b3480156104e8575f80fd5b5061039e6104f7366004612add565b610bf5565b348015610507575f80fd5b5061039e610516366004612b55565b610c45565b61039e610529366004612b55565b610d00565b348015610539575f80fd5b506103e9610548366004612b6c565b61105e565b348015610558575f80fd5b5061044661dead81565b34801561056d575f80fd5b5061039e61057c366004612b55565b6110ae565b34801561058c575f80fd5b50604051601281526020016103c1565b3480156105a7575f80fd5b506103e96105b6366004612a98565b611113565b3480156105c6575f80fd5b506014546103e99060ff1681565b3480156105df575f80fd5b506103e96105ee366004612ac2565b6001600160a01b03165f908152601e602052604090205460ff1690565b348015610616575f80fd5b5061049b610625366004612ac2565b600e6020525f908152604090205481565b348015610641575f80fd5b5061039e611149565b348015610655575f80fd5b5061039e610664366004612a08565b61117d565b348015610674575f80fd5b5061049b60185481565b348015610689575f80fd5b506014546103e99062010000900460ff1681565b3480156106a8575f80fd5b5061049b6106b7366004612ac2565b6001600160a01b03165f9081526020819052604090205490565b3480156106dc575f80fd5b506103e96111ee565b3480156106f0575f80fd5b5061039e6106ff366004612bb7565b611207565b34801561070f575f80fd5b5061039e611239565b348015610723575f80fd5b5061039e6112e6565b348015610737575f80fd5b506006546001600160a01b0316610446565b348015610754575f80fd5b50601054610446906001600160a01b031681565b348015610773575f80fd5b5061039e610782366004612ac2565b611301565b348015610792575f80fd5b5061039e6107a1366004612bee565b6113f3565b3480156107b1575f80fd5b5061049b601b5481565b3480156107c6575f80fd5b506103b4611417565b3480156107da575f80fd5b5061039e6107e9366004612bb7565b611426565b3480156107f9575f80fd5b5061049b60175481565b34801561080e575f80fd5b50600854610446906001600160a01b031681565b34801561082d575f80fd5b5061049b601d5481565b348015610842575f80fd5b5061049b601a5481565b348015610857575f80fd5b506103e9610866366004612a98565b611438565b348015610876575f80fd5b5061049b610885366004612ac2565b600d6020525f908152604090205481565b3480156108a1575f80fd5b506103e96108b0366004612a98565b61146e565b3480156108c0575f80fd5b506103e96108cf366004612ac2565b602080525f908152604090205460ff1681565b3480156108ed575f80fd5b506014546103e990610100900460ff1681565b34801561090b575f80fd5b5061039e61091a366004612bb7565b61147a565b34801561092a575f80fd5b5061039e610939366004612ac2565b6114e0565b348015610949575f80fd5b5061039e610958366004612b55565b611517565b348015610968575f80fd5b5061049b60115481565b34801561097d575f80fd5b5061039e6115c6565b348015610991575f80fd5b506103e96109a0366004612b55565b6116e8565b3480156109b0575f80fd5b5061049b60155481565b3480156109c5575f80fd5b5061049b6109d4366004612c09565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b348015610a09575f80fd5b5061049b60125481565b348015610a1e575f80fd5b5061049b60165481565b348015610a33575f80fd5b5061039e610a42366004612ac2565b611813565b348015610a52575f80fd5b5061049b60195481565b348015610a67575f80fd5b5061049b60135481565b610a79611824565b6019829055601a819055610a8d8183612c49565b601881905560191015610ae75760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323525206f72206c65737300000060448201526064015b60405180910390fd5b5050565b606060038054610afa90612c5c565b80601f0160208091040260200160405190810160405280929190818152602001828054610b2690612c5c565b8015610b715780601f10610b4857610100808354040283529160200191610b71565b820191905f5260205f20905b815481529060010190602001808311610b5457829003601f168201915b5050505050905090565b5f610b87338484611879565b5060015b92915050565b610b99611824565b6010546040516001600160a01b03918216918316907f90b8024c4923d3873ff5b9fcb43d0360d4b9217fa41225d07ba379993552e743905f90a3601080546001600160a01b0319166001600160a01b0392909216919091179055565b6008546001600160a01b03163314610c355760085460405163073e64fd60e21b81523360048201526001600160a01b039091166024820152604401610ade565b610c4083838361199d565b505050565b610c4d611824565b670de0b6b3a76400006103e8610c6260025490565b610c6d906001612c94565b610c779190612cbf565b610c819190612cbf565b811015610ce85760405162461bcd60e51b815260206004820152602f60248201527f43616e6e6f7420736574206d61785472616e73616374696f6e416d6f756e742060448201526e6c6f776572207468616e20302e312560881b6064820152608401610ade565b610cfa81670de0b6b3a7640000612c94565b60115550565b600554600114610d235760405163558a1e0360e11b815260040160405180910390fd5b60026005556064610d3360025490565b610d3d9190612cbf565b811115610da65760405162461bcd60e51b815260206004820152603160248201527f43616e206e6f7420666c6970206d6f7265207468616e203125206f662074686560448201527020737570706c7920617420612074696d6560781b6064820152608401610ade565b335f908152600d602052604090205415610df85760405162461bcd60e51b81526020600482015260136024820152724f6e6520666c697020617420612074696d652160681b6044820152606401610ade565b601b54341015610e405760405162461bcd60e51b8152602060048201526013602482015272496e73756666696369656e742056524646656560681b6044820152606401610ade565b601054601b546040515f926001600160a01b031691908381818185875af1925050503d805f8114610e8c576040519150601f19603f3d011682016040523d82523d5f602084013e610e91565b606091505b5050905080610eda5760405162461bcd60e51b81526020600482015260156024820152744661696c656420746f2073656e642056524646656560581b6044820152606401610ade565b610ee43383611b77565b6008546040805160c081018252600a548152600954602080830191909152600b5461ffff6401000000008204168385015263ffffffff808216606085015266010000000000009091041660808301528251908101909252600182525f926001600160a01b031691639b1c385e919060a0820190610f6090611c68565b8152506040518263ffffffff1660e01b8152600401610f7f9190612cd2565b6020604051808303815f875af1158015610f9b573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fbf9190612d36565b5f818152600c6020908152604080832080546001600160a01b031916339081179091558352600d909152902081905590506064610ffd8460c7612c94565b6110079190612cbf565b335f818152600e6020526040908190209290925590517feb60f01d57d2fe4e66ef31e4b2166288174d4cf64772f0a4e59d66e6a4a832589061104c9086815260200190565b60405180910390a25050600160055550565b5f61106a848484611cd9565b6001600160a01b0384165f908152600160209081526040808320338085529252909120546110a491869161109f908690612d4d565b611879565b5060019392505050565b6110b6611824565b67016345785d8a000081111561110e5760405162461bcd60e51b815260206004820152601c60248201527f4d757374206b6565702056524620666565203c3d20302e3120455448000000006044820152606401610ade565b601b55565b335f8181526001602090815260408083206001600160a01b03871684529091528120549091610b8791859061109f908690612c49565b611151611824565b60405133904780156108fc02915f818181858888f1935050505015801561117a573d5f803e3d5ffd5b50565b611185611824565b601682905560178190556111998183612c49565b601581905560141015610ae75760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323025206f72206c6573730000006044820152606401610ade565b5f6111f7611824565b506014805460ff19169055600190565b61120f611824565b6001600160a01b03919091165f908152601f60205260409020805460ff1916911515919091179055565b6007546001600160a01b0316331461128c5760405162461bcd60e51b815260206004820152601660248201527526bab9ba10313290383937b837b9b2b21037bbb732b960511b6044820152606401610ade565b600680546001600160a01b0319808216339081179093556007805490911690556040516001600160a01b03909116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a350565b6112ee611824565b6014805462ffff00191662010100179055565b6006546001600160a01b0316331480159061132757506008546001600160a01b03163314155b15611378573361133f6006546001600160a01b031690565b60085460405163061db9c160e01b81526001600160a01b0393841660048201529183166024830152919091166044820152606401610ade565b6001600160a01b03811661139f5760405163d92e233d60e01b815260040160405180910390fd5b600880546001600160a01b0319166001600160a01b0383169081179091556040519081527fd1a6a14209a385a964d036e404cb5cfb71f4000cdb03c9366292430787261be69060200160405180910390a150565b6113fb611824565b60148054911515620100000262ff000019909216919091179055565b606060048054610afa90612c5c565b61142e611824565b610ae7828261235e565b335f8181526001602090815260408083206001600160a01b03871684529091528120549091610b8791859061109f908690612d4d565b5f610b87338484611cd9565b611482611824565b6001600160a01b0382165f818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6114e8611824565b806114f4816001611207565b600f80546001600160a01b0319166001600160a01b039290921691909117905550565b61151f611824565b670de0b6b3a76400006103e861153460025490565b61153f906005612c94565b6115499190612cbf565b6115539190612cbf565b8110156115ae5760405162461bcd60e51b8152602060048201526024808201527f43616e6e6f7420736574206d617857616c6c6574206c6f776572207468616e20604482015263302e352560e01b6064820152608401610ade565b6115c081670de0b6b3a7640000612c94565b60135550565b6115ce611824565b3063095ea7b3816115de60025490565b6040516001600160e01b031960e085901b1681526001600160a01b03909216600483015260248201526044016020604051808303815f875af1158015611626573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061164a9190612d60565b50306323b872dd816116646006546001600160a01b031690565b305f908152602081905260409020546040516001600160e01b031960e086901b1681526001600160a01b03938416600482015292909116602483015260448201526064016020604051808303815f875af11580156116c4573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061117a9190612d60565b5f6116f1611824565b620186a06116fe60025490565b611709906001612c94565b6117139190612cbf565b8210156117805760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610ade565b606461178b60025490565b611796906001612c94565b6117a09190612cbf565b82111561180a5760405162461bcd60e51b815260206004820152603260248201527f5377617020616d6f756e742063616e6e6f74206265206869676865722074686160448201527137101892903a37ba30b61039bab838363c9760711b6064820152608401610ade565b50601255600190565b61181b611824565b61117a816123b0565b6006546001600160a01b031633146118775760405162461bcd60e51b815260206004820152601660248201527527b7363c9031b0b63630b1363290313c9037bbb732b960511b6044820152606401610ade565b565b6001600160a01b0383166118db5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610ade565b6001600160a01b03821661193c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610ade565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b5f838152600c60205260409020546001600160a01b031680611a015760405162461bcd60e51b815260206004820152601a60248201527f4e6f2067616d6520666f756e6420666f722074686520757365720000000000006044820152606401610ade565b5f83835f818110611a1457611a14612d7b565b90506020020135905084600d5f846001600160a01b03166001600160a01b031681526020019081526020015f205403611b70575f611a53600283612d8f565b9050805f03611ae9576001600160a01b0383165f908152600e6020526040902054611a7f908490612459565b6001600160a01b0383165f818152600e6020526040908190205490517f7f1653baa84473fed2c40782149eb60e20923fed5bbfb0c39cafa599018a7ad991611adc9185916001919283529015156020830152604082015260600190565b60405180910390a2611b49565b6001600160a01b0383165f818152600e60205260408082205490517f7f1653baa84473fed2c40782149eb60e20923fed5bbfb0c39cafa599018a7ad992611b40928683529015156020830152604082015260600190565b60405180910390a25b506001600160a01b0382165f908152600e60209081526040808320839055600d9091528120555b5050505050565b6001600160a01b038216611bd75760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610ade565b6001600160a01b0382165f90815260208190526040902054611bfa908290612d4d565b6001600160a01b0383165f90815260208190526040902055600254611c20908290612d4d565b6002556040518181525f906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906020015b60405180910390a35050565b60607f92fd13387c7fe7befbc38d303d6468778fb9731bc4583f17d92989c6fcfdeaaa82604051602401611ca191511515815260200190565b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b03199093169290921790915292915050565b6001600160a01b038316611cff5760405162461bcd60e51b8152600401610ade90612da2565b6001600160a01b038216611d255760405162461bcd60e51b8152600401610ade90612de7565b805f03611d3757610c4083835f612530565b60145460ff16156120a2576006546001600160a01b03848116911614801590611d6e57506006546001600160a01b03838116911614155b8015611d8257506001600160a01b03821615155b8015611d9957506001600160a01b03821661dead14155b8015611daf5750600f54600160a01b900460ff16155b156120a257601454610100900460ff16611e45576001600160a01b0383165f908152601e602052604090205460ff1680611e0057506001600160a01b0382165f908152601e602052604090205460ff165b611e455760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610ade565b6001600160a01b0383165f90815260208052604090205460ff168015611e8357506001600160a01b0382165f908152601f602052604090205460ff16155b15611f6657601154811115611ef85760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610ade565b6013546001600160a01b0383165f90815260208190526040902054611f1d9083612c49565b1115611f615760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ade565b6120a2565b6001600160a01b0382165f90815260208052604090205460ff168015611fa457506001600160a01b0383165f908152601f602052604090205460ff16155b1561201a57601154811115611f615760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610ade565b6001600160a01b0382165f908152601f602052604090205460ff166120a2576013546001600160a01b0383165f9081526020819052604090205461205e9083612c49565b11156120a25760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ade565b305f90815260208190526040902054601254811080159081906120cd575060145462010000900460ff165b80156120e35750600f54600160a01b900460ff16155b801561210657506001600160a01b0385165f90815260208052604090205460ff16155b801561212a57506001600160a01b0385165f908152601e602052604090205460ff16155b801561214e57506001600160a01b0384165f908152601e602052604090205460ff16155b1561217c57600f805460ff60a01b1916600160a01b17905561216e61261e565b600f805460ff60a01b191690555b600f546001600160a01b0386165f908152601e602052604090205460ff600160a01b9092048216159116806121c857506001600160a01b0385165f908152601e602052604090205460ff165b156121d057505f5b5f811561234a576001600160a01b0386165f90815260208052604090205460ff1680156121fe57505f601854115b15612284576064601854866122139190612c94565b61221d9190612cbf565b9050601854601954826122309190612c94565b61223a9190612cbf565b601c5f82825461224a9190612c49565b9091555050601854601a5461225f9083612c94565b6122699190612cbf565b601d5f8282546122799190612c49565b9091555061232c9050565b6001600160a01b0387165f90815260208052604090205460ff1680156122ab57505f601554115b1561232c576064601554866122c09190612c94565b6122ca9190612cbf565b9050601554601654826122dd9190612c94565b6122e79190612cbf565b601c5f8282546122f79190612c49565b909155505060155460175461230c9083612c94565b6123169190612cbf565b601d5f8282546123269190612c49565b90915550505b801561233d5761233d873083612530565b6123478186612d4d565b94505b612355878787612530565b50505050505050565b6001600160a01b0382165f818152602080526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b336001600160a01b038216036124085760405162461bcd60e51b815260206004820152601760248201527f43616e6e6f74207472616e7366657220746f2073656c660000000000000000006044820152606401610ade565b600780546001600160a01b0319166001600160a01b03838116918217909255600654604051919216907fed8889f560326eb138920d842192f0eb3dd22b4f139c87a2c57538e05bae1278905f90a350565b6001600160a01b0382166124af5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401610ade565b806002546124bd9190612c49565b6002556001600160a01b0382165f908152602081905260409020546124e3908290612c49565b6001600160a01b0383165f81815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611c5c565b6001600160a01b0383166125565760405162461bcd60e51b8152600401610ade90612da2565b6001600160a01b03821661257c5760405162461bcd60e51b8152600401610ade90612de7565b6001600160a01b0383165f9081526020819052604090205461259f908290612d4d565b6001600160a01b038085165f9081526020819052604080822093909355908416815220546125ce908290612c49565b6001600160a01b038381165f818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611990565b305f9081526020819052604081205490505f601d54601c546126409190612c49565b90505f82158061264e575081155b1561265857505050565b601254612666906014612c94565b83111561267e5760125461267b906014612c94565b92505b5f600283601c54866126909190612c94565b61269a9190612cbf565b6126a49190612cbf565b90505f6126b18286612d4d565b9050476126bd8261280e565b5f6126c88247612d4d565b90505f86601d54836126da9190612c94565b6126e49190612cbf565b90505f6126f18284612d4d565b5f601c819055601d8190556010546040519293506001600160a01b031691849181818185875af1925050503d805f8114612746576040519150601f19603f3d011682016040523d82523d5f602084013e61274b565b606091505b5090975050851580159061275e57505f81115b156127b15761276d868261295e565b601c54604080518781526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6010546040516001600160a01b039091169047905f81818185875af1925050503d805f81146127fb576040519150601f19603f3d011682016040523d82523d5f602084013e612800565b606091505b505050505050505050505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f8151811061284157612841612d7b565b6001600160a01b03928316602091820292909201810191909152600f54604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015612898573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906128bc9190612e2a565b816001815181106128cf576128cf612d7b565b6001600160a01b039283166020918202929092010152600f546128f59130911684611879565b600f5460405163791ac94760e01b81526001600160a01b039091169063791ac9479061292d9085905f90869030904290600401612e45565b5f604051808303815f87803b158015612944575f80fd5b505af1158015612956573d5f803e3d5ffd5b505050505050565b600f546129769030906001600160a01b031684611879565b600f5460105460405163f305d71960e01b8152306004820152602481018590525f6044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990839060c40160606040518083038185885af11580156129e3573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190611b709190612eb4565b5f8060408385031215612a19575f80fd5b50508035926020909101359150565b5f81518084525f5b81811015612a4c57602081850181015186830182015201612a30565b505f602082860101526020601f19601f83011685010191505092915050565b602081525f612a7d6020830184612a28565b9392505050565b6001600160a01b038116811461117a575f80fd5b5f8060408385031215612aa9575f80fd5b8235612ab481612a84565b946020939093013593505050565b5f60208284031215612ad2575f80fd5b8135612a7d81612a84565b5f805f60408486031215612aef575f80fd5b83359250602084013567ffffffffffffffff80821115612b0d575f80fd5b818601915086601f830112612b20575f80fd5b813581811115612b2e575f80fd5b8760208260051b8501011115612b42575f80fd5b6020830194508093505050509250925092565b5f60208284031215612b65575f80fd5b5035919050565b5f805f60608486031215612b7e575f80fd5b8335612b8981612a84565b92506020840135612b9981612a84565b929592945050506040919091013590565b801515811461117a575f80fd5b5f8060408385031215612bc8575f80fd5b8235612bd381612a84565b91506020830135612be381612baa565b809150509250929050565b5f60208284031215612bfe575f80fd5b8135612a7d81612baa565b5f8060408385031215612c1a575f80fd5b8235612c2581612a84565b91506020830135612be381612a84565b634e487b7160e01b5f52601160045260245ffd5b80820180821115610b8b57610b8b612c35565b600181811c90821680612c7057607f821691505b602082108103612c8e57634e487b7160e01b5f52602260045260245ffd5b50919050565b8082028115828204841417610b8b57610b8b612c35565b634e487b7160e01b5f52601260045260245ffd5b5f82612ccd57612ccd612cab565b500490565b60208152815160208201526020820151604082015261ffff60408301511660608201525f606083015163ffffffff80821660808501528060808601511660a0850152505060a083015160c080840152612d2e60e0840182612a28565b949350505050565b5f60208284031215612d46575f80fd5b5051919050565b81810381811115610b8b57610b8b612c35565b5f60208284031215612d70575f80fd5b8151612a7d81612baa565b634e487b7160e01b5f52603260045260245ffd5b5f82612d9d57612d9d612cab565b500690565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b5f60208284031215612e3a575f80fd5b8151612a7d81612a84565b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b81811015612e935784516001600160a01b031683529383019391830191600101612e6e565b50506001600160a01b03969096166060850152505050608001529392505050565b5f805f60608486031215612ec6575f80fd5b835192506020840151915060408401519050925092509256fea264697066735822122014be96ed9d9fb8d1b8c3c6e9e26a76af88c3b76cdba8357b467974145befaba764736f6c63430008140033940b920f11c8c7b8390dd47c0546649f040ca93ee4cdcaa197401765c8762e71

Deployed Bytecode

0x608060405260043610610374575f3560e01c80638da5cb5b116101c8578063b62496f5116100fd578063d257b34f1161009d578063f11a24d31161006d578063f11a24d314610a13578063f2fde38b14610a28578063f637434214610a47578063f8b45b0514610a5c575f80fd5b8063d257b34f14610986578063d85ba063146109a5578063dd62ed3e146109ba578063e2f45605146109fe575f80fd5b8063c0d78655116100d8578063c0d786551461091f578063c18bc1951461093e578063c8c8ebe41461095d578063ca628c7814610972575f80fd5b8063b62496f5146108b5578063bbc0c742146108e2578063c024666814610900575f80fd5b80639c3b4fdc11610168578063a0d82dc511610143578063a0d82dc514610837578063a457c2d71461084c578063a6b5717c1461086b578063a9059cbb14610896575f80fd5b80639c3b4fdc146107ee5780639eccacf6146108035780639fccce3214610822575f80fd5b8063924de9b7116101a3578063924de9b714610787578063935cbe15146107a657806395d89b41146107bb5780639a7a23d6146107cf575f80fd5b80638da5cb5b1461072c5780638ea5220f146107495780638ea9811714610768575f80fd5b80632aec3ab9116102a957806366ca9b8311610249578063751039fc11610219578063751039fc146106d15780637571336a146106e557806379ba5097146107045780638a8c523c14610718575f80fd5b806366ca9b831461064a5780636a486a8e146106695780636ddd17131461067e57806370a082311461069d575f80fd5b80634a62bb65116102845780634a62bb65146105bb5780634fbee193146105d45780635fb7a3021461060b57806363bd1d4a14610636575f80fd5b80632aec3ab914610562578063313ce56714610581578063395093511461059c575f80fd5b80631816467f11610314578063203e727e116102ef578063203e727e146104fc578063221e885d1461051b57806323b872dd1461052e57806327c8f8351461054d575f80fd5b80631816467f146104a95780631a8145bb146104c85780631fe543e3146104dd575f80fd5b806310d5de531161034f57806310d5de53146103f95780631694505e1461042757806316fd63021461045e57806318160ddd1461048b575f80fd5b806302dbd8f81461037f57806306fdde03146103a0578063095ea7b3146103ca575f80fd5b3661037b57005b5f80fd5b34801561038a575f80fd5b5061039e610399366004612a08565b610a71565b005b3480156103ab575f80fd5b506103b4610aeb565b6040516103c19190612a6b565b60405180910390f35b3480156103d5575f80fd5b506103e96103e4366004612a98565b610b7b565b60405190151581526020016103c1565b348015610404575f80fd5b506103e9610413366004612ac2565b601f6020525f908152604090205460ff1681565b348015610432575f80fd5b50600f54610446906001600160a01b031681565b6040516001600160a01b0390911681526020016103c1565b348015610469575f80fd5b5061039e335f908152600e60209081526040808320839055600d909152812055565b348015610496575f80fd5b506002545b6040519081526020016103c1565b3480156104b4575f80fd5b5061039e6104c3366004612ac2565b610b91565b3480156104d3575f80fd5b5061049b601c5481565b3480156104e8575f80fd5b5061039e6104f7366004612add565b610bf5565b348015610507575f80fd5b5061039e610516366004612b55565b610c45565b61039e610529366004612b55565b610d00565b348015610539575f80fd5b506103e9610548366004612b6c565b61105e565b348015610558575f80fd5b5061044661dead81565b34801561056d575f80fd5b5061039e61057c366004612b55565b6110ae565b34801561058c575f80fd5b50604051601281526020016103c1565b3480156105a7575f80fd5b506103e96105b6366004612a98565b611113565b3480156105c6575f80fd5b506014546103e99060ff1681565b3480156105df575f80fd5b506103e96105ee366004612ac2565b6001600160a01b03165f908152601e602052604090205460ff1690565b348015610616575f80fd5b5061049b610625366004612ac2565b600e6020525f908152604090205481565b348015610641575f80fd5b5061039e611149565b348015610655575f80fd5b5061039e610664366004612a08565b61117d565b348015610674575f80fd5b5061049b60185481565b348015610689575f80fd5b506014546103e99062010000900460ff1681565b3480156106a8575f80fd5b5061049b6106b7366004612ac2565b6001600160a01b03165f9081526020819052604090205490565b3480156106dc575f80fd5b506103e96111ee565b3480156106f0575f80fd5b5061039e6106ff366004612bb7565b611207565b34801561070f575f80fd5b5061039e611239565b348015610723575f80fd5b5061039e6112e6565b348015610737575f80fd5b506006546001600160a01b0316610446565b348015610754575f80fd5b50601054610446906001600160a01b031681565b348015610773575f80fd5b5061039e610782366004612ac2565b611301565b348015610792575f80fd5b5061039e6107a1366004612bee565b6113f3565b3480156107b1575f80fd5b5061049b601b5481565b3480156107c6575f80fd5b506103b4611417565b3480156107da575f80fd5b5061039e6107e9366004612bb7565b611426565b3480156107f9575f80fd5b5061049b60175481565b34801561080e575f80fd5b50600854610446906001600160a01b031681565b34801561082d575f80fd5b5061049b601d5481565b348015610842575f80fd5b5061049b601a5481565b348015610857575f80fd5b506103e9610866366004612a98565b611438565b348015610876575f80fd5b5061049b610885366004612ac2565b600d6020525f908152604090205481565b3480156108a1575f80fd5b506103e96108b0366004612a98565b61146e565b3480156108c0575f80fd5b506103e96108cf366004612ac2565b602080525f908152604090205460ff1681565b3480156108ed575f80fd5b506014546103e990610100900460ff1681565b34801561090b575f80fd5b5061039e61091a366004612bb7565b61147a565b34801561092a575f80fd5b5061039e610939366004612ac2565b6114e0565b348015610949575f80fd5b5061039e610958366004612b55565b611517565b348015610968575f80fd5b5061049b60115481565b34801561097d575f80fd5b5061039e6115c6565b348015610991575f80fd5b506103e96109a0366004612b55565b6116e8565b3480156109b0575f80fd5b5061049b60155481565b3480156109c5575f80fd5b5061049b6109d4366004612c09565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b348015610a09575f80fd5b5061049b60125481565b348015610a1e575f80fd5b5061049b60165481565b348015610a33575f80fd5b5061039e610a42366004612ac2565b611813565b348015610a52575f80fd5b5061049b60195481565b348015610a67575f80fd5b5061049b60135481565b610a79611824565b6019829055601a819055610a8d8183612c49565b601881905560191015610ae75760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323525206f72206c65737300000060448201526064015b60405180910390fd5b5050565b606060038054610afa90612c5c565b80601f0160208091040260200160405190810160405280929190818152602001828054610b2690612c5c565b8015610b715780601f10610b4857610100808354040283529160200191610b71565b820191905f5260205f20905b815481529060010190602001808311610b5457829003601f168201915b5050505050905090565b5f610b87338484611879565b5060015b92915050565b610b99611824565b6010546040516001600160a01b03918216918316907f90b8024c4923d3873ff5b9fcb43d0360d4b9217fa41225d07ba379993552e743905f90a3601080546001600160a01b0319166001600160a01b0392909216919091179055565b6008546001600160a01b03163314610c355760085460405163073e64fd60e21b81523360048201526001600160a01b039091166024820152604401610ade565b610c4083838361199d565b505050565b610c4d611824565b670de0b6b3a76400006103e8610c6260025490565b610c6d906001612c94565b610c779190612cbf565b610c819190612cbf565b811015610ce85760405162461bcd60e51b815260206004820152602f60248201527f43616e6e6f7420736574206d61785472616e73616374696f6e416d6f756e742060448201526e6c6f776572207468616e20302e312560881b6064820152608401610ade565b610cfa81670de0b6b3a7640000612c94565b60115550565b600554600114610d235760405163558a1e0360e11b815260040160405180910390fd5b60026005556064610d3360025490565b610d3d9190612cbf565b811115610da65760405162461bcd60e51b815260206004820152603160248201527f43616e206e6f7420666c6970206d6f7265207468616e203125206f662074686560448201527020737570706c7920617420612074696d6560781b6064820152608401610ade565b335f908152600d602052604090205415610df85760405162461bcd60e51b81526020600482015260136024820152724f6e6520666c697020617420612074696d652160681b6044820152606401610ade565b601b54341015610e405760405162461bcd60e51b8152602060048201526013602482015272496e73756666696369656e742056524646656560681b6044820152606401610ade565b601054601b546040515f926001600160a01b031691908381818185875af1925050503d805f8114610e8c576040519150601f19603f3d011682016040523d82523d5f602084013e610e91565b606091505b5050905080610eda5760405162461bcd60e51b81526020600482015260156024820152744661696c656420746f2073656e642056524646656560581b6044820152606401610ade565b610ee43383611b77565b6008546040805160c081018252600a548152600954602080830191909152600b5461ffff6401000000008204168385015263ffffffff808216606085015266010000000000009091041660808301528251908101909252600182525f926001600160a01b031691639b1c385e919060a0820190610f6090611c68565b8152506040518263ffffffff1660e01b8152600401610f7f9190612cd2565b6020604051808303815f875af1158015610f9b573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610fbf9190612d36565b5f818152600c6020908152604080832080546001600160a01b031916339081179091558352600d909152902081905590506064610ffd8460c7612c94565b6110079190612cbf565b335f818152600e6020526040908190209290925590517feb60f01d57d2fe4e66ef31e4b2166288174d4cf64772f0a4e59d66e6a4a832589061104c9086815260200190565b60405180910390a25050600160055550565b5f61106a848484611cd9565b6001600160a01b0384165f908152600160209081526040808320338085529252909120546110a491869161109f908690612d4d565b611879565b5060019392505050565b6110b6611824565b67016345785d8a000081111561110e5760405162461bcd60e51b815260206004820152601c60248201527f4d757374206b6565702056524620666565203c3d20302e3120455448000000006044820152606401610ade565b601b55565b335f8181526001602090815260408083206001600160a01b03871684529091528120549091610b8791859061109f908690612c49565b611151611824565b60405133904780156108fc02915f818181858888f1935050505015801561117a573d5f803e3d5ffd5b50565b611185611824565b601682905560178190556111998183612c49565b601581905560141015610ae75760405162461bcd60e51b815260206004820152601d60248201527f4d757374206b656570206665657320617420323025206f72206c6573730000006044820152606401610ade565b5f6111f7611824565b506014805460ff19169055600190565b61120f611824565b6001600160a01b03919091165f908152601f60205260409020805460ff1916911515919091179055565b6007546001600160a01b0316331461128c5760405162461bcd60e51b815260206004820152601660248201527526bab9ba10313290383937b837b9b2b21037bbb732b960511b6044820152606401610ade565b600680546001600160a01b0319808216339081179093556007805490911690556040516001600160a01b03909116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a350565b6112ee611824565b6014805462ffff00191662010100179055565b6006546001600160a01b0316331480159061132757506008546001600160a01b03163314155b15611378573361133f6006546001600160a01b031690565b60085460405163061db9c160e01b81526001600160a01b0393841660048201529183166024830152919091166044820152606401610ade565b6001600160a01b03811661139f5760405163d92e233d60e01b815260040160405180910390fd5b600880546001600160a01b0319166001600160a01b0383169081179091556040519081527fd1a6a14209a385a964d036e404cb5cfb71f4000cdb03c9366292430787261be69060200160405180910390a150565b6113fb611824565b60148054911515620100000262ff000019909216919091179055565b606060048054610afa90612c5c565b61142e611824565b610ae7828261235e565b335f8181526001602090815260408083206001600160a01b03871684529091528120549091610b8791859061109f908690612d4d565b5f610b87338484611cd9565b611482611824565b6001600160a01b0382165f818152601e6020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6114e8611824565b806114f4816001611207565b600f80546001600160a01b0319166001600160a01b039290921691909117905550565b61151f611824565b670de0b6b3a76400006103e861153460025490565b61153f906005612c94565b6115499190612cbf565b6115539190612cbf565b8110156115ae5760405162461bcd60e51b8152602060048201526024808201527f43616e6e6f7420736574206d617857616c6c6574206c6f776572207468616e20604482015263302e352560e01b6064820152608401610ade565b6115c081670de0b6b3a7640000612c94565b60135550565b6115ce611824565b3063095ea7b3816115de60025490565b6040516001600160e01b031960e085901b1681526001600160a01b03909216600483015260248201526044016020604051808303815f875af1158015611626573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061164a9190612d60565b50306323b872dd816116646006546001600160a01b031690565b305f908152602081905260409020546040516001600160e01b031960e086901b1681526001600160a01b03938416600482015292909116602483015260448201526064016020604051808303815f875af11580156116c4573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061117a9190612d60565b5f6116f1611824565b620186a06116fe60025490565b611709906001612c94565b6117139190612cbf565b8210156117805760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610ade565b606461178b60025490565b611796906001612c94565b6117a09190612cbf565b82111561180a5760405162461bcd60e51b815260206004820152603260248201527f5377617020616d6f756e742063616e6e6f74206265206869676865722074686160448201527137101892903a37ba30b61039bab838363c9760711b6064820152608401610ade565b50601255600190565b61181b611824565b61117a816123b0565b6006546001600160a01b031633146118775760405162461bcd60e51b815260206004820152601660248201527527b7363c9031b0b63630b1363290313c9037bbb732b960511b6044820152606401610ade565b565b6001600160a01b0383166118db5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610ade565b6001600160a01b03821661193c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610ade565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b5f838152600c60205260409020546001600160a01b031680611a015760405162461bcd60e51b815260206004820152601a60248201527f4e6f2067616d6520666f756e6420666f722074686520757365720000000000006044820152606401610ade565b5f83835f818110611a1457611a14612d7b565b90506020020135905084600d5f846001600160a01b03166001600160a01b031681526020019081526020015f205403611b70575f611a53600283612d8f565b9050805f03611ae9576001600160a01b0383165f908152600e6020526040902054611a7f908490612459565b6001600160a01b0383165f818152600e6020526040908190205490517f7f1653baa84473fed2c40782149eb60e20923fed5bbfb0c39cafa599018a7ad991611adc9185916001919283529015156020830152604082015260600190565b60405180910390a2611b49565b6001600160a01b0383165f818152600e60205260408082205490517f7f1653baa84473fed2c40782149eb60e20923fed5bbfb0c39cafa599018a7ad992611b40928683529015156020830152604082015260600190565b60405180910390a25b506001600160a01b0382165f908152600e60209081526040808320839055600d9091528120555b5050505050565b6001600160a01b038216611bd75760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b6064820152608401610ade565b6001600160a01b0382165f90815260208190526040902054611bfa908290612d4d565b6001600160a01b0383165f90815260208190526040902055600254611c20908290612d4d565b6002556040518181525f906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906020015b60405180910390a35050565b60607f92fd13387c7fe7befbc38d303d6468778fb9731bc4583f17d92989c6fcfdeaaa82604051602401611ca191511515815260200190565b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b03199093169290921790915292915050565b6001600160a01b038316611cff5760405162461bcd60e51b8152600401610ade90612da2565b6001600160a01b038216611d255760405162461bcd60e51b8152600401610ade90612de7565b805f03611d3757610c4083835f612530565b60145460ff16156120a2576006546001600160a01b03848116911614801590611d6e57506006546001600160a01b03838116911614155b8015611d8257506001600160a01b03821615155b8015611d9957506001600160a01b03821661dead14155b8015611daf5750600f54600160a01b900460ff16155b156120a257601454610100900460ff16611e45576001600160a01b0383165f908152601e602052604090205460ff1680611e0057506001600160a01b0382165f908152601e602052604090205460ff165b611e455760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610ade565b6001600160a01b0383165f90815260208052604090205460ff168015611e8357506001600160a01b0382165f908152601f602052604090205460ff16155b15611f6657601154811115611ef85760405162461bcd60e51b815260206004820152603560248201527f427579207472616e7366657220616d6f756e742065786365656473207468652060448201527436b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760591b6064820152608401610ade565b6013546001600160a01b0383165f90815260208190526040902054611f1d9083612c49565b1115611f615760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ade565b6120a2565b6001600160a01b0382165f90815260208052604090205460ff168015611fa457506001600160a01b0383165f908152601f602052604090205460ff16155b1561201a57601154811115611f615760405162461bcd60e51b815260206004820152603660248201527f53656c6c207472616e7366657220616d6f756e742065786365656473207468656044820152751036b0bc2a3930b739b0b1ba34b7b720b6b7bab73a1760511b6064820152608401610ade565b6001600160a01b0382165f908152601f602052604090205460ff166120a2576013546001600160a01b0383165f9081526020819052604090205461205e9083612c49565b11156120a25760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610ade565b305f90815260208190526040902054601254811080159081906120cd575060145462010000900460ff165b80156120e35750600f54600160a01b900460ff16155b801561210657506001600160a01b0385165f90815260208052604090205460ff16155b801561212a57506001600160a01b0385165f908152601e602052604090205460ff16155b801561214e57506001600160a01b0384165f908152601e602052604090205460ff16155b1561217c57600f805460ff60a01b1916600160a01b17905561216e61261e565b600f805460ff60a01b191690555b600f546001600160a01b0386165f908152601e602052604090205460ff600160a01b9092048216159116806121c857506001600160a01b0385165f908152601e602052604090205460ff165b156121d057505f5b5f811561234a576001600160a01b0386165f90815260208052604090205460ff1680156121fe57505f601854115b15612284576064601854866122139190612c94565b61221d9190612cbf565b9050601854601954826122309190612c94565b61223a9190612cbf565b601c5f82825461224a9190612c49565b9091555050601854601a5461225f9083612c94565b6122699190612cbf565b601d5f8282546122799190612c49565b9091555061232c9050565b6001600160a01b0387165f90815260208052604090205460ff1680156122ab57505f601554115b1561232c576064601554866122c09190612c94565b6122ca9190612cbf565b9050601554601654826122dd9190612c94565b6122e79190612cbf565b601c5f8282546122f79190612c49565b909155505060155460175461230c9083612c94565b6123169190612cbf565b601d5f8282546123269190612c49565b90915550505b801561233d5761233d873083612530565b6123478186612d4d565b94505b612355878787612530565b50505050505050565b6001600160a01b0382165f818152602080526040808220805460ff191685151590811790915590519092917fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab91a35050565b336001600160a01b038216036124085760405162461bcd60e51b815260206004820152601760248201527f43616e6e6f74207472616e7366657220746f2073656c660000000000000000006044820152606401610ade565b600780546001600160a01b0319166001600160a01b03838116918217909255600654604051919216907fed8889f560326eb138920d842192f0eb3dd22b4f139c87a2c57538e05bae1278905f90a350565b6001600160a01b0382166124af5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401610ade565b806002546124bd9190612c49565b6002556001600160a01b0382165f908152602081905260409020546124e3908290612c49565b6001600160a01b0383165f81815260208181526040808320949094559251848152919290917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611c5c565b6001600160a01b0383166125565760405162461bcd60e51b8152600401610ade90612da2565b6001600160a01b03821661257c5760405162461bcd60e51b8152600401610ade90612de7565b6001600160a01b0383165f9081526020819052604090205461259f908290612d4d565b6001600160a01b038085165f9081526020819052604080822093909355908416815220546125ce908290612c49565b6001600160a01b038381165f818152602081815260409182902094909455518481529092918616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101611990565b305f9081526020819052604081205490505f601d54601c546126409190612c49565b90505f82158061264e575081155b1561265857505050565b601254612666906014612c94565b83111561267e5760125461267b906014612c94565b92505b5f600283601c54866126909190612c94565b61269a9190612cbf565b6126a49190612cbf565b90505f6126b18286612d4d565b9050476126bd8261280e565b5f6126c88247612d4d565b90505f86601d54836126da9190612c94565b6126e49190612cbf565b90505f6126f18284612d4d565b5f601c819055601d8190556010546040519293506001600160a01b031691849181818185875af1925050503d805f8114612746576040519150601f19603f3d011682016040523d82523d5f602084013e61274b565b606091505b5090975050851580159061275e57505f81115b156127b15761276d868261295e565b601c54604080518781526020810184905280820192909252517f17bbfb9a6069321b6ded73bd96327c9e6b7212a5cd51ff219cd61370acafb5619181900360600190a15b6010546040516001600160a01b039091169047905f81818185875af1925050503d805f81146127fb576040519150601f19603f3d011682016040523d82523d5f602084013e612800565b606091505b505050505050505050505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f8151811061284157612841612d7b565b6001600160a01b03928316602091820292909201810191909152600f54604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015612898573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906128bc9190612e2a565b816001815181106128cf576128cf612d7b565b6001600160a01b039283166020918202929092010152600f546128f59130911684611879565b600f5460405163791ac94760e01b81526001600160a01b039091169063791ac9479061292d9085905f90869030904290600401612e45565b5f604051808303815f87803b158015612944575f80fd5b505af1158015612956573d5f803e3d5ffd5b505050505050565b600f546129769030906001600160a01b031684611879565b600f5460105460405163f305d71960e01b8152306004820152602481018590525f6044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990839060c40160606040518083038185885af11580156129e3573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190611b709190612eb4565b5f8060408385031215612a19575f80fd5b50508035926020909101359150565b5f81518084525f5b81811015612a4c57602081850181015186830182015201612a30565b505f602082860101526020601f19601f83011685010191505092915050565b602081525f612a7d6020830184612a28565b9392505050565b6001600160a01b038116811461117a575f80fd5b5f8060408385031215612aa9575f80fd5b8235612ab481612a84565b946020939093013593505050565b5f60208284031215612ad2575f80fd5b8135612a7d81612a84565b5f805f60408486031215612aef575f80fd5b83359250602084013567ffffffffffffffff80821115612b0d575f80fd5b818601915086601f830112612b20575f80fd5b813581811115612b2e575f80fd5b8760208260051b8501011115612b42575f80fd5b6020830194508093505050509250925092565b5f60208284031215612b65575f80fd5b5035919050565b5f805f60608486031215612b7e575f80fd5b8335612b8981612a84565b92506020840135612b9981612a84565b929592945050506040919091013590565b801515811461117a575f80fd5b5f8060408385031215612bc8575f80fd5b8235612bd381612a84565b91506020830135612be381612baa565b809150509250929050565b5f60208284031215612bfe575f80fd5b8135612a7d81612baa565b5f8060408385031215612c1a575f80fd5b8235612c2581612a84565b91506020830135612be381612a84565b634e487b7160e01b5f52601160045260245ffd5b80820180821115610b8b57610b8b612c35565b600181811c90821680612c7057607f821691505b602082108103612c8e57634e487b7160e01b5f52602260045260245ffd5b50919050565b8082028115828204841417610b8b57610b8b612c35565b634e487b7160e01b5f52601260045260245ffd5b5f82612ccd57612ccd612cab565b500490565b60208152815160208201526020820151604082015261ffff60408301511660608201525f606083015163ffffffff80821660808501528060808601511660a0850152505060a083015160c080840152612d2e60e0840182612a28565b949350505050565b5f60208284031215612d46575f80fd5b5051919050565b81810381811115610b8b57610b8b612c35565b5f60208284031215612d70575f80fd5b8151612a7d81612baa565b634e487b7160e01b5f52603260045260245ffd5b5f82612d9d57612d9d612cab565b500690565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b5f60208284031215612e3a575f80fd5b8151612a7d81612a84565b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b81811015612e935784516001600160a01b031683529383019391830191600101612e6e565b50506001600160a01b03969096166060850152505050608001529392505050565b5f805f60608486031215612ec6575f80fd5b835192506020840151915060408401519050925092509256fea264697066735822122014be96ed9d9fb8d1b8c3c6e9e26a76af88c3b76cdba8357b467974145befaba764736f6c63430008140033

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

940b920f11c8c7b8390dd47c0546649f040ca93ee4cdcaa197401765c8762e71

-----Decoded View---------------
Arg [0] : subscriptionId (uint256): 66962744969274724259737974286973259105020480573706440157425268360644436307569

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 940b920f11c8c7b8390dd47c0546649f040ca93ee4cdcaa197401765c8762e71


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.