ERC-20
Overview
Max Total Supply
6,350,000,000 EGGMAN
Holders
18
Market
Price
-
Onchain Market Cap
-
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 18 Decimals)
Balance
39,290,804.940110098552803189 EGGMANValue
$0.00Loading...
Loading
Loading...
Loading
Loading...
Loading
Contract Name:
DrEggMan
Compiler Version
v0.8.19+commit.7dd6d404
Contract Source Code (Solidity)
/** *Submitted for verification at SonicScan.org on 2024-12-18 */ /** *Submitted for verification at ftmscan.com on 2023-12-20 */ /** */ /** Website: https://doctoreggman.xyz// Telegram: https://t.me/DrEggmanFTM Twitter: https://x.com/DrEggManFTM */ // File: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/audit/2023-07-10/contracts/interfaces/draft-IERC6093.sol // SPDX-License-Identifier: MIT pragma solidity ^0.8.19; /** * @dev Standard ERC20 Errors * Interface of the ERC6093 custom errors for ERC20 tokens * as defined in https://eips.ethereum.org/EIPS/eip-6093 */ interface IERC20Errors { /** * @dev Indicates an error related to the current `balance` of a `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. * @param balance Current balance for the interacting account. * @param needed Minimum amount required to perform a transfer. */ error ERC20InsufficientBalance(address sender, uint256 balance, uint256 needed); /** * @dev Indicates a failure with the token `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. */ error ERC20InvalidSender(address sender); /** * @dev Indicates a failure with the token `receiver`. Used in transfers. * @param receiver Address to which tokens are being transferred. */ error ERC20InvalidReceiver(address receiver); /** * @dev Indicates a failure with the `spender`’s `allowance`. Used in transfers. * @param spender Address that may be allowed to operate on tokens without being their owner. * @param allowance Amount of tokens a `spender` is allowed to operate with. * @param needed Minimum amount required to perform a transfer. */ error ERC20InsufficientAllowance(address spender, uint256 allowance, uint256 needed); /** * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals. * @param approver Address initiating an approval operation. */ error ERC20InvalidApprover(address approver); /** * @dev Indicates a failure with the `spender` to be approved. Used in approvals. * @param spender Address that may be allowed to operate on tokens without being their owner. */ error ERC20InvalidSpender(address spender); } /** * @dev Standard ERC721 Errors * Interface of the ERC6093 custom errors for ERC721 tokens * as defined in https://eips.ethereum.org/EIPS/eip-6093 */ interface IERC721Errors { /** * @dev Indicates that an address can't be an owner. For example, `address(0)` is a forbidden owner in EIP-20. * Used in balance queries. * @param owner Address of the current owner of a token. */ error ERC721InvalidOwner(address owner); /** * @dev Indicates a `tokenId` whose `owner` is the zero address. * @param tokenId Identifier number of a token. */ error ERC721NonexistentToken(uint256 tokenId); /** * @dev Indicates an error related to the ownership over a particular token. Used in transfers. * @param sender Address whose tokens are being transferred. * @param tokenId Identifier number of a token. * @param owner Address of the current owner of a token. */ error ERC721IncorrectOwner(address sender, uint256 tokenId, address owner); /** * @dev Indicates a failure with the token `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. */ error ERC721InvalidSender(address sender); /** * @dev Indicates a failure with the token `receiver`. Used in transfers. * @param receiver Address to which tokens are being transferred. */ error ERC721InvalidReceiver(address receiver); /** * @dev Indicates a failure with the `operator`’s approval. Used in transfers. * @param operator Address that may be allowed to operate on tokens without being their owner. * @param tokenId Identifier number of a token. */ error ERC721InsufficientApproval(address operator, uint256 tokenId); /** * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals. * @param approver Address initiating an approval operation. */ error ERC721InvalidApprover(address approver); /** * @dev Indicates a failure with the `operator` to be approved. Used in approvals. * @param operator Address that may be allowed to operate on tokens without being their owner. */ error ERC721InvalidOperator(address operator); } /** * @dev Standard ERC1155 Errors * Interface of the ERC6093 custom errors for ERC1155 tokens * as defined in https://eips.ethereum.org/EIPS/eip-6093 */ interface IERC1155Errors { /** * @dev Indicates an error related to the current `balance` of a `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. * @param balance Current balance for the interacting account. * @param needed Minimum amount required to perform a transfer. * @param tokenId Identifier number of a token. */ error ERC1155InsufficientBalance(address sender, uint256 balance, uint256 needed, uint256 tokenId); /** * @dev Indicates a failure with the token `sender`. Used in transfers. * @param sender Address whose tokens are being transferred. */ error ERC1155InvalidSender(address sender); /** * @dev Indicates a failure with the token `receiver`. Used in transfers. * @param receiver Address to which tokens are being transferred. */ error ERC1155InvalidReceiver(address receiver); /** * @dev Indicates a failure with the `operator`’s approval. Used in transfers. * @param operator Address that may be allowed to operate on tokens without being their owner. * @param owner Address of the current owner of a token. */ error ERC1155MissingApprovalForAll(address operator, address owner); /** * @dev Indicates a failure with the `approver` of a token to be approved. Used in approvals. * @param approver Address initiating an approval operation. */ error ERC1155InvalidApprover(address approver); /** * @dev Indicates a failure with the `operator` to be approved. Used in approvals. * @param operator Address that may be allowed to operate on tokens without being their owner. */ error ERC1155InvalidOperator(address operator); /** * @dev Indicates an array length mismatch between ids and values in a safeBatchTransferFrom operation. * Used in batch transfers. * @param idsLength Length of the array of token identifiers * @param valuesLength Length of the array of token amounts */ error ERC1155InvalidArrayLength(uint256 idsLength, uint256 valuesLength); } // File: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/audit/2023-07-10/contracts/utils/Context.sol // OpenZeppelin Contracts v4.4.1 (utils/Context.sol) pragma solidity ^0.8.19; /** * @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; } } // File: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/audit/2023-07-10/contracts/token/ERC20/IERC20.sol // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/IERC20.sol) pragma solidity ^0.8.19; /** * @dev Interface of the ERC20 standard as defined in the EIP. */ interface IERC20 { /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); /** * @dev Returns the value of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the value of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves a `value` amount of tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 value) 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 a `value` amount of tokens 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 value) external returns (bool); /** * @dev Moves a `value` amount of tokens from `from` to `to` using the * allowance mechanism. `value` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom(address from, address to, uint256 value) external returns (bool); } // File: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/audit/2023-07-10/contracts/token/ERC20/extensions/IERC20Metadata.sol // OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol) pragma solidity ^0.8.19; /** * @dev Interface for the optional metadata functions from the ERC20 standard. */ 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: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/audit/2023-07-10/contracts/token/ERC20/ERC20.sol // OpenZeppelin Contracts (last updated v4.9.0) (token/ERC20/ERC20.sol) pragma solidity ^0.8.19; /** * @dev Implementation of the {IERC20} interface. * * This implementation is agnostic to the way tokens are created. This means * that a supply mechanism has to be added in a derived contract using {_mint}. * * TIP: For a detailed writeup see our guide * https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How * to implement supply mechanisms]. * * The default value of {decimals} is 18. To change this, you should override * this function so it returns a different value. * * We have followed general OpenZeppelin Contracts guidelines: functions revert * instead returning `false` on failure. This behavior is nonetheless * conventional and does not conflict with the expectations of ERC20 * applications. * * Additionally, an {Approval} event is emitted on calls to {transferFrom}. * This allows applications to reconstruct the allowance for all accounts just * by listening to said events. Other implementations of the EIP may not emit * these events, as it isn't required by the specification. * * Finally, the non-standard {decreaseAllowance} and {increaseAllowance} * functions have been added to mitigate the well-known issues around setting * allowances. See {IERC20-approve}. */ abstract contract ERC20 is Context, IERC20, IERC20Metadata, IERC20Errors { mapping(address => uint256) private _balances; mapping(address => mapping(address => uint256)) private _allowances; uint256 private _totalSupply; string private _name; string private _symbol; /** * @dev Indicates a failed `decreaseAllowance` request. */ error ERC20FailedDecreaseAllowance(address spender, uint256 currentAllowance, uint256 requestedDecrease); /** * @dev Sets the values for {name} and {symbol}. * * 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 returns (string memory) { return _name; } /** * @dev Returns the symbol of the token, usually a shorter version of the * name. */ function symbol() public view virtual 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 default value returned by this function, unless * it's 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 returns (uint8) { return 18; } /** * @dev See {IERC20-totalSupply}. */ function totalSupply() public view virtual returns (uint256) { return _totalSupply; } /** * @dev See {IERC20-balanceOf}. */ function balanceOf(address account) public view virtual returns (uint256) { return _balances[account]; } /** * @dev See {IERC20-transfer}. * * Requirements: * * - `to` cannot be the zero address. * - the caller must have a balance of at least `value`. */ function transfer(address to, uint256 value) public virtual returns (bool) { address owner = _msgSender(); _transfer(owner, to, value); return true; } /** * @dev See {IERC20-allowance}. */ function allowance(address owner, address spender) public view virtual returns (uint256) { return _allowances[owner][spender]; } /** * @dev See {IERC20-approve}. * * NOTE: If `value` is the maximum `uint256`, the allowance is not updated on * `transferFrom`. This is semantically equivalent to an infinite approval. * * Requirements: * * - `spender` cannot be the zero address. */ function approve(address spender, uint256 value) public virtual returns (bool) { address owner = _msgSender(); _approve(owner, spender, value); 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}. * * NOTE: Does not update the allowance if the current allowance * is the maximum `uint256`. * * Requirements: * * - `from` and `to` cannot be the zero address. * - `from` must have a balance of at least `value`. * - the caller must have allowance for ``from``'s tokens of at least * `value`. */ function transferFrom(address from, address to, uint256 value) public virtual returns (bool) { address spender = _msgSender(); _spendAllowance(from, spender, value); _transfer(from, to, value); 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) { address owner = _msgSender(); _approve(owner, spender, allowance(owner, 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 * `requestedDecrease`. * * NOTE: Although this function is designed to avoid double spending with {approval}, * it can still be frontrunned, preventing any attempt of allowance reduction. */ function decreaseAllowance(address spender, uint256 requestedDecrease) public virtual returns (bool) { address owner = _msgSender(); uint256 currentAllowance = allowance(owner, spender); if (currentAllowance < requestedDecrease) { revert ERC20FailedDecreaseAllowance(spender, currentAllowance, requestedDecrease); } unchecked { _approve(owner, spender, currentAllowance - requestedDecrease); } return true; } /** * @dev Moves a `value` amount of tokens from `from` to `to`. * * This internal function is equivalent to {transfer}, and can be used to * e.g. implement automatic token fees, slashing mechanisms, etc. * * Emits a {Transfer} event. * * NOTE: This function is not virtual, {_update} should be overridden instead. */ function _transfer(address from, address to, uint256 value) internal { if (from == address(0)) { revert ERC20InvalidSender(address(0)); } if (to == address(0)) { revert ERC20InvalidReceiver(address(0)); } _update(from, to, value); } /** * @dev Transfers a `value` amount of tokens from `from` to `to`, or alternatively mints (or burns) if `from` (or `to`) is * the zero address. All customizations to transfers, mints, and burns should be done by overriding this function. * * Emits a {Transfer} event. */ function _update(address from, address to, uint256 value) internal virtual { if (from == address(0)) { // Overflow check required: The rest of the code assumes that totalSupply never overflows _totalSupply += value; } else { uint256 fromBalance = _balances[from]; if (fromBalance < value) { revert ERC20InsufficientBalance(from, fromBalance, value); } unchecked { // Overflow not possible: value <= fromBalance <= totalSupply. _balances[from] = fromBalance - value; } } if (to == address(0)) { unchecked { // Overflow not possible: value <= totalSupply or value <= fromBalance <= totalSupply. _totalSupply -= value; } } else { unchecked { // Overflow not possible: balance + value is at most totalSupply, which we know fits into a uint256. _balances[to] += value; } } emit Transfer(from, to, value); } /** * @dev Creates a `value` amount of tokens and assigns them to `account`, by transferring it from address(0). * Relies on the `_update` mechanism * * Emits a {Transfer} event with `from` set to the zero address. * * NOTE: This function is not virtual, {_update} should be overridden instead. */ function _mint(address account, uint256 value) internal { if (account == address(0)) { revert ERC20InvalidReceiver(address(0)); } _update(address(0), account, value); } /** * @dev Destroys a `value` amount of tokens from `account`, by transferring it to address(0). * Relies on the `_update` mechanism. * * Emits a {Transfer} event with `to` set to the zero address. * * NOTE: This function is not virtual, {_update} should be overridden instead */ function _burn(address account, uint256 value) internal { if (account == address(0)) { revert ERC20InvalidSender(address(0)); } _update(account, address(0), value); } /** * @dev Sets `value` 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 value) internal virtual { _approve(owner, spender, value, true); } /** * @dev Alternative version of {_approve} with an optional flag that can enable or disable the Approval event. * * By default (when calling {_approve}) the flag is set to true. On the other hand, approval changes made by * `_spendAllowance` during the `transferFrom` operation set the flag to false. This saves gas by not emitting any * `Approval` event during `transferFrom` operations. * * Anyone who wishes to continue emitting `Approval` events on the`transferFrom` operation can force the flag to true * using the following override: * ``` * function _approve(address owner, address spender, uint256 value, bool) internal virtual override { * super._approve(owner, spender, value, true); * } * ``` * * Requirements are the same as {_approve}. */ function _approve(address owner, address spender, uint256 value, bool emitEvent) internal virtual { if (owner == address(0)) { revert ERC20InvalidApprover(address(0)); } if (spender == address(0)) { revert ERC20InvalidSpender(address(0)); } _allowances[owner][spender] = value; if (emitEvent) { emit Approval(owner, spender, value); } } /** * @dev Updates `owner` s allowance for `spender` based on spent `value`. * * Does not update the allowance value in case of infinite allowance. * Revert if not enough allowance is available. * * Might emit an {Approval} event. */ function _spendAllowance(address owner, address spender, uint256 value) internal virtual { uint256 currentAllowance = allowance(owner, spender); if (currentAllowance != type(uint256).max) { if (currentAllowance < value) { revert ERC20InsufficientAllowance(spender, currentAllowance, value); } unchecked { _approve(owner, spender, currentAllowance - value, false); } } } } // File: dummyToken.sol pragma solidity ^0.8.19; contract DrEggMan is ERC20 { constructor() ERC20("Dr. EggMan", "EGGMAN") { _mint(msg.sender, 6350000000 * 10 ** decimals()); } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"currentAllowance","type":"uint256"},{"internalType":"uint256","name":"requestedDecrease","type":"uint256"}],"name":"ERC20FailedDecreaseAllowance","type":"error"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"allowance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientAllowance","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"uint256","name":"balance","type":"uint256"},{"internalType":"uint256","name":"needed","type":"uint256"}],"name":"ERC20InsufficientBalance","type":"error"},{"inputs":[{"internalType":"address","name":"approver","type":"address"}],"name":"ERC20InvalidApprover","type":"error"},{"inputs":[{"internalType":"address","name":"receiver","type":"address"}],"name":"ERC20InvalidReceiver","type":"error"},{"inputs":[{"internalType":"address","name":"sender","type":"address"}],"name":"ERC20InvalidSender","type":"error"},{"inputs":[{"internalType":"address","name":"spender","type":"address"}],"name":"ERC20InvalidSpender","type":"error"},{"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":"value","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":"requestedDecrease","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":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
60806040523480156200001157600080fd5b506040518060400160405280600a81526020017f44722e204567674d616e000000000000000000000000000000000000000000008152506040518060400160405280600681526020017f4547474d414e000000000000000000000000000000000000000000000000000081525081600390816200008f91906200062b565b508060049081620000a191906200062b565b505050620000e533620000b9620000eb60201b60201c565b600a620000c79190620008a2565b64017a7d4f80620000d99190620008f3565b620000f460201b60201c565b62000a46565b60006012905090565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603620001695760006040517fec442f0500000000000000000000000000000000000000000000000000000000815260040162000160919062000983565b60405180910390fd5b6200017d600083836200018160201b60201c565b5050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603620001d7578060026000828254620001ca9190620009a0565b92505081905550620002ad565b60008060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205490508181101562000266578381836040517fe450d38c0000000000000000000000000000000000000000000000000000000081526004016200025d93929190620009ec565b60405180910390fd5b8181036000808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550505b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603620002f8578060026000828254039250508190555062000345565b806000808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825401925050819055505b8173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051620003a4919062000a29565b60405180910390a3505050565b600081519050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b600060028204905060018216806200043357607f821691505b602082108103620004495762000448620003eb565b5b50919050565b60008190508160005260206000209050919050565b60006020601f8301049050919050565b600082821b905092915050565b600060088302620004b37fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8262000474565b620004bf868362000474565b95508019841693508086168417925050509392505050565b6000819050919050565b6000819050919050565b60006200050c620005066200050084620004d7565b620004e1565b620004d7565b9050919050565b6000819050919050565b6200052883620004eb565b62000540620005378262000513565b84845462000481565b825550505050565b600090565b6200055762000548565b620005648184846200051d565b505050565b5b818110156200058c57620005806000826200054d565b6001810190506200056a565b5050565b601f821115620005db57620005a5816200044f565b620005b08462000464565b81016020851015620005c0578190505b620005d8620005cf8562000464565b83018262000569565b50505b505050565b600082821c905092915050565b60006200060060001984600802620005e0565b1980831691505092915050565b60006200061b8383620005ed565b9150826002028217905092915050565b6200063682620003b1565b67ffffffffffffffff811115620006525762000651620003bc565b5b6200065e82546200041a565b6200066b82828562000590565b600060209050601f831160018114620006a357600084156200068e578287015190505b6200069a85826200060d565b8655506200070a565b601f198416620006b3866200044f565b60005b82811015620006dd57848901518255600182019150602085019450602081019050620006b6565b86831015620006fd5784890151620006f9601f891682620005ed565b8355505b6001600288020188555050505b505050505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b60008160011c9050919050565b6000808291508390505b6001851115620007a05780860481111562000778576200077762000712565b5b6001851615620007885780820291505b8081029050620007988562000741565b945062000758565b94509492505050565b600082620007bb57600190506200088e565b81620007cb57600090506200088e565b8160018114620007e45760028114620007ef5762000825565b60019150506200088e565b60ff84111562000804576200080362000712565b5b8360020a9150848211156200081e576200081d62000712565b5b506200088e565b5060208310610133831016604e8410600b84101617156200085f5782820a90508381111562000859576200085862000712565b5b6200088e565b6200086e84848460016200074e565b9250905081840481111562000888576200088762000712565b5b81810290505b9392505050565b600060ff82169050919050565b6000620008af82620004d7565b9150620008bc8362000895565b9250620008eb7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8484620007a9565b905092915050565b60006200090082620004d7565b91506200090d83620004d7565b92508282026200091d81620004d7565b9150828204841483151762000937576200093662000712565b5b5092915050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b60006200096b826200093e565b9050919050565b6200097d816200095e565b82525050565b60006020820190506200099a600083018462000972565b92915050565b6000620009ad82620004d7565b9150620009ba83620004d7565b9250828201905080821115620009d557620009d462000712565b5b92915050565b620009e681620004d7565b82525050565b600060608201905062000a03600083018662000972565b62000a126020830185620009db565b62000a216040830184620009db565b949350505050565b600060208201905062000a406000830184620009db565b92915050565b610f7f8062000a566000396000f3fe608060405234801561001057600080fd5b50600436106100a95760003560e01c80633950935111610071578063395093511461016857806370a082311461019857806395d89b41146101c8578063a457c2d7146101e6578063a9059cbb14610216578063dd62ed3e14610246576100a9565b806306fdde03146100ae578063095ea7b3146100cc57806318160ddd146100fc57806323b872dd1461011a578063313ce5671461014a575b600080fd5b6100b6610276565b6040516100c39190610bd3565b60405180910390f35b6100e660048036038101906100e19190610c8e565b610308565b6040516100f39190610ce9565b60405180910390f35b61010461032b565b6040516101119190610d13565b60405180910390f35b610134600480360381019061012f9190610d2e565b610335565b6040516101419190610ce9565b60405180910390f35b610152610364565b60405161015f9190610d9d565b60405180910390f35b610182600480360381019061017d9190610c8e565b61036d565b60405161018f9190610ce9565b60405180910390f35b6101b260048036038101906101ad9190610db8565b6103a4565b6040516101bf9190610d13565b60405180910390f35b6101d06103ec565b6040516101dd9190610bd3565b60405180910390f35b61020060048036038101906101fb9190610c8e565b61047e565b60405161020d9190610ce9565b60405180910390f35b610230600480360381019061022b9190610c8e565b6104fb565b60405161023d9190610ce9565b60405180910390f35b610260600480360381019061025b9190610de5565b61051e565b60405161026d9190610d13565b60405180910390f35b60606003805461028590610e54565b80601f01602080910402602001604051908101604052809291908181526020018280546102b190610e54565b80156102fe5780601f106102d3576101008083540402835291602001916102fe565b820191906000526020600020905b8154815290600101906020018083116102e157829003601f168201915b5050505050905090565b6000806103136105a5565b90506103208185856105ad565b600191505092915050565b6000600254905090565b6000806103406105a5565b905061034d8582856105bf565b610358858585610653565b60019150509392505050565b60006012905090565b6000806103786105a5565b905061039981858561038a858961051e565b6103949190610eb4565b6105ad565b600191505092915050565b60008060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6060600480546103fb90610e54565b80601f016020809104026020016040519081016040528092919081815260200182805461042790610e54565b80156104745780601f1061044957610100808354040283529160200191610474565b820191906000526020600020905b81548152906001019060200180831161045757829003601f168201915b5050505050905090565b6000806104896105a5565b90506000610497828661051e565b9050838110156104e2578481856040517fa60f030c0000000000000000000000000000000000000000000000000000000081526004016104d993929190610ef7565b60405180910390fd5b6104ef82868684036105ad565b60019250505092915050565b6000806105066105a5565b9050610513818585610653565b600191505092915050565b6000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600033905090565b6105ba8383836001610747565b505050565b60006105cb848461051e565b90507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff811461064d578181101561063d578281836040517ffb8f41b200000000000000000000000000000000000000000000000000000000815260040161063493929190610ef7565b60405180910390fd5b61064c84848484036000610747565b5b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036106c55760006040517f96c6fd1e0000000000000000000000000000000000000000000000000000000081526004016106bc9190610f2e565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036107375760006040517fec442f0500000000000000000000000000000000000000000000000000000000815260040161072e9190610f2e565b60405180910390fd5b61074283838361091e565b505050565b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16036107b95760006040517fe602df050000000000000000000000000000000000000000000000000000000081526004016107b09190610f2e565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361082b5760006040517f94280d620000000000000000000000000000000000000000000000000000000081526004016108229190610f2e565b60405180910390fd5b81600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508015610918578273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258460405161090f9190610d13565b60405180910390a35b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036109705780600260008282546109649190610eb4565b92505081905550610a43565b60008060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050818110156109fc578381836040517fe450d38c0000000000000000000000000000000000000000000000000000000081526004016109f393929190610ef7565b60405180910390fd5b8181036000808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550505b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610a8c5780600260008282540392505081905550610ad9565b806000808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825401925050819055505b8173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610b369190610d13565b60405180910390a3505050565b600081519050919050565b600082825260208201905092915050565b60005b83811015610b7d578082015181840152602081019050610b62565b60008484015250505050565b6000601f19601f8301169050919050565b6000610ba582610b43565b610baf8185610b4e565b9350610bbf818560208601610b5f565b610bc881610b89565b840191505092915050565b60006020820190508181036000830152610bed8184610b9a565b905092915050565b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000610c2582610bfa565b9050919050565b610c3581610c1a565b8114610c4057600080fd5b50565b600081359050610c5281610c2c565b92915050565b6000819050919050565b610c6b81610c58565b8114610c7657600080fd5b50565b600081359050610c8881610c62565b92915050565b60008060408385031215610ca557610ca4610bf5565b5b6000610cb385828601610c43565b9250506020610cc485828601610c79565b9150509250929050565b60008115159050919050565b610ce381610cce565b82525050565b6000602082019050610cfe6000830184610cda565b92915050565b610d0d81610c58565b82525050565b6000602082019050610d286000830184610d04565b92915050565b600080600060608486031215610d4757610d46610bf5565b5b6000610d5586828701610c43565b9350506020610d6686828701610c43565b9250506040610d7786828701610c79565b9150509250925092565b600060ff82169050919050565b610d9781610d81565b82525050565b6000602082019050610db26000830184610d8e565b92915050565b600060208284031215610dce57610dcd610bf5565b5b6000610ddc84828501610c43565b91505092915050565b60008060408385031215610dfc57610dfb610bf5565b5b6000610e0a85828601610c43565b9250506020610e1b85828601610c43565b9150509250929050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60006002820490506001821680610e6c57607f821691505b602082108103610e7f57610e7e610e25565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6000610ebf82610c58565b9150610eca83610c58565b9250828201905080821115610ee257610ee1610e85565b5b92915050565b610ef181610c1a565b82525050565b6000606082019050610f0c6000830186610ee8565b610f196020830185610d04565b610f266040830184610d04565b949350505050565b6000602082019050610f436000830184610ee8565b9291505056fea2646970667358221220af97170eae9cc0ac5d74f315d2532f355bee4484c44a21560076a8156c87f4ed64736f6c63430008130033
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106100a95760003560e01c80633950935111610071578063395093511461016857806370a082311461019857806395d89b41146101c8578063a457c2d7146101e6578063a9059cbb14610216578063dd62ed3e14610246576100a9565b806306fdde03146100ae578063095ea7b3146100cc57806318160ddd146100fc57806323b872dd1461011a578063313ce5671461014a575b600080fd5b6100b6610276565b6040516100c39190610bd3565b60405180910390f35b6100e660048036038101906100e19190610c8e565b610308565b6040516100f39190610ce9565b60405180910390f35b61010461032b565b6040516101119190610d13565b60405180910390f35b610134600480360381019061012f9190610d2e565b610335565b6040516101419190610ce9565b60405180910390f35b610152610364565b60405161015f9190610d9d565b60405180910390f35b610182600480360381019061017d9190610c8e565b61036d565b60405161018f9190610ce9565b60405180910390f35b6101b260048036038101906101ad9190610db8565b6103a4565b6040516101bf9190610d13565b60405180910390f35b6101d06103ec565b6040516101dd9190610bd3565b60405180910390f35b61020060048036038101906101fb9190610c8e565b61047e565b60405161020d9190610ce9565b60405180910390f35b610230600480360381019061022b9190610c8e565b6104fb565b60405161023d9190610ce9565b60405180910390f35b610260600480360381019061025b9190610de5565b61051e565b60405161026d9190610d13565b60405180910390f35b60606003805461028590610e54565b80601f01602080910402602001604051908101604052809291908181526020018280546102b190610e54565b80156102fe5780601f106102d3576101008083540402835291602001916102fe565b820191906000526020600020905b8154815290600101906020018083116102e157829003601f168201915b5050505050905090565b6000806103136105a5565b90506103208185856105ad565b600191505092915050565b6000600254905090565b6000806103406105a5565b905061034d8582856105bf565b610358858585610653565b60019150509392505050565b60006012905090565b6000806103786105a5565b905061039981858561038a858961051e565b6103949190610eb4565b6105ad565b600191505092915050565b60008060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6060600480546103fb90610e54565b80601f016020809104026020016040519081016040528092919081815260200182805461042790610e54565b80156104745780601f1061044957610100808354040283529160200191610474565b820191906000526020600020905b81548152906001019060200180831161045757829003601f168201915b5050505050905090565b6000806104896105a5565b90506000610497828661051e565b9050838110156104e2578481856040517fa60f030c0000000000000000000000000000000000000000000000000000000081526004016104d993929190610ef7565b60405180910390fd5b6104ef82868684036105ad565b60019250505092915050565b6000806105066105a5565b9050610513818585610653565b600191505092915050565b6000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600033905090565b6105ba8383836001610747565b505050565b60006105cb848461051e565b90507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff811461064d578181101561063d578281836040517ffb8f41b200000000000000000000000000000000000000000000000000000000815260040161063493929190610ef7565b60405180910390fd5b61064c84848484036000610747565b5b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036106c55760006040517f96c6fd1e0000000000000000000000000000000000000000000000000000000081526004016106bc9190610f2e565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16036107375760006040517fec442f0500000000000000000000000000000000000000000000000000000000815260040161072e9190610f2e565b60405180910390fd5b61074283838361091e565b505050565b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16036107b95760006040517fe602df050000000000000000000000000000000000000000000000000000000081526004016107b09190610f2e565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361082b5760006040517f94280d620000000000000000000000000000000000000000000000000000000081526004016108229190610f2e565b60405180910390fd5b81600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508015610918578273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258460405161090f9190610d13565b60405180910390a35b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036109705780600260008282546109649190610eb4565b92505081905550610a43565b60008060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050818110156109fc578381836040517fe450d38c0000000000000000000000000000000000000000000000000000000081526004016109f393929190610ef7565b60405180910390fd5b8181036000808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550505b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610a8c5780600260008282540392505081905550610ad9565b806000808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825401925050819055505b8173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610b369190610d13565b60405180910390a3505050565b600081519050919050565b600082825260208201905092915050565b60005b83811015610b7d578082015181840152602081019050610b62565b60008484015250505050565b6000601f19601f8301169050919050565b6000610ba582610b43565b610baf8185610b4e565b9350610bbf818560208601610b5f565b610bc881610b89565b840191505092915050565b60006020820190508181036000830152610bed8184610b9a565b905092915050565b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000610c2582610bfa565b9050919050565b610c3581610c1a565b8114610c4057600080fd5b50565b600081359050610c5281610c2c565b92915050565b6000819050919050565b610c6b81610c58565b8114610c7657600080fd5b50565b600081359050610c8881610c62565b92915050565b60008060408385031215610ca557610ca4610bf5565b5b6000610cb385828601610c43565b9250506020610cc485828601610c79565b9150509250929050565b60008115159050919050565b610ce381610cce565b82525050565b6000602082019050610cfe6000830184610cda565b92915050565b610d0d81610c58565b82525050565b6000602082019050610d286000830184610d04565b92915050565b600080600060608486031215610d4757610d46610bf5565b5b6000610d5586828701610c43565b9350506020610d6686828701610c43565b9250506040610d7786828701610c79565b9150509250925092565b600060ff82169050919050565b610d9781610d81565b82525050565b6000602082019050610db26000830184610d8e565b92915050565b600060208284031215610dce57610dcd610bf5565b5b6000610ddc84828501610c43565b91505092915050565b60008060408385031215610dfc57610dfb610bf5565b5b6000610e0a85828601610c43565b9250506020610e1b85828601610c43565b9150509250929050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60006002820490506001821680610e6c57607f821691505b602082108103610e7f57610e7e610e25565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6000610ebf82610c58565b9150610eca83610c58565b9250828201905080821115610ee257610ee1610e85565b5b92915050565b610ef181610c1a565b82525050565b6000606082019050610f0c6000830186610ee8565b610f196020830185610d04565b610f266040830184610d04565b949350505050565b6000602082019050610f436000830184610ee8565b9291505056fea2646970667358221220af97170eae9cc0ac5d74f315d2532f355bee4484c44a21560076a8156c87f4ed64736f6c63430008130033
Deployed Bytecode Sourcemap
25170:148:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14038:91;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;16331:190;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;15140:99;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;17099:249;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;14991:84;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;17757:238;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;15302:118;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;14248:95;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;18683:504;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;15625:182;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;15870:142;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;14038:91;14083:13;14116:5;14109:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14038:91;:::o;16331:190::-;16404:4;16421:13;16437:12;:10;:12::i;:::-;16421:28;;16460:31;16469:5;16476:7;16485:5;16460:8;:31::i;:::-;16509:4;16502:11;;;16331:190;;;;:::o;15140:99::-;15192:7;15219:12;;15212:19;;15140:99;:::o;17099:249::-;17186:4;17203:15;17221:12;:10;:12::i;:::-;17203:30;;17244:37;17260:4;17266:7;17275:5;17244:15;:37::i;:::-;17292:26;17302:4;17308:2;17312:5;17292:9;:26::i;:::-;17336:4;17329:11;;;17099:249;;;;;:::o;14991:84::-;15040:5;15065:2;15058:9;;14991:84;:::o;17757:238::-;17845:4;17862:13;17878:12;:10;:12::i;:::-;17862:28;;17901:64;17910:5;17917:7;17954:10;17926:25;17936:5;17943:7;17926:9;:25::i;:::-;:38;;;;:::i;:::-;17901:8;:64::i;:::-;17983:4;17976:11;;;17757:238;;;;:::o;15302:118::-;15367:7;15394:9;:18;15404:7;15394:18;;;;;;;;;;;;;;;;15387:25;;15302:118;;;:::o;14248:95::-;14295:13;14328:7;14321:14;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14248:95;:::o;18683:504::-;18778:4;18795:13;18811:12;:10;:12::i;:::-;18795:28;;18834:24;18861:25;18871:5;18878:7;18861:9;:25::i;:::-;18834:52;;18920:17;18901:16;:36;18897:150;;;18990:7;18999:16;19017:17;18961:74;;;;;;;;;;;;;:::i;:::-;;;;;;;;18897:150;19082:62;19091:5;19098:7;19126:17;19107:16;:36;19082:8;:62::i;:::-;19175:4;19168:11;;;;18683:504;;;;:::o;15625:182::-;15694:4;15711:13;15727:12;:10;:12::i;:::-;15711:28;;15750:27;15760:5;15767:2;15771:5;15750:9;:27::i;:::-;15795:4;15788:11;;;15625:182;;;;:::o;15870:142::-;15950:7;15977:11;:18;15989:5;15977:18;;;;;;;;;;;;;;;:27;15996:7;15977:27;;;;;;;;;;;;;;;;15970:34;;15870:142;;;;:::o;7736:98::-;7789:7;7816:10;7809:17;;7736:98;:::o;22880:138::-;22973:37;22982:5;22989:7;22998:5;23005:4;22973:8;:37::i;:::-;22880:138;;;:::o;24617:487::-;24717:24;24744:25;24754:5;24761:7;24744:9;:25::i;:::-;24717:52;;24804:17;24784:16;:37;24780:317;;24861:5;24842:16;:24;24838:132;;;24921:7;24930:16;24948:5;24894:60;;;;;;;;;;;;;:::i;:::-;;;;;;;;24838:132;25013:57;25022:5;25029:7;25057:5;25038:16;:24;25064:5;25013:8;:57::i;:::-;24780:317;24706:398;24617:487;;;:::o;19572:308::-;19672:1;19656:18;;:4;:18;;;19652:88;;19725:1;19698:30;;;;;;;;;;;:::i;:::-;;;;;;;;19652:88;19768:1;19754:16;;:2;:16;;;19750:88;;19823:1;19794:32;;;;;;;;;;;:::i;:::-;;;;;;;;19750:88;19848:24;19856:4;19862:2;19866:5;19848:7;:24::i;:::-;19572:308;;;:::o;23885:443::-;24015:1;23998:19;;:5;:19;;;23994:91;;24070:1;24041:32;;;;;;;;;;;:::i;:::-;;;;;;;;23994:91;24118:1;24099:21;;:7;:21;;;24095:92;;24172:1;24144:31;;;;;;;;;;;:::i;:::-;;;;;;;;24095:92;24227:5;24197:11;:18;24209:5;24197:18;;;;;;;;;;;;;;;:27;24216:7;24197:27;;;;;;;;;;;;;;;:35;;;;24247:9;24243:78;;;24294:7;24278:31;;24287:5;24278:31;;;24303:5;24278:31;;;;;;:::i;:::-;;;;;;;;24243:78;23885:443;;;;:::o;20196:1135::-;20302:1;20286:18;;:4;:18;;;20282:552;;20440:5;20424:12;;:21;;;;;;;:::i;:::-;;;;;;;;20282:552;;;20478:19;20500:9;:15;20510:4;20500:15;;;;;;;;;;;;;;;;20478:37;;20548:5;20534:11;:19;20530:117;;;20606:4;20612:11;20625:5;20581:50;;;;;;;;;;;;;:::i;:::-;;;;;;;;20530:117;20802:5;20788:11;:19;20770:9;:15;20780:4;20770:15;;;;;;;;;;;;;;;:37;;;;20463:371;20282:552;20864:1;20850:16;;:2;:16;;;20846:435;;21032:5;21016:12;;:21;;;;;;;;;;;20846:435;;;21249:5;21232:9;:13;21242:2;21232:13;;;;;;;;;;;;;;;;:22;;;;;;;;;;;20846:435;21313:2;21298:25;;21307:4;21298:25;;;21317:5;21298:25;;;;;;:::i;:::-;;;;;;;;20196:1135;;;:::o;7:99:1:-;59:6;93:5;87:12;77:22;;7:99;;;:::o;112:169::-;196:11;230:6;225:3;218:19;270:4;265:3;261:14;246:29;;112:169;;;;:::o;287:246::-;368:1;378:113;392:6;389:1;386:13;378:113;;;477:1;472:3;468:11;462:18;458:1;453:3;449:11;442:39;414:2;411:1;407:10;402:15;;378:113;;;525:1;516:6;511:3;507:16;500:27;349:184;287:246;;;:::o;539:102::-;580:6;631:2;627:7;622:2;615:5;611:14;607:28;597:38;;539:102;;;:::o;647:377::-;735:3;763:39;796:5;763:39;:::i;:::-;818:71;882:6;877:3;818:71;:::i;:::-;811:78;;898:65;956:6;951:3;944:4;937:5;933:16;898:65;:::i;:::-;988:29;1010:6;988:29;:::i;:::-;983:3;979:39;972:46;;739:285;647:377;;;;:::o;1030:313::-;1143:4;1181:2;1170:9;1166:18;1158:26;;1230:9;1224:4;1220:20;1216:1;1205:9;1201:17;1194:47;1258:78;1331:4;1322:6;1258:78;:::i;:::-;1250:86;;1030:313;;;;:::o;1430:117::-;1539:1;1536;1529:12;1676:126;1713:7;1753:42;1746:5;1742:54;1731:65;;1676:126;;;:::o;1808:96::-;1845:7;1874:24;1892:5;1874:24;:::i;:::-;1863:35;;1808:96;;;:::o;1910:122::-;1983:24;2001:5;1983:24;:::i;:::-;1976:5;1973:35;1963:63;;2022:1;2019;2012:12;1963:63;1910:122;:::o;2038:139::-;2084:5;2122:6;2109:20;2100:29;;2138:33;2165:5;2138:33;:::i;:::-;2038:139;;;;:::o;2183:77::-;2220:7;2249:5;2238:16;;2183:77;;;:::o;2266:122::-;2339:24;2357:5;2339:24;:::i;:::-;2332:5;2329:35;2319:63;;2378:1;2375;2368:12;2319:63;2266:122;:::o;2394:139::-;2440:5;2478:6;2465:20;2456:29;;2494:33;2521:5;2494:33;:::i;:::-;2394:139;;;;:::o;2539:474::-;2607:6;2615;2664:2;2652:9;2643:7;2639:23;2635:32;2632:119;;;2670:79;;:::i;:::-;2632:119;2790:1;2815:53;2860:7;2851:6;2840:9;2836:22;2815:53;:::i;:::-;2805:63;;2761:117;2917:2;2943:53;2988:7;2979:6;2968:9;2964:22;2943:53;:::i;:::-;2933:63;;2888:118;2539:474;;;;;:::o;3019:90::-;3053:7;3096:5;3089:13;3082:21;3071:32;;3019:90;;;:::o;3115:109::-;3196:21;3211:5;3196:21;:::i;:::-;3191:3;3184:34;3115:109;;:::o;3230:210::-;3317:4;3355:2;3344:9;3340:18;3332:26;;3368:65;3430:1;3419:9;3415:17;3406:6;3368:65;:::i;:::-;3230:210;;;;:::o;3446:118::-;3533:24;3551:5;3533:24;:::i;:::-;3528:3;3521:37;3446:118;;:::o;3570:222::-;3663:4;3701:2;3690:9;3686:18;3678:26;;3714:71;3782:1;3771:9;3767:17;3758:6;3714:71;:::i;:::-;3570:222;;;;:::o;3798:619::-;3875:6;3883;3891;3940:2;3928:9;3919:7;3915:23;3911:32;3908:119;;;3946:79;;:::i;:::-;3908:119;4066:1;4091:53;4136:7;4127:6;4116:9;4112:22;4091:53;:::i;:::-;4081:63;;4037:117;4193:2;4219:53;4264:7;4255:6;4244:9;4240:22;4219:53;:::i;:::-;4209:63;;4164:118;4321:2;4347:53;4392:7;4383:6;4372:9;4368:22;4347:53;:::i;:::-;4337:63;;4292:118;3798:619;;;;;:::o;4423:86::-;4458:7;4498:4;4491:5;4487:16;4476:27;;4423:86;;;:::o;4515:112::-;4598:22;4614:5;4598:22;:::i;:::-;4593:3;4586:35;4515:112;;:::o;4633:214::-;4722:4;4760:2;4749:9;4745:18;4737:26;;4773:67;4837:1;4826:9;4822:17;4813:6;4773:67;:::i;:::-;4633:214;;;;:::o;4853:329::-;4912:6;4961:2;4949:9;4940:7;4936:23;4932:32;4929:119;;;4967:79;;:::i;:::-;4929:119;5087:1;5112:53;5157:7;5148:6;5137:9;5133:22;5112:53;:::i;:::-;5102:63;;5058:117;4853:329;;;;:::o;5188:474::-;5256:6;5264;5313:2;5301:9;5292:7;5288:23;5284:32;5281:119;;;5319:79;;:::i;:::-;5281:119;5439:1;5464:53;5509:7;5500:6;5489:9;5485:22;5464:53;:::i;:::-;5454:63;;5410:117;5566:2;5592:53;5637:7;5628:6;5617:9;5613:22;5592:53;:::i;:::-;5582:63;;5537:118;5188:474;;;;;:::o;5668:180::-;5716:77;5713:1;5706:88;5813:4;5810:1;5803:15;5837:4;5834:1;5827:15;5854:320;5898:6;5935:1;5929:4;5925:12;5915:22;;5982:1;5976:4;5972:12;6003:18;5993:81;;6059:4;6051:6;6047:17;6037:27;;5993:81;6121:2;6113:6;6110:14;6090:18;6087:38;6084:84;;6140:18;;:::i;:::-;6084:84;5905:269;5854:320;;;:::o;6180:180::-;6228:77;6225:1;6218:88;6325:4;6322:1;6315:15;6349:4;6346:1;6339:15;6366:191;6406:3;6425:20;6443:1;6425:20;:::i;:::-;6420:25;;6459:20;6477:1;6459:20;:::i;:::-;6454:25;;6502:1;6499;6495:9;6488:16;;6523:3;6520:1;6517:10;6514:36;;;6530:18;;:::i;:::-;6514:36;6366:191;;;;:::o;6563:118::-;6650:24;6668:5;6650:24;:::i;:::-;6645:3;6638:37;6563:118;;:::o;6687:442::-;6836:4;6874:2;6863:9;6859:18;6851:26;;6887:71;6955:1;6944:9;6940:17;6931:6;6887:71;:::i;:::-;6968:72;7036:2;7025:9;7021:18;7012:6;6968:72;:::i;:::-;7050;7118:2;7107:9;7103:18;7094:6;7050:72;:::i;:::-;6687:442;;;;;;:::o;7135:222::-;7228:4;7266:2;7255:9;7251:18;7243:26;;7279:71;7347:1;7336:9;7332:17;7323:6;7279:71;:::i;:::-;7135:222;;;;:::o
Swarm Source
ipfs://af97170eae9cc0ac5d74f315d2532f355bee4484c44a21560076a8156c87f4ed
[ 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.