ETH Price: $3,424.39 (+3.89%)

Token

DivergenceProtocol (DIVER)
 

Overview

Max Total Supply

1,000,000,000 DIVER

Holders

7,777 (0.00%)

Market

Price

$0.01 @ 0.000003 ETH (+0.23%)

Onchain Market Cap

$10,447,160.00

Circulating Supply Market Cap

$6,871,781.00

Other Info

Token Contract (WITH 18 Decimals)

Balance
0.263615711511584283 DIVER

Value
$0.00 ( ~0 Eth) [0.0000%]
0xb217967c62e1d5d7ccc080db90b78378a1081389
Loading...
Loading
Loading...
Loading
Loading...
Loading

OVERVIEW

A platform for on-chain composable crypto options.

Market

Volume (24H):$156,367.00
Market Capitalization:$6,871,781.00
Circulating Supply:660,000,000.00 DIVER
Market Data Source: Coinmarketcap

# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
Diver

Compiler Version
v0.8.5+commit.a4f2e591

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license
/**
 *Submitted for verification at Etherscan.io on 2021-09-13
*/

// Sources flattened with hardhat v2.2.1 https://hardhat.org

// File @openzeppelin/contracts/token/ERC20/[email protected]

// SPDX-License-Identifier: MIT

pragma solidity ^0.8.0;

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

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

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

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

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

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

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

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


// File @openzeppelin/contracts/token/ERC20/extensions/[email protected]

// SPD-License-Identifier: MIT

pragma solidity ^0.8.0;

/**
 * @dev Interface for the optional metadata functions from the ERC20 standard.
 *
 * _Available since v4.1._
 */
interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

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

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


// File @openzeppelin/contracts/utils/[email protected]

// SPD-License-Identifier: MIT

pragma solidity ^0.8.0;

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

    function _msgData() internal view virtual returns (bytes calldata) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}


// File @openzeppelin/contracts/token/ERC20/[email protected]

// SPD-License-Identifier: MIT

pragma solidity ^0.8.0;



/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 * For a generic mechanism see {ERC20PresetMinterPauser}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin guidelines: functions revert instead
 * of returning `false` on failure. This behavior is nonetheless conventional
 * and does not conflict with the expectations of ERC20 applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 *
 * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
 * functions have been added to mitigate the well-known issues around setting
 * allowances. See {IERC20-approve}.
 */
contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping (address => uint256) private _balances;

    mapping (address => mapping (address => uint256)) private _allowances;

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

        return true;
    }

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

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

        return true;
    }

    /**
     * @dev Moves tokens `amount` from `sender` to `recipient`.
     *
     * This is internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(address sender, address recipient, uint256 amount) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

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

        emit Transfer(sender, recipient, amount);
    }

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

        _beforeTokenTransfer(address(0), account, amount);

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

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

        _beforeTokenTransfer(account, address(0), amount);

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

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

    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    function _approve(address owner, address spender, uint256 amount) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

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

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


// File @openzeppelin/contracts/token/ERC20/extensions/[email protected]

// SPD-License-Identifier: MIT

pragma solidity ^0.8.0;


/**
 * @dev Extension of {ERC20} that allows token holders to destroy both their own
 * tokens and those that they have an allowance for, in a way that can be
 * recognized off-chain (via event analysis).
 */
abstract contract ERC20Burnable is Context, ERC20 {
    /**
     * @dev Destroys `amount` tokens from the caller.
     *
     * See {ERC20-_burn}.
     */
    function burn(uint256 amount) public virtual {
        _burn(_msgSender(), amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, deducting from the caller's
     * allowance.
     *
     * See {ERC20-_burn} and {ERC20-allowance}.
     *
     * Requirements:
     *
     * - the caller must have allowance for ``accounts``'s tokens of at least
     * `amount`.
     */
    function burnFrom(address account, uint256 amount) public virtual {
        uint256 currentAllowance = allowance(account, _msgSender());
        require(currentAllowance >= amount, "ERC20: burn amount exceeds allowance");
        _approve(account, _msgSender(), currentAllowance - amount);
        _burn(account, amount);
    }
}


// File contracts/token/Diver.sol

// SPD-License-Identifier: MIT

pragma solidity ^0.8.0;

contract Diver is ERC20Burnable {
    constructor() ERC20("DivergenceProtocol", "DIVER") {
        _mint(msg.sender, 1000000000e18);
    }

    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        super._beforeTokenTransfer(from, to, amount);
        require(to != address(this), "Diver::address to is token contract");
    }
}

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"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burnFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"}]

60806040523480156200001157600080fd5b506040805180820182526012815271111a5d995c99d95b98d9541c9bdd1bd8dbdb60721b6020808301918252835180850190945260058452642224ab22a960d91b908401528151919291620000699160039162000221565b5080516200007f90600490602084019062000221565b505050620000a0336b033b2e3c9fd0803ce8000000620000a660201b60201c565b6200032b565b6001600160a01b038216620001025760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064015b60405180910390fd5b62000110600083836200019d565b8060026000828254620001249190620002c7565b90915550506001600160a01b0382166000908152602081905260408120805483929062000153908490620002c7565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b620001b58383836200021c60201b620004391760201c565b6001600160a01b0382163014156200021c5760405162461bcd60e51b815260206004820152602360248201527f44697665723a3a6164647265737320746f20697320746f6b656e20636f6e74726044820152621858dd60ea1b6064820152608401620000f9565b505050565b8280546200022f90620002ee565b90600052602060002090601f0160209004810192826200025357600085556200029e565b82601f106200026e57805160ff19168380011785556200029e565b828001600101855582156200029e579182015b828111156200029e57825182559160200191906001019062000281565b50620002ac929150620002b0565b5090565b5b80821115620002ac5760008155600101620002b1565b60008219821115620002e957634e487b7160e01b600052601160045260246000fd5b500190565b600181811c908216806200030357607f821691505b602082108114156200032557634e487b7160e01b600052602260045260246000fd5b50919050565b610bb8806200033b6000396000f3fe608060405234801561001057600080fd5b50600436106100cf5760003560e01c806342966c681161008c57806395d89b411161006657806395d89b41146101ad578063a457c2d7146101b5578063a9059cbb146101c8578063dd62ed3e146101db57600080fd5b806342966c681461015c57806370a082311461017157806379cc67901461019a57600080fd5b806306fdde03146100d4578063095ea7b3146100f257806318160ddd1461011557806323b872dd14610127578063313ce5671461013a5780633950935114610149575b600080fd5b6100dc610214565b6040516100e99190610aad565b60405180910390f35b610105610100366004610a6a565b6102a6565b60405190151581526020016100e9565b6002545b6040519081526020016100e9565b610105610135366004610a2e565b6102bc565b604051601281526020016100e9565b610105610157366004610a6a565b610372565b61016f61016a366004610a94565b6103a9565b005b61011961017f3660046109d9565b6001600160a01b031660009081526020819052604090205490565b61016f6101a8366004610a6a565b6103b6565b6100dc61043e565b6101056101c3366004610a6a565b61044d565b6101056101d6366004610a6a565b6104e8565b6101196101e93660046109fb565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b60606003805461022390610b31565b80601f016020809104026020016040519081016040528092919081815260200182805461024f90610b31565b801561029c5780601f106102715761010080835404028352916020019161029c565b820191906000526020600020905b81548152906001019060200180831161027f57829003601f168201915b5050505050905090565b60006102b33384846104f5565b50600192915050565b60006102c984848461061a565b6001600160a01b0384166000908152600160209081526040808320338452909152902054828110156103535760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b61036785336103628685610b1a565b6104f5565b506001949350505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916102b3918590610362908690610b02565b6103b333826107fd565b50565b60006103c283336101e9565b9050818110156104205760405162461bcd60e51b8152602060048201526024808201527f45524332303a206275726e20616d6f756e74206578636565647320616c6c6f77604482015263616e636560e01b606482015260840161034a565b61042f83336103628585610b1a565b61043983836107fd565b505050565b60606004805461022390610b31565b3360009081526001602090815260408083206001600160a01b0386168452909152812054828110156104cf5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b606482015260840161034a565b6104de33856103628685610b1a565b5060019392505050565b60006102b333848461061a565b6001600160a01b0383166105575760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161034a565b6001600160a01b0382166105b85760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161034a565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661067e5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161034a565b6001600160a01b0382166106e05760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161034a565b6106eb838383610958565b6001600160a01b038316600090815260208190526040902054818110156107635760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b606482015260840161034a565b61076d8282610b1a565b6001600160a01b0380861660009081526020819052604080822093909355908516815290812080548492906107a3908490610b02565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516107ef91815260200190565b60405180910390a350505050565b6001600160a01b03821661085d5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b606482015260840161034a565b61086982600083610958565b6001600160a01b038216600090815260208190526040902054818110156108dd5760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b606482015260840161034a565b6108e78282610b1a565b6001600160a01b03841660009081526020819052604081209190915560028054849290610915908490610b1a565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200161060d565b6001600160a01b0382163014156104395760405162461bcd60e51b815260206004820152602360248201527f44697665723a3a6164647265737320746f20697320746f6b656e20636f6e74726044820152621858dd60ea1b606482015260840161034a565b80356001600160a01b03811681146109d457600080fd5b919050565b6000602082840312156109eb57600080fd5b6109f4826109bd565b9392505050565b60008060408385031215610a0e57600080fd5b610a17836109bd565b9150610a25602084016109bd565b90509250929050565b600080600060608486031215610a4357600080fd5b610a4c846109bd565b9250610a5a602085016109bd565b9150604084013590509250925092565b60008060408385031215610a7d57600080fd5b610a86836109bd565b946020939093013593505050565b600060208284031215610aa657600080fd5b5035919050565b600060208083528351808285015260005b81811015610ada57858101830151858201604001528201610abe565b81811115610aec576000604083870101525b50601f01601f1916929092016040019392505050565b60008219821115610b1557610b15610b6c565b500190565b600082821015610b2c57610b2c610b6c565b500390565b600181811c90821680610b4557607f821691505b60208210811415610b6657634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fdfea2646970667358221220c7aae552dbfed06950f622ed0fbaf6c3ef30b4b4ba8e987193ecd95827cc453264736f6c63430008050033

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106100cf5760003560e01c806342966c681161008c57806395d89b411161006657806395d89b41146101ad578063a457c2d7146101b5578063a9059cbb146101c8578063dd62ed3e146101db57600080fd5b806342966c681461015c57806370a082311461017157806379cc67901461019a57600080fd5b806306fdde03146100d4578063095ea7b3146100f257806318160ddd1461011557806323b872dd14610127578063313ce5671461013a5780633950935114610149575b600080fd5b6100dc610214565b6040516100e99190610aad565b60405180910390f35b610105610100366004610a6a565b6102a6565b60405190151581526020016100e9565b6002545b6040519081526020016100e9565b610105610135366004610a2e565b6102bc565b604051601281526020016100e9565b610105610157366004610a6a565b610372565b61016f61016a366004610a94565b6103a9565b005b61011961017f3660046109d9565b6001600160a01b031660009081526020819052604090205490565b61016f6101a8366004610a6a565b6103b6565b6100dc61043e565b6101056101c3366004610a6a565b61044d565b6101056101d6366004610a6a565b6104e8565b6101196101e93660046109fb565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b60606003805461022390610b31565b80601f016020809104026020016040519081016040528092919081815260200182805461024f90610b31565b801561029c5780601f106102715761010080835404028352916020019161029c565b820191906000526020600020905b81548152906001019060200180831161027f57829003601f168201915b5050505050905090565b60006102b33384846104f5565b50600192915050565b60006102c984848461061a565b6001600160a01b0384166000908152600160209081526040808320338452909152902054828110156103535760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b61036785336103628685610b1a565b6104f5565b506001949350505050565b3360008181526001602090815260408083206001600160a01b038716845290915281205490916102b3918590610362908690610b02565b6103b333826107fd565b50565b60006103c283336101e9565b9050818110156104205760405162461bcd60e51b8152602060048201526024808201527f45524332303a206275726e20616d6f756e74206578636565647320616c6c6f77604482015263616e636560e01b606482015260840161034a565b61042f83336103628585610b1a565b61043983836107fd565b505050565b60606004805461022390610b31565b3360009081526001602090815260408083206001600160a01b0386168452909152812054828110156104cf5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b606482015260840161034a565b6104de33856103628685610b1a565b5060019392505050565b60006102b333848461061a565b6001600160a01b0383166105575760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161034a565b6001600160a01b0382166105b85760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161034a565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661067e5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161034a565b6001600160a01b0382166106e05760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161034a565b6106eb838383610958565b6001600160a01b038316600090815260208190526040902054818110156107635760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b606482015260840161034a565b61076d8282610b1a565b6001600160a01b0380861660009081526020819052604080822093909355908516815290812080548492906107a3908490610b02565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516107ef91815260200190565b60405180910390a350505050565b6001600160a01b03821661085d5760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b606482015260840161034a565b61086982600083610958565b6001600160a01b038216600090815260208190526040902054818110156108dd5760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b606482015260840161034a565b6108e78282610b1a565b6001600160a01b03841660009081526020819052604081209190915560028054849290610915908490610b1a565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200161060d565b6001600160a01b0382163014156104395760405162461bcd60e51b815260206004820152602360248201527f44697665723a3a6164647265737320746f20697320746f6b656e20636f6e74726044820152621858dd60ea1b606482015260840161034a565b80356001600160a01b03811681146109d457600080fd5b919050565b6000602082840312156109eb57600080fd5b6109f4826109bd565b9392505050565b60008060408385031215610a0e57600080fd5b610a17836109bd565b9150610a25602084016109bd565b90509250929050565b600080600060608486031215610a4357600080fd5b610a4c846109bd565b9250610a5a602085016109bd565b9150604084013590509250925092565b60008060408385031215610a7d57600080fd5b610a86836109bd565b946020939093013593505050565b600060208284031215610aa657600080fd5b5035919050565b600060208083528351808285015260005b81811015610ada57858101830151858201604001528201610abe565b81811115610aec576000604083870101525b50601f01601f1916929092016040019392505050565b60008219821115610b1557610b15610b6c565b500190565b600082821015610b2c57610b2c610b6c565b500390565b600181811c90821680610b4557607f821691505b60208210811415610b6657634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fdfea2646970667358221220c7aae552dbfed06950f622ed0fbaf6c3ef30b4b4ba8e987193ecd95827cc453264736f6c63430008050033

Deployed Bytecode Sourcemap

16855:417:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6708:100;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;8875:169;;;;;;:::i;:::-;;:::i;:::-;;;1590:14:1;;1583:22;1565:41;;1553:2;1538:18;8875:169:0;1520:92:1;7828:108:0;7916:12;;7828:108;;;6819:25:1;;;6807:2;6792:18;7828:108:0;6774:76:1;9526:422:0;;;;;;:::i;:::-;;:::i;7670:93::-;;;7753:2;6997:36:1;;6985:2;6970:18;7670:93:0;6952:87:1;10357:215:0;;;;;;:::i;:::-;;:::i;16006:91::-;;;;;;:::i;:::-;;:::i;:::-;;7999:127;;;;;;:::i;:::-;-1:-1:-1;;;;;8100:18:0;8073:7;8100:18;;;;;;;;;;;;7999:127;16416:332;;;;;;:::i;:::-;;:::i;6927:104::-;;;:::i;11075:377::-;;;;;;:::i;:::-;;:::i;8339:175::-;;;;;;:::i;:::-;;:::i;8577:151::-;;;;;;:::i;:::-;-1:-1:-1;;;;;8693:18:0;;;8666:7;8693:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;8577:151;6708:100;6762:13;6795:5;6788:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6708:100;:::o;8875:169::-;8958:4;8975:39;4339:10;8998:7;9007:6;8975:8;:39::i;:::-;-1:-1:-1;9032:4:0;8875:169;;;;:::o;9526:422::-;9632:4;9649:36;9659:6;9667:9;9678:6;9649:9;:36::i;:::-;-1:-1:-1;;;;;9725:19:0;;9698:24;9725:19;;;:11;:19;;;;;;;;4339:10;9725:33;;;;;;;;9777:26;;;;9769:79;;;;-1:-1:-1;;;9769:79:0;;4442:2:1;9769:79:0;;;4424:21:1;4481:2;4461:18;;;4454:30;4520:34;4500:18;;;4493:62;-1:-1:-1;;;4571:18:1;;;4564:38;4619:19;;9769:79:0;;;;;;;;;9859:57;9868:6;4339:10;9890:25;9909:6;9890:16;:25;:::i;:::-;9859:8;:57::i;:::-;-1:-1:-1;9936:4:0;;9526:422;-1:-1:-1;;;;9526:422:0:o;10357:215::-;4339:10;10445:4;10494:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;10494:34:0;;;;;;;;;;10445:4;;10462:80;;10485:7;;10494:47;;10531:10;;10494:47;:::i;16006:91::-;16062:27;4339:10;16082:6;16062:5;:27::i;:::-;16006:91;:::o;16416:332::-;16493:24;16520:32;16530:7;4339:10;8577:151;:::i;16520:32::-;16493:59;;16591:6;16571:16;:26;;16563:75;;;;-1:-1:-1;;;16563:75:0;;4851:2:1;16563:75:0;;;4833:21:1;4890:2;4870:18;;;4863:30;4929:34;4909:18;;;4902:62;-1:-1:-1;;;4980:18:1;;;4973:34;5024:19;;16563:75:0;4823:226:1;16563:75:0;16649:58;16658:7;4339:10;16681:25;16700:6;16681:16;:25;:::i;16649:58::-;16718:22;16724:7;16733:6;16718:5;:22::i;:::-;16482:266;16416:332;;:::o;6927:104::-;6983:13;7016:7;7009:14;;;;;:::i;11075:377::-;4339:10;11168:4;11212:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11212:34:0;;;;;;;;;;11265:35;;;;11257:85;;;;-1:-1:-1;;;11257:85:0;;6469:2:1;11257:85:0;;;6451:21:1;6508:2;6488:18;;;6481:30;6547:34;6527:18;;;6520:62;-1:-1:-1;;;6598:18:1;;;6591:35;6643:19;;11257:85:0;6441:227:1;11257:85:0;11353:67;4339:10;11376:7;11385:34;11404:15;11385:16;:34;:::i;11353:67::-;-1:-1:-1;11440:4:0;;11075:377;-1:-1:-1;;;11075:377:0:o;8339:175::-;8425:4;8442:42;4339:10;8466:9;8477:6;8442:9;:42::i;14431:346::-;-1:-1:-1;;;;;14533:19:0;;14525:68;;;;-1:-1:-1;;;14525:68:0;;6064:2:1;14525:68:0;;;6046:21:1;6103:2;6083:18;;;6076:30;6142:34;6122:18;;;6115:62;-1:-1:-1;;;6193:18:1;;;6186:34;6237:19;;14525:68:0;6036:226:1;14525:68:0;-1:-1:-1;;;;;14612:21:0;;14604:68;;;;-1:-1:-1;;;14604:68:0;;3228:2:1;14604:68:0;;;3210:21:1;3267:2;3247:18;;;3240:30;3306:34;3286:18;;;3279:62;-1:-1:-1;;;3357:18:1;;;3350:32;3399:19;;14604:68:0;3200:224:1;14604:68:0;-1:-1:-1;;;;;14685:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;14737:32;;6819:25:1;;;14737:32:0;;6792:18:1;14737:32:0;;;;;;;;14431:346;;;:::o;11942:604::-;-1:-1:-1;;;;;12048:20:0;;12040:70;;;;-1:-1:-1;;;12040:70:0;;5658:2:1;12040:70:0;;;5640:21:1;5697:2;5677:18;;;5670:30;5736:34;5716:18;;;5709:62;-1:-1:-1;;;5787:18:1;;;5780:35;5832:19;;12040:70:0;5630:227:1;12040:70:0;-1:-1:-1;;;;;12129:23:0;;12121:71;;;;-1:-1:-1;;;12121:71:0;;2421:2:1;12121:71:0;;;2403:21:1;2460:2;2440:18;;;2433:30;2499:34;2479:18;;;2472:62;-1:-1:-1;;;2550:18:1;;;2543:33;2593:19;;12121:71:0;2393:225:1;12121:71:0;12205:47;12226:6;12234:9;12245:6;12205:20;:47::i;:::-;-1:-1:-1;;;;;12289:17:0;;12265:21;12289:17;;;;;;;;;;;12325:23;;;;12317:74;;;;-1:-1:-1;;;12317:74:0;;3631:2:1;12317:74:0;;;3613:21:1;3670:2;3650:18;;;3643:30;3709:34;3689:18;;;3682:62;-1:-1:-1;;;3760:18:1;;;3753:36;3806:19;;12317:74:0;3603:228:1;12317:74:0;12422:22;12438:6;12422:13;:22;:::i;:::-;-1:-1:-1;;;;;12402:17:0;;;:9;:17;;;;;;;;;;;:42;;;;12455:20;;;;;;;;:30;;12479:6;;12402:9;12455:30;;12479:6;;12455:30;:::i;:::-;;;;;;;;12520:9;-1:-1:-1;;;;;12503:35:0;12512:6;-1:-1:-1;;;;;12503:35:0;;12531:6;12503:35;;;;6819:25:1;;6807:2;6792:18;;6774:76;12503:35:0;;;;;;;;12029:517;11942:604;;;:::o;13499:494::-;-1:-1:-1;;;;;13583:21:0;;13575:67;;;;-1:-1:-1;;;13575:67:0;;5256:2:1;13575:67:0;;;5238:21:1;5295:2;5275:18;;;5268:30;5334:34;5314:18;;;5307:62;-1:-1:-1;;;5385:18:1;;;5378:31;5426:19;;13575:67:0;5228:223:1;13575:67:0;13655:49;13676:7;13693:1;13697:6;13655:20;:49::i;:::-;-1:-1:-1;;;;;13742:18:0;;13717:22;13742:18;;;;;;;;;;;13779:24;;;;13771:71;;;;-1:-1:-1;;;13771:71:0;;2825:2:1;13771:71:0;;;2807:21:1;2864:2;2844:18;;;2837:30;2903:34;2883:18;;;2876:62;-1:-1:-1;;;2954:18:1;;;2947:32;2996:19;;13771:71:0;2797:224:1;13771:71:0;13874:23;13891:6;13874:14;:23;:::i;:::-;-1:-1:-1;;;;;13853:18:0;;:9;:18;;;;;;;;;;:44;;;;13908:12;:22;;13924:6;;13853:9;13908:22;;13924:6;;13908:22;:::i;:::-;;;;-1:-1:-1;;13948:37:0;;6819:25:1;;;13974:1:0;;-1:-1:-1;;;;;13948:37:0;;;;;6807:2:1;6792:18;13948:37:0;6774:76:1;17004:265:0;-1:-1:-1;;;;;17202:19:0;;17216:4;17202:19;;17194:67;;;;-1:-1:-1;;;17194:67:0;;4038:2:1;17194:67:0;;;4020:21:1;4077:2;4057:18;;;4050:30;4116:34;4096:18;;;4089:62;-1:-1:-1;;;4167:18:1;;;4160:33;4210:19;;17194:67:0;4010:225:1;14:173;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;:::-;333:39;262:116;-1:-1:-1;;;262:116:1:o;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:180::-;1299:6;1352:2;1340:9;1331:7;1327:23;1323:32;1320:2;;;1368:1;1365;1358:12;1320:2;-1:-1:-1;1391:23:1;;1310:110;-1:-1:-1;1310:110:1:o;1617:597::-;1729:4;1758:2;1787;1776:9;1769:21;1819:6;1813:13;1862:6;1857:2;1846:9;1842:18;1835:34;1887:1;1897:140;1911:6;1908:1;1905:13;1897:140;;;2006:14;;;2002:23;;1996:30;1972:17;;;1991:2;1968:26;1961:66;1926:10;;1897:140;;;2055:6;2052:1;2049:13;2046:2;;;2125:1;2120:2;2111:6;2100:9;2096:22;2092:31;2085:42;2046:2;-1:-1:-1;2198:2:1;2177:15;-1:-1:-1;;2173:29:1;2158:45;;;;2205:2;2154:54;;1738:476;-1:-1:-1;;;1738:476:1:o;7044:128::-;7084:3;7115:1;7111:6;7108:1;7105:13;7102:2;;;7121:18;;:::i;:::-;-1:-1:-1;7157:9:1;;7092:80::o;7177:125::-;7217:4;7245:1;7242;7239:8;7236:2;;;7250:18;;:::i;:::-;-1:-1:-1;7287:9:1;;7226:76::o;7307:380::-;7386:1;7382:12;;;;7429;;;7450:2;;7504:4;7496:6;7492:17;7482:27;;7450:2;7557;7549:6;7546:14;7526:18;7523:38;7520:2;;;7603:10;7598:3;7594:20;7591:1;7584:31;7638:4;7635:1;7628:15;7666:4;7663:1;7656:15;7520:2;;7362:325;;;:::o;7692:127::-;7753:10;7748:3;7744:20;7741:1;7734:31;7784:4;7781:1;7774:15;7808:4;7805:1;7798:15

Swarm Source

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