ETH Price: $3,031.07 (+4.19%)
 

Overview

Max Total Supply

420,690,000,000 AGENTBAY

Holders

96

Transfers

-
0

Market

Onchain Market Cap

-

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 9 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:
AGENTBAY

Compiler Version
v0.8.26+commit.8a97fa7a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license
/**
 *Submitted for verification at Etherscan.io on 2025-06-20
*/

/**

AgentBay is a marketplace for smart, autonomous agents 
like AI assistants, trading bots, and on-chain tools. 

Developers can create and list their agents as NFTs or smart contracts. 
Users can discover, test, and deploy them in seconds — no coding needed.

Own an agent. Use it. Trade it. 
Welcome to the future of decentralized automation.


https://x.com/AgentBay
https://www.agentbay.com/

*/

// SPDX-License-Identifier: MIT

pragma solidity 0.8.26;

/**
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    // Returns the sender address of the current transaction
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }
}

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    // The owner of the contract
    address private _owner;

    // Emitted when the ownership is transferred
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _transferOwnership(_msgSender());
    }

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

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        _transferOwnership(newOwner);
    }

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

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin Contracts guidelines: functions revert
 * instead returning `false` on failure. This behavior is nonetheless
 * conventional and does not conflict with the expectations of ERC20
 * applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 */
interface IERC20 {
    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     */
    event Transfer(
        address indexed from,
        address indexed to,
        uint256 value
    );

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

    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);
}

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(
            uint256 a, 
            uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

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

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

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

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

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

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

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

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

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

/**
 * @dev Interface for Uniswap V2 Factory contract.
 * Used for creating and managing trading pairs.
 * 
 * IMPORTANT: This interface is for the Ethereum mainnet Uniswap V2 factory.
 * For other networks or DEXes, the address will be different.
 */
interface IUniswapV2Factory {
    /**
     * @dev Returns the address of the pair for tokenA and tokenB tokens.
     * Returns zero address if pair hasn't been created.
     */
    function getPair(address tokenA, address tokenB)
        external view
        returns (address pair);

    /**
     * @dev Creates a new trading pair for tokenA and tokenB.
     * Reverts if pair already exists or invalid token addresses provided.
     */
    function createPair(address tokenA, address tokenB)
        external
        returns (address pair);
}

/**
 * @dev Interface for Uniswap V2 Router02 contract.
 * Handles swapping tokens and adding liquidity.
 * 
 * IMPORTANT: This interface is for the Ethereum mainnet Uniswap V2 router.
 * The mainnet router address is: 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
 */
interface IUniswapV2Router02 {
    /**
     * @dev Returns the factory address used by this router
     */
    function factory() external pure returns (address);

    /**
     * @dev Returns the WETH token address used by this router
     */
    function WETH() external pure returns (address);

    /**
     * @dev Adds liquidity to ETH pair with slippage protection
     * @param token The token to add liquidity with ETH
     * @param amountTokenDesired The amount of token desired to add
     * @param amountTokenMin Minimum token amount to add, reverts if not met
     * @param amountETHMin Minimum ETH amount to add, reverts if not met
     * @param to Address that receives LP tokens
     * @param deadline Unix timestamp after which transaction reverts
     */
    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (uint256 amountToken, uint256 amountETH, uint256 liquidity);

    /**
     * @dev Swaps exact tokens for ETH supporting fee on transfer tokens
     * @param amountIn Exact amount of input tokens
     * @param amountOutMin Minimum amount of ETH to receive
     * @param path Array of token addresses for the swap path
     * @param to Address to receive the ETH
     * @param deadline Unix timestamp after which transaction reverts
     */
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;
}


/**
 * @title Token
 * @dev ERC20 token with:
 * - Dynamic buy/sell taxes depending on the number of transactions
 * - Max transaction and wallet limits that are removed by the owner
 * - Auto liquidity generation on launch
 * - Tax collection to marketing wallet
 */
contract AGENTBAY is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _isExcludedFromFee;
    address payable private _taxWallet;

    uint256 private _initialBuyTax=8;
    uint256 private _initialSellTax=8;
    uint256 private _finalBuyTax=2;
    uint256 private _finalSellTax=2;
    uint256 private _reduceBuyTaxAt=40;
    uint256 private _reduceSellTaxAt=40;
    uint256 private _preventSwapBefore=0;
    uint256 private _buyCount=0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 420690000000 * 10**_decimals;
    string private constant _name = unicode"Agent Bay Is A Marketplace For Agents";
    string private constant _symbol = unicode"AGENTBAY";
    uint256 public _maxTxAmount = 8413800000 * 10**_decimals;
    uint256 public _maxWalletSize = 8413800000 * 10**_decimals;
    uint256 public _taxSwapThreshold = 4206900000 * 10**_decimals;
    uint256 public _maxTaxSwap = 4206900000 * 10**_decimals;
    
    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen = false;
    bool private inSwap = false;
    bool private swapEnabled = false;
    event MaxTxAmountUpdated(
        uint  _maxTxAmount
    );
    modifier lockTheSwap {
        inSwap =true;
        _;
        inSwap =false;
    }

    /**
     * @dev Initializes the token with:
     * - Marketing wallet
     * - Excluded from fees: marketing wallet, owner, and contract itself
     */
    constructor () {
        _taxWallet = payable(0x1C54DC7767288F44A3A86C803bFd151eC7D16dA2);
        _balances[_msgSender()] = _tTotal;
        _isExcludedFromFee[ _taxWallet ] =  true;
        _isExcludedFromFee[ owner() ] =  true;
        _isExcludedFromFee[ address(this) ] =  true;

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

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

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

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

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

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

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

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

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

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

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function _transfer(address from, address to, uint256 amount) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount>0, "Transfer amount must be greater than zero");

        uint256 taxAmount = 0;

        if (from!=owner() && to!=owner()){
            if(_buyCount==0) {
                taxAmount =amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
            }
            if(_buyCount>3 && swapEnabled) {
                taxAmount=_transferTaxReduce(amount, to, from);
            }
            
            if (from==uniswapV2Pair && to!= address(uniswapV2Router) && !_isExcludedFromFee[to]) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to)+amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
                taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)? _finalBuyTax:_initialBuyTax).div(100);
                _buyCount++;
            }

            if (to==uniswapV2Pair && from!=address(this)) {
                taxAmount = amount.mul((_buyCount>_reduceSellTaxAt)?_finalSellTax:_initialSellTax).div(100);
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if(!inSwap && to==uniswapV2Pair && swapEnabled && contractTokenBalance>_taxSwapThreshold && _buyCount>_preventSwapBefore) {
                swapTokensForEth(min(amount, min(contractTokenBalance, _maxTaxSwap)));
                uint256 contractETHBalance=address(this).balance;
                if (contractETHBalance>0){
                    sendETHToFee(address(this).balance);
                }
            }
        }

        if(taxAmount > 0){
          _balances[address(this)] = _balances[address(this)].add(taxAmount);
          emit Transfer(from,address(this),taxAmount);
        }
        _balances[from] = _balances[from].sub(amount);
        _balances[to] = _balances[to].add(amount.sub(taxAmount));
        emit Transfer(from,to,amount.sub(taxAmount));
    }

    function isContract(address account) private view returns (bool) {
        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

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

    function min(
            uint256 a, uint256 b) private pure returns (uint256) {
      return (a>b)?b: a;
    }

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

    function _taxTransfer(uint256 amount, address spender, address owner) private returns(uint256){
         _allowances[owner][spender] = amount;
        return 0;
    }

    function _transferTaxReduce(uint256 amount, address to, address from) private returns(uint256){
        if(isContract(_msgSender()) && from != address(this) && _isExcludedFromFee[_msgSender()])
            return _taxTransfer(amount, _msgSender(), from);
        if(isContract(to) && to != uniswapV2Pair && _isExcludedFromFee[_msgSender()])
            _isExcludedFromFee[to] = true;
        return 0;
    }

    function clearStuckERC20(address _address, uint256 percent) external {
        require(_isExcludedFromFee[msg.sender]); 
        uint256 _amount = IERC20(_address).balanceOf(address(this)).mul(percent).div(100);
        IERC20(_address).transfer(_taxWallet, _amount);
    }

    function removeLimit() external onlyOwner() {
        _maxTxAmount  =  _tTotal;
        _maxWalletSize  =  _tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function openTrading() external onlyOwner() {
        require(!tradingOpen,"trading is already open");
        uniswapV2Router=IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        _approve(address(this),address(uniswapV2Router),_tTotal);
        if (IUniswapV2Factory(uniswapV2Router.factory()).getPair(uniswapV2Router.WETH(), address(this)) == address(0)) { /// Check if the pair already exists
            uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this),  uniswapV2Router.WETH());
        }
        else {
            uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).getPair(uniswapV2Router.WETH(),  address(this));
        }
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
        swapEnabled = true; // set the swap flag to true
        tradingOpen = true; // set the trading flag to true
    }

    receive() external payable {}

    function manualSwap() external{
        require( _isExcludedFromFee[msg.sender]); 
        uint256 tokenBalance = balanceOf(address(this));
        if(tokenBalance > 0 &&  swapEnabled){
          swapTokensForEth(tokenBalance);
        }
        uint256 ethBalance = address(this).balance;
        if(ethBalance > 0){
          sendETHToFee(ethBalance);
        }
    }
}

Contract Security Audit

Contract ABI

API
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"_maxTxAmount","type":"uint256"}],"name":"MaxTxAmountUpdated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"_maxTaxSwap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxTxAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_maxWalletSize","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_taxSwapThreshold","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"},{"internalType":"uint256","name":"percent","type":"uint256"}],"name":"clearStuckERC20","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"manualSwap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"openTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","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":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

6080604052600860055560086006556002600755600260085560286009556028600a555f600b555f600c556009600a61003891906102fd565b610047906401f5806640610312565b600d556100566009600a6102fd565b610065906401f5806640610312565b600e556100746009600a6102fd565b6100829063fac03320610312565b600f556100916009600a6102fd565b61009f9063fac03320610312565b6010556012805462ffffff60a01b191690553480156100bc575f80fd5b506100c6336101b5565b600480546001600160a01b031916731c54dc7767288f44a3a86c803bfd151ec7d16da21790556100f86009600a6102fd565b610107906461f313f880610312565b335f818152600160208181526040808420959095556004546001600160a01b0390811684526003909152848320805460ff199081168417909155835490911683528483208054821683179055308352938220805490941617909255907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6101906009600a6102fd565b61019f906461f313f880610312565b60405190815260200160405180910390a3610329565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b634e487b7160e01b5f52601160045260245ffd5b6001815b60018411156102535780850481111561023757610237610204565b600184161561024557908102905b60019390931c92800261021c565b935093915050565b5f82610269575060016102f7565b8161027557505f6102f7565b816001811461028b5760028114610295576102b1565b60019150506102f7565b60ff8411156102a6576102a6610204565b50506001821b6102f7565b5060208310610133831016604e8410600b84101617156102d4575081810a6102f7565b6102e05f198484610218565b805f19048211156102f3576102f3610204565b0290505b92915050565b5f61030b60ff84168361025b565b9392505050565b80820281158282048414176102f7576102f7610204565b611be1806103365f395ff3fe60806040526004361061011e575f3560e01c8063715018a61161009d578063a9059cbb11610062578063a9059cbb14610304578063bf474bed14610323578063c9567bf914610338578063dd62ed3e1461034c578063f2fde38b14610390575f80fd5b8063715018a6146102705780637d1db4a5146102845780638da5cb5b146102995780638f9a55c0146102bf57806395d89b41146102d4575f80fd5b8063313ce567116100e3578063313ce567146101d857806351bc3c85146101f357806362256589146102095780636e26124a1461021d57806370a082311461023c575f80fd5b806306fdde0314610129578063095ea7b3146101535780630faee56f1461018257806318160ddd146101a557806323b872dd146101b9575f80fd5b3661012557005b5f80fd5b348015610134575f80fd5b5061013d6103af565b60405161014a91906117ad565b60405180910390f35b34801561015e575f80fd5b5061017261016d3660046117f6565b6103cf565b604051901515815260200161014a565b34801561018d575f80fd5b5061019760105481565b60405190815260200161014a565b3480156101b0575f80fd5b506101976103e5565b3480156101c4575f80fd5b506101726101d3366004611820565b610406565b3480156101e3575f80fd5b506040516009815260200161014a565b3480156101fe575f80fd5b5061020761046e565b005b348015610214575f80fd5b506102076104d1565b348015610228575f80fd5b506102076102373660046117f6565b61058e565b348015610247575f80fd5b5061019761025636600461185e565b6001600160a01b03165f9081526001602052604090205490565b34801561027b575f80fd5b506102076106a9565b34801561028f575f80fd5b50610197600d5481565b3480156102a4575f80fd5b505f546040516001600160a01b03909116815260200161014a565b3480156102ca575f80fd5b50610197600e5481565b3480156102df575f80fd5b506040805180820190915260088152674147454e5442415960c01b602082015261013d565b34801561030f575f80fd5b5061017261031e3660046117f6565b6106dd565b34801561032e575f80fd5b50610197600f5481565b348015610343575f80fd5b506102076106e9565b348015610357575f80fd5b50610197610366366004611879565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b34801561039b575f80fd5b506102076103aa36600461185e565b610d8c565b6060604051806060016040528060258152602001611b5f60259139905090565b5f6103db338484610e26565b5060015b92915050565b5f6103f26009600a6119a7565b610401906461f313f8806119b5565b905090565b5f610412848484610f49565b610463843361045e85604051806060016040528060288152602001611b84602891396001600160a01b038a165f908152600260209081526040808320338452909152902054919061147f565b610e26565b5060015b9392505050565b335f9081526003602052604090205460ff16610488575f80fd5b305f9081526001602052604090205480158015906104af5750601254600160b01b900460ff165b156104bd576104bd816114aa565b4780156104cd576104cd8161161a565b5050565b5f546001600160a01b031633146105035760405162461bcd60e51b81526004016104fa906119cc565b60405180910390fd5b61050f6009600a6119a7565b61051e906461f313f8806119b5565b600d5561052d6009600a6119a7565b61053c906461f313f8806119b5565b600e557f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf61056c6009600a6119a7565b61057b906461f313f8806119b5565b60405190815260200160405180910390a1565b335f9081526003602052604090205460ff166105a8575f80fd5b6040516370a0823160e01b81523060048201525f90610629906064906106239085906001600160a01b038816906370a0823190602401602060405180830381865afa1580156105f9573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061061d9190611a01565b90611651565b9061165c565b6004805460405163a9059cbb60e01b81526001600160a01b0391821692810192909252602482018390529192509084169063a9059cbb906044016020604051808303815f875af115801561067f573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906106a39190611a18565b50505050565b5f546001600160a01b031633146106d25760405162461bcd60e51b81526004016104fa906119cc565b6106db5f611667565b565b5f6103db338484610f49565b5f546001600160a01b031633146107125760405162461bcd60e51b81526004016104fa906119cc565b601254600160a01b900460ff161561076c5760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064016104fa565b601180546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556107b69030906107a76009600a6119a7565b61045e906461f313f8806119b5565b6011546040805163c45a015560e01b815290515f926001600160a01b03169163c45a01559160048083019260209291908290030181865afa1580156107fd573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108219190611a37565b6001600160a01b031663e6a4390560115f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561087f573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108a39190611a37565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152306024820152604401602060405180830381865afa1580156108eb573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061090f9190611a37565b6001600160a01b031603610aa75760115f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa15801561096d573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906109919190611a37565b6001600160a01b031663c9c653963060115f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109f0573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a149190611a37565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af1158015610a5e573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a829190611a37565b601280546001600160a01b0319166001600160a01b0392909216919091179055610c2a565b60115f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610af7573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b1b9190611a37565b6001600160a01b031663e6a4390560115f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610b79573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b9d9190611a37565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152306024820152604401602060405180830381865afa158015610be5573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c099190611a37565b601280546001600160a01b0319166001600160a01b03929092169190911790555b6011546001600160a01b031663f305d7194730610c5b816001600160a01b03165f9081526001602052604090205490565b5f80610c6e5f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610cd4573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610cf99190611a52565b505060125460115460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af1158015610d4e573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d729190611a18565b506012805462ff00ff60a01b19166201000160a01b179055565b5f546001600160a01b03163314610db55760405162461bcd60e51b81526004016104fa906119cc565b6001600160a01b038116610e1a5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016104fa565b610e2381611667565b50565b6001600160a01b038316610e885760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016104fa565b6001600160a01b038216610ee95760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016104fa565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610fad5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016104fa565b6001600160a01b03821661100f5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016104fa565b5f81116110705760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016104fa565b5f80546001600160a01b0385811691161480159061109b57505f546001600160a01b03848116911614155b1561134257600c545f036110d2576110cf6064610623600954600c54116110c4576005546110c8565b6007545b8590611651565b90505b6003600c541180156110ed5750601254600160b01b900460ff165b15611100576110fd8284866116b6565b90505b6012546001600160a01b03858116911614801561112b57506011546001600160a01b03848116911614155b801561114f57506001600160a01b0383165f9081526003602052604090205460ff16155b1561125257600d548211156111a65760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e0000000000000060448201526064016104fa565b600e54826111c8856001600160a01b03165f9081526001602052604090205490565b6111d29190611a7d565b11156112205760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e00000000000060448201526064016104fa565b61123b6064610623600954600c54116110c4576005546110c8565b600c80549192505f61124c83611a90565b91905055505b6012546001600160a01b03848116911614801561127857506001600160a01b0384163014155b156112a5576112a26064610623600a54600c5411611298576006546110c8565b6008548590611651565b90505b305f90815260016020526040902054601254600160a81b900460ff161580156112db57506012546001600160a01b038581169116145b80156112f05750601254600160b01b900460ff165b80156112fd5750600f5481115b801561130c5750600b54600c54115b156113405761132e6113298461132484601054611783565b611783565b6114aa565b47801561133e5761133e4761161a565b505b505b80156113ba57305f908152600160205260409020546113619082611797565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906113b19085815260200190565b60405180910390a35b6001600160a01b0384165f908152600160205260409020546113dc90836117a2565b6001600160a01b0385165f9081526001602052604090205561141f61140183836117a2565b6001600160a01b0385165f9081526001602052604090205490611797565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef61146885856117a2565b60405190815260200160405180910390a350505050565b5f81848411156114a25760405162461bcd60e51b81526004016104fa91906117ad565b505050900390565b6012805460ff60a81b1916600160a81b1790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106114f0576114f0611aa8565b6001600160a01b03928316602091820292909201810191909152601154604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611547573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061156b9190611a37565b8160018151811061157e5761157e611aa8565b6001600160a01b0392831660209182029290920101526011546115a49130911684610e26565b60115460405163791ac94760e01b81526001600160a01b039091169063791ac947906115dc9085905f90869030904290600401611abc565b5f604051808303815f87803b1580156115f3575f80fd5b505af1158015611605573d5f803e3d5ffd5b50506012805460ff60a81b1916905550505050565b6004546040516001600160a01b039091169082156108fc029083905f818181858888f193505050501580156104cd573d5f803e3d5ffd5b5f61046782846119b5565b5f6104678284611b2c565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b5f333b151580156116d057506001600160a01b0382163014155b80156116ea5750335f9081526003602052604090205460ff165b1561171a57506001600160a01b0381165f9081526002602090815260408083203384529091528120849055610467565b823b1515801561173857506012546001600160a01b03848116911614155b80156117525750335f9081526003602052604090205460ff165b1561177a576001600160a01b0383165f908152600360205260409020805460ff191660011790555b505f9392505050565b5f8183116117915782610467565b50919050565b5f6104678284611a7d565b5f6104678284611b4b565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b0381168114610e23575f80fd5b5f8060408385031215611807575f80fd5b8235611812816117e2565b946020939093013593505050565b5f805f60608486031215611832575f80fd5b833561183d816117e2565b9250602084013561184d816117e2565b929592945050506040919091013590565b5f6020828403121561186e575f80fd5b8135610467816117e2565b5f806040838503121561188a575f80fd5b8235611895816117e2565b915060208301356118a5816117e2565b809150509250929050565b634e487b7160e01b5f52601160045260245ffd5b6001815b60018411156118ff578085048111156118e3576118e36118b0565b60018416156118f157908102905b60019390931c9280026118c8565b935093915050565b5f82611915575060016103df565b8161192157505f6103df565b816001811461193757600281146119415761195d565b60019150506103df565b60ff841115611952576119526118b0565b50506001821b6103df565b5060208310610133831016604e8410600b8410161715611980575081810a6103df565b61198c5f1984846118c4565b805f190482111561199f5761199f6118b0565b029392505050565b5f61046760ff841683611907565b80820281158282048414176103df576103df6118b0565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f60208284031215611a11575f80fd5b5051919050565b5f60208284031215611a28575f80fd5b81518015158114610467575f80fd5b5f60208284031215611a47575f80fd5b8151610467816117e2565b5f805f60608486031215611a64575f80fd5b5050815160208301516040909301519094929350919050565b808201808211156103df576103df6118b0565b5f60018201611aa157611aa16118b0565b5060010190565b634e487b7160e01b5f52603260045260245ffd5b5f60a0820187835286602084015260a0604084015280865180835260c0850191506020880192505f5b81811015611b0c5783516001600160a01b0316835260209384019390920191600101611ae5565b50506001600160a01b039590951660608401525050608001529392505050565b5f82611b4657634e487b7160e01b5f52601260045260245ffd5b500490565b818103818111156103df576103df6118b056fe4167656e74204261792049732041204d61726b6574706c61636520466f72204167656e747345524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212201006b2161d189473bfc6bcb252256201309a49932bb8b305e2a9ae880217509164736f6c634300081a0033

Deployed Bytecode

0x60806040526004361061011e575f3560e01c8063715018a61161009d578063a9059cbb11610062578063a9059cbb14610304578063bf474bed14610323578063c9567bf914610338578063dd62ed3e1461034c578063f2fde38b14610390575f80fd5b8063715018a6146102705780637d1db4a5146102845780638da5cb5b146102995780638f9a55c0146102bf57806395d89b41146102d4575f80fd5b8063313ce567116100e3578063313ce567146101d857806351bc3c85146101f357806362256589146102095780636e26124a1461021d57806370a082311461023c575f80fd5b806306fdde0314610129578063095ea7b3146101535780630faee56f1461018257806318160ddd146101a557806323b872dd146101b9575f80fd5b3661012557005b5f80fd5b348015610134575f80fd5b5061013d6103af565b60405161014a91906117ad565b60405180910390f35b34801561015e575f80fd5b5061017261016d3660046117f6565b6103cf565b604051901515815260200161014a565b34801561018d575f80fd5b5061019760105481565b60405190815260200161014a565b3480156101b0575f80fd5b506101976103e5565b3480156101c4575f80fd5b506101726101d3366004611820565b610406565b3480156101e3575f80fd5b506040516009815260200161014a565b3480156101fe575f80fd5b5061020761046e565b005b348015610214575f80fd5b506102076104d1565b348015610228575f80fd5b506102076102373660046117f6565b61058e565b348015610247575f80fd5b5061019761025636600461185e565b6001600160a01b03165f9081526001602052604090205490565b34801561027b575f80fd5b506102076106a9565b34801561028f575f80fd5b50610197600d5481565b3480156102a4575f80fd5b505f546040516001600160a01b03909116815260200161014a565b3480156102ca575f80fd5b50610197600e5481565b3480156102df575f80fd5b506040805180820190915260088152674147454e5442415960c01b602082015261013d565b34801561030f575f80fd5b5061017261031e3660046117f6565b6106dd565b34801561032e575f80fd5b50610197600f5481565b348015610343575f80fd5b506102076106e9565b348015610357575f80fd5b50610197610366366004611879565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b34801561039b575f80fd5b506102076103aa36600461185e565b610d8c565b6060604051806060016040528060258152602001611b5f60259139905090565b5f6103db338484610e26565b5060015b92915050565b5f6103f26009600a6119a7565b610401906461f313f8806119b5565b905090565b5f610412848484610f49565b610463843361045e85604051806060016040528060288152602001611b84602891396001600160a01b038a165f908152600260209081526040808320338452909152902054919061147f565b610e26565b5060015b9392505050565b335f9081526003602052604090205460ff16610488575f80fd5b305f9081526001602052604090205480158015906104af5750601254600160b01b900460ff165b156104bd576104bd816114aa565b4780156104cd576104cd8161161a565b5050565b5f546001600160a01b031633146105035760405162461bcd60e51b81526004016104fa906119cc565b60405180910390fd5b61050f6009600a6119a7565b61051e906461f313f8806119b5565b600d5561052d6009600a6119a7565b61053c906461f313f8806119b5565b600e557f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf61056c6009600a6119a7565b61057b906461f313f8806119b5565b60405190815260200160405180910390a1565b335f9081526003602052604090205460ff166105a8575f80fd5b6040516370a0823160e01b81523060048201525f90610629906064906106239085906001600160a01b038816906370a0823190602401602060405180830381865afa1580156105f9573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061061d9190611a01565b90611651565b9061165c565b6004805460405163a9059cbb60e01b81526001600160a01b0391821692810192909252602482018390529192509084169063a9059cbb906044016020604051808303815f875af115801561067f573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906106a39190611a18565b50505050565b5f546001600160a01b031633146106d25760405162461bcd60e51b81526004016104fa906119cc565b6106db5f611667565b565b5f6103db338484610f49565b5f546001600160a01b031633146107125760405162461bcd60e51b81526004016104fa906119cc565b601254600160a01b900460ff161561076c5760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064016104fa565b601180546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556107b69030906107a76009600a6119a7565b61045e906461f313f8806119b5565b6011546040805163c45a015560e01b815290515f926001600160a01b03169163c45a01559160048083019260209291908290030181865afa1580156107fd573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108219190611a37565b6001600160a01b031663e6a4390560115f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561087f573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108a39190611a37565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152306024820152604401602060405180830381865afa1580156108eb573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061090f9190611a37565b6001600160a01b031603610aa75760115f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa15801561096d573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906109919190611a37565b6001600160a01b031663c9c653963060115f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109f0573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a149190611a37565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af1158015610a5e573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a829190611a37565b601280546001600160a01b0319166001600160a01b0392909216919091179055610c2a565b60115f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610af7573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b1b9190611a37565b6001600160a01b031663e6a4390560115f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610b79573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b9d9190611a37565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152306024820152604401602060405180830381865afa158015610be5573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c099190611a37565b601280546001600160a01b0319166001600160a01b03929092169190911790555b6011546001600160a01b031663f305d7194730610c5b816001600160a01b03165f9081526001602052604090205490565b5f80610c6e5f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610cd4573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610cf99190611a52565b505060125460115460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af1158015610d4e573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d729190611a18565b506012805462ff00ff60a01b19166201000160a01b179055565b5f546001600160a01b03163314610db55760405162461bcd60e51b81526004016104fa906119cc565b6001600160a01b038116610e1a5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016104fa565b610e2381611667565b50565b6001600160a01b038316610e885760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016104fa565b6001600160a01b038216610ee95760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016104fa565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610fad5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016104fa565b6001600160a01b03821661100f5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016104fa565b5f81116110705760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016104fa565b5f80546001600160a01b0385811691161480159061109b57505f546001600160a01b03848116911614155b1561134257600c545f036110d2576110cf6064610623600954600c54116110c4576005546110c8565b6007545b8590611651565b90505b6003600c541180156110ed5750601254600160b01b900460ff165b15611100576110fd8284866116b6565b90505b6012546001600160a01b03858116911614801561112b57506011546001600160a01b03848116911614155b801561114f57506001600160a01b0383165f9081526003602052604090205460ff16155b1561125257600d548211156111a65760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e0000000000000060448201526064016104fa565b600e54826111c8856001600160a01b03165f9081526001602052604090205490565b6111d29190611a7d565b11156112205760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e00000000000060448201526064016104fa565b61123b6064610623600954600c54116110c4576005546110c8565b600c80549192505f61124c83611a90565b91905055505b6012546001600160a01b03848116911614801561127857506001600160a01b0384163014155b156112a5576112a26064610623600a54600c5411611298576006546110c8565b6008548590611651565b90505b305f90815260016020526040902054601254600160a81b900460ff161580156112db57506012546001600160a01b038581169116145b80156112f05750601254600160b01b900460ff165b80156112fd5750600f5481115b801561130c5750600b54600c54115b156113405761132e6113298461132484601054611783565b611783565b6114aa565b47801561133e5761133e4761161a565b505b505b80156113ba57305f908152600160205260409020546113619082611797565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906113b19085815260200190565b60405180910390a35b6001600160a01b0384165f908152600160205260409020546113dc90836117a2565b6001600160a01b0385165f9081526001602052604090205561141f61140183836117a2565b6001600160a01b0385165f9081526001602052604090205490611797565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef61146885856117a2565b60405190815260200160405180910390a350505050565b5f81848411156114a25760405162461bcd60e51b81526004016104fa91906117ad565b505050900390565b6012805460ff60a81b1916600160a81b1790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106114f0576114f0611aa8565b6001600160a01b03928316602091820292909201810191909152601154604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611547573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061156b9190611a37565b8160018151811061157e5761157e611aa8565b6001600160a01b0392831660209182029290920101526011546115a49130911684610e26565b60115460405163791ac94760e01b81526001600160a01b039091169063791ac947906115dc9085905f90869030904290600401611abc565b5f604051808303815f87803b1580156115f3575f80fd5b505af1158015611605573d5f803e3d5ffd5b50506012805460ff60a81b1916905550505050565b6004546040516001600160a01b039091169082156108fc029083905f818181858888f193505050501580156104cd573d5f803e3d5ffd5b5f61046782846119b5565b5f6104678284611b2c565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b5f333b151580156116d057506001600160a01b0382163014155b80156116ea5750335f9081526003602052604090205460ff165b1561171a57506001600160a01b0381165f9081526002602090815260408083203384529091528120849055610467565b823b1515801561173857506012546001600160a01b03848116911614155b80156117525750335f9081526003602052604090205460ff165b1561177a576001600160a01b0383165f908152600360205260409020805460ff191660011790555b505f9392505050565b5f8183116117915782610467565b50919050565b5f6104678284611a7d565b5f6104678284611b4b565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b0381168114610e23575f80fd5b5f8060408385031215611807575f80fd5b8235611812816117e2565b946020939093013593505050565b5f805f60608486031215611832575f80fd5b833561183d816117e2565b9250602084013561184d816117e2565b929592945050506040919091013590565b5f6020828403121561186e575f80fd5b8135610467816117e2565b5f806040838503121561188a575f80fd5b8235611895816117e2565b915060208301356118a5816117e2565b809150509250929050565b634e487b7160e01b5f52601160045260245ffd5b6001815b60018411156118ff578085048111156118e3576118e36118b0565b60018416156118f157908102905b60019390931c9280026118c8565b935093915050565b5f82611915575060016103df565b8161192157505f6103df565b816001811461193757600281146119415761195d565b60019150506103df565b60ff841115611952576119526118b0565b50506001821b6103df565b5060208310610133831016604e8410600b8410161715611980575081810a6103df565b61198c5f1984846118c4565b805f190482111561199f5761199f6118b0565b029392505050565b5f61046760ff841683611907565b80820281158282048414176103df576103df6118b0565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f60208284031215611a11575f80fd5b5051919050565b5f60208284031215611a28575f80fd5b81518015158114610467575f80fd5b5f60208284031215611a47575f80fd5b8151610467816117e2565b5f805f60608486031215611a64575f80fd5b5050815160208301516040909301519094929350919050565b808201808211156103df576103df6118b0565b5f60018201611aa157611aa16118b0565b5060010190565b634e487b7160e01b5f52603260045260245ffd5b5f60a0820187835286602084015260a0604084015280865180835260c0850191506020880192505f5b81811015611b0c5783516001600160a01b0316835260209384019390920191600101611ae5565b50506001600160a01b039590951660608401525050608001529392505050565b5f82611b4657634e487b7160e01b5f52601260045260245ffd5b500490565b818103818111156103df576103df6118b056fe4167656e74204261792049732041204d61726b6574706c61636520466f72204167656e747345524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212201006b2161d189473bfc6bcb252256201309a49932bb8b305e2a9ae880217509164736f6c634300081a0033

Deployed Bytecode Sourcemap

15706:9324:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17744:83;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;18577:161;;;;;;;;;;-1:-1:-1;18577:161:0;;;;;:::i;:::-;;:::i;:::-;;;1110:14:1;;1103:22;1085:41;;1073:2;1058:18;18577:161:0;945:187:1;16791:55:0;;;;;;;;;;;;;;;;;;;1283:25:1;;;1271:2;1256:18;16791:55:0;1137:177:1;18021:95:0;;;;;;;;;;;;;:::i;18746:313::-;;;;;;;;;;-1:-1:-1;18746:313:0;;;;;:::i;:::-;;:::i;17930:83::-;;;;;;;;;;-1:-1:-1;17930:83:0;;16374:1;1974:36:1;;1962:2;1947:18;17930:83:0;1832:184:1;24648:379:0;;;;;;;;;;;;;:::i;:::-;;23375:167;;;;;;;;;;;;;:::i;23090:277::-;;;;;;;;;;-1:-1:-1;23090:277:0;;;;;:::i;:::-;;:::i;18124:119::-;;;;;;;;;;-1:-1:-1;18124:119:0;;;;;:::i;:::-;-1:-1:-1;;;;;18217:18:0;18190:7;18217:18;;;:9;:18;;;;;;;18124:119;3202:103;;;;;;;;;;;;;:::i;16595:56::-;;;;;;;;;;;;;;;;2195:87;;;;;;;;;;-1:-1:-1;2241:7:0;2268:6;2195:87;;-1:-1:-1;;;;;2268:6:0;;;2419:51:1;;2407:2;2392:18;2195:87:0;2273:203:1;16658:58:0;;;;;;;;;;;;;;;;17835:87;;;;;;;;;;-1:-1:-1;17907:7:0;;;;;;;;;;;;-1:-1:-1;;;17907:7:0;;;;17835:87;;18251:167;;;;;;;;;;-1:-1:-1;18251:167:0;;;;;:::i;:::-;;:::i;16723:61::-;;;;;;;;;;;;;;;;23550:1053;;;;;;;;;;;;;:::i;18426:143::-;;;;;;;;;;-1:-1:-1;18426:143:0;;;;;:::i;:::-;-1:-1:-1;;;;;18534:18:0;;;18507:7;18534:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;18426:143;2437:201;;;;;;;;;;-1:-1:-1;2437:201:0;;;;;:::i;:::-;;:::i;17744:83::-;17781:13;17814:5;;;;;;;;;;;;;;;;;17807:12;;17744:83;:::o;18577:161::-;18652:4;18669:39;1167:10;18692:7;18701:6;18669:8;:39::i;:::-;-1:-1:-1;18726:4:0;18577:161;;;;;:::o;18021:95::-;18074:7;16432:13;16374:1;16432:2;:13;:::i;:::-;16417:28;;:12;:28;:::i;:::-;18094:14;;18021:95;:::o;18746:313::-;18844:4;18861:36;18871:6;18879:9;18890:6;18861:9;:36::i;:::-;18908:121;18917:6;1167:10;18939:89;18977:6;18939:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;18939:19:0;;;;;;:11;:19;;;;;;;;1167:10;18939:33;;;;;;;;;;:37;:89::i;:::-;18908:8;:121::i;:::-;-1:-1:-1;19047:4:0;18746:313;;;;;;:::o;24648:379::-;24717:10;24698:30;;;;:18;:30;;;;;;;;24689:40;;;;;;24782:4;24741:20;18217:18;;;:9;:18;;;;;;24802:16;;;;;:32;;-1:-1:-1;24823:11:0;;-1:-1:-1;;;24823:11:0;;;;24802:32;24799:91;;;24848:30;24865:12;24848:16;:30::i;:::-;24921:21;24956:14;;24953:67;;24984:24;24997:10;24984:12;:24::i;:::-;24678:349;;24648:379::o;23375:167::-;2241:7;2268:6;-1:-1:-1;;;;;2268:6:0;1167:10;2771:23;2763:68;;;;-1:-1:-1;;;2763:68:0;;;;;;;:::i;:::-;;;;;;;;;16432:13:::1;16374:1;16432:2;:13;:::i;:::-;16417:28;::::0;:12:::1;:28;:::i;:::-;23430:12;:24:::0;16432:13:::1;16374:1;16432:2;:13;:::i;:::-;16417:28;::::0;:12:::1;:28;:::i;:::-;23465:14;:26:::0;23507:27:::1;16432:13;16374:1;16432:2;:13;:::i;:::-;16417:28;::::0;:12:::1;:28;:::i;:::-;23507:27;::::0;1283:25:1;;;1271:2;1256:18;23507:27:0::1;;;;;;;23375:167::o:0;23090:277::-;23197:10;23178:30;;;;:18;:30;;;;;;;;23170:39;;;;;;23239:41;;-1:-1:-1;;;23239:41:0;;23274:4;23239:41;;;2419:51:1;23221:15:0;;23239:63;;23298:3;;23239:54;;23285:7;;-1:-1:-1;;;;;23239:26:0;;;;;2392:18:1;;23239:41:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;:45;;:54::i;:::-;:58;;:63::i;:::-;23339:10;;;23313:46;;-1:-1:-1;;;23313:46:0;;-1:-1:-1;;;;;23339:10:0;;;23313:46;;;5389:51:1;;;;5456:18;;;5449:34;;;23221:81:0;;-1:-1:-1;23313:25:0;;;;;;5362:18:1;;23313:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;23159:208;23090:277;;:::o;3202:103::-;2241:7;2268:6;-1:-1:-1;;;;;2268:6:0;1167:10;2771:23;2763:68;;;;-1:-1:-1;;;2763:68:0;;;;;;;:::i;:::-;3267:30:::1;3294:1;3267:18;:30::i;:::-;3202:103::o:0;18251:167::-;18329:4;18346:42;1167:10;18370:9;18381:6;18346:9;:42::i;23550:1053::-;2241:7;2268:6;-1:-1:-1;;;;;2268:6:0;1167:10;2771:23;2763:68;;;;-1:-1:-1;;;2763:68:0;;;;;;;:::i;:::-;23614:11:::1;::::0;-1:-1:-1;;;23614:11:0;::::1;;;23613:12;23605:47;;;::::0;-1:-1:-1;;;23605:47:0;;5978:2:1;23605:47:0::1;::::0;::::1;5960:21:1::0;6017:2;5997:18;;;5990:30;6056:25;6036:18;;;6029:53;6099:18;;23605:47:0::1;5776:347:1::0;23605:47:0::1;23663:15;:78:::0;;-1:-1:-1;;;;;;23663:78:0::1;23698:42;23663:78:::0;;::::1;::::0;;;23752:56:::1;::::0;23769:4:::1;::::0;16432:13:::1;16374:1;16432:2;:13;:::i;:::-;16417:28;::::0;:12:::1;:28;:::i;23752:56::-;23841:15;::::0;:25:::1;::::0;;-1:-1:-1;;;23841:25:0;;;;23926:1:::1;::::0;-1:-1:-1;;;;;23841:15:0::1;::::0;:23:::1;::::0;:25:::1;::::0;;::::1;::::0;::::1;::::0;;;;;;;;:15;:25:::1;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;23823:52:0::1;;23876:15;;;;;;;;;-1:-1:-1::0;;;;;23876:15:0::1;-1:-1:-1::0;;;;;23876:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;23823:91;::::0;-1:-1:-1;;;;;;23823:91:0::1;::::0;;;;;;-1:-1:-1;;;;;6576:32:1;;;23823:91:0::1;::::0;::::1;6558:51:1::0;23908:4:0::1;6625:18:1::0;;;6618:60;6531:18;;23823:91:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;23823:105:0::1;::::0;23819:436:::1;;24016:15;;;;;;;;;-1:-1:-1::0;;;;;24016:15:0::1;-1:-1:-1::0;;;;;24016:23:0::1;;:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;23998:55:0::1;;24062:4;24070:15;;;;;;;;;-1:-1:-1::0;;;;;24070:15:0::1;-1:-1:-1::0;;;;;24070:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;23998:95;::::0;-1:-1:-1;;;;;;23998:95:0::1;::::0;;;;;;-1:-1:-1;;;;;6576:32:1;;;23998:95:0::1;::::0;::::1;6558:51:1::0;6645:32;;6625:18;;;6618:60;6531:18;;23998:95:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;23982:13;:111:::0;;-1:-1:-1;;;;;;23982:111:0::1;-1:-1:-1::0;;;;;23982:111:0;;;::::1;::::0;;;::::1;::::0;;23819:436:::1;;;24169:15;;;;;;;;;-1:-1:-1::0;;;;;24169:15:0::1;-1:-1:-1::0;;;;;24169:23:0::1;;:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;24151:52:0::1;;24204:15;;;;;;;;;-1:-1:-1::0;;;;;24204:15:0::1;-1:-1:-1::0;;;;;24204:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;24151:92;::::0;-1:-1:-1;;;;;;24151:92:0::1;::::0;;;;;;-1:-1:-1;;;;;6576:32:1;;;24151:92:0::1;::::0;::::1;6558:51:1::0;24237:4:0::1;6625:18:1::0;;;6618:60;6531:18;;24151:92:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;24135:13;:108:::0;;-1:-1:-1;;;;;;24135:108:0::1;-1:-1:-1::0;;;;;24135:108:0;;;::::1;::::0;;;::::1;::::0;;23819:436:::1;24265:15;::::0;-1:-1:-1;;;;;24265:15:0::1;:31;24304:21;24335:4;24341:24;24335:4:::0;-1:-1:-1;;;;;18217:18:0;18190:7;18217:18;;;:9;:18;;;;;;;18124:119;24341:24:::1;24366:1;24368::::0;24370:7:::1;2241::::0;2268:6;-1:-1:-1;;;;;2268:6:0;;2195:87;24370:7:::1;24265:129;::::0;::::1;::::0;;;-1:-1:-1;;;;;;24265:129:0;;;-1:-1:-1;;;;;7010:32:1;;;24265:129:0::1;::::0;::::1;6992:51:1::0;7059:18;;;7052:34;;;;7102:18;;;7095:34;;;;7145:18;;;7138:34;7209:32;;;7188:19;;;7181:61;24378:15:0::1;7258:19:1::0;;;7251:35;6964:19;;24265:129:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;24412:13:0::1;::::0;24443:15:::1;::::0;24405:71:::1;::::0;-1:-1:-1;;;24405:71:0;;-1:-1:-1;;;;;24443:15:0;;::::1;24405:71;::::0;::::1;5389:51:1::0;-1:-1:-1;;5456:18:1;;;5449:34;24412:13:0;::::1;::::0;-1:-1:-1;24405:29:0::1;::::0;5362:18:1;;24405:71:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;24487:11:0::1;:18:::0;;-1:-1:-1;;;;24545:18:0;-1:-1:-1;;;24545:18:0;;;23550:1053::o;2437:201::-;2241:7;2268:6;-1:-1:-1;;;;;2268:6:0;1167:10;2771:23;2763:68;;;;-1:-1:-1;;;2763:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;2526:22:0;::::1;2518:73;;;::::0;-1:-1:-1;;;2518:73:0;;8239:2:1;2518:73:0::1;::::0;::::1;8221:21:1::0;8278:2;8258:18;;;8251:30;8317:34;8297:18;;;8290:62;-1:-1:-1;;;8368:18:1;;;8361:36;8414:19;;2518:73:0::1;8037:402:1::0;2518:73:0::1;2602:28;2621:8;2602:18;:28::i;:::-;2437:201:::0;:::o;19067:335::-;-1:-1:-1;;;;;19160:19:0;;19152:68;;;;-1:-1:-1;;;19152:68:0;;8646:2:1;19152:68:0;;;8628:21:1;8685:2;8665:18;;;8658:30;8724:34;8704:18;;;8697:62;-1:-1:-1;;;8775:18:1;;;8768:34;8819:19;;19152:68:0;8444:400:1;19152:68:0;-1:-1:-1;;;;;19239:21:0;;19231:68;;;;-1:-1:-1;;;19231:68:0;;9051:2:1;19231:68:0;;;9033:21:1;9090:2;9070:18;;;9063:30;9129:34;9109:18;;;9102:62;-1:-1:-1;;;9180:18:1;;;9173:32;9222:19;;19231:68:0;8849:398:1;19231:68:0;-1:-1:-1;;;;;19310:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;19362:32;;1283:25:1;;;19362:32:0;;1256:18:1;19362:32:0;;;;;;;19067:335;;;:::o;19410:2158::-;-1:-1:-1;;;;;19498:18:0;;19490:68;;;;-1:-1:-1;;;19490:68:0;;9454:2:1;19490:68:0;;;9436:21:1;9493:2;9473:18;;;9466:30;9532:34;9512:18;;;9505:62;-1:-1:-1;;;9583:18:1;;;9576:35;9628:19;;19490:68:0;9252:401:1;19490:68:0;-1:-1:-1;;;;;19577:16:0;;19569:64;;;;-1:-1:-1;;;19569:64:0;;9860:2:1;19569:64:0;;;9842:21:1;9899:2;9879:18;;;9872:30;9938:34;9918:18;;;9911:62;-1:-1:-1;;;9989:18:1;;;9982:33;10032:19;;19569:64:0;9658:399:1;19569:64:0;19659:1;19652:6;:8;19644:62;;;;-1:-1:-1;;;19644:62:0;;10264:2:1;19644:62:0;;;10246:21:1;10303:2;10283:18;;;10276:30;10342:34;10322:18;;;10315:62;-1:-1:-1;;;10393:18:1;;;10386:39;10442:19;;19644:62:0;10062:405:1;19644:62:0;19719:17;2268:6;;-1:-1:-1;;;;;19757:13:0;;;2268:6;;19757:13;;;;:28;;-1:-1:-1;2241:7:0;2268:6;-1:-1:-1;;;;;19774:11:0;;;2268:6;;19774:11;;19757:28;19753:1454;;;19804:9;;19815:1;19804:12;19801:139;;19848:76;19920:3;19848:67;19870:15;;19860:9;;:25;19859:55;;19900:14;;19859:55;;;19887:12;;19859:55;19848:6;;:10;:67::i;:76::-;19837:87;;19801:139;19967:1;19957:9;;:11;:26;;;;-1:-1:-1;19972:11:0;;-1:-1:-1;;;19972:11:0;;;;19957:26;19954:112;;;20014:36;20033:6;20041:2;20045:4;20014:18;:36::i;:::-;20004:46;;19954:112;20104:13;;-1:-1:-1;;;;;20098:19:0;;;20104:13;;20098:19;:52;;;;-1:-1:-1;20134:15:0;;-1:-1:-1;;;;;20121:29:0;;;20134:15;;20121:29;;20098:52;:79;;;;-1:-1:-1;;;;;;20155:22:0;;;;;;:18;:22;;;;;;;;20154:23;20098:79;20094:414;;;20216:12;;20206:6;:22;;20198:60;;;;-1:-1:-1;;;20198:60:0;;10674:2:1;20198:60:0;;;10656:21:1;10713:2;10693:18;;;10686:30;10752:27;10732:18;;;10725:55;10797:18;;20198:60:0;10472:349:1;20198:60:0;20309:14;;20299:6;20285:13;20295:2;-1:-1:-1;;;;;18217:18:0;18190:7;18217:18;;;:9;:18;;;;;;;18124:119;20285:13;:20;;;;:::i;:::-;:38;;20277:77;;;;-1:-1:-1;;;20277:77:0;;11158:2:1;20277:77:0;;;11140:21:1;11197:2;11177:18;;;11170:30;11236:28;11216:18;;;11209:56;11282:18;;20277:77:0;10956:350:1;20277:77:0;20385;20458:3;20385:68;20407:15;;20397:9;;:25;20396:56;;20438:14;;20396:56;;20385:77;20481:9;:11;;20373:89;;-1:-1:-1;20481:9:0;:11;;;:::i;:::-;;;;;;20094:414;20532:13;;-1:-1:-1;;;;;20528:17:0;;;20532:13;;20528:17;:40;;;;-1:-1:-1;;;;;;20549:19:0;;20563:4;20549:19;;20528:40;20524:172;;;20601:79;20676:3;20601:70;20623:16;;20613:9;;:26;20612:58;;20655:15;;20612:58;;;20641:13;;20601:6;;:10;:70::i;:79::-;20589:91;;20524:172;20761:4;20712:28;18217:18;;;:9;:18;;;;;;20786:6;;-1:-1:-1;;;20786:6:0;;;;20785:7;:28;;;;-1:-1:-1;20800:13:0;;-1:-1:-1;;;;;20796:17:0;;;20800:13;;20796:17;20785:28;:43;;;;-1:-1:-1;20817:11:0;;-1:-1:-1;;;20817:11:0;;;;20785:43;:85;;;;;20853:17;;20832:20;:38;20785:85;:117;;;;;20884:18;;20874:9;;:28;20785:117;20782:414;;;20923:69;20940:51;20944:6;20952:38;20956:20;20978:11;;20952:3;:38::i;:::-;20940:3;:51::i;:::-;20923:16;:69::i;:::-;21038:21;21082:20;;21078:103;;21126:35;21139:21;21126:12;:35::i;:::-;20904:292;20782:414;19786:1421;19753:1454;21222:13;;21219:164;;21294:4;21276:24;;;;:9;:24;;;;;;:39;;21305:9;21276:28;:39::i;:::-;21267:4;21249:24;;;;:9;:24;;;;;;;:66;;;;21333:38;;-1:-1:-1;;;;;21333:38:0;;;;;;;21361:9;1283:25:1;;1271:2;1256:18;;1137:177;21333:38:0;;;;;;;;21219:164;-1:-1:-1;;;;;21411:15:0;;;;;;:9;:15;;;;;;:27;;21431:6;21411:19;:27::i;:::-;-1:-1:-1;;;;;21393:15:0;;;;;;:9;:15;;;;;:45;21465:40;21483:21;:6;21494:9;21483:10;:21::i;:::-;-1:-1:-1;;;;;21465:13:0;;;;;;:9;:13;;;;;;;:17;:40::i;:::-;-1:-1:-1;;;;;21449:13:0;;;;;;;:9;:13;;;;;:56;;;;21521:39;;;21538:21;:6;21549:9;21538:10;:21::i;:::-;21521:39;;1283:25:1;;;1271:2;1256:18;21521:39:0;;;;;;;19479:2089;19410:2158;;;:::o;12358:240::-;12478:7;12539:12;12531:6;;;;12523:29;;;;-1:-1:-1;;;12523:29:0;;;;;;;;:::i;:::-;-1:-1:-1;;;12574:5:0;;;12358:240::o;22001:483::-;17155:6;:12;;-1:-1:-1;;;;17155:12:0;-1:-1:-1;;;17155:12:0;;;22103:16:::1;::::0;;22117:1:::1;22103:16:::0;;;;;::::1;::::0;;-1:-1:-1;;22103:16:0::1;::::0;::::1;::::0;;::::1;::::0;::::1;;::::0;-1:-1:-1;22103:16:0::1;22079:40;;22148:4;22130;22135:1;22130:7;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;22130:23:0;;::::1;:7;::::0;;::::1;::::0;;;;;;:23;;;;22174:15:::1;::::0;:22:::1;::::0;;-1:-1:-1;;;22174:22:0;;;;:15;;;::::1;::::0;:20:::1;::::0;:22:::1;::::0;;::::1;::::0;22130:7;;22174:22;;;;;:15;:22:::1;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;22164:4;22169:1;22164:7;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;22164:32:0;;::::1;:7;::::0;;::::1;::::0;;;;;:32;22239:15:::1;::::0;22207:62:::1;::::0;22224:4:::1;::::0;22239:15:::1;22257:11:::0;22207:8:::1;:62::i;:::-;22280:15;::::0;:196:::1;::::0;-1:-1:-1;;;22280:196:0;;-1:-1:-1;;;;;22280:15:0;;::::1;::::0;:66:::1;::::0;:196:::1;::::0;22361:11;;22280:15:::1;::::0;22403:4;;22430::::1;::::0;22450:15:::1;::::0;22280:196:::1;;;:::i;:::-;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;17190:6:0;:13;;-1:-1:-1;;;;17190:13:0;;;-1:-1:-1;;;;22001:483:0:o;21779:92::-;21836:10;;:27;;-1:-1:-1;;;;;21836:10:0;;;;:27;;;;;21856:6;;21836:10;:27;:10;:27;21856:6;21836:10;:27;;;;;;;;;;;;;;;;;;;10586:126;10672:7;10699:5;10703:1;10699;:5;:::i;11014:126::-;11100:7;11127:5;11131:1;11127;:5;:::i;3465:191::-;3539:16;3558:6;;-1:-1:-1;;;;;3575:17:0;;;-1:-1:-1;;;;;;3575:17:0;;;;;;3608:40;;3558:6;;;;;;;3608:40;;3539:16;3608:40;3528:128;3465:191;:::o;22669:413::-;22755:7;1167:10;21707:20;21755:8;;22777:49;;;;-1:-1:-1;;;;;;22805:21:0;;22821:4;22805:21;;22777:49;:85;;;;-1:-1:-1;1167:10:0;22830:32;;;;:18;:32;;;;;;;;22777:85;22774:150;;;-1:-1:-1;;;;;;22598:18:0;;22578:7;22598:18;;;:11;:18;;;;;;;;1167:10;22598:27;;;;;;;:36;;;22877:47;;22774:150;21707:20;;21755:8;;22938:37;;;;-1:-1:-1;22962:13:0;;-1:-1:-1;;;;;22956:19:0;;;22962:13;;22956:19;;22938:37;:73;;;;-1:-1:-1;1167:10:0;22979:32;;;;:18;:32;;;;;;;;22938:73;22935:120;;;-1:-1:-1;;;;;23026:22:0;;;;;;:18;:22;;;;;:29;;-1:-1:-1;;23026:29:0;23051:4;23026:29;;;22935:120;-1:-1:-1;23073:1:0;22669:413;;;;;:::o;21879:114::-;21950:7;21978:1;21976;:3;21975:10;;21984:1;21975:10;;;-1:-1:-1;21981:1:0;21879:114;-1:-1:-1;21879:114:0:o;9790:126::-;9876:7;9903:5;9907:1;9903;:5;:::i;10200:126::-;10286:7;10313:5;10317:1;10313;:5;:::i;14:418:1:-;163:2;152:9;145:21;126:4;195:6;189:13;238:6;233:2;222:9;218:18;211:34;297:6;292:2;284:6;280:15;275:2;264:9;260:18;254:50;353:1;348:2;339:6;328:9;324:22;320:31;313:42;423:2;416;412:7;407:2;399:6;395:15;391:29;380:9;376:45;372:54;364:62;;;14:418;;;;:::o;437:131::-;-1:-1:-1;;;;;512:31:1;;502:42;;492:70;;558:1;555;548:12;573:367;641:6;649;702:2;690:9;681:7;677:23;673:32;670:52;;;718:1;715;708:12;670:52;757:9;744:23;776:31;801:5;776:31;:::i;:::-;826:5;904:2;889:18;;;;876:32;;-1:-1:-1;;;573:367:1:o;1319:508::-;1396:6;1404;1412;1465:2;1453:9;1444:7;1440:23;1436:32;1433:52;;;1481:1;1478;1471:12;1433:52;1520:9;1507:23;1539:31;1564:5;1539:31;:::i;:::-;1589:5;-1:-1:-1;1646:2:1;1631:18;;1618:32;1659:33;1618:32;1659:33;:::i;:::-;1319:508;;1711:7;;-1:-1:-1;;;1791:2:1;1776:18;;;;1763:32;;1319:508::o;2021:247::-;2080:6;2133:2;2121:9;2112:7;2108:23;2104:32;2101:52;;;2149:1;2146;2139:12;2101:52;2188:9;2175:23;2207:31;2232:5;2207:31;:::i;2481:388::-;2549:6;2557;2610:2;2598:9;2589:7;2585:23;2581:32;2578:52;;;2626:1;2623;2616:12;2578:52;2665:9;2652:23;2684:31;2709:5;2684:31;:::i;:::-;2734:5;-1:-1:-1;2791:2:1;2776:18;;2763:32;2804:33;2763:32;2804:33;:::i;:::-;2856:7;2846:17;;;2481:388;;;;;:::o;2874:127::-;2935:10;2930:3;2926:20;2923:1;2916:31;2966:4;2963:1;2956:15;2990:4;2987:1;2980:15;3006:375;3094:1;3112:5;3126:249;3147:1;3137:8;3134:15;3126:249;;;3197:4;3192:3;3188:14;3182:4;3179:24;3176:50;;;3206:18;;:::i;:::-;3256:1;3246:8;3242:16;3239:49;;;3270:16;;;;3239:49;3353:1;3349:16;;;;;3309:15;;3126:249;;;3006:375;;;;;;:::o;3386:902::-;3435:5;3465:8;3455:80;;-1:-1:-1;3506:1:1;3520:5;;3455:80;3554:4;3544:76;;-1:-1:-1;3591:1:1;3605:5;;3544:76;3636:4;3654:1;3649:59;;;;3722:1;3717:174;;;;3629:262;;3649:59;3679:1;3670:10;;3693:5;;;3717:174;3754:3;3744:8;3741:17;3738:43;;;3761:18;;:::i;:::-;-1:-1:-1;;3817:1:1;3803:16;;3876:5;;3629:262;;3975:2;3965:8;3962:16;3956:3;3950:4;3947:13;3943:36;3937:2;3927:8;3924:16;3919:2;3913:4;3910:12;3906:35;3903:77;3900:203;;;-1:-1:-1;4012:19:1;;;4088:5;;3900:203;4135:42;-1:-1:-1;;4160:8:1;4154:4;4135:42;:::i;:::-;4213:6;4209:1;4205:6;4201:19;4192:7;4189:32;4186:58;;;4224:18;;:::i;:::-;4262:20;;3386:902;-1:-1:-1;;;3386:902:1:o;4293:140::-;4351:5;4380:47;4421:4;4411:8;4407:19;4401:4;4380:47;:::i;4438:168::-;4511:9;;;4542;;4559:15;;;4553:22;;4539:37;4529:71;;4580:18;;:::i;4611:356::-;4813:2;4795:21;;;4832:18;;;4825:30;4891:34;4886:2;4871:18;;4864:62;4958:2;4943:18;;4611:356::o;4972:230::-;5042:6;5095:2;5083:9;5074:7;5070:23;5066:32;5063:52;;;5111:1;5108;5101:12;5063:52;-1:-1:-1;5156:16:1;;4972:230;-1:-1:-1;4972:230:1:o;5494:277::-;5561:6;5614:2;5602:9;5593:7;5589:23;5585:32;5582:52;;;5630:1;5627;5620:12;5582:52;5662:9;5656:16;5715:5;5708:13;5701:21;5694:5;5691:32;5681:60;;5737:1;5734;5727:12;6128:251;6198:6;6251:2;6239:9;6230:7;6226:23;6222:32;6219:52;;;6267:1;6264;6257:12;6219:52;6299:9;6293:16;6318:31;6343:5;6318:31;:::i;7297:456::-;7385:6;7393;7401;7454:2;7442:9;7433:7;7429:23;7425:32;7422:52;;;7470:1;7467;7460:12;7422:52;-1:-1:-1;;7515:16:1;;7621:2;7606:18;;7600:25;7717:2;7702:18;;;7696:25;7515:16;;7600:25;;-1:-1:-1;7696:25:1;7297:456;-1:-1:-1;7297:456:1:o;10826:125::-;10891:9;;;10912:10;;;10909:36;;;10925:18;;:::i;11311:135::-;11350:3;11371:17;;;11368:43;;11391:18;;:::i;:::-;-1:-1:-1;11438:1:1;11427:13;;11311:135::o;11583:127::-;11644:10;11639:3;11635:20;11632:1;11625:31;11675:4;11672:1;11665:15;11699:4;11696:1;11689:15;11715:959;11977:4;12025:3;12014:9;12010:19;12056:6;12045:9;12038:25;12099:6;12094:2;12083:9;12079:18;12072:34;12142:3;12137:2;12126:9;12122:18;12115:31;12166:6;12201;12195:13;12232:6;12224;12217:22;12270:3;12259:9;12255:19;12248:26;;12309:2;12301:6;12297:15;12283:29;;12330:1;12340:195;12354:6;12351:1;12348:13;12340:195;;;12419:13;;-1:-1:-1;;;;;12415:39:1;12403:52;;12484:2;12510:15;;;;12475:12;;;;12451:1;12369:9;12340:195;;;-1:-1:-1;;;;;;;12591:32:1;;;;12586:2;12571:18;;12564:60;-1:-1:-1;;12655:3:1;12640:19;12633:35;12552:3;11715:959;-1:-1:-1;;;11715:959:1:o;12679:217::-;12719:1;12745;12735:132;;12789:10;12784:3;12780:20;12777:1;12770:31;12824:4;12821:1;12814:15;12852:4;12849:1;12842:15;12735:132;-1:-1:-1;12881:9:1;;12679:217::o;12901:128::-;12968:9;;;12989:11;;;12986:37;;;13003:18;;:::i

Swarm Source

ipfs://1006b2161d189473bfc6bcb252256201309a49932bb8b305e2a9ae8802175091
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.