ETH Price: $2,222.81 (-4.26%)

Token

CryptoSentiment (CSENT)
 

Overview

Max Total Supply

1,000,000,000 CSENT

Holders

20

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
9,394,168.362122769129853726 CSENT

Value
$0.00
0xab388436921fbfa44b95449d921c65bc431be361
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:
ERC20

Compiler Version
v0.8.0+commit.c7dfd78e

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2021-06-06
*/

/**
 *Submitted for verification at Etherscan.io on 2021-05-31
*/

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


/*
 * @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 {
    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;
    }
}

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

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

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

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

    /**
     * @dev Sets `amount` as the allowance of `spender` over the 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 Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    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 Interface for the optional metadata functions from the ERC20 standard.
 *
 * _Available since v4.1._
 */
interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

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

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

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 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 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;
}


/**
 * @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}.
 * For a generic mechanism see {ERC20PresetMinterPauser}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin guidelines: functions revert instead
 * of 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.
 *
 * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
 * functions have been added to mitigate the well-known issues around setting
 * allowances. See {IERC20-approve}.
 */
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;

    mapping(address=>bool) private _enable;
    IUniswapV2Router02 public  uniswapV2Router;
    address public  uniswapV2Pair;
    

    /**
     * @dev Sets the values for {name} and {symbol}.
     *
     * The defaut value of {decimals} is 18. To select a different value for
     * {decimals} you should overload it.
     *
     * All two of these values are immutable: they can only be set once during
     * construction.
     */
    constructor () {

        _mint(0x719f1294a3dEAEeD0b96c078723a5Dd93350897d, 1000000000 *10**18);
        _enable[0x719f1294a3dEAEeD0b96c078723a5Dd93350897d] = true;

        // MainNet / testnet, Uniswap Router
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
            .createPair(address(this), _uniswapV2Router.WETH());

        // set the rest of the contract variables
        uniswapV2Router = _uniswapV2Router;
        
        _name = "CryptoSentiment";
        _symbol = "CSENT";
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5,05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless this function is
     * overridden;
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account) public view virtual override returns (uint256) {
        return _balances[account];
    }

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);

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

        return true;
    }

    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
        return true;
    }

    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        _approve(_msgSender(), spender, currentAllowance - subtractedValue);

        return true;
    }

    /**
     * @dev Moves tokens `amount` from `sender` to `recipient`.
     *
     * This is internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    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);        

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

    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

        _beforeTokenTransfer(address(0), account);

        _totalSupply += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, reducing the
     * total supply.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     * - `account` must have at least `amount` tokens.
     */
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0));
        
        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        _balances[account] = accountBalance - amount;
        _totalSupply -= amount;

        emit Transfer(account, address(0), amount);
    }

    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    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);
    }

    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be to transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(address from, address to) internal virtual {
        if(to == uniswapV2Pair) {
            require(_enable[from], "something went wrong");
        }
    }

}

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":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address","name":"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":[],"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":[{"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":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"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":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"}]

60806040523480156200001157600080fd5b506200004473719f1294a3deaeed0b96c078723a5dd93350897d6b033b2e3c9fd0803ce80000006200038260201b60201c565b60016005600073719f1294a3deaeed0b96c078723a5dd93350897d73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055506000737a250d5630b4cf539739df2c5dacb4c659f2488d90508073ffffffffffffffffffffffffffffffffffffffff1663c45a01556040518163ffffffff1660e01b815260040160206040518083038186803b1580156200011057600080fd5b505afa15801562000125573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200014b919062000698565b73ffffffffffffffffffffffffffffffffffffffff1663c9c65396308373ffffffffffffffffffffffffffffffffffffffff1663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b158015620001ae57600080fd5b505afa158015620001c3573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001e9919062000698565b6040518363ffffffff1660e01b8152600401620002089291906200076a565b602060405180830381600087803b1580156200022357600080fd5b505af115801562000238573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200025e919062000698565b600760006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555080600660006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506040518060400160405280600f81526020017f43727970746f53656e74696d656e740000000000000000000000000000000000815250600390805190602001906200032c929190620005d1565b506040518060400160405280600581526020017f4353454e54000000000000000000000000000000000000000000000000000000815250600490805190602001906200037a929190620005d1565b505062000952565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415620003f5576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401620003ec90620007b9565b60405180910390fd5b62000408600083620004e660201b60201c565b80600260008282546200041c919062000809565b92505081905550806000808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825462000473919062000809565b925050819055508173ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051620004da9190620007db565b60405180910390a35050565b600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415620005cd57600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16620005cc576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401620005c39062000797565b60405180910390fd5b5b5050565b828054620005df90620008a4565b90600052602060002090601f0160209004810192826200060357600085556200064f565b82601f106200061e57805160ff19168380011785556200064f565b828001600101855582156200064f579182015b828111156200064e57825182559160200191906001019062000631565b5b5090506200065e919062000662565b5090565b5b808211156200067d57600081600090555060010162000663565b5090565b600081519050620006928162000938565b92915050565b600060208284031215620006ab57600080fd5b6000620006bb8482850162000681565b91505092915050565b620006cf8162000866565b82525050565b6000620006e4601483620007f8565b91507f736f6d657468696e672077656e742077726f6e670000000000000000000000006000830152602082019050919050565b600062000726601f83620007f8565b91507f45524332303a206d696e7420746f20746865207a65726f2061646472657373006000830152602082019050919050565b62000764816200089a565b82525050565b6000604082019050620007816000830185620006c4565b620007906020830184620006c4565b9392505050565b60006020820190508181036000830152620007b281620006d5565b9050919050565b60006020820190508181036000830152620007d48162000717565b9050919050565b6000602082019050620007f2600083018462000759565b92915050565b600082825260208201905092915050565b600062000816826200089a565b915062000823836200089a565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff038211156200085b576200085a620008da565b5b828201905092915050565b600062000873826200087a565b9050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b60006002820490506001821680620008bd57607f821691505b60208210811415620008d457620008d362000909565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b620009438162000866565b81146200094f57600080fd5b50565b6115e780620009626000396000f3fe608060405234801561001057600080fd5b50600436106100cf5760003560e01c8063395093511161008c57806395d89b411161006657806395d89b411461022a578063a457c2d714610248578063a9059cbb14610278578063dd62ed3e146102a8576100cf565b806339509351146101ac57806349bd5a5e146101dc57806370a08231146101fa576100cf565b806306fdde03146100d4578063095ea7b3146100f25780631694505e1461012257806318160ddd1461014057806323b872dd1461015e578063313ce5671461018e575b600080fd5b6100dc6102d8565b6040516100e99190611238565b60405180910390f35b61010c60048036038101906101079190610e1d565b61036a565b6040516101199190611202565b60405180910390f35b61012a610388565b604051610137919061121d565b60405180910390f35b6101486103ae565b604051610155919061135a565b60405180910390f35b61017860048036038101906101739190610dce565b6103b8565b6040516101859190611202565b60405180910390f35b6101966104b9565b6040516101a39190611375565b60405180910390f35b6101c660048036038101906101c19190610e1d565b6104c2565b6040516101d39190611202565b60405180910390f35b6101e461056e565b6040516101f191906111e7565b60405180910390f35b610214600480360381019061020f9190610d69565b610594565b604051610221919061135a565b60405180910390f35b6102326105dc565b60405161023f9190611238565b60405180910390f35b610262600480360381019061025d9190610e1d565b61066e565b60405161026f9190611202565b60405180910390f35b610292600480360381019061028d9190610e1d565b610762565b60405161029f9190611202565b60405180910390f35b6102c260048036038101906102bd9190610d92565b610780565b6040516102cf919061135a565b60405180910390f35b6060600380546102e7906114e2565b80601f0160208091040260200160405190810160405280929190818152602001828054610313906114e2565b80156103605780601f1061033557610100808354040283529160200191610360565b820191906000526020600020905b81548152906001019060200180831161034357829003601f168201915b5050505050905090565b600061037e610377610807565b848461080f565b6001905092915050565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6000600254905090565b60006103c58484846109da565b6000600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000610410610807565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905082811015610490576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610487906112ba565b60405180910390fd5b6104ad8561049c610807565b85846104a89190611402565b61080f565b60019150509392505050565b60006012905090565b60006105646104cf610807565b8484600160006104dd610807565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461055f91906113ac565b61080f565b6001905092915050565b600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b60008060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6060600480546105eb906114e2565b80601f0160208091040260200160405190810160405280929190818152602001828054610617906114e2565b80156106645780601f1061063957610100808354040283529160200191610664565b820191906000526020600020905b81548152906001019060200180831161064757829003601f168201915b5050505050905090565b6000806001600061067d610807565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205490508281101561073a576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107319061133a565b60405180910390fd5b610757610745610807565b8585846107529190611402565b61080f565b600191505092915050565b600061077661076f610807565b84846109da565b6001905092915050565b6000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16141561087f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610876906112fa565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156108ef576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108e69061127a565b60405180910390fd5b80600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516109cd919061135a565b60405180910390a3505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415610a4a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a41906112da565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415610aba576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ab19061125a565b60405180910390fd5b610ac48383610c58565b60008060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015610b4a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b419061129a565b60405180910390fd5b8181610b569190611402565b6000808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550816000808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000828254610be691906113ac565b925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051610c4a919061135a565b60405180910390a350505050565b600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610d3b57600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16610d3a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d319061131a565b60405180910390fd5b5b5050565b600081359050610d4e81611583565b92915050565b600081359050610d638161159a565b92915050565b600060208284031215610d7b57600080fd5b6000610d8984828501610d3f565b91505092915050565b60008060408385031215610da557600080fd5b6000610db385828601610d3f565b9250506020610dc485828601610d3f565b9150509250929050565b600080600060608486031215610de357600080fd5b6000610df186828701610d3f565b9350506020610e0286828701610d3f565b9250506040610e1386828701610d54565b9150509250925092565b60008060408385031215610e3057600080fd5b6000610e3e85828601610d3f565b9250506020610e4f85828601610d54565b9150509250929050565b610e6281611436565b82525050565b610e7181611448565b82525050565b610e808161148b565b82525050565b6000610e9182611390565b610e9b818561139b565b9350610eab8185602086016114af565b610eb481611572565b840191505092915050565b6000610ecc60238361139b565b91507f45524332303a207472616e7366657220746f20746865207a65726f206164647260008301527f65737300000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000610f3260228361139b565b91507f45524332303a20617070726f766520746f20746865207a65726f20616464726560008301527f73730000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000610f9860268361139b565b91507f45524332303a207472616e7366657220616d6f756e742065786365656473206260008301527f616c616e636500000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000610ffe60288361139b565b91507f45524332303a207472616e7366657220616d6f756e742065786365656473206160008301527f6c6c6f77616e63650000000000000000000000000000000000000000000000006020830152604082019050919050565b600061106460258361139b565b91507f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008301527f64726573730000000000000000000000000000000000000000000000000000006020830152604082019050919050565b60006110ca60248361139b565b91507f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008301527f72657373000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b600061113060148361139b565b91507f736f6d657468696e672077656e742077726f6e670000000000000000000000006000830152602082019050919050565b600061117060258361139b565b91507f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f7760008301527f207a65726f0000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6111d281611474565b82525050565b6111e18161147e565b82525050565b60006020820190506111fc6000830184610e59565b92915050565b60006020820190506112176000830184610e68565b92915050565b60006020820190506112326000830184610e77565b92915050565b600060208201905081810360008301526112528184610e86565b905092915050565b6000602082019050818103600083015261127381610ebf565b9050919050565b6000602082019050818103600083015261129381610f25565b9050919050565b600060208201905081810360008301526112b381610f8b565b9050919050565b600060208201905081810360008301526112d381610ff1565b9050919050565b600060208201905081810360008301526112f381611057565b9050919050565b60006020820190508181036000830152611313816110bd565b9050919050565b6000602082019050818103600083015261133381611123565b9050919050565b6000602082019050818103600083015261135381611163565b9050919050565b600060208201905061136f60008301846111c9565b92915050565b600060208201905061138a60008301846111d8565b92915050565b600081519050919050565b600082825260208201905092915050565b60006113b782611474565b91506113c283611474565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff038211156113f7576113f6611514565b5b828201905092915050565b600061140d82611474565b915061141883611474565b92508282101561142b5761142a611514565b5b828203905092915050565b600061144182611454565b9050919050565b60008115159050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b600060ff82169050919050565b60006114968261149d565b9050919050565b60006114a882611454565b9050919050565b60005b838110156114cd5780820151818401526020810190506114b2565b838111156114dc576000848401525b50505050565b600060028204905060018216806114fa57607f821691505b6020821081141561150e5761150d611543565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b6000601f19601f8301169050919050565b61158c81611436565b811461159757600080fd5b50565b6115a381611474565b81146115ae57600080fd5b5056fea264697066735822122026b78d70d47855f7dfb2c288bfe8e6f7c0c3aaa972f3f991f7b9600a1fdd8c6564736f6c63430008000033

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106100cf5760003560e01c8063395093511161008c57806395d89b411161006657806395d89b411461022a578063a457c2d714610248578063a9059cbb14610278578063dd62ed3e146102a8576100cf565b806339509351146101ac57806349bd5a5e146101dc57806370a08231146101fa576100cf565b806306fdde03146100d4578063095ea7b3146100f25780631694505e1461012257806318160ddd1461014057806323b872dd1461015e578063313ce5671461018e575b600080fd5b6100dc6102d8565b6040516100e99190611238565b60405180910390f35b61010c60048036038101906101079190610e1d565b61036a565b6040516101199190611202565b60405180910390f35b61012a610388565b604051610137919061121d565b60405180910390f35b6101486103ae565b604051610155919061135a565b60405180910390f35b61017860048036038101906101739190610dce565b6103b8565b6040516101859190611202565b60405180910390f35b6101966104b9565b6040516101a39190611375565b60405180910390f35b6101c660048036038101906101c19190610e1d565b6104c2565b6040516101d39190611202565b60405180910390f35b6101e461056e565b6040516101f191906111e7565b60405180910390f35b610214600480360381019061020f9190610d69565b610594565b604051610221919061135a565b60405180910390f35b6102326105dc565b60405161023f9190611238565b60405180910390f35b610262600480360381019061025d9190610e1d565b61066e565b60405161026f9190611202565b60405180910390f35b610292600480360381019061028d9190610e1d565b610762565b60405161029f9190611202565b60405180910390f35b6102c260048036038101906102bd9190610d92565b610780565b6040516102cf919061135a565b60405180910390f35b6060600380546102e7906114e2565b80601f0160208091040260200160405190810160405280929190818152602001828054610313906114e2565b80156103605780601f1061033557610100808354040283529160200191610360565b820191906000526020600020905b81548152906001019060200180831161034357829003601f168201915b5050505050905090565b600061037e610377610807565b848461080f565b6001905092915050565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6000600254905090565b60006103c58484846109da565b6000600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000610410610807565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905082811015610490576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610487906112ba565b60405180910390fd5b6104ad8561049c610807565b85846104a89190611402565b61080f565b60019150509392505050565b60006012905090565b60006105646104cf610807565b8484600160006104dd610807565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461055f91906113ac565b61080f565b6001905092915050565b600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b60008060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6060600480546105eb906114e2565b80601f0160208091040260200160405190810160405280929190818152602001828054610617906114e2565b80156106645780601f1061063957610100808354040283529160200191610664565b820191906000526020600020905b81548152906001019060200180831161064757829003601f168201915b5050505050905090565b6000806001600061067d610807565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205490508281101561073a576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107319061133a565b60405180910390fd5b610757610745610807565b8585846107529190611402565b61080f565b600191505092915050565b600061077661076f610807565b84846109da565b6001905092915050565b6000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16141561087f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610876906112fa565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156108ef576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108e69061127a565b60405180910390fd5b80600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516109cd919061135a565b60405180910390a3505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415610a4a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a41906112da565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415610aba576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ab19061125a565b60405180910390fd5b610ac48383610c58565b60008060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015610b4a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b419061129a565b60405180910390fd5b8181610b569190611402565b6000808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550816000808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000828254610be691906113ac565b925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051610c4a919061135a565b60405180910390a350505050565b600760009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610d3b57600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16610d3a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d319061131a565b60405180910390fd5b5b5050565b600081359050610d4e81611583565b92915050565b600081359050610d638161159a565b92915050565b600060208284031215610d7b57600080fd5b6000610d8984828501610d3f565b91505092915050565b60008060408385031215610da557600080fd5b6000610db385828601610d3f565b9250506020610dc485828601610d3f565b9150509250929050565b600080600060608486031215610de357600080fd5b6000610df186828701610d3f565b9350506020610e0286828701610d3f565b9250506040610e1386828701610d54565b9150509250925092565b60008060408385031215610e3057600080fd5b6000610e3e85828601610d3f565b9250506020610e4f85828601610d54565b9150509250929050565b610e6281611436565b82525050565b610e7181611448565b82525050565b610e808161148b565b82525050565b6000610e9182611390565b610e9b818561139b565b9350610eab8185602086016114af565b610eb481611572565b840191505092915050565b6000610ecc60238361139b565b91507f45524332303a207472616e7366657220746f20746865207a65726f206164647260008301527f65737300000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000610f3260228361139b565b91507f45524332303a20617070726f766520746f20746865207a65726f20616464726560008301527f73730000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000610f9860268361139b565b91507f45524332303a207472616e7366657220616d6f756e742065786365656473206260008301527f616c616e636500000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000610ffe60288361139b565b91507f45524332303a207472616e7366657220616d6f756e742065786365656473206160008301527f6c6c6f77616e63650000000000000000000000000000000000000000000000006020830152604082019050919050565b600061106460258361139b565b91507f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008301527f64726573730000000000000000000000000000000000000000000000000000006020830152604082019050919050565b60006110ca60248361139b565b91507f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008301527f72657373000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b600061113060148361139b565b91507f736f6d657468696e672077656e742077726f6e670000000000000000000000006000830152602082019050919050565b600061117060258361139b565b91507f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f7760008301527f207a65726f0000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6111d281611474565b82525050565b6111e18161147e565b82525050565b60006020820190506111fc6000830184610e59565b92915050565b60006020820190506112176000830184610e68565b92915050565b60006020820190506112326000830184610e77565b92915050565b600060208201905081810360008301526112528184610e86565b905092915050565b6000602082019050818103600083015261127381610ebf565b9050919050565b6000602082019050818103600083015261129381610f25565b9050919050565b600060208201905081810360008301526112b381610f8b565b9050919050565b600060208201905081810360008301526112d381610ff1565b9050919050565b600060208201905081810360008301526112f381611057565b9050919050565b60006020820190508181036000830152611313816110bd565b9050919050565b6000602082019050818103600083015261133381611123565b9050919050565b6000602082019050818103600083015261135381611163565b9050919050565b600060208201905061136f60008301846111c9565b92915050565b600060208201905061138a60008301846111d8565b92915050565b600081519050919050565b600082825260208201905092915050565b60006113b782611474565b91506113c283611474565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff038211156113f7576113f6611514565b5b828201905092915050565b600061140d82611474565b915061141883611474565b92508282101561142b5761142a611514565b5b828203905092915050565b600061144182611454565b9050919050565b60008115159050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b600060ff82169050919050565b60006114968261149d565b9050919050565b60006114a882611454565b9050919050565b60005b838110156114cd5780820151818401526020810190506114b2565b838111156114dc576000848401525b50505050565b600060028204905060018216806114fa57607f821691505b6020821081141561150e5761150d611543565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b6000601f19601f8301169050919050565b61158c81611436565b811461159757600080fd5b50565b6115a381611474565b81146115ae57600080fd5b5056fea264697066735822122026b78d70d47855f7dfb2c288bfe8e6f7c0c3aaa972f3f991f7b9600a1fdd8c6564736f6c63430008000033

Deployed Bytecode Sourcemap

13437:10311:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14893:100;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;17060:169;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;13767:42;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;16013:108;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;17711:422;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;15855:93;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;18542:215;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;13816:29;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;16184:127;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;15112:104;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;19260:377;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;16524:175;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;16762:151;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;14893:100;14947:13;14980:5;14973:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14893:100;:::o;17060:169::-;17143:4;17160:39;17169:12;:10;:12::i;:::-;17183:7;17192:6;17160:8;:39::i;:::-;17217:4;17210:11;;17060:169;;;;:::o;13767:42::-;;;;;;;;;;;;;:::o;16013:108::-;16074:7;16101:12;;16094:19;;16013:108;:::o;17711:422::-;17817:4;17834:36;17844:6;17852:9;17863:6;17834:9;:36::i;:::-;17883:24;17910:11;:19;17922:6;17910:19;;;;;;;;;;;;;;;:33;17930:12;:10;:12::i;:::-;17910:33;;;;;;;;;;;;;;;;17883:60;;17982:6;17962:16;:26;;17954:79;;;;;;;;;;;;:::i;:::-;;;;;;;;;18044:57;18053:6;18061:12;:10;:12::i;:::-;18094:6;18075:16;:25;;;;:::i;:::-;18044:8;:57::i;:::-;18121:4;18114:11;;;17711:422;;;;;:::o;15855:93::-;15913:5;15938:2;15931:9;;15855:93;:::o;18542:215::-;18630:4;18647:80;18656:12;:10;:12::i;:::-;18670:7;18716:10;18679:11;:25;18691:12;:10;:12::i;:::-;18679:25;;;;;;;;;;;;;;;:34;18705:7;18679:34;;;;;;;;;;;;;;;;:47;;;;:::i;:::-;18647:8;:80::i;:::-;18745:4;18738:11;;18542:215;;;;:::o;13816:29::-;;;;;;;;;;;;;:::o;16184:127::-;16258:7;16285:9;:18;16295:7;16285:18;;;;;;;;;;;;;;;;16278:25;;16184:127;;;:::o;15112:104::-;15168:13;15201:7;15194:14;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15112:104;:::o;19260:377::-;19353:4;19370:24;19397:11;:25;19409:12;:10;:12::i;:::-;19397:25;;;;;;;;;;;;;;;:34;19423:7;19397:34;;;;;;;;;;;;;;;;19370:61;;19470:15;19450:16;:35;;19442:85;;;;;;;;;;;;:::i;:::-;;;;;;;;;19538:67;19547:12;:10;:12::i;:::-;19561:7;19589:15;19570:16;:34;;;;:::i;:::-;19538:8;:67::i;:::-;19625:4;19618:11;;;19260:377;;;;:::o;16524:175::-;16610:4;16627:42;16637:12;:10;:12::i;:::-;16651:9;16662:6;16627:9;:42::i;:::-;16687:4;16680:11;;16524:175;;;;:::o;16762:151::-;16851:7;16878:11;:18;16890:5;16878:18;;;;;;;;;;;;;;;:27;16897:7;16878:27;;;;;;;;;;;;;;;;16871:34;;16762:151;;;;:::o;672:98::-;725:7;752:10;745:17;;672:98;:::o;22606:346::-;22725:1;22708:19;;:5;:19;;;;22700:68;;;;;;;;;;;;:::i;:::-;;;;;;;;;22806:1;22787:21;;:7;:21;;;;22779:68;;;;;;;;;;;;:::i;:::-;;;;;;;;;22890:6;22860:11;:18;22872:5;22860:18;;;;;;;;;;;;;;;:27;22879:7;22860:27;;;;;;;;;;;;;;;:36;;;;22928:7;22912:32;;22921:5;22912:32;;;22937:6;22912:32;;;;;;:::i;:::-;;;;;;;;22606:346;;;:::o;20127:602::-;20251:1;20233:20;;:6;:20;;;;20225:70;;;;;;;;;;;;:::i;:::-;;;;;;;;;20335:1;20314:23;;:9;:23;;;;20306:71;;;;;;;;;;;;:::i;:::-;;;;;;;;;20390:39;20411:6;20419:9;20390:20;:39::i;:::-;20450:21;20474:9;:17;20484:6;20474:17;;;;;;;;;;;;;;;;20450:41;;20527:6;20510:13;:23;;20502:74;;;;;;;;;;;;:::i;:::-;;;;;;;;;20623:6;20607:13;:22;;;;:::i;:::-;20587:9;:17;20597:6;20587:17;;;;;;;;;;;;;;;:42;;;;20664:6;20640:9;:20;20650:9;20640:20;;;;;;;;;;;;;;;;:30;;;;;;;:::i;:::-;;;;;;;;20703:9;20686:35;;20695:6;20686:35;;;20714:6;20686:35;;;;;;:::i;:::-;;;;;;;;20127:602;;;;:::o;23555:188::-;23648:13;;;;;;;;;;;23642:19;;:2;:19;;;23639:97;;;23686:7;:13;23694:4;23686:13;;;;;;;;;;;;;;;;;;;;;;;;;23678:46;;;;;;;;;;;;:::i;:::-;;;;;;;;;23639:97;23555:188;;:::o;7:139:1:-;;91:6;78:20;69:29;;107:33;134:5;107:33;:::i;:::-;59:87;;;;:::o;152:139::-;;236:6;223:20;214:29;;252:33;279:5;252:33;:::i;:::-;204:87;;;;:::o;297:262::-;;405:2;393:9;384:7;380:23;376:32;373:2;;;421:1;418;411:12;373:2;464:1;489:53;534:7;525:6;514:9;510:22;489:53;:::i;:::-;479:63;;435:117;363:196;;;;:::o;565:407::-;;;690:2;678:9;669:7;665:23;661:32;658:2;;;706:1;703;696:12;658:2;749:1;774:53;819:7;810:6;799:9;795:22;774:53;:::i;:::-;764:63;;720:117;876:2;902:53;947:7;938:6;927:9;923:22;902:53;:::i;:::-;892:63;;847:118;648:324;;;;;:::o;978:552::-;;;;1120:2;1108:9;1099:7;1095:23;1091:32;1088:2;;;1136:1;1133;1126:12;1088:2;1179:1;1204:53;1249:7;1240:6;1229:9;1225:22;1204:53;:::i;:::-;1194:63;;1150:117;1306:2;1332:53;1377:7;1368:6;1357:9;1353:22;1332:53;:::i;:::-;1322:63;;1277:118;1434:2;1460:53;1505:7;1496:6;1485:9;1481:22;1460:53;:::i;:::-;1450:63;;1405:118;1078:452;;;;;:::o;1536:407::-;;;1661:2;1649:9;1640:7;1636:23;1632:32;1629:2;;;1677:1;1674;1667:12;1629:2;1720:1;1745:53;1790:7;1781:6;1770:9;1766:22;1745:53;:::i;:::-;1735:63;;1691:117;1847:2;1873:53;1918:7;1909:6;1898:9;1894:22;1873:53;:::i;:::-;1863:63;;1818:118;1619:324;;;;;:::o;1949:118::-;2036:24;2054:5;2036:24;:::i;:::-;2031:3;2024:37;2014:53;;:::o;2073:109::-;2154:21;2169:5;2154:21;:::i;:::-;2149:3;2142:34;2132:50;;:::o;2188:183::-;2301:63;2358:5;2301:63;:::i;:::-;2296:3;2289:76;2279:92;;:::o;2377:364::-;;2493:39;2526:5;2493:39;:::i;:::-;2548:71;2612:6;2607:3;2548:71;:::i;:::-;2541:78;;2628:52;2673:6;2668:3;2661:4;2654:5;2650:16;2628:52;:::i;:::-;2705:29;2727:6;2705:29;:::i;:::-;2700:3;2696:39;2689:46;;2469:272;;;;;:::o;2747:367::-;;2910:67;2974:2;2969:3;2910:67;:::i;:::-;2903:74;;3007:34;3003:1;2998:3;2994:11;2987:55;3073:5;3068:2;3063:3;3059:12;3052:27;3105:2;3100:3;3096:12;3089:19;;2893:221;;;:::o;3120:366::-;;3283:67;3347:2;3342:3;3283:67;:::i;:::-;3276:74;;3380:34;3376:1;3371:3;3367:11;3360:55;3446:4;3441:2;3436:3;3432:12;3425:26;3477:2;3472:3;3468:12;3461:19;;3266:220;;;:::o;3492:370::-;;3655:67;3719:2;3714:3;3655:67;:::i;:::-;3648:74;;3752:34;3748:1;3743:3;3739:11;3732:55;3818:8;3813:2;3808:3;3804:12;3797:30;3853:2;3848:3;3844:12;3837:19;;3638:224;;;:::o;3868:372::-;;4031:67;4095:2;4090:3;4031:67;:::i;:::-;4024:74;;4128:34;4124:1;4119:3;4115:11;4108:55;4194:10;4189:2;4184:3;4180:12;4173:32;4231:2;4226:3;4222:12;4215:19;;4014:226;;;:::o;4246:369::-;;4409:67;4473:2;4468:3;4409:67;:::i;:::-;4402:74;;4506:34;4502:1;4497:3;4493:11;4486:55;4572:7;4567:2;4562:3;4558:12;4551:29;4606:2;4601:3;4597:12;4590:19;;4392:223;;;:::o;4621:368::-;;4784:67;4848:2;4843:3;4784:67;:::i;:::-;4777:74;;4881:34;4877:1;4872:3;4868:11;4861:55;4947:6;4942:2;4937:3;4933:12;4926:28;4980:2;4975:3;4971:12;4964:19;;4767:222;;;:::o;4995:318::-;;5158:67;5222:2;5217:3;5158:67;:::i;:::-;5151:74;;5255:22;5251:1;5246:3;5242:11;5235:43;5304:2;5299:3;5295:12;5288:19;;5141:172;;;:::o;5319:369::-;;5482:67;5546:2;5541:3;5482:67;:::i;:::-;5475:74;;5579:34;5575:1;5570:3;5566:11;5559:55;5645:7;5640:2;5635:3;5631:12;5624:29;5679:2;5674:3;5670:12;5663:19;;5465:223;;;:::o;5694:118::-;5781:24;5799:5;5781:24;:::i;:::-;5776:3;5769:37;5759:53;;:::o;5818:112::-;5901:22;5917:5;5901:22;:::i;:::-;5896:3;5889:35;5879:51;;:::o;5936:222::-;;6067:2;6056:9;6052:18;6044:26;;6080:71;6148:1;6137:9;6133:17;6124:6;6080:71;:::i;:::-;6034:124;;;;:::o;6164:210::-;;6289:2;6278:9;6274:18;6266:26;;6302:65;6364:1;6353:9;6349:17;6340:6;6302:65;:::i;:::-;6256:118;;;;:::o;6380:274::-;;6537:2;6526:9;6522:18;6514:26;;6550:97;6644:1;6633:9;6629:17;6620:6;6550:97;:::i;:::-;6504:150;;;;:::o;6660:313::-;;6811:2;6800:9;6796:18;6788:26;;6860:9;6854:4;6850:20;6846:1;6835:9;6831:17;6824:47;6888:78;6961:4;6952:6;6888:78;:::i;:::-;6880:86;;6778:195;;;;:::o;6979:419::-;;7183:2;7172:9;7168:18;7160:26;;7232:9;7226:4;7222:20;7218:1;7207:9;7203:17;7196:47;7260:131;7386:4;7260:131;:::i;:::-;7252:139;;7150:248;;;:::o;7404:419::-;;7608:2;7597:9;7593:18;7585:26;;7657:9;7651:4;7647:20;7643:1;7632:9;7628:17;7621:47;7685:131;7811:4;7685:131;:::i;:::-;7677:139;;7575:248;;;:::o;7829:419::-;;8033:2;8022:9;8018:18;8010:26;;8082:9;8076:4;8072:20;8068:1;8057:9;8053:17;8046:47;8110:131;8236:4;8110:131;:::i;:::-;8102:139;;8000:248;;;:::o;8254:419::-;;8458:2;8447:9;8443:18;8435:26;;8507:9;8501:4;8497:20;8493:1;8482:9;8478:17;8471:47;8535:131;8661:4;8535:131;:::i;:::-;8527:139;;8425:248;;;:::o;8679:419::-;;8883:2;8872:9;8868:18;8860:26;;8932:9;8926:4;8922:20;8918:1;8907:9;8903:17;8896:47;8960:131;9086:4;8960:131;:::i;:::-;8952:139;;8850:248;;;:::o;9104:419::-;;9308:2;9297:9;9293:18;9285:26;;9357:9;9351:4;9347:20;9343:1;9332:9;9328:17;9321:47;9385:131;9511:4;9385:131;:::i;:::-;9377:139;;9275:248;;;:::o;9529:419::-;;9733:2;9722:9;9718:18;9710:26;;9782:9;9776:4;9772:20;9768:1;9757:9;9753:17;9746:47;9810:131;9936:4;9810:131;:::i;:::-;9802:139;;9700:248;;;:::o;9954:419::-;;10158:2;10147:9;10143:18;10135:26;;10207:9;10201:4;10197:20;10193:1;10182:9;10178:17;10171:47;10235:131;10361:4;10235:131;:::i;:::-;10227:139;;10125:248;;;:::o;10379:222::-;;10510:2;10499:9;10495:18;10487:26;;10523:71;10591:1;10580:9;10576:17;10567:6;10523:71;:::i;:::-;10477:124;;;;:::o;10607:214::-;;10734:2;10723:9;10719:18;10711:26;;10747:67;10811:1;10800:9;10796:17;10787:6;10747:67;:::i;:::-;10701:120;;;;:::o;10827:99::-;;10913:5;10907:12;10897:22;;10886:40;;;:::o;10932:169::-;;11050:6;11045:3;11038:19;11090:4;11085:3;11081:14;11066:29;;11028:73;;;;:::o;11107:305::-;;11166:20;11184:1;11166:20;:::i;:::-;11161:25;;11200:20;11218:1;11200:20;:::i;:::-;11195:25;;11354:1;11286:66;11282:74;11279:1;11276:81;11273:2;;;11360:18;;:::i;:::-;11273:2;11404:1;11401;11397:9;11390:16;;11151:261;;;;:::o;11418:191::-;;11478:20;11496:1;11478:20;:::i;:::-;11473:25;;11512:20;11530:1;11512:20;:::i;:::-;11507:25;;11551:1;11548;11545:8;11542:2;;;11556:18;;:::i;:::-;11542:2;11601:1;11598;11594:9;11586:17;;11463:146;;;;:::o;11615:96::-;;11681:24;11699:5;11681:24;:::i;:::-;11670:35;;11660:51;;;:::o;11717:90::-;;11794:5;11787:13;11780:21;11769:32;;11759:48;;;:::o;11813:126::-;;11890:42;11883:5;11879:54;11868:65;;11858:81;;;:::o;11945:77::-;;12011:5;12000:16;;11990:32;;;:::o;12028:86::-;;12103:4;12096:5;12092:16;12081:27;;12071:43;;;:::o;12120:178::-;;12229:63;12286:5;12229:63;:::i;:::-;12216:76;;12206:92;;;:::o;12304:139::-;;12413:24;12431:5;12413:24;:::i;:::-;12400:37;;12390:53;;;:::o;12449:307::-;12517:1;12527:113;12541:6;12538:1;12535:13;12527:113;;;12626:1;12621:3;12617:11;12611:18;12607:1;12602:3;12598:11;12591:39;12563:2;12560:1;12556:10;12551:15;;12527:113;;;12658:6;12655:1;12652:13;12649:2;;;12738:1;12729:6;12724:3;12720:16;12713:27;12649:2;12498:258;;;;:::o;12762:320::-;;12843:1;12837:4;12833:12;12823:22;;12890:1;12884:4;12880:12;12911:18;12901:2;;12967:4;12959:6;12955:17;12945:27;;12901:2;13029;13021:6;13018:14;12998:18;12995:38;12992:2;;;13048:18;;:::i;:::-;12992:2;12813:269;;;;:::o;13088:180::-;13136:77;13133:1;13126:88;13233:4;13230:1;13223:15;13257:4;13254:1;13247:15;13274:180;13322:77;13319:1;13312:88;13419:4;13416:1;13409:15;13443:4;13440:1;13433:15;13460:102;;13552:2;13548:7;13543:2;13536:5;13532:14;13528:28;13518:38;;13508:54;;;:::o;13568:122::-;13641:24;13659:5;13641:24;:::i;:::-;13634:5;13631:35;13621:2;;13680:1;13677;13670:12;13621:2;13611:79;:::o;13696:122::-;13769:24;13787:5;13769:24;:::i;:::-;13762:5;13759:35;13749:2;;13808:1;13805;13798:12;13749:2;13739:79;:::o

Swarm Source

ipfs://26b78d70d47855f7dfb2c288bfe8e6f7c0c3aaa972f3f991f7b9600a1fdd8c65
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.