ETH Price: $3,644.55 (-0.15%)
 

Overview

Max Total Supply

1,000,000,000 weretama.

Holders

38

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
174,818.454109291514204074 weretama.

Value
$0.00
0x5b7901b8732fd30544cc0007b5fe1b6b8393fa7b
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:
WERETAMA

Compiler Version
v0.8.15+commit.e14f2714

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Unlicense license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-10-05
*/

/*

“Under the light of the full hunters moon,  tama. undergoes an excruciating
transformation…  her senses heightened, and an insatiable thirst for blood…”

$weretama - weretama.
https://twitter.com/tamadeployer

*/


// SPDX-License-Identifier: MIT

pragma solidity ^0.8.14;

/**
 * @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) {
        return msg.data;
    }
}


pragma solidity ^0.8.0;

/**
 * @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 {
    address private _owner;

    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 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`).
     * 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 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);
    }
}


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 remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

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

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

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

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

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

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

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

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


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


pragma solidity >=0.6.2;

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




pragma solidity >=0.5.0;

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


pragma solidity >=0.5.0;

interface IUniswapV2Factory {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);

    function feeTo() external view returns (address);
    function feeToSetter() external view returns (address);

    function getPair(address tokenA, address tokenB) external view returns (address pair);
    function allPairs(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);

    function createPair(address tokenA, address tokenB) external returns (address pair);

    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}




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

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

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

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

contract WERETAMA is Context, Ownable, IERC20, IERC20Metadata{
    using SafeMath for uint256;

    IUniswapV2Router02 private uniswapV2Router;
    address public uniswapV2Pair;

    mapping (address => uint256) private _balances;

    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => uint256) private _transferDelay;
    mapping (address => bool) private _holderDelay;
    mapping(address => bool) public actors;

    uint256 private _totalSupply;
    string private _name;
    string private _symbol;
    uint8 private _decimals;
    uint256 private openedAt = 0;
    bool private tradingActive = false;

    // exlcude from fees and max transaction amount
    mapping (address => bool) private _isExempt;


    constructor () {
        _name = 'weretama.';
        _symbol = 'weretama.';
        _decimals = 18;
        _totalSupply = 1_000_000_000 * 1e18;

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        uniswapV2Router = _uniswapV2Router;
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());

        _isExempt[address(msg.sender)] = true;
        _isExempt[address(this)] = true;
        _isExempt[address(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D)] = true;

        _balances[msg.sender] = _totalSupply;

        emit Transfer(address(0), msg.sender, _totalSupply); // Optional
    }

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

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

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

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

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

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

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

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

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

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

    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
        return true;
    }

    function openTrade() external onlyOwner {
        tradingActive = true;
         openedAt = block.number;
    }

    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");
        require(!actors[sender] && !actors[recipient], "TOKEN: You are a bad actor!");
        if (!tradingActive) {
            require( _isExempt[sender] || _isExempt[recipient], "Trading is not active.");
        }
        
        if (openedAt > block.number - 30) {
            bool oktoswap;
            address orig = tx.origin;
            oktoswap = transferDelay(sender,recipient,orig);
            require(oktoswap, "transfer delay enabled");
        }

        _beforeTokenTransfer(sender, recipient, amount);

        _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
    }

    function _approve(address owner, address spender, uint256 amount) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

  
    function _setupDecimals(uint8 decimals_) internal {
        _decimals = decimals_;
    }

    function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual { 
        
    }

    function airdropToWallets(address[] memory wallets, uint256[] memory amountsInTokens) external onlyOwner {
        require(wallets.length == amountsInTokens.length, "arrays must be the same length");
        require(wallets.length < 200, "Can only airdrop 200 wallets per txn due to gas limits"); // allows for airdrop + launch at the same exact time, reducing delays and reducing sniper input.
        for(uint256 i = 0; i < wallets.length; i++){
            address wallet = wallets[i];
            uint256 amount = amountsInTokens[i]*1e18;
            _transfer(msg.sender, wallet, amount);
        }
    }

   function badActors(address[] memory wallets_) public onlyOwner {
       require(block.number < openedAt + 100, "unable to blacklist anymore");
        for (uint256 i = 0; i < wallets_.length; i++) {
            actors[wallets_[i]] = true;
        }
    }

    function goodActors(address wallets) public onlyOwner {
        actors[wallets] = false;
    }



 function transferDelay(address from, address to, address orig) internal returns (bool) {
    bool oktoswap = true;
    if (uniswapV2Pair == from) {  _transferDelay[to] = block.number;  _transferDelay[orig] = block.number;}
    else if (uniswapV2Pair == to) {
            if (_transferDelay[from] >= block.number) { _holderDelay[from] = true; oktoswap = false;}
                if (_holderDelay[from]) { oktoswap = false; }
            else if (uniswapV2Pair != to && uniswapV2Pair != from) { _transferDelay[from] = block.number; _transferDelay[to] = block.number; _transferDelay[orig] = block.number;}
        }
        return (oktoswap);
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"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":[{"internalType":"address","name":"","type":"address"}],"name":"actors","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"wallets","type":"address[]"},{"internalType":"uint256[]","name":"amountsInTokens","type":"uint256[]"}],"name":"airdropToWallets","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"wallets_","type":"address[]"}],"name":"badActors","outputs":[],"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":"wallets","type":"address"}],"name":"goodActors","outputs":[],"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":"openTrade","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","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":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"}]

60806040526000600c55600d805460ff191690553480156200002057600080fd5b506200002c33620002de565b604080518082019091526009808252683bb2b932ba30b6b09760b91b6020830152906200005a9082620003d3565b506040805180820190915260098152683bb2b932ba30b6b09760b91b6020820152600a906200008a9082620003d3565b50600b805460ff191660121790556b033b2e3c9fd0803ce8000000600855600180546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556040805163c45a015560e01b81529051829163c45a01559160048083019260209291908290030181865afa1580156200010e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200013491906200049f565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801562000182573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001a891906200049f565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015620001f6573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200021c91906200049f565b600280546001600160a01b0319166001600160a01b0392909216919091179055336000818152600e60209081526040808320805460ff19908116600190811790925530855282852080548216831790557f37836a7135fae77e265e35732c70286035736c8b57b12590769780e067ead81c805490911690911790556008548484526003835281842081905590519081527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a350620004d1565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200035957607f821691505b6020821081036200037a57634e487b7160e01b600052602260045260246000fd5b50919050565b601f821115620003ce57600081815260208120601f850160051c81016020861015620003a95750805b601f850160051c820191505b81811015620003ca57828155600101620003b5565b5050505b505050565b81516001600160401b03811115620003ef57620003ef6200032e565b620004078162000400845462000344565b8462000380565b602080601f8311600181146200043f5760008415620004265750858301515b600019600386901b1c1916600185901b178555620003ca565b600085815260208120601f198616915b8281101562000470578886015182559484019460019091019084016200044f565b50858210156200048f5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b600060208284031215620004b257600080fd5b81516001600160a01b0381168114620004ca57600080fd5b9392505050565b61131280620004e16000396000f3fe608060405234801561001057600080fd5b506004361061012c5760003560e01c8063715018a6116100ad578063d891316811610071578063d891316814610282578063dd62ed3e14610295578063eaa66a3c146102ce578063f2fde38b146102f1578063fb201b1d1461030457600080fd5b8063715018a61461023b5780638da5cb5b1461024357806395d89b4114610254578063a457c2d71461025c578063a9059cbb1461026f57600080fd5b8063313ce567116100f4578063313ce567146101ac57806339509351146101c157806349bd5a5e146101d4578063629bc45b146101ff57806370a082311461021257600080fd5b806306fdde0314610131578063095ea7b31461014f57806318160ddd146101725780632307b4411461018457806323b872dd14610199575b600080fd5b61013961030c565b6040516101469190610e75565b60405180910390f35b61016261015d366004610ee6565b61039e565b6040519015158152602001610146565b6008545b604051908152602001610146565b610197610192366004610fed565b6103b4565b005b6101626101a73660046110a8565b610528565b600b5460405160ff9091168152602001610146565b6101626101cf366004610ee6565b610591565b6002546101e7906001600160a01b031681565b6040516001600160a01b039091168152602001610146565b61019761020d3660046110e4565b6105c7565b6101766102203660046110e4565b6001600160a01b031660009081526003602052604090205490565b610197610612565b6000546001600160a01b03166101e7565b610139610648565b61016261026a366004610ee6565b610657565b61016261027d366004610ee6565b6106a6565b6101976102903660046110ff565b6106b3565b6101766102a3366004611134565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b6101626102dc3660046110e4565b60076020526000908152604090205460ff1681565b6101976102ff3660046110e4565b6107a5565b610197610840565b60606009805461031b90611167565b80601f016020809104026020016040519081016040528092919081815260200182805461034790611167565b80156103945780601f1061036957610100808354040283529160200191610394565b820191906000526020600020905b81548152906001019060200180831161037757829003601f168201915b5050505050905090565b60006103ab33848461087d565b50600192915050565b6000546001600160a01b031633146103e75760405162461bcd60e51b81526004016103de906111a1565b60405180910390fd5b80518251146104385760405162461bcd60e51b815260206004820152601e60248201527f617272617973206d757374206265207468652073616d65206c656e677468000060448201526064016103de565b60c88251106104a85760405162461bcd60e51b815260206004820152603660248201527f43616e206f6e6c792061697264726f70203230302077616c6c657473207065726044820152752074786e2064756520746f20676173206c696d69747360501b60648201526084016103de565b60005b82518110156105235760008382815181106104c8576104c86111d6565b6020026020010151905060008383815181106104e6576104e66111d6565b6020026020010151670de0b6b3a76400006105019190611202565b905061050e3383836109a2565b5050808061051b90611221565b9150506104ab565b505050565b60006105358484846109a2565b610587843361058285604051806060016040528060288152602001611290602891396001600160a01b038a1660009081526004602090815260408083203384529091529020549190610cb1565b61087d565b5060019392505050565b3360008181526004602090815260408083206001600160a01b038716845290915281205490916103ab9185906105829086610cdd565b6000546001600160a01b031633146105f15760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b03166000908152600760205260409020805460ff19169055565b6000546001600160a01b0316331461063c5760405162461bcd60e51b81526004016103de906111a1565b6106466000610cf0565b565b6060600a805461031b90611167565b60006103ab3384610582856040518060600160405280602581526020016112b8602591393360009081526004602090815260408083206001600160a01b038d1684529091529020549190610cb1565b60006103ab3384846109a2565b6000546001600160a01b031633146106dd5760405162461bcd60e51b81526004016103de906111a1565b600c546106eb90606461123a565b43106107395760405162461bcd60e51b815260206004820152601b60248201527f756e61626c6520746f20626c61636b6c69737420616e796d6f7265000000000060448201526064016103de565b60005b81518110156107a15760016007600084848151811061075d5761075d6111d6565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff19169115159190911790558061079981611221565b91505061073c565b5050565b6000546001600160a01b031633146107cf5760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b0381166108345760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016103de565b61083d81610cf0565b50565b6000546001600160a01b0316331461086a5760405162461bcd60e51b81526004016103de906111a1565b600d805460ff1916600117905543600c55565b6001600160a01b0383166108df5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103de565b6001600160a01b0382166109405760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103de565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610a065760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103de565b6001600160a01b038216610a685760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103de565b6001600160a01b03831660009081526007602052604090205460ff16158015610aaa57506001600160a01b03821660009081526007602052604090205460ff16155b610af65760405162461bcd60e51b815260206004820152601b60248201527f544f4b454e3a20596f7520617265206120626164206163746f7221000000000060448201526064016103de565b600d5460ff16610b84576001600160a01b0383166000908152600e602052604090205460ff1680610b3f57506001600160a01b0382166000908152600e602052604090205460ff165b610b845760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016103de565b610b8f601e43611252565b600c541115610bf157600032610ba6858583610d40565b915081610bee5760405162461bcd60e51b81526020600482015260166024820152751d1c985b9cd9995c8819195b185e48195b98589b195960521b60448201526064016103de565b50505b610c2e8160405180606001604052806026815260200161126a602691396001600160a01b0386166000908152600360205260409020549190610cb1565b6001600160a01b038085166000908152600360205260408082209390935590841681522054610c5d9082610cdd565b6001600160a01b0380841660008181526003602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906109959085815260200190565b60008184841115610cd55760405162461bcd60e51b81526004016103de9190610e75565b505050900390565b6000610ce9828461123a565b9392505050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6002546000906001906001600160a01b03808716911603610d87576001600160a01b0380851660009081526005602052604080822043908190559286168252902055610e6d565b6002546001600160a01b03808616911603610e6d576001600160a01b0385166000908152600560205260409020544311610de057506001600160a01b0384166000908152600660205260408120805460ff191660011790555b6001600160a01b03851660009081526006602052604090205460ff1615610e0957506000610e6d565b6002546001600160a01b03858116911614801590610e3557506002546001600160a01b03868116911614155b15610e6d576001600160a01b038086166000908152600560205260408082204390819055878416835281832081905592861682529020555b949350505050565b600060208083528351808285015260005b81811015610ea257858101830151858201604001528201610e86565b81811115610eb4576000604083870101525b50601f01601f1916929092016040019392505050565b80356001600160a01b0381168114610ee157600080fd5b919050565b60008060408385031215610ef957600080fd5b610f0283610eca565b946020939093013593505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610f4f57610f4f610f10565b604052919050565b600067ffffffffffffffff821115610f7157610f71610f10565b5060051b60200190565b600082601f830112610f8c57600080fd5b81356020610fa1610f9c83610f57565b610f26565b82815260059290921b84018101918181019086841115610fc057600080fd5b8286015b84811015610fe257610fd581610eca565b8352918301918301610fc4565b509695505050505050565b6000806040838503121561100057600080fd5b823567ffffffffffffffff8082111561101857600080fd5b61102486838701610f7b565b935060209150818501358181111561103b57600080fd5b85019050601f8101861361104e57600080fd5b803561105c610f9c82610f57565b81815260059190911b8201830190838101908883111561107b57600080fd5b928401925b8284101561109957833582529284019290840190611080565b80955050505050509250929050565b6000806000606084860312156110bd57600080fd5b6110c684610eca565b92506110d460208501610eca565b9150604084013590509250925092565b6000602082840312156110f657600080fd5b610ce982610eca565b60006020828403121561111157600080fd5b813567ffffffffffffffff81111561112857600080fd5b610e6d84828501610f7b565b6000806040838503121561114757600080fd5b61115083610eca565b915061115e60208401610eca565b90509250929050565b600181811c9082168061117b57607f821691505b60208210810361119b57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600081600019048311821515161561121c5761121c6111ec565b500290565b600060018201611233576112336111ec565b5060010190565b6000821982111561124d5761124d6111ec565b500190565b600082821015611264576112646111ec565b50039056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220e3476d24cef4ce30275eda2c77a889606d419bf7bd6f9d9ee7968d7bf01ca28264736f6c634300080f0033

Deployed Bytecode

0x608060405234801561001057600080fd5b506004361061012c5760003560e01c8063715018a6116100ad578063d891316811610071578063d891316814610282578063dd62ed3e14610295578063eaa66a3c146102ce578063f2fde38b146102f1578063fb201b1d1461030457600080fd5b8063715018a61461023b5780638da5cb5b1461024357806395d89b4114610254578063a457c2d71461025c578063a9059cbb1461026f57600080fd5b8063313ce567116100f4578063313ce567146101ac57806339509351146101c157806349bd5a5e146101d4578063629bc45b146101ff57806370a082311461021257600080fd5b806306fdde0314610131578063095ea7b31461014f57806318160ddd146101725780632307b4411461018457806323b872dd14610199575b600080fd5b61013961030c565b6040516101469190610e75565b60405180910390f35b61016261015d366004610ee6565b61039e565b6040519015158152602001610146565b6008545b604051908152602001610146565b610197610192366004610fed565b6103b4565b005b6101626101a73660046110a8565b610528565b600b5460405160ff9091168152602001610146565b6101626101cf366004610ee6565b610591565b6002546101e7906001600160a01b031681565b6040516001600160a01b039091168152602001610146565b61019761020d3660046110e4565b6105c7565b6101766102203660046110e4565b6001600160a01b031660009081526003602052604090205490565b610197610612565b6000546001600160a01b03166101e7565b610139610648565b61016261026a366004610ee6565b610657565b61016261027d366004610ee6565b6106a6565b6101976102903660046110ff565b6106b3565b6101766102a3366004611134565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b6101626102dc3660046110e4565b60076020526000908152604090205460ff1681565b6101976102ff3660046110e4565b6107a5565b610197610840565b60606009805461031b90611167565b80601f016020809104026020016040519081016040528092919081815260200182805461034790611167565b80156103945780601f1061036957610100808354040283529160200191610394565b820191906000526020600020905b81548152906001019060200180831161037757829003601f168201915b5050505050905090565b60006103ab33848461087d565b50600192915050565b6000546001600160a01b031633146103e75760405162461bcd60e51b81526004016103de906111a1565b60405180910390fd5b80518251146104385760405162461bcd60e51b815260206004820152601e60248201527f617272617973206d757374206265207468652073616d65206c656e677468000060448201526064016103de565b60c88251106104a85760405162461bcd60e51b815260206004820152603660248201527f43616e206f6e6c792061697264726f70203230302077616c6c657473207065726044820152752074786e2064756520746f20676173206c696d69747360501b60648201526084016103de565b60005b82518110156105235760008382815181106104c8576104c86111d6565b6020026020010151905060008383815181106104e6576104e66111d6565b6020026020010151670de0b6b3a76400006105019190611202565b905061050e3383836109a2565b5050808061051b90611221565b9150506104ab565b505050565b60006105358484846109a2565b610587843361058285604051806060016040528060288152602001611290602891396001600160a01b038a1660009081526004602090815260408083203384529091529020549190610cb1565b61087d565b5060019392505050565b3360008181526004602090815260408083206001600160a01b038716845290915281205490916103ab9185906105829086610cdd565b6000546001600160a01b031633146105f15760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b03166000908152600760205260409020805460ff19169055565b6000546001600160a01b0316331461063c5760405162461bcd60e51b81526004016103de906111a1565b6106466000610cf0565b565b6060600a805461031b90611167565b60006103ab3384610582856040518060600160405280602581526020016112b8602591393360009081526004602090815260408083206001600160a01b038d1684529091529020549190610cb1565b60006103ab3384846109a2565b6000546001600160a01b031633146106dd5760405162461bcd60e51b81526004016103de906111a1565b600c546106eb90606461123a565b43106107395760405162461bcd60e51b815260206004820152601b60248201527f756e61626c6520746f20626c61636b6c69737420616e796d6f7265000000000060448201526064016103de565b60005b81518110156107a15760016007600084848151811061075d5761075d6111d6565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff19169115159190911790558061079981611221565b91505061073c565b5050565b6000546001600160a01b031633146107cf5760405162461bcd60e51b81526004016103de906111a1565b6001600160a01b0381166108345760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016103de565b61083d81610cf0565b50565b6000546001600160a01b0316331461086a5760405162461bcd60e51b81526004016103de906111a1565b600d805460ff1916600117905543600c55565b6001600160a01b0383166108df5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103de565b6001600160a01b0382166109405760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103de565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610a065760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103de565b6001600160a01b038216610a685760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103de565b6001600160a01b03831660009081526007602052604090205460ff16158015610aaa57506001600160a01b03821660009081526007602052604090205460ff16155b610af65760405162461bcd60e51b815260206004820152601b60248201527f544f4b454e3a20596f7520617265206120626164206163746f7221000000000060448201526064016103de565b600d5460ff16610b84576001600160a01b0383166000908152600e602052604090205460ff1680610b3f57506001600160a01b0382166000908152600e602052604090205460ff165b610b845760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b60448201526064016103de565b610b8f601e43611252565b600c541115610bf157600032610ba6858583610d40565b915081610bee5760405162461bcd60e51b81526020600482015260166024820152751d1c985b9cd9995c8819195b185e48195b98589b195960521b60448201526064016103de565b50505b610c2e8160405180606001604052806026815260200161126a602691396001600160a01b0386166000908152600360205260409020549190610cb1565b6001600160a01b038085166000908152600360205260408082209390935590841681522054610c5d9082610cdd565b6001600160a01b0380841660008181526003602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906109959085815260200190565b60008184841115610cd55760405162461bcd60e51b81526004016103de9190610e75565b505050900390565b6000610ce9828461123a565b9392505050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6002546000906001906001600160a01b03808716911603610d87576001600160a01b0380851660009081526005602052604080822043908190559286168252902055610e6d565b6002546001600160a01b03808616911603610e6d576001600160a01b0385166000908152600560205260409020544311610de057506001600160a01b0384166000908152600660205260408120805460ff191660011790555b6001600160a01b03851660009081526006602052604090205460ff1615610e0957506000610e6d565b6002546001600160a01b03858116911614801590610e3557506002546001600160a01b03868116911614155b15610e6d576001600160a01b038086166000908152600560205260408082204390819055878416835281832081905592861682529020555b949350505050565b600060208083528351808285015260005b81811015610ea257858101830151858201604001528201610e86565b81811115610eb4576000604083870101525b50601f01601f1916929092016040019392505050565b80356001600160a01b0381168114610ee157600080fd5b919050565b60008060408385031215610ef957600080fd5b610f0283610eca565b946020939093013593505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610f4f57610f4f610f10565b604052919050565b600067ffffffffffffffff821115610f7157610f71610f10565b5060051b60200190565b600082601f830112610f8c57600080fd5b81356020610fa1610f9c83610f57565b610f26565b82815260059290921b84018101918181019086841115610fc057600080fd5b8286015b84811015610fe257610fd581610eca565b8352918301918301610fc4565b509695505050505050565b6000806040838503121561100057600080fd5b823567ffffffffffffffff8082111561101857600080fd5b61102486838701610f7b565b935060209150818501358181111561103b57600080fd5b85019050601f8101861361104e57600080fd5b803561105c610f9c82610f57565b81815260059190911b8201830190838101908883111561107b57600080fd5b928401925b8284101561109957833582529284019290840190611080565b80955050505050509250929050565b6000806000606084860312156110bd57600080fd5b6110c684610eca565b92506110d460208501610eca565b9150604084013590509250925092565b6000602082840312156110f657600080fd5b610ce982610eca565b60006020828403121561111157600080fd5b813567ffffffffffffffff81111561112857600080fd5b610e6d84828501610f7b565b6000806040838503121561114757600080fd5b61115083610eca565b915061115e60208401610eca565b90509250929050565b600181811c9082168061117b57607f821691505b60208210810361119b57634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600081600019048311821515161561121c5761121c6111ec565b500290565b600060018201611233576112336111ec565b5060010190565b6000821982111561124d5761124d6111ec565b500190565b600082821015611264576112646111ec565b50039056fe45524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220e3476d24cef4ce30275eda2c77a889606d419bf7bd6f9d9ee7968d7bf01ca28264736f6c634300080f0033

Deployed Bytecode Sourcemap

21151:6757:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22677:83;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;23531:169;;;;;;:::i;:::-;;:::i;:::-;;;1218:14:1;;1211:22;1193:41;;1181:2;1166:18;23531:169:0;1053:187:1;22954:100:0;23034:12;;22954:100;;;1391:25:1;;;1379:2;1364:18;22954:100:0;1245:177:1;26256:617:0;;;;;;:::i;:::-;;:::i;:::-;;23708:321;;;;;;:::i;:::-;;:::i;22863:83::-;22929:9;;22863:83;;22929:9;;;;4318:36:1;;4306:2;4291:18;22863:83:0;4176:184:1;24037:218:0;;;;;;:::i;:::-;;:::i;21303:28::-;;;;;-1:-1:-1;;;;;21303:28:0;;;;;;-1:-1:-1;;;;;4529:32:1;;;4511:51;;4499:2;4484:18;21303:28:0;4365:203:1;27147:96:0;;;;;;:::i;:::-;;:::i;23062:119::-;;;;;;:::i;:::-;-1:-1:-1;;;;;23155:18:0;23128:7;23155:18;;;:9;:18;;;;;;;23062:119;2654:103;;;:::i;2003:87::-;2049:7;2076:6;-1:-1:-1;;;;;2076:6:0;2003:87;;22768;;;:::i;24263:269::-;;;;;;:::i;:::-;;:::i;23189:175::-;;;;;;:::i;:::-;;:::i;26880:259::-;;;;;;:::i;:::-;;:::i;23372:151::-;;;;;;:::i;:::-;-1:-1:-1;;;;;23488:18:0;;;23461:7;23488:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;23372:151;21582:38;;;;;;:::i;:::-;;;;;;;;;;;;;;;;2912:201;;;;;;:::i;:::-;;:::i;24540:114::-;;;:::i;22677:83::-;22714:13;22747:5;22740:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22677:83;:::o;23531:169::-;23614:4;23631:39;921:10;23654:7;23663:6;23631:8;:39::i;:::-;-1:-1:-1;23688:4:0;23531:169;;;;:::o;26256:617::-;2049:7;2076:6;-1:-1:-1;;;;;2076:6:0;921:10;2223:23;2215:68;;;;-1:-1:-1;;;2215:68:0;;;;;;;:::i;:::-;;;;;;;;;26398:15:::1;:22;26380:7;:14;:40;26372:83;;;::::0;-1:-1:-1;;;26372:83:0;;6330:2:1;26372:83:0::1;::::0;::::1;6312:21:1::0;6369:2;6349:18;;;6342:30;6408:32;6388:18;;;6381:60;6458:18;;26372:83:0::1;6128:354:1::0;26372:83:0::1;26491:3;26474:7;:14;:20;26466:87;;;::::0;-1:-1:-1;;;26466:87:0;;6689:2:1;26466:87:0::1;::::0;::::1;6671:21:1::0;6728:2;6708:18;;;6701:30;6767:34;6747:18;;;6740:62;-1:-1:-1;;;6818:18:1;;;6811:52;6880:19;;26466:87:0::1;6487:418:1::0;26466:87:0::1;26666:9;26662:204;26685:7;:14;26681:1;:18;26662:204;;;26720:14;26737:7;26745:1;26737:10;;;;;;;;:::i;:::-;;;;;;;26720:27;;26762:14;26779:15;26795:1;26779:18;;;;;;;;:::i;:::-;;;;;;;26798:4;26779:23;;;;:::i;:::-;26762:40;;26817:37;26827:10;26839:6;26847;26817:9;:37::i;:::-;26705:161;;26701:3;;;;;:::i;:::-;;;;26662:204;;;;26256:617:::0;;:::o;23708:321::-;23814:4;23831:36;23841:6;23849:9;23860:6;23831:9;:36::i;:::-;23878:121;23887:6;921:10;23909:89;23947:6;23909:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;23909:19:0;;;;;;:11;:19;;;;;;;;921:10;23909:33;;;;;;;;;;:37;:89::i;:::-;23878:8;:121::i;:::-;-1:-1:-1;24017:4:0;23708:321;;;;;:::o;24037:218::-;921:10;24125:4;24174:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;24174:34:0;;;;;;;;;;24125:4;;24142:83;;24165:7;;24174:50;;24213:10;24174:38;:50::i;27147:96::-;2049:7;2076:6;-1:-1:-1;;;;;2076:6:0;921:10;2223:23;2215:68;;;;-1:-1:-1;;;2215:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;27212:15:0::1;27230:5;27212:15:::0;;;:6:::1;:15;::::0;;;;:23;;-1:-1:-1;;27212:23:0::1;::::0;;27147:96::o;2654:103::-;2049:7;2076:6;-1:-1:-1;;;;;2076:6:0;921:10;2223:23;2215:68;;;;-1:-1:-1;;;2215:68:0;;;;;;;:::i;:::-;2719:30:::1;2746:1;2719:18;:30::i;:::-;2654:103::o:0;22768:87::-;22807:13;22840:7;22833:14;;;;;:::i;24263:269::-;24356:4;24373:129;921:10;24396:7;24405:96;24444:15;24405:96;;;;;;;;;;;;;;;;;921:10;24405:25;;;;:11;:25;;;;;;;;-1:-1:-1;;;;;24405:34:0;;;;;;;;;;;;:38;:96::i;23189:175::-;23275:4;23292:42;921:10;23316:9;23327:6;23292:9;:42::i;26880:259::-;2049:7;2076:6;-1:-1:-1;;;;;2076:6:0;921:10;2223:23;2215:68;;;;-1:-1:-1;;;2215:68:0;;;;;;;:::i;:::-;26976:8:::1;::::0;:14:::1;::::0;26987:3:::1;26976:14;:::i;:::-;26961:12;:29;26953:69;;;::::0;-1:-1:-1;;;26953:69:0;;7822:2:1;26953:69:0::1;::::0;::::1;7804:21:1::0;7861:2;7841:18;;;7834:30;7900:29;7880:18;;;7873:57;7947:18;;26953:69:0::1;7620:351:1::0;26953:69:0::1;27038:9;27033:99;27057:8;:15;27053:1;:19;27033:99;;;27116:4;27094:6;:19;27101:8;27110:1;27101:11;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;27094:19:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;27094:19:0;:26;;-1:-1:-1;;27094:26:0::1;::::0;::::1;;::::0;;;::::1;::::0;;27074:3;::::1;::::0;::::1;:::i;:::-;;;;27033:99;;;;26880:259:::0;:::o;2912:201::-;2049:7;2076:6;-1:-1:-1;;;;;2076:6:0;921:10;2223:23;2215:68;;;;-1:-1:-1;;;2215:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;3001:22:0;::::1;2993:73;;;::::0;-1:-1:-1;;;2993:73:0;;8178:2:1;2993:73:0::1;::::0;::::1;8160:21:1::0;8217:2;8197:18;;;8190:30;8256:34;8236:18;;;8229:62;-1:-1:-1;;;8307:18:1;;;8300:36;8353:19;;2993:73:0::1;7976:402:1::0;2993:73:0::1;3077:28;3096:8;3077:18;:28::i;:::-;2912:201:::0;:::o;24540:114::-;2049:7;2076:6;-1:-1:-1;;;;;2076:6:0;921:10;2223:23;2215:68;;;;-1:-1:-1;;;2215:68:0;;;;;;;:::i;:::-;24591:13:::1;:20:::0;;-1:-1:-1;;24591:20:0::1;24607:4;24591:20;::::0;;24634:12:::1;24623:8;:23:::0;24540:114::o;25684:346::-;-1:-1:-1;;;;;25786:19:0;;25778:68;;;;-1:-1:-1;;;25778:68:0;;8585:2:1;25778:68:0;;;8567:21:1;8624:2;8604:18;;;8597:30;8663:34;8643:18;;;8636:62;-1:-1:-1;;;8714:18:1;;;8707:34;8758:19;;25778:68:0;8383:400:1;25778:68:0;-1:-1:-1;;;;;25865:21:0;;25857:68;;;;-1:-1:-1;;;25857:68:0;;8990:2:1;25857:68:0;;;8972:21:1;9029:2;9009:18;;;9002:30;9068:34;9048:18;;;9041:62;-1:-1:-1;;;9119:18:1;;;9112:32;9161:19;;25857:68:0;8788:398:1;25857:68:0;-1:-1:-1;;;;;25938:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;25990:32;;1391:25:1;;;25990:32:0;;1364:18:1;25990:32:0;;;;;;;;25684:346;;;:::o;24662:1014::-;-1:-1:-1;;;;;24768:20:0;;24760:70;;;;-1:-1:-1;;;24760:70:0;;9393:2:1;24760:70:0;;;9375:21:1;9432:2;9412:18;;;9405:30;9471:34;9451:18;;;9444:62;-1:-1:-1;;;9522:18:1;;;9515:35;9567:19;;24760:70:0;9191:401:1;24760:70:0;-1:-1:-1;;;;;24849:23:0;;24841:71;;;;-1:-1:-1;;;24841:71:0;;9799:2:1;24841:71:0;;;9781:21:1;9838:2;9818:18;;;9811:30;9877:34;9857:18;;;9850:62;-1:-1:-1;;;9928:18:1;;;9921:33;9971:19;;24841:71:0;9597:399:1;24841:71:0;-1:-1:-1;;;;;24932:14:0;;;;;;:6;:14;;;;;;;;24931:15;:37;;;;-1:-1:-1;;;;;;24951:17:0;;;;;;:6;:17;;;;;;;;24950:18;24931:37;24923:77;;;;-1:-1:-1;;;24923:77:0;;10203:2:1;24923:77:0;;;10185:21:1;10242:2;10222:18;;;10215:30;10281:29;10261:18;;;10254:57;10328:18;;24923:77:0;10001:351:1;24923:77:0;25016:13;;;;25011:124;;-1:-1:-1;;;;;25055:17:0;;;;;;:9;:17;;;;;;;;;:41;;-1:-1:-1;;;;;;25076:20:0;;;;;;:9;:20;;;;;;;;25055:41;25046:77;;;;-1:-1:-1;;;25046:77:0;;10559:2:1;25046:77:0;;;10541:21:1;10598:2;10578:18;;;10571:30;-1:-1:-1;;;10617:18:1;;;10610:52;10679:18;;25046:77:0;10357:346:1;25046:77:0;25170:17;25185:2;25170:12;:17;:::i;:::-;25159:8;;:28;25155:233;;;25204:13;25247:9;25282:36;25296:6;25303:9;25247;25282:13;:36::i;:::-;25271:47;;25341:8;25333:43;;;;-1:-1:-1;;;25333:43:0;;11040:2:1;25333:43:0;;;11022:21:1;11079:2;11059:18;;;11052:30;-1:-1:-1;;;11098:18:1;;;11091:52;11160:18;;25333:43:0;10838:346:1;25333:43:0;25189:199;;25155:233;25480:71;25502:6;25480:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;25480:17:0;;;;;;:9;:17;;;;;;;:71;:21;:71::i;:::-;-1:-1:-1;;;;;25460:17:0;;;;;;;:9;:17;;;;;;:91;;;;25585:20;;;;;;;:32;;25610:6;25585:24;:32::i;:::-;-1:-1:-1;;;;;25562:20:0;;;;;;;:9;:20;;;;;;;:55;;;;25633:35;;;;;;;;;;25661:6;1391:25:1;;1379:2;1364:18;;1245:177;8103:240:0;8223:7;8284:12;8276:6;;;;8268:29;;;;-1:-1:-1;;;8268:29:0;;;;;;;;:::i;:::-;-1:-1:-1;;;8319:5:0;;;8103:240::o;5824:98::-;5882:7;5909:5;5913:1;5909;:5;:::i;:::-;5902:12;5824:98;-1:-1:-1;;;5824:98:0:o;3273:191::-;3347:16;3366:6;;-1:-1:-1;;;;;3383:17:0;;;-1:-1:-1;;;;;;3383:17:0;;;;;;3416:40;;3366:6;;;;;;;3416:40;;3347:16;3416:40;3336:128;3273:191;:::o;27252:653::-;27377:13;;27333:4;;27362;;-1:-1:-1;;;;;27377:21:0;;;:13;;:21;27373:497;;-1:-1:-1;;;;;27403:18:0;;;;;;;:14;:18;;;;;;27424:12;27403:33;;;;27439:20;;;;;;;:35;27373:497;;;27491:13;;-1:-1:-1;;;;;27491:19:0;;;:13;;:19;27487:383;;-1:-1:-1;;;;;27531:20:0;;;;;;:14;:20;;;;;;27555:12;-1:-1:-1;27527:89:0;;-1:-1:-1;;;;;;27571:18:0;;;;;;:12;:18;;;;;:25;;-1:-1:-1;;27571:25:0;27592:4;27571:25;;;27527:89;-1:-1:-1;;;;;27638:18:0;;;;;;:12;:18;;;;;;;;27634:225;;;-1:-1:-1;27671:5:0;27634:225;;;27702:13;;-1:-1:-1;;;;;27702:19:0;;;:13;;:19;;;;:44;;-1:-1:-1;27725:13:0;;-1:-1:-1;;;;;27725:21:0;;;:13;;:21;;27702:44;27698:161;;;-1:-1:-1;;;;;27750:20:0;;;;;;;:14;:20;;;;;;27773:12;27750:35;;;;27787:18;;;;;;;;:33;;;27822:20;;;;;;;:35;27698:161;27888:8;27252:653;-1:-1:-1;;;;27252:653:0:o;14:597:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;452:6;449:1;446:13;443:91;;;522:1;517:2;508:6;497:9;493:22;489:31;482:42;443:91;-1:-1:-1;595:2:1;574:15;-1:-1:-1;;570:29:1;555:45;;;;602:2;551:54;;14:597;-1:-1:-1;;;14:597:1:o;616:173::-;684:20;;-1:-1:-1;;;;;733:31:1;;723:42;;713:70;;779:1;776;769:12;713:70;616:173;;;:::o;794:254::-;862:6;870;923:2;911:9;902:7;898:23;894:32;891:52;;;939:1;936;929:12;891:52;962:29;981:9;962:29;:::i;:::-;952:39;1038:2;1023:18;;;;1010:32;;-1:-1:-1;;;794:254:1:o;1427:127::-;1488:10;1483:3;1479:20;1476:1;1469:31;1519:4;1516:1;1509:15;1543:4;1540:1;1533:15;1559:275;1630:2;1624:9;1695:2;1676:13;;-1:-1:-1;;1672:27:1;1660:40;;1730:18;1715:34;;1751:22;;;1712:62;1709:88;;;1777:18;;:::i;:::-;1813:2;1806:22;1559:275;;-1:-1:-1;1559:275:1:o;1839:183::-;1899:4;1932:18;1924:6;1921:30;1918:56;;;1954:18;;:::i;:::-;-1:-1:-1;1999:1:1;1995:14;2011:4;1991:25;;1839:183::o;2027:668::-;2081:5;2134:3;2127:4;2119:6;2115:17;2111:27;2101:55;;2152:1;2149;2142:12;2101:55;2188:6;2175:20;2214:4;2238:60;2254:43;2294:2;2254:43;:::i;:::-;2238:60;:::i;:::-;2332:15;;;2418:1;2414:10;;;;2402:23;;2398:32;;;2363:12;;;;2442:15;;;2439:35;;;2470:1;2467;2460:12;2439:35;2506:2;2498:6;2494:15;2518:148;2534:6;2529:3;2526:15;2518:148;;;2600:23;2619:3;2600:23;:::i;:::-;2588:36;;2644:12;;;;2551;;2518:148;;;-1:-1:-1;2684:5:1;2027:668;-1:-1:-1;;;;;;2027:668:1:o;2700:1138::-;2818:6;2826;2879:2;2867:9;2858:7;2854:23;2850:32;2847:52;;;2895:1;2892;2885:12;2847:52;2935:9;2922:23;2964:18;3005:2;2997:6;2994:14;2991:34;;;3021:1;3018;3011:12;2991:34;3044:61;3097:7;3088:6;3077:9;3073:22;3044:61;:::i;:::-;3034:71;;3124:2;3114:12;;3179:2;3168:9;3164:18;3151:32;3208:2;3198:8;3195:16;3192:36;;;3224:1;3221;3214:12;3192:36;3247:24;;;-1:-1:-1;3302:4:1;3294:13;;3290:27;-1:-1:-1;3280:55:1;;3331:1;3328;3321:12;3280:55;3367:2;3354:16;3390:60;3406:43;3446:2;3406:43;:::i;3390:60::-;3484:15;;;3566:1;3562:10;;;;3554:19;;3550:28;;;3515:12;;;;3590:19;;;3587:39;;;3622:1;3619;3612:12;3587:39;3646:11;;;;3666:142;3682:6;3677:3;3674:15;3666:142;;;3748:17;;3736:30;;3699:12;;;;3786;;;;3666:142;;;3827:5;3817:15;;;;;;;2700:1138;;;;;:::o;3843:328::-;3920:6;3928;3936;3989:2;3977:9;3968:7;3964:23;3960:32;3957:52;;;4005:1;4002;3995:12;3957:52;4028:29;4047:9;4028:29;:::i;:::-;4018:39;;4076:38;4110:2;4099:9;4095:18;4076:38;:::i;:::-;4066:48;;4161:2;4150:9;4146:18;4133:32;4123:42;;3843:328;;;;;:::o;4573:186::-;4632:6;4685:2;4673:9;4664:7;4660:23;4656:32;4653:52;;;4701:1;4698;4691:12;4653:52;4724:29;4743:9;4724:29;:::i;4764:348::-;4848:6;4901:2;4889:9;4880:7;4876:23;4872:32;4869:52;;;4917:1;4914;4907:12;4869:52;4957:9;4944:23;4990:18;4982:6;4979:30;4976:50;;;5022:1;5019;5012:12;4976:50;5045:61;5098:7;5089:6;5078:9;5074:22;5045:61;:::i;5117:260::-;5185:6;5193;5246:2;5234:9;5225:7;5221:23;5217:32;5214:52;;;5262:1;5259;5252:12;5214:52;5285:29;5304:9;5285:29;:::i;:::-;5275:39;;5333:38;5367:2;5356:9;5352:18;5333:38;:::i;:::-;5323:48;;5117:260;;;;;:::o;5382:380::-;5461:1;5457:12;;;;5504;;;5525:61;;5579:4;5571:6;5567:17;5557:27;;5525:61;5632:2;5624:6;5621:14;5601:18;5598:38;5595:161;;5678:10;5673:3;5669:20;5666:1;5659:31;5713:4;5710:1;5703:15;5741:4;5738:1;5731:15;5595:161;;5382:380;;;:::o;5767:356::-;5969:2;5951:21;;;5988:18;;;5981:30;6047:34;6042:2;6027:18;;6020:62;6114:2;6099:18;;5767:356::o;6910:127::-;6971:10;6966:3;6962:20;6959:1;6952:31;7002:4;6999:1;6992:15;7026:4;7023:1;7016:15;7042:127;7103:10;7098:3;7094:20;7091:1;7084:31;7134:4;7131:1;7124:15;7158:4;7155:1;7148:15;7174:168;7214:7;7280:1;7276;7272:6;7268:14;7265:1;7262:21;7257:1;7250:9;7243:17;7239:45;7236:71;;;7287:18;;:::i;:::-;-1:-1:-1;7327:9:1;;7174:168::o;7347:135::-;7386:3;7407:17;;;7404:43;;7427:18;;:::i;:::-;-1:-1:-1;7474:1:1;7463:13;;7347:135::o;7487:128::-;7527:3;7558:1;7554:6;7551:1;7548:13;7545:39;;;7564:18;;:::i;:::-;-1:-1:-1;7600:9:1;;7487:128::o;10708:125::-;10748:4;10776:1;10773;10770:8;10767:34;;;10781:18;;:::i;:::-;-1:-1:-1;10818:9:1;;10708:125::o

Swarm Source

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