ETH Price: $3,192.54 (+0.31%)

Token

Safuchain (SAFU)
 

Overview

Max Total Supply

17,482,211,396.05 SAFU

Holders

442

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Filtered by Token Holder
cryptosmillie.eth
Balance
7,600,000 SAFU

Value
$0.00
0xf831b3099806bb94bb23002b20fdb42e75294073
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
JBToken

Compiler Version
v0.8.6+commit.11564f7e

Optimization Enabled:
Yes with 10000 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-09-19
*/

// File: IJBToken.sol


pragma solidity 0.8.6;

interface IJBToken {
  function decimals() external view returns (uint8);

  function totalSupply(uint256 _projectId) external view returns (uint256);

  function balanceOf(address _account, uint256 _projectId) external view returns (uint256);

  function mint(
    uint256 _projectId,
    address _account,
    uint256 _amount
  ) external;

  function burn(
    uint256 _projectId,
    address _account,
    uint256 _amount
  ) external;

  function approve(
    uint256,
    address _spender,
    uint256 _amount
  ) external;

  function transfer(
    uint256 _projectId,
    address _to,
    uint256 _amount
  ) external;

  function transferFrom(
    uint256 _projectId,
    address _from,
    address _to,
    uint256 _amount
  ) external;

  function transferOwnership(uint256 _projectId, address _newOwner) external;
}
// File: Counters.sol


// OpenZeppelin Contracts v4.4.1 (utils/Counters.sol)

pragma solidity ^0.8.0;

/**
 * @title Counters
 * @author Matt Condon (@shrugs)
 * @dev Provides counters that can only be incremented, decremented or reset. This can be used e.g. to track the number
 * of elements in a mapping, issuing ERC721 ids, or counting request ids.
 *
 * Include with `using Counters for Counters.Counter;`
 */
library Counters {
    struct Counter {
        // This variable should never be directly accessed by users of the library: interactions must be restricted to
        // the library's function. As of Solidity v0.5.2, this cannot be enforced, though there is a proposal to add
        // this feature: see https://github.com/ethereum/solidity/issues/4637
        uint256 _value; // default: 0
    }

    function current(Counter storage counter) internal view returns (uint256) {
        return counter._value;
    }

    function increment(Counter storage counter) internal {
        unchecked {
            counter._value += 1;
        }
    }

    function decrement(Counter storage counter) internal {
        uint256 value = counter._value;
        require(value > 0, "Counter: decrement overflow");
        unchecked {
            counter._value = value - 1;
        }
    }

    function reset(Counter storage counter) internal {
        counter._value = 0;
    }
}
// File: Strings.sol


// OpenZeppelin Contracts v4.4.1 (utils/Strings.sol)

pragma solidity ^0.8.0;

/**
 * @dev String operations.
 */
library Strings {
    bytes16 private constant _HEX_SYMBOLS = "0123456789abcdef";

    /**
     * @dev Converts a `uint256` to its ASCII `string` decimal representation.
     */
    function toString(uint256 value) internal pure returns (string memory) {
        // Inspired by OraclizeAPI's implementation - MIT licence
        // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol

        if (value == 0) {
            return "0";
        }
        uint256 temp = value;
        uint256 digits;
        while (temp != 0) {
            digits++;
            temp /= 10;
        }
        bytes memory buffer = new bytes(digits);
        while (value != 0) {
            digits -= 1;
            buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));
            value /= 10;
        }
        return string(buffer);
    }

    /**
     * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.
     */
    function toHexString(uint256 value) internal pure returns (string memory) {
        if (value == 0) {
            return "0x00";
        }
        uint256 temp = value;
        uint256 length = 0;
        while (temp != 0) {
            length++;
            temp >>= 8;
        }
        return toHexString(value, length);
    }

    /**
     * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.
     */
    function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {
        bytes memory buffer = new bytes(2 * length + 2);
        buffer[0] = "0";
        buffer[1] = "x";
        for (uint256 i = 2 * length + 1; i > 1; --i) {
            buffer[i] = _HEX_SYMBOLS[value & 0xf];
            value >>= 4;
        }
        require(value == 0, "Strings: hex length insufficient");
        return string(buffer);
    }
}
// File: ECDSA.sol


// OpenZeppelin Contracts (last updated v4.5.0-rc.0) (utils/cryptography/ECDSA.sol)

pragma solidity ^0.8.0;


/**
 * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.
 *
 * These functions can be used to verify that a message was signed by the holder
 * of the private keys of a given address.
 */
library ECDSA {
    enum RecoverError {
        NoError,
        InvalidSignature,
        InvalidSignatureLength,
        InvalidSignatureS,
        InvalidSignatureV
    }

    function _throwError(RecoverError error) private pure {
        if (error == RecoverError.NoError) {
            return; // no error: do nothing
        } else if (error == RecoverError.InvalidSignature) {
            revert("ECDSA: invalid signature");
        } else if (error == RecoverError.InvalidSignatureLength) {
            revert("ECDSA: invalid signature length");
        } else if (error == RecoverError.InvalidSignatureS) {
            revert("ECDSA: invalid signature 's' value");
        } else if (error == RecoverError.InvalidSignatureV) {
            revert("ECDSA: invalid signature 'v' value");
        }
    }

    /**
     * @dev Returns the address that signed a hashed message (`hash`) with
     * `signature` or error string. This address can then be used for verification purposes.
     *
     * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:
     * this function rejects them by requiring the `s` value to be in the lower
     * half order, and the `v` value to be either 27 or 28.
     *
     * IMPORTANT: `hash` _must_ be the result of a hash operation for the
     * verification to be secure: it is possible to craft signatures that
     * recover to arbitrary addresses for non-hashed data. A safe way to ensure
     * this is by receiving a hash of the original message (which may otherwise
     * be too long), and then calling {toEthSignedMessageHash} on it.
     *
     * Documentation for signature generation:
     * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]
     * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]
     *
     * _Available since v4.3._
     */
    function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {
        // Check the signature length
        // - case 65: r,s,v signature (standard)
        // - case 64: r,vs signature (cf https://eips.ethereum.org/EIPS/eip-2098) _Available since v4.1._
        if (signature.length == 65) {
            bytes32 r;
            bytes32 s;
            uint8 v;
            // ecrecover takes the signature parameters, and the only way to get them
            // currently is to use assembly.
            assembly {
                r := mload(add(signature, 0x20))
                s := mload(add(signature, 0x40))
                v := byte(0, mload(add(signature, 0x60)))
            }
            return tryRecover(hash, v, r, s);
        } else if (signature.length == 64) {
            bytes32 r;
            bytes32 vs;
            // ecrecover takes the signature parameters, and the only way to get them
            // currently is to use assembly.
            assembly {
                r := mload(add(signature, 0x20))
                vs := mload(add(signature, 0x40))
            }
            return tryRecover(hash, r, vs);
        } else {
            return (address(0), RecoverError.InvalidSignatureLength);
        }
    }

    /**
     * @dev Returns the address that signed a hashed message (`hash`) with
     * `signature`. This address can then be used for verification purposes.
     *
     * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:
     * this function rejects them by requiring the `s` value to be in the lower
     * half order, and the `v` value to be either 27 or 28.
     *
     * IMPORTANT: `hash` _must_ be the result of a hash operation for the
     * verification to be secure: it is possible to craft signatures that
     * recover to arbitrary addresses for non-hashed data. A safe way to ensure
     * this is by receiving a hash of the original message (which may otherwise
     * be too long), and then calling {toEthSignedMessageHash} on it.
     */
    function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {
        (address recovered, RecoverError error) = tryRecover(hash, signature);
        _throwError(error);
        return recovered;
    }

    /**
     * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.
     *
     * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]
     *
     * _Available since v4.3._
     */
    function tryRecover(
        bytes32 hash,
        bytes32 r,
        bytes32 vs
    ) internal pure returns (address, RecoverError) {
        bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);
        uint8 v = uint8((uint256(vs) >> 255) + 27);
        return tryRecover(hash, v, r, s);
    }

    /**
     * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.
     *
     * _Available since v4.2._
     */
    function recover(
        bytes32 hash,
        bytes32 r,
        bytes32 vs
    ) internal pure returns (address) {
        (address recovered, RecoverError error) = tryRecover(hash, r, vs);
        _throwError(error);
        return recovered;
    }

    /**
     * @dev Overload of {ECDSA-tryRecover} that receives the `v`,
     * `r` and `s` signature fields separately.
     *
     * _Available since v4.3._
     */
    function tryRecover(
        bytes32 hash,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) internal pure returns (address, RecoverError) {
        // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature
        // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines
        // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most
        // signatures from current libraries generate a unique signature with an s-value in the lower half order.
        //
        // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value
        // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or
        // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept
        // these malleable signatures as well.
        if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {
            return (address(0), RecoverError.InvalidSignatureS);
        }
        if (v != 27 && v != 28) {
            return (address(0), RecoverError.InvalidSignatureV);
        }

        // If the signature is valid (and not malleable), return the signer address
        address signer = ecrecover(hash, v, r, s);
        if (signer == address(0)) {
            return (address(0), RecoverError.InvalidSignature);
        }

        return (signer, RecoverError.NoError);
    }

    /**
     * @dev Overload of {ECDSA-recover} that receives the `v`,
     * `r` and `s` signature fields separately.
     */
    function recover(
        bytes32 hash,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) internal pure returns (address) {
        (address recovered, RecoverError error) = tryRecover(hash, v, r, s);
        _throwError(error);
        return recovered;
    }

    /**
     * @dev Returns an Ethereum Signed Message, created from a `hash`. This
     * produces hash corresponding to the one signed with the
     * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]
     * JSON-RPC method as part of EIP-191.
     *
     * See {recover}.
     */
    function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {
        // 32 is the length in bytes of hash,
        // enforced by the type signature above
        return keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n32", hash));
    }

    /**
     * @dev Returns an Ethereum Signed Message, created from `s`. This
     * produces hash corresponding to the one signed with the
     * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]
     * JSON-RPC method as part of EIP-191.
     *
     * See {recover}.
     */
    function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {
        return keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n", Strings.toString(s.length), s));
    }

    /**
     * @dev Returns an Ethereum Signed Typed Data, created from a
     * `domainSeparator` and a `structHash`. This produces hash corresponding
     * to the one signed with the
     * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]
     * JSON-RPC method as part of EIP-712.
     *
     * See {recover}.
     */
    function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {
        return keccak256(abi.encodePacked("\x19\x01", domainSeparator, structHash));
    }
}
// File: draft-EIP712.sol


// OpenZeppelin Contracts v4.4.1 (utils/cryptography/draft-EIP712.sol)

pragma solidity ^0.8.0;


/**
 * @dev https://eips.ethereum.org/EIPS/eip-712[EIP 712] is a standard for hashing and signing of typed structured data.
 *
 * The encoding specified in the EIP is very generic, and such a generic implementation in Solidity is not feasible,
 * thus this contract does not implement the encoding itself. Protocols need to implement the type-specific encoding
 * they need in their contracts using a combination of `abi.encode` and `keccak256`.
 *
 * This contract implements the EIP 712 domain separator ({_domainSeparatorV4}) that is used as part of the encoding
 * scheme, and the final step of the encoding to obtain the message digest that is then signed via ECDSA
 * ({_hashTypedDataV4}).
 *
 * The implementation of the domain separator was designed to be as efficient as possible while still properly updating
 * the chain id to protect against replay attacks on an eventual fork of the chain.
 *
 * NOTE: This contract implements the version of the encoding known as "v4", as implemented by the JSON RPC method
 * https://docs.metamask.io/guide/signing-data.html[`eth_signTypedDataV4` in MetaMask].
 *
 * _Available since v3.4._
 */
abstract contract EIP712 {
    /* solhint-disable var-name-mixedcase */
    // Cache the domain separator as an immutable value, but also store the chain id that it corresponds to, in order to
    // invalidate the cached domain separator if the chain id changes.
    bytes32 private immutable _CACHED_DOMAIN_SEPARATOR;
    uint256 private immutable _CACHED_CHAIN_ID;
    address private immutable _CACHED_THIS;

    bytes32 private immutable _HASHED_NAME;
    bytes32 private immutable _HASHED_VERSION;
    bytes32 private immutable _TYPE_HASH;

    /* solhint-enable var-name-mixedcase */

    /**
     * @dev Initializes the domain separator and parameter caches.
     *
     * The meaning of `name` and `version` is specified in
     * https://eips.ethereum.org/EIPS/eip-712#definition-of-domainseparator[EIP 712]:
     *
     * - `name`: the user readable name of the signing domain, i.e. the name of the DApp or the protocol.
     * - `version`: the current major version of the signing domain.
     *
     * NOTE: These parameters cannot be changed except through a xref:learn::upgrading-smart-contracts.adoc[smart
     * contract upgrade].
     */
    constructor(string memory name, string memory version) {
        bytes32 hashedName = keccak256(bytes(name));
        bytes32 hashedVersion = keccak256(bytes(version));
        bytes32 typeHash = keccak256(
            "EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)"
        );
        _HASHED_NAME = hashedName;
        _HASHED_VERSION = hashedVersion;
        _CACHED_CHAIN_ID = block.chainid;
        _CACHED_DOMAIN_SEPARATOR = _buildDomainSeparator(typeHash, hashedName, hashedVersion);
        _CACHED_THIS = address(this);
        _TYPE_HASH = typeHash;
    }

    /**
     * @dev Returns the domain separator for the current chain.
     */
    function _domainSeparatorV4() internal view returns (bytes32) {
        if (address(this) == _CACHED_THIS && block.chainid == _CACHED_CHAIN_ID) {
            return _CACHED_DOMAIN_SEPARATOR;
        } else {
            return _buildDomainSeparator(_TYPE_HASH, _HASHED_NAME, _HASHED_VERSION);
        }
    }

    function _buildDomainSeparator(
        bytes32 typeHash,
        bytes32 nameHash,
        bytes32 versionHash
    ) private view returns (bytes32) {
        return keccak256(abi.encode(typeHash, nameHash, versionHash, block.chainid, address(this)));
    }

    /**
     * @dev Given an already https://eips.ethereum.org/EIPS/eip-712#definition-of-hashstruct[hashed struct], this
     * function returns the hash of the fully encoded EIP712 message for this domain.
     *
     * This hash can be used together with {ECDSA-recover} to obtain the signer of a message. For example:
     *
     * ```solidity
     * bytes32 digest = _hashTypedDataV4(keccak256(abi.encode(
     *     keccak256("Mail(address to,string contents)"),
     *     mailTo,
     *     keccak256(bytes(mailContents))
     * )));
     * address signer = ECDSA.recover(digest, signature);
     * ```
     */
    function _hashTypedDataV4(bytes32 structHash) internal view virtual returns (bytes32) {
        return ECDSA.toTypedDataHash(_domainSeparatorV4(), structHash);
    }
}
// File: Context.sol


// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)

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) {
        return msg.data;
    }
}
// File: Ownable.sol


// OpenZeppelin Contracts v4.4.1 (access/Ownable.sol)

pragma solidity ^0.8.0;


/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _transferOwnership(_msgSender());
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}
// File: IERC20.sol


// OpenZeppelin Contracts v4.4.1 (token/ERC20/IERC20.sol)

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: IERC20Metadata.sol


// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)

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: ERC20.sol


// OpenZeppelin Contracts (last updated v4.5.0-rc.0) (token/ERC20/ERC20.sol)

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 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}.
 */
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 default 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}.
     *
     * NOTE: If `amount` 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 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}.
     *
     * NOTE: Does not update the allowance if the current allowance
     * is the maximum `uint256`.
     *
     * 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) {
        uint256 currentAllowance = _allowances[sender][_msgSender()];
        if (currentAllowance != type(uint256).max) {
            require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");
            unchecked {
                _approve(sender, _msgSender(), currentAllowance - amount);
            }
        }

        _transfer(sender, recipient, 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");
        unchecked {
            _approve(_msgSender(), spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    /**
     * @dev Moves `amount` of tokens from `sender` to `recipient`.
     *
     * 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.
     *
     * 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");
        unchecked {
            _balances[sender] = senderBalance - amount;
        }
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);

        _afterTokenTransfer(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:
     *
     * - `account` 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);

        _afterTokenTransfer(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");
        unchecked {
            _balances[account] = accountBalance - amount;
        }
        _totalSupply -= amount;

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

        _afterTokenTransfer(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 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 {}

    /**
     * @dev Hook that is called after any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * has been transferred to `to`.
     * - when `from` is zero, `amount` tokens have been minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens have been 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 _afterTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}
// File: draft-IERC20Permit.sol


// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/draft-IERC20Permit.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC20 Permit extension allowing approvals to be made via signatures, as defined in
 * https://eips.ethereum.org/EIPS/eip-2612[EIP-2612].
 *
 * Adds the {permit} method, which can be used to change an account's ERC20 allowance (see {IERC20-allowance}) by
 * presenting a message signed by the account. By not relying on {IERC20-approve}, the token holder account doesn't
 * need to send a transaction, and thus is not required to hold Ether at all.
 */
interface IERC20Permit {
    /**
     * @dev Sets `value` as the allowance of `spender` over ``owner``'s tokens,
     * given ``owner``'s signed approval.
     *
     * IMPORTANT: The same issues {IERC20-approve} has related to transaction
     * ordering also apply here.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `deadline` must be a timestamp in the future.
     * - `v`, `r` and `s` must be a valid `secp256k1` signature from `owner`
     * over the EIP712-formatted function arguments.
     * - the signature must use ``owner``'s current nonce (see {nonces}).
     *
     * For more information on the signature format, see the
     * https://eips.ethereum.org/EIPS/eip-2612#specification[relevant EIP
     * section].
     */
    function permit(
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external;

    /**
     * @dev Returns the current nonce for `owner`. This value must be
     * included whenever a signature is generated for {permit}.
     *
     * Every successful call to {permit} increases ``owner``'s nonce by one. This
     * prevents a signature from being used multiple times.
     */
    function nonces(address owner) external view returns (uint256);

    /**
     * @dev Returns the domain separator used in the encoding of the signature for {permit}, as defined by {EIP712}.
     */
    // solhint-disable-next-line func-name-mixedcase
    function DOMAIN_SEPARATOR() external view returns (bytes32);
}
// File: draft-ERC20Permit.sol


// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/draft-ERC20Permit.sol)

pragma solidity ^0.8.0;






/**
 * @dev Implementation of the ERC20 Permit extension allowing approvals to be made via signatures, as defined in
 * https://eips.ethereum.org/EIPS/eip-2612[EIP-2612].
 *
 * Adds the {permit} method, which can be used to change an account's ERC20 allowance (see {IERC20-allowance}) by
 * presenting a message signed by the account. By not relying on `{IERC20-approve}`, the token holder account doesn't
 * need to send a transaction, and thus is not required to hold Ether at all.
 *
 * _Available since v3.4._
 */
abstract contract ERC20Permit is ERC20, IERC20Permit, EIP712 {
    using Counters for Counters.Counter;

    mapping(address => Counters.Counter) private _nonces;

    // solhint-disable-next-line var-name-mixedcase
    bytes32 private immutable _PERMIT_TYPEHASH =
        keccak256("Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)");

    /**
     * @dev Initializes the {EIP712} domain separator using the `name` parameter, and setting `version` to `"1"`.
     *
     * It's a good idea to use the same `name` that is defined as the ERC20 token name.
     */
    constructor(string memory name) EIP712(name, "1") {}

    /**
     * @dev See {IERC20Permit-permit}.
     */
    function permit(
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) public virtual override {
        require(block.timestamp <= deadline, "ERC20Permit: expired deadline");

        bytes32 structHash = keccak256(abi.encode(_PERMIT_TYPEHASH, owner, spender, value, _useNonce(owner), deadline));

        bytes32 hash = _hashTypedDataV4(structHash);

        address signer = ECDSA.recover(hash, v, r, s);
        require(signer == owner, "ERC20Permit: invalid signature");

        _approve(owner, spender, value);
    }

    /**
     * @dev See {IERC20Permit-nonces}.
     */
    function nonces(address owner) public view virtual override returns (uint256) {
        return _nonces[owner].current();
    }

    /**
     * @dev See {IERC20Permit-DOMAIN_SEPARATOR}.
     */
    // solhint-disable-next-line func-name-mixedcase
    function DOMAIN_SEPARATOR() external view override returns (bytes32) {
        return _domainSeparatorV4();
    }

    /**
     * @dev "Consume a nonce": return the current value and increment.
     *
     * _Available since v4.1._
     */
    function _useNonce(address owner) internal virtual returns (uint256 current) {
        Counters.Counter storage nonce = _nonces[owner];
        current = nonce.current();
        nonce.increment();
    }
}
// File: JBToken.sol


pragma solidity 0.8.6;




/** 
  @notice
  An ERC-20 token that can be used by a project in the `JBTokenStore`.

  @dev
  Adheres to -
  IJBToken: Allows this contract to be used by projects in the JBTokenStore.

  @dev
  Inherits from -
  ERC20Permit: General token standard for fungible accounting. 
  Ownable: Includes convenience functionality for checking a message sender's permissions before executing certain transactions.
*/
contract JBToken is IJBToken, ERC20Permit, Ownable {
  //*********************************************************************//
  // ------------------------- external views -------------------------- //
  //*********************************************************************//

  /** 
    @notice
    The total supply of this ERC20.

    @param _projectId the ID of the project to which the token belongs. This is ignored.

    @return The total supply of this ERC20, as a fixed point number.
  */
  function totalSupply(uint256 _projectId) external view override returns (uint256) {
    _projectId; // Prevents unused var compiler and natspec complaints.

    return super.totalSupply();
  }

  /** 
    @notice
    An account's balance of this ERC20.

    @param _account The account to get a balance of.
    @param _projectId is the ID of the project to which the token belongs. This is ignored.

    @return The balance of the `_account` of this ERC20, as a fixed point number with 18 decimals.
  */
  function balanceOf(address _account, uint256 _projectId)
    external
    view
    override
    returns (uint256)
  {
    _account; // Prevents unused var compiler and natspec complaints.
    _projectId; // Prevents unused var compiler and natspec complaints.

    return super.balanceOf(_account);
  }

  //*********************************************************************//
  // -------------------------- public views --------------------------- //
  //*********************************************************************//

  /** 
    @notice
    The number of decimals included in the fixed point accounting of this token.

    @return The number of decimals.
  */
  function decimals() public view override(ERC20, IJBToken) returns (uint8) {
    return super.decimals();
  }

  //*********************************************************************//
  // -------------------------- constructor ---------------------------- //
  //*********************************************************************//

  /** 
    @param _name The name of the token.
    @param _symbol The symbol that the token should be represented by.
  */
  constructor(string memory _name, string memory _symbol)
    ERC20(_name, _symbol)
    ERC20Permit(_name)
  // solhint-disable-next-line no-empty-blocks
  {

  }

  //*********************************************************************//
  // ---------------------- external transactions ---------------------- //
  //*********************************************************************//

  /** 
    @notice
    Mints more of the token.

    @dev
    Only the owner of this contract cant mint more of it.

    @param _projectId The ID of the project to which the token belongs. This is ignored.
    @param _account The account to mint the tokens for.
    @param _amount The amount of tokens to mint, as a fixed point number with 18 decimals.
  */
  function mint(
    uint256 _projectId,
    address _account,
    uint256 _amount
  ) external override onlyOwner {
    _projectId; // Prevents unused var compiler and natspec complaints.

    return _mint(_account, _amount);
  }

  /** 
    @notice
    Burn some outstanding tokens.

    @dev
    Only the owner of this contract cant burn some of its supply.

    @param _projectId The ID of the project to which the token belongs. This is ignored.
    @param _account The account to burn tokens from.
    @param _amount The amount of tokens to burn, as a fixed point number with 18 decimals.
  */
  function burn(
    uint256 _projectId,
    address _account,
    uint256 _amount
  ) external override onlyOwner {
    _projectId; // Prevents unused var compiler and natspec complaints.

    return _burn(_account, _amount);
  }

  /** 
    @notice
    Approves an account to spend tokens on the `msg.sender`s behalf.

    @param _projectId the ID of the project to which the token belongs. This is ignored.
    @param _spender The address that will be spending tokens on the `msg.sender`s behalf.
    @param _amount The amount the `_spender` is allowed to spend.
  */
  function approve(
    uint256 _projectId,
    address _spender,
    uint256 _amount
  ) external override {
    _projectId; // Prevents unused var compiler and natspec complaints.

    approve(_spender, _amount);
  }

  /** 
    @notice
    Transfer tokens to an account.
    
    @param _projectId The ID of the project to which the token belongs. This is ignored.
    @param _to The destination address.
    @param _amount The amount of the transfer, as a fixed point number with 18 decimals.
  */
  function transfer(
    uint256 _projectId,
    address _to,
    uint256 _amount
  ) external override {
    _projectId; // Prevents unused var compiler and natspec complaints.

    transfer(_to, _amount);
  }

  /** 
    @notice
    Transfer tokens between accounts.

    @param _projectId The ID of the project to which the token belongs. This is ignored.
    @param _from The originating address.
    @param _to The destination address.
    @param _amount The amount of the transfer, as a fixed point number with 18 decimals.
  */
  function transferFrom(
    uint256 _projectId,
    address _from,
    address _to,
    uint256 _amount
  ) external override {
    _projectId; // Prevents unused var compiler and natspec complaints.

    transferFrom(_from, _to, _amount);
  }

  //*********************************************************************//
  // ------------------------ public transactions ---------------------- //
  //*********************************************************************//

  /** 
    @notice
    Transfer ownership of this contract to another address.

    @dev
    Only the owner of this contract can transfer it.

    @param _projectId The ID of the project to which the token belongs. This is ignored.
    @param _newOwner The new owner.
  */
  function transferOwnership(uint256 _projectId, address _newOwner)
    public
    virtual
    override
    onlyOwner
  {
    _projectId; // Prevents unused var compiler and natspec complaints.

    return super.transferOwnership(_newOwner);
  }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_projectId","type":"uint256"},{"internalType":"address","name":"_spender","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"approve","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_account","type":"address"},{"internalType":"uint256","name":"_projectId","type":"uint256"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","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":"_projectId","type":"uint256"},{"internalType":"address","name":"_account","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"burn","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":[{"internalType":"uint256","name":"_projectId","type":"uint256"},{"internalType":"address","name":"_account","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"permit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_projectId","type":"uint256"}],"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":"uint256","name":"_projectId","type":"uint256"},{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"transfer","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_projectId","type":"uint256"},{"internalType":"address","name":"_from","type":"address"},{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"transferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_projectId","type":"uint256"},{"internalType":"address","name":"_newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]

6101606040527f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9610140523480156200003757600080fd5b5060405162001f5c38038062001f5c8339810160408190526200005a9162000310565b8180604051806040016040528060018152602001603160f81b8152508484816003908051906020019062000090929190620001b3565b508051620000a6906004906020840190620001b3565b5050825160208085019190912083518483012060e08290526101008190524660a0818152604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f81880181905281830187905260608201869052608082019490945230818401528151808203909301835260c0019052805194019390932091935091906080523060601b60c05261012052506200015593506200014f9250506200015d9050565b62000161565b5050620003cd565b3390565b600680546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b828054620001c1906200037a565b90600052602060002090601f016020900481019282620001e5576000855562000230565b82601f106200020057805160ff191683800117855562000230565b8280016001018555821562000230579182015b828111156200023057825182559160200191906001019062000213565b506200023e92915062000242565b5090565b5b808211156200023e576000815560010162000243565b600082601f8301126200026b57600080fd5b81516001600160401b0380821115620002885762000288620003b7565b604051601f8301601f19908116603f01168101908282118183101715620002b357620002b3620003b7565b81604052838152602092508683858801011115620002d057600080fd5b600091505b83821015620002f45785820183015181830184015290820190620002d5565b83821115620003065760008385830101525b9695505050505050565b600080604083850312156200032457600080fd5b82516001600160401b03808211156200033c57600080fd5b6200034a8683870162000259565b935060208501519150808211156200036157600080fd5b50620003708582860162000259565b9150509250929050565b600181811c908216806200038f57607f821691505b60208210811415620003b157634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052604160045260246000fd5b60805160a05160c05160601c60e051610100516101205161014051611b316200042b600039600061095e01526000611016015260006110650152600061104001526000610f9901526000610fc301526000610fed0152611b316000f3fe608060405234801561001057600080fd5b50600436106101a25760003560e01c80637ecebe00116100ee578063a457c2d711610097578063d505accf11610071578063d505accf14610365578063dd62ed3e14610378578063f2fde38b146103be578063f8548e36146103d157600080fd5b8063a457c2d71461032c578063a9059cbb1461033f578063bd85b0391461035257600080fd5b80638da5cb5b116100c85780638da5cb5b146102e957806395d89b41146103115780639eea5f661461031957600080fd5b80637ecebe00146102b0578063836a1040146102c35780638cb0a511146102d657600080fd5b806329507f7311610150578063395093511161012a578063395093511461025f57806370a0823114610272578063715018a6146102a857600080fd5b806329507f7314610235578063313ce567146102485780633644e5151461025757600080fd5b806318160ddd1161018157806318160ddd146102055780631c0f12b61461020d57806323b872dd1461022257600080fd5b8062fdd58e146101a757806306fdde03146101cd578063095ea7b3146101e2575b600080fd5b6101ba6101b53660046118de565b6103e4565b6040519081526020015b60405180910390f35b6101d5610412565b6040516101c491906119ad565b6101f56101f03660046118de565b6104a4565b60405190151581526020016101c4565b6002546101ba565b61022061021b366004611944565b6104ba565b005b6101f561023036600461182f565b6104cc565b610220610243366004611921565b6105c2565b604051601281526020016101c4565b6101ba61063b565b6101f561026d3660046118de565b610645565b6101ba6102803660046117e1565b73ffffffffffffffffffffffffffffffffffffffff1660009081526020819052604090205490565b61022061068e565b6101ba6102be3660046117e1565b610701565b6102206102d1366004611988565b61072e565b6102206102e4366004611988565b6107a4565b60065460405173ffffffffffffffffffffffffffffffffffffffff90911681526020016101c4565b6101d56107b4565b610220610327366004611988565b6107c3565b6101f561033a3660046118de565b610834565b6101f561034d3660046118de565b6108f2565b6101ba610360366004611908565b6108ff565b61022061037336600461186b565b61090a565b6101ba6103863660046117fc565b73ffffffffffffffffffffffffffffffffffffffff918216600090815260016020908152604080832093909416825291909152205490565b6102206103cc3660046117e1565b610a95565b6102206103df366004611988565b610b91565b73ffffffffffffffffffffffffffffffffffffffff82166000908152602081905260408120545b9392505050565b60606003805461042190611a4f565b80601f016020809104026020016040519081016040528092919081815260200182805461044d90611a4f565b801561049a5780601f1061046f5761010080835404028352916020019161049a565b820191906000526020600020905b81548152906001019060200180831161047d57829003601f168201915b5050505050905090565b60006104b1338484610b9b565b50600192915050565b6104c58383836104cc565b5050505050565b73ffffffffffffffffffffffffffffffffffffffff831660009081526001602090815260408083203384529091528120547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff81146105ac578281101561059f5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e742065786365656473206160448201527f6c6c6f77616e636500000000000000000000000000000000000000000000000060648201526084015b60405180910390fd5b6105ac8533858403610b9b565b6105b7858585610d1a565b506001949350505050565b60065473ffffffffffffffffffffffffffffffffffffffff1633146106295760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610596565b61063281610a95565b5050565b905090565b6000610636610f7f565b33600081815260016020908152604080832073ffffffffffffffffffffffffffffffffffffffff8716845290915281205490916104b1918590610689908690611a20565b610b9b565b60065473ffffffffffffffffffffffffffffffffffffffff1633146106f55760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610596565b6106ff60006110b3565b565b73ffffffffffffffffffffffffffffffffffffffff81166000908152600560205260408120545b92915050565b60065473ffffffffffffffffffffffffffffffffffffffff1633146107955760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610596565b61079f828261112a565b505050565b6107ae82826104a4565b50505050565b60606004805461042190611a4f565b60065473ffffffffffffffffffffffffffffffffffffffff16331461082a5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610596565b61079f8282611230565b33600090815260016020908152604080832073ffffffffffffffffffffffffffffffffffffffff86168452909152812054828110156108db5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f7760448201527f207a65726f0000000000000000000000000000000000000000000000000000006064820152608401610596565b6108e83385858403610b9b565b5060019392505050565b60006104b1338484610d1a565b600061072860025490565b8342111561095a5760405162461bcd60e51b815260206004820152601d60248201527f45524332305065726d69743a206578706972656420646561646c696e650000006044820152606401610596565b60007f00000000000000000000000000000000000000000000000000000000000000008888886109898c6113e9565b60408051602081019690965273ffffffffffffffffffffffffffffffffffffffff94851690860152929091166060840152608083015260a082015260c0810186905260e00160405160208183030381529060405280519060200120905060006109f18261141e565b90506000610a0182878787611487565b90508973ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614610a7e5760405162461bcd60e51b815260206004820152601e60248201527f45524332305065726d69743a20696e76616c6964207369676e617475726500006044820152606401610596565b610a898a8a8a610b9b565b50505050505050505050565b60065473ffffffffffffffffffffffffffffffffffffffff163314610afc5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610596565b73ffffffffffffffffffffffffffffffffffffffff8116610b855760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f64647265737300000000000000000000000000000000000000000000000000006064820152608401610596565b610b8e816110b3565b50565b6107ae82826108f2565b73ffffffffffffffffffffffffffffffffffffffff8316610c235760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460448201527f72657373000000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff8216610cac5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f20616464726560448201527f73730000000000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff83811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b73ffffffffffffffffffffffffffffffffffffffff8316610da35760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f20616460448201527f64726573730000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff8216610e2c5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201527f65737300000000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff831660009081526020819052604090205481811015610ec85760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e742065786365656473206260448201527f616c616e636500000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff808516600090815260208190526040808220858503905591851681529081208054849290610f0c908490611a20565b925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051610f7291815260200190565b60405180910390a36107ae565b60003073ffffffffffffffffffffffffffffffffffffffff7f000000000000000000000000000000000000000000000000000000000000000016148015610fe557507f000000000000000000000000000000000000000000000000000000000000000046145b1561100f57507f000000000000000000000000000000000000000000000000000000000000000090565b50604080517f00000000000000000000000000000000000000000000000000000000000000006020808301919091527f0000000000000000000000000000000000000000000000000000000000000000828401527f000000000000000000000000000000000000000000000000000000000000000060608301524660808301523060a0808401919091528351808403909101815260c0909201909252805191012090565b6006805473ffffffffffffffffffffffffffffffffffffffff8381167fffffffffffffffffffffffff0000000000000000000000000000000000000000831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b73ffffffffffffffffffffffffffffffffffffffff821661118d5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401610596565b806002600082825461119f9190611a20565b909155505073ffffffffffffffffffffffffffffffffffffffff8216600090815260208190526040812080548392906111d9908490611a20565b909155505060405181815273ffffffffffffffffffffffffffffffffffffffff8316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b73ffffffffffffffffffffffffffffffffffffffff82166112b95760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f2061646472657360448201527f73000000000000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff8216600090815260208190526040902054818110156113555760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e60448201527f63650000000000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff83166000908152602081905260408120838303905560028054849290611391908490611a38565b909155505060405182815260009073ffffffffffffffffffffffffffffffffffffffff8516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3505050565b73ffffffffffffffffffffffffffffffffffffffff811660009081526005602052604090208054600181018255905b50919050565b600061072861142b610f7f565b836040517f19010000000000000000000000000000000000000000000000000000000000006020820152602281018390526042810182905260009060620160405160208183030381529060405280519060200120905092915050565b6000806000611498878787876114af565b915091506114a5816115c7565b5095945050505050565b6000807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a08311156114e657506000905060036115be565b8460ff16601b141580156114fe57508460ff16601c14155b1561150f57506000905060046115be565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa158015611563573d6000803e3d6000fd5b50506040517fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe0015191505073ffffffffffffffffffffffffffffffffffffffff81166115b7576000600192509250506115be565b9150600090505b94509492505050565b60008160048111156115db576115db611acc565b14156115e45750565b60018160048111156115f8576115f8611acc565b14156116465760405162461bcd60e51b815260206004820152601860248201527f45434453413a20696e76616c6964207369676e617475726500000000000000006044820152606401610596565b600281600481111561165a5761165a611acc565b14156116a85760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610596565b60038160048111156116bc576116bc611acc565b14156117305760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c60448201527f75650000000000000000000000000000000000000000000000000000000000006064820152608401610596565b600481600481111561174457611744611acc565b1415610b8e5760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c60448201527f75650000000000000000000000000000000000000000000000000000000000006064820152608401610596565b803573ffffffffffffffffffffffffffffffffffffffff811681146117dc57600080fd5b919050565b6000602082840312156117f357600080fd5b61040b826117b8565b6000806040838503121561180f57600080fd5b611818836117b8565b9150611826602084016117b8565b90509250929050565b60008060006060848603121561184457600080fd5b61184d846117b8565b925061185b602085016117b8565b9150604084013590509250925092565b600080600080600080600060e0888a03121561188657600080fd5b61188f886117b8565b965061189d602089016117b8565b95506040880135945060608801359350608088013560ff811681146118c157600080fd5b9699959850939692959460a0840135945060c09093013592915050565b600080604083850312156118f157600080fd5b6118fa836117b8565b946020939093013593505050565b60006020828403121561191a57600080fd5b5035919050565b6000806040838503121561193457600080fd5b82359150611826602084016117b8565b6000806000806080858703121561195a57600080fd5b8435935061196a602086016117b8565b9250611978604086016117b8565b9396929550929360600135925050565b60008060006060848603121561199d57600080fd5b8335925061185b602085016117b8565b600060208083528351808285015260005b818110156119da578581018301518582016040015282016119be565b818111156119ec576000604083870101525b50601f017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe016929092016040019392505050565b60008219821115611a3357611a33611a9d565b500190565b600082821015611a4a57611a4a611a9d565b500390565b600181811c90821680611a6357607f821691505b60208210811415611418577f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602160045260246000fdfea2646970667358221220586a7a11e0cbfbbd87a10728794d4dc92939154620539c3d548c9e1e576c2e8e64736f6c6343000806003300000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000000953616675636861696e000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000045341465500000000000000000000000000000000000000000000000000000000

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101a25760003560e01c80637ecebe00116100ee578063a457c2d711610097578063d505accf11610071578063d505accf14610365578063dd62ed3e14610378578063f2fde38b146103be578063f8548e36146103d157600080fd5b8063a457c2d71461032c578063a9059cbb1461033f578063bd85b0391461035257600080fd5b80638da5cb5b116100c85780638da5cb5b146102e957806395d89b41146103115780639eea5f661461031957600080fd5b80637ecebe00146102b0578063836a1040146102c35780638cb0a511146102d657600080fd5b806329507f7311610150578063395093511161012a578063395093511461025f57806370a0823114610272578063715018a6146102a857600080fd5b806329507f7314610235578063313ce567146102485780633644e5151461025757600080fd5b806318160ddd1161018157806318160ddd146102055780631c0f12b61461020d57806323b872dd1461022257600080fd5b8062fdd58e146101a757806306fdde03146101cd578063095ea7b3146101e2575b600080fd5b6101ba6101b53660046118de565b6103e4565b6040519081526020015b60405180910390f35b6101d5610412565b6040516101c491906119ad565b6101f56101f03660046118de565b6104a4565b60405190151581526020016101c4565b6002546101ba565b61022061021b366004611944565b6104ba565b005b6101f561023036600461182f565b6104cc565b610220610243366004611921565b6105c2565b604051601281526020016101c4565b6101ba61063b565b6101f561026d3660046118de565b610645565b6101ba6102803660046117e1565b73ffffffffffffffffffffffffffffffffffffffff1660009081526020819052604090205490565b61022061068e565b6101ba6102be3660046117e1565b610701565b6102206102d1366004611988565b61072e565b6102206102e4366004611988565b6107a4565b60065460405173ffffffffffffffffffffffffffffffffffffffff90911681526020016101c4565b6101d56107b4565b610220610327366004611988565b6107c3565b6101f561033a3660046118de565b610834565b6101f561034d3660046118de565b6108f2565b6101ba610360366004611908565b6108ff565b61022061037336600461186b565b61090a565b6101ba6103863660046117fc565b73ffffffffffffffffffffffffffffffffffffffff918216600090815260016020908152604080832093909416825291909152205490565b6102206103cc3660046117e1565b610a95565b6102206103df366004611988565b610b91565b73ffffffffffffffffffffffffffffffffffffffff82166000908152602081905260408120545b9392505050565b60606003805461042190611a4f565b80601f016020809104026020016040519081016040528092919081815260200182805461044d90611a4f565b801561049a5780601f1061046f5761010080835404028352916020019161049a565b820191906000526020600020905b81548152906001019060200180831161047d57829003601f168201915b5050505050905090565b60006104b1338484610b9b565b50600192915050565b6104c58383836104cc565b5050505050565b73ffffffffffffffffffffffffffffffffffffffff831660009081526001602090815260408083203384529091528120547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff81146105ac578281101561059f5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e742065786365656473206160448201527f6c6c6f77616e636500000000000000000000000000000000000000000000000060648201526084015b60405180910390fd5b6105ac8533858403610b9b565b6105b7858585610d1a565b506001949350505050565b60065473ffffffffffffffffffffffffffffffffffffffff1633146106295760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610596565b61063281610a95565b5050565b905090565b6000610636610f7f565b33600081815260016020908152604080832073ffffffffffffffffffffffffffffffffffffffff8716845290915281205490916104b1918590610689908690611a20565b610b9b565b60065473ffffffffffffffffffffffffffffffffffffffff1633146106f55760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610596565b6106ff60006110b3565b565b73ffffffffffffffffffffffffffffffffffffffff81166000908152600560205260408120545b92915050565b60065473ffffffffffffffffffffffffffffffffffffffff1633146107955760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610596565b61079f828261112a565b505050565b6107ae82826104a4565b50505050565b60606004805461042190611a4f565b60065473ffffffffffffffffffffffffffffffffffffffff16331461082a5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610596565b61079f8282611230565b33600090815260016020908152604080832073ffffffffffffffffffffffffffffffffffffffff86168452909152812054828110156108db5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f7760448201527f207a65726f0000000000000000000000000000000000000000000000000000006064820152608401610596565b6108e83385858403610b9b565b5060019392505050565b60006104b1338484610d1a565b600061072860025490565b8342111561095a5760405162461bcd60e51b815260206004820152601d60248201527f45524332305065726d69743a206578706972656420646561646c696e650000006044820152606401610596565b60007f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c98888886109898c6113e9565b60408051602081019690965273ffffffffffffffffffffffffffffffffffffffff94851690860152929091166060840152608083015260a082015260c0810186905260e00160405160208183030381529060405280519060200120905060006109f18261141e565b90506000610a0182878787611487565b90508973ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614610a7e5760405162461bcd60e51b815260206004820152601e60248201527f45524332305065726d69743a20696e76616c6964207369676e617475726500006044820152606401610596565b610a898a8a8a610b9b565b50505050505050505050565b60065473ffffffffffffffffffffffffffffffffffffffff163314610afc5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610596565b73ffffffffffffffffffffffffffffffffffffffff8116610b855760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f64647265737300000000000000000000000000000000000000000000000000006064820152608401610596565b610b8e816110b3565b50565b6107ae82826108f2565b73ffffffffffffffffffffffffffffffffffffffff8316610c235760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460448201527f72657373000000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff8216610cac5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f20616464726560448201527f73730000000000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff83811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b73ffffffffffffffffffffffffffffffffffffffff8316610da35760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f20616460448201527f64726573730000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff8216610e2c5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201527f65737300000000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff831660009081526020819052604090205481811015610ec85760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e742065786365656473206260448201527f616c616e636500000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff808516600090815260208190526040808220858503905591851681529081208054849290610f0c908490611a20565b925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051610f7291815260200190565b60405180910390a36107ae565b60003073ffffffffffffffffffffffffffffffffffffffff7f0000000000000000000000007f7670f9d074679014929a89440480b7bca0762216148015610fe557507f000000000000000000000000000000000000000000000000000000000000000146145b1561100f57507fc292655b0cfb1a92d743ea662b1ab3345c0225f7ba2e7813c8611c8e9988f1ac90565b50604080517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f6020808301919091527ffea9f5d8ffae132bb3671ab54606e20ae5dd80d6504a450bb6f4584102840e49828401527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608301524660808301523060a0808401919091528351808403909101815260c0909201909252805191012090565b6006805473ffffffffffffffffffffffffffffffffffffffff8381167fffffffffffffffffffffffff0000000000000000000000000000000000000000831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b73ffffffffffffffffffffffffffffffffffffffff821661118d5760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f2061646472657373006044820152606401610596565b806002600082825461119f9190611a20565b909155505073ffffffffffffffffffffffffffffffffffffffff8216600090815260208190526040812080548392906111d9908490611a20565b909155505060405181815273ffffffffffffffffffffffffffffffffffffffff8316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b73ffffffffffffffffffffffffffffffffffffffff82166112b95760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f2061646472657360448201527f73000000000000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff8216600090815260208190526040902054818110156113555760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e60448201527f63650000000000000000000000000000000000000000000000000000000000006064820152608401610596565b73ffffffffffffffffffffffffffffffffffffffff83166000908152602081905260408120838303905560028054849290611391908490611a38565b909155505060405182815260009073ffffffffffffffffffffffffffffffffffffffff8516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3505050565b73ffffffffffffffffffffffffffffffffffffffff811660009081526005602052604090208054600181018255905b50919050565b600061072861142b610f7f565b836040517f19010000000000000000000000000000000000000000000000000000000000006020820152602281018390526042810182905260009060620160405160208183030381529060405280519060200120905092915050565b6000806000611498878787876114af565b915091506114a5816115c7565b5095945050505050565b6000807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a08311156114e657506000905060036115be565b8460ff16601b141580156114fe57508460ff16601c14155b1561150f57506000905060046115be565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa158015611563573d6000803e3d6000fd5b50506040517fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe0015191505073ffffffffffffffffffffffffffffffffffffffff81166115b7576000600192509250506115be565b9150600090505b94509492505050565b60008160048111156115db576115db611acc565b14156115e45750565b60018160048111156115f8576115f8611acc565b14156116465760405162461bcd60e51b815260206004820152601860248201527f45434453413a20696e76616c6964207369676e617475726500000000000000006044820152606401610596565b600281600481111561165a5761165a611acc565b14156116a85760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610596565b60038160048111156116bc576116bc611acc565b14156117305760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c60448201527f75650000000000000000000000000000000000000000000000000000000000006064820152608401610596565b600481600481111561174457611744611acc565b1415610b8e5760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c60448201527f75650000000000000000000000000000000000000000000000000000000000006064820152608401610596565b803573ffffffffffffffffffffffffffffffffffffffff811681146117dc57600080fd5b919050565b6000602082840312156117f357600080fd5b61040b826117b8565b6000806040838503121561180f57600080fd5b611818836117b8565b9150611826602084016117b8565b90509250929050565b60008060006060848603121561184457600080fd5b61184d846117b8565b925061185b602085016117b8565b9150604084013590509250925092565b600080600080600080600060e0888a03121561188657600080fd5b61188f886117b8565b965061189d602089016117b8565b95506040880135945060608801359350608088013560ff811681146118c157600080fd5b9699959850939692959460a0840135945060c09093013592915050565b600080604083850312156118f157600080fd5b6118fa836117b8565b946020939093013593505050565b60006020828403121561191a57600080fd5b5035919050565b6000806040838503121561193457600080fd5b82359150611826602084016117b8565b6000806000806080858703121561195a57600080fd5b8435935061196a602086016117b8565b9250611978604086016117b8565b9396929550929360600135925050565b60008060006060848603121561199d57600080fd5b8335925061185b602085016117b8565b600060208083528351808285015260005b818110156119da578581018301518582016040015282016119be565b818111156119ec576000604083870101525b50601f017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe016929092016040019392505050565b60008219821115611a3357611a33611a9d565b500190565b600082821015611a4a57611a4a611a9d565b500390565b600181811c90821680611a6357607f821691505b60208210811415611418577f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602160045260246000fdfea2646970667358221220586a7a11e0cbfbbd87a10728794d4dc92939154620539c3d548c9e1e576c2e8e64736f6c63430008060033

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

00000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000000953616675636861696e000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000045341465500000000000000000000000000000000000000000000000000000000

-----Decoded View---------------
Arg [0] : _name (string): Safuchain
Arg [1] : _symbol (string): SAFU

-----Encoded View---------------
6 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000040
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000080
Arg [2] : 0000000000000000000000000000000000000000000000000000000000000009
Arg [3] : 53616675636861696e0000000000000000000000000000000000000000000000
Arg [4] : 0000000000000000000000000000000000000000000000000000000000000004
Arg [5] : 5341465500000000000000000000000000000000000000000000000000000000


Deployed Bytecode Sourcemap

43512:6299:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;44550:312;;;;;;:::i;:::-;;:::i;:::-;;;4152:25:1;;;4140:2;4125:18;44550:312:0;;;;;;;;27543:100;;;:::i;:::-;;;;;;;:::i;29883:169::-;;;;;;:::i;:::-;;:::i;:::-;;;3979:14:1;;3972:22;3954:41;;3942:2;3927:18;29883:169:0;3909:92:1;28663:108:0;28751:12;;28663:108;;48783:251;;;;;;:::i;:::-;;:::i;:::-;;30645:573;;;;;;:::i;:::-;;:::i;49556:252::-;;;;;;:::i;:::-;;:::i;45249:110::-;;;28588:2;13721:36:1;;13709:2;13694:18;45249:110:0;13676:87:1;42568:115:0;;;:::i;31627:215::-;;;;;;:::i;:::-;;:::i;28834:127::-;;;;;;:::i;:::-;28935:18;;28908:7;28935:18;;;;;;;;;;;;28834:127;21069:103;;;:::i;42310:128::-;;;;;;:::i;:::-;;:::i;46499:236::-;;;;;;:::i;:::-;;:::i;47709:224::-;;;;;;:::i;:::-;;:::i;20418:87::-;20491:6;;20418:87;;20491:6;;;;3729:74:1;;3717:2;3702:18;20418:87:0;3684:125:1;27762:104:0;;;:::i;47120:236::-;;;;;;:::i;:::-;;:::i;32345:413::-;;;;;;:::i;:::-;;:::i;29174:175::-;;;;;;:::i;:::-;;:::i;44029:196::-;;;;;;:::i;:::-;;:::i;41599:645::-;;;;;;:::i;:::-;;:::i;29412:151::-;;;;;;:::i;:::-;29528:18;;;;29501:7;29528:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;29412:151;21327:201;;;;;;:::i;:::-;;:::i;48229:216::-;;;;;;:::i;:::-;;:::i;44550:312::-;28935:18;;;44659:7;28935:18;;;;;;;;;;;44831:25;44824:32;44550:312;-1:-1:-1;;;44550:312:0:o;27543:100::-;27597:13;27630:5;27623:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27543:100;:::o;29883:169::-;29966:4;29983:39;19255:10;30006:7;30015:6;29983:8;:39::i;:::-;-1:-1:-1;30040:4:0;29883:169;;;;:::o;48783:251::-;48995:33;49008:5;49015:3;49020:7;48995:12;:33::i;:::-;;48783:251;;;;:::o;30645:573::-;30829:19;;;30785:4;30829:19;;;:11;:19;;;;;;;;19255:10;30829:33;;;;;;;;30897:17;30877:37;;30873:265;;30959:6;30939:16;:26;;30931:79;;;;-1:-1:-1;;;30931:79:0;;10850:2:1;30931:79:0;;;10832:21:1;10889:2;10869:18;;;10862:30;10928:34;10908:18;;;10901:62;10999:10;10979:18;;;10972:38;11027:19;;30931:79:0;;;;;;;;;31054:57;31063:6;19255:10;31104:6;31085:16;:25;31054:8;:57::i;:::-;31150:36;31160:6;31168:9;31179:6;31150:9;:36::i;:::-;-1:-1:-1;31206:4:0;;30645:573;-1:-1:-1;;;;30645:573:0:o;49556:252::-;20491:6;;20638:23;20491:6;19255:10;20638:23;20630:68;;;;-1:-1:-1;;;20630:68:0;;11259:2:1;20630:68:0;;;11241:21:1;;;11278:18;;;11271:30;11337:34;11317:18;;;11310:62;11389:18;;20630:68:0;11231:182:1;20630:68:0;49768:34:::1;49792:9;49768:23;:34::i;:::-;49556:252:::0;;:::o;45337:16::-;45330:23;;45249:110;:::o;42568:115::-;42628:7;42655:20;:18;:20::i;31627:215::-;19255:10;31715:4;31764:25;;;:11;:25;;;;;;;;;:34;;;;;;;;;;31715:4;;31732:80;;31755:7;;31764:47;;31801:10;;31764:47;:::i;:::-;31732:8;:80::i;21069:103::-;20491:6;;20638:23;20491:6;19255:10;20638:23;20630:68;;;;-1:-1:-1;;;20630:68:0;;11259:2:1;20630:68:0;;;11241:21:1;;;11278:18;;;11271:30;11337:34;11317:18;;;11310:62;11389:18;;20630:68:0;11231:182:1;20630:68:0;21134:30:::1;21161:1;21134:18;:30::i;:::-;21069:103::o:0;42310:128::-;42406:14;;;42379:7;42406:14;;;:7;:14;;;;;1855;42406:24;42399:31;42310:128;-1:-1:-1;;42310:128:0:o;46499:236::-;20491:6;;20638:23;20491:6;19255:10;20638:23;20630:68;;;;-1:-1:-1;;;20630:68:0;;11259:2:1;20630:68:0;;;11241:21:1;;;11278:18;;;11271:30;11337:34;11317:18;;;11310:62;11389:18;;20630:68:0;11231:182:1;20630:68:0;46705:24:::1;46711:8;46721:7;46705:5;:24::i;:::-;46499:236:::0;;;:::o;47709:224::-;47901:26;47909:8;47919:7;47901;:26::i;:::-;;47709:224;;;:::o;27762:104::-;27818:13;27851:7;27844:14;;;;;:::i;47120:236::-;20491:6;;20638:23;20491:6;19255:10;20638:23;20630:68;;;;-1:-1:-1;;;20630:68:0;;11259:2:1;20630:68:0;;;11241:21:1;;;11278:18;;;11271:30;11337:34;11317:18;;;11310:62;11389:18;;20630:68:0;11231:182:1;20630:68:0;47326:24:::1;47332:8;47342:7;47326:5;:24::i;32345:413::-:0;19255:10;32438:4;32482:25;;;:11;:25;;;;;;;;;:34;;;;;;;;;;32535:35;;;;32527:85;;;;-1:-1:-1;;;32527:85:0;;12833:2:1;32527:85:0;;;12815:21:1;12872:2;12852:18;;;12845:30;12911:34;12891:18;;;12884:62;12982:7;12962:18;;;12955:35;13007:19;;32527:85:0;12805:227:1;32527:85:0;32648:67;19255:10;32671:7;32699:15;32680:16;:34;32648:8;:67::i;:::-;-1:-1:-1;32746:4:0;;32345:413;-1:-1:-1;;;32345:413:0:o;29174:175::-;29260:4;29277:42;19255:10;29301:9;29312:6;29277:9;:42::i;44029:196::-;44102:7;44200:19;28751:12;;;28663:108;41599:645;41843:8;41824:15;:27;;41816:69;;;;-1:-1:-1;;;41816:69:0;;8920:2:1;41816:69:0;;;8902:21:1;8959:2;8939:18;;;8932:30;8998:31;8978:18;;;8971:59;9047:18;;41816:69:0;8892:179:1;41816:69:0;41898:18;41940:16;41958:5;41965:7;41974:5;41981:16;41991:5;41981:9;:16::i;:::-;41929:79;;;;;;4475:25:1;;;;4519:42;4597:15;;;4577:18;;;4570:43;4649:15;;;;4629:18;;;4622:43;4681:18;;;4674:34;4724:19;;;4717:35;4768:19;;;4761:35;;;4447:19;;41929:79:0;;;;;;;;;;;;41919:90;;;;;;41898:111;;42022:12;42037:28;42054:10;42037:16;:28::i;:::-;42022:43;;42078:14;42095:28;42109:4;42115:1;42118;42121;42095:13;:28::i;:::-;42078:45;;42152:5;42142:15;;:6;:15;;;42134:58;;;;-1:-1:-1;;;42134:58:0;;10491:2:1;42134:58:0;;;10473:21:1;10530:2;10510:18;;;10503:30;10569:32;10549:18;;;10542:60;10619:18;;42134:58:0;10463:180:1;42134:58:0;42205:31;42214:5;42221:7;42230:5;42205:8;:31::i;:::-;41805:439;;;41599:645;;;;;;;:::o;21327:201::-;20491:6;;20638:23;20491:6;19255:10;20638:23;20630:68;;;;-1:-1:-1;;;20630:68:0;;11259:2:1;20630:68:0;;;11241:21:1;;;11278:18;;;11271:30;11337:34;11317:18;;;11310:62;11389:18;;20630:68:0;11231:182:1;20630:68:0;21416:22:::1;::::0;::::1;21408:73;;;::::0;-1:-1:-1;;;21408:73:0;;8110:2:1;21408:73:0::1;::::0;::::1;8092:21:1::0;8149:2;8129:18;;;8122:30;8188:34;8168:18;;;8161:62;8259:8;8239:18;;;8232:36;8285:19;;21408:73:0::1;8082:228:1::0;21408:73:0::1;21492:28;21511:8;21492:18;:28::i;:::-;21327:201:::0;:::o;48229:216::-;48417:22;48426:3;48431:7;48417:8;:22::i;36029:380::-;36165:19;;;36157:68;;;;-1:-1:-1;;;36157:68:0;;12428:2:1;36157:68:0;;;12410:21:1;12467:2;12447:18;;;12440:30;12506:34;12486:18;;;12479:62;12577:6;12557:18;;;12550:34;12601:19;;36157:68:0;12400:226:1;36157:68:0;36244:21;;;36236:68;;;;-1:-1:-1;;;36236:68:0;;8517:2:1;36236:68:0;;;8499:21:1;8556:2;8536:18;;;8529:30;8595:34;8575:18;;;8568:62;8666:4;8646:18;;;8639:32;8688:19;;36236:68:0;8489:224:1;36236:68:0;36317:18;;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;36369:32;;4152:25:1;;;36369:32:0;;4125:18:1;36369:32:0;;;;;;;36029:380;;;:::o;33248:733::-;33388:20;;;33380:70;;;;-1:-1:-1;;;33380:70:0;;12022:2:1;33380:70:0;;;12004:21:1;12061:2;12041:18;;;12034:30;12100:34;12080:18;;;12073:62;12171:7;12151:18;;;12144:35;12196:19;;33380:70:0;11994:227:1;33380:70:0;33469:23;;;33461:71;;;;-1:-1:-1;;;33461:71:0;;6943:2:1;33461:71:0;;;6925:21:1;6982:2;6962:18;;;6955:30;7021:34;7001:18;;;6994:62;7092:5;7072:18;;;7065:33;7115:19;;33461:71:0;6915:225:1;33461:71:0;33629:17;;;33605:21;33629:17;;;;;;;;;;;33665:23;;;;33657:74;;;;-1:-1:-1;;;33657:74:0;;9278:2:1;33657:74:0;;;9260:21:1;9317:2;9297:18;;;9290:30;9356:34;9336:18;;;9329:62;9427:8;9407:18;;;9400:36;9453:19;;33657:74:0;9250:228:1;33657:74:0;33767:17;;;;:9;:17;;;;;;;;;;;33787:22;;;33767:42;;33831:20;;;;;;;;:30;;33803:6;;33767:9;33831:30;;33803:6;;33831:30;:::i;:::-;;;;;;;;33896:9;33879:35;;33888:6;33879:35;;;33907:6;33879:35;;;;4152:25:1;;4140:2;4125:18;;4107:76;33879:35:0;;;;;;;;33927:46;46499:236;17127:314;17180:7;17212:4;17204:29;17221:12;17204:29;;:66;;;;;17254:16;17237:13;:33;17204:66;17200:234;;;-1:-1:-1;17294:24:0;;17127:314::o;17200:234::-;-1:-1:-1;17630:73:0;;;17380:10;17630:73;;;;5066:25:1;;;;17392:12:0;5107:18:1;;;5100:34;17406:15:0;5150:18:1;;;5143:34;17674:13:0;5193:18:1;;;5186:34;17697:4:0;5236:19:1;;;;5229:84;;;;17630:73:0;;;;;;;;;;5038:19:1;;;;17630:73:0;;;17620:84;;;;;;45249:110::o;21688:191::-;21781:6;;;;21798:17;;;;;;;;;;;21831:40;;21781:6;;;21798:17;21781:6;;21831:40;;21762:16;;21831:40;21751:128;21688:191;:::o;34268:399::-;34352:21;;;34344:65;;;;-1:-1:-1;;;34344:65:0;;13239:2:1;34344:65:0;;;13221:21:1;13278:2;13258:18;;;13251:30;13317:33;13297:18;;;13290:61;13368:18;;34344:65:0;13211:181:1;34344:65:0;34500:6;34484:12;;:22;;;;;;;:::i;:::-;;;;-1:-1:-1;;34517:18:0;;;:9;:18;;;;;;;;;;:28;;34539:6;;34517:9;:28;;34539:6;;34517:28;:::i;:::-;;;;-1:-1:-1;;34561:37:0;;4152:25:1;;;34561:37:0;;;;34578:1;;34561:37;;4140:2:1;4125:18;34561:37:0;;;;;;;49556:252;;:::o;35000:591::-;35084:21;;;35076:67;;;;-1:-1:-1;;;35076:67:0;;11620:2:1;35076:67:0;;;11602:21:1;11659:2;11639:18;;;11632:30;11698:34;11678:18;;;11671:62;11769:3;11749:18;;;11742:31;11790:19;;35076:67:0;11592:223:1;35076:67:0;35243:18;;;35218:22;35243:18;;;;;;;;;;;35280:24;;;;35272:71;;;;-1:-1:-1;;;35272:71:0;;7347:2:1;35272:71:0;;;7329:21:1;7386:2;7366:18;;;7359:30;7425:34;7405:18;;;7398:62;7496:4;7476:18;;;7469:32;7518:19;;35272:71:0;7319:224:1;35272:71:0;35379:18;;;:9;:18;;;;;;;;;;35400:23;;;35379:44;;35445:12;:22;;35417:6;;35379:9;35445:22;;35417:6;;35445:22;:::i;:::-;;;;-1:-1:-1;;35485:37:0;;4152:25:1;;;35511:1:0;;35485:37;;;;;;4140:2:1;4125:18;35485:37:0;;;;;;;46499:236;;;:::o;42821:207::-;42942:14;;;42881:15;42942:14;;;:7;:14;;;;;1855;;1992:1;1974:19;;;;1855:14;43003:17;42898:130;42821:207;;;:::o;18354:167::-;18431:7;18458:55;18480:20;:18;:20::i;:::-;18502:10;13869:57;;3404:66:1;13869:57:0;;;3392:79:1;3487:11;;;3480:27;;;3523:12;;;3516:28;;;13832:7:0;;3560:12:1;;13869:57:0;;;;;;;;;;;;13859:68;;;;;;13852:75;;13739:196;;;;;12048:279;12176:7;12197:17;12216:18;12238:25;12249:4;12255:1;12258;12261;12238:10;:25::i;:::-;12196:67;;;;12274:18;12286:5;12274:11;:18::i;:::-;-1:-1:-1;12310:9:0;12048:279;-1:-1:-1;;;;;12048:279:0:o;10277:1632::-;10408:7;;11342:66;11329:79;;11325:163;;;-1:-1:-1;11441:1:0;;-1:-1:-1;11445:30:0;11425:51;;11325:163;11502:1;:7;;11507:2;11502:7;;:18;;;;;11513:1;:7;;11518:2;11513:7;;11502:18;11498:102;;;-1:-1:-1;11553:1:0;;-1:-1:-1;11557:30:0;11537:51;;11498:102;11714:24;;;11697:14;11714:24;;;;;;;;;5551:25:1;;;5624:4;5612:17;;5592:18;;;5585:45;;;;5646:18;;;5639:34;;;5689:18;;;5682:34;;;11714:24:0;;5523:19:1;;11714:24:0;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;11714:24:0;;;;;;-1:-1:-1;;11753:20:0;;;11749:103;;11806:1;11810:29;11790:50;;;;;;;11749:103;11872:6;-1:-1:-1;11880:20:0;;-1:-1:-1;10277:1632:0;;;;;;;;:::o;4986:643::-;5064:20;5055:5;:29;;;;;;;;:::i;:::-;;5051:571;;;4986:643;:::o;5051:571::-;5162:29;5153:5;:38;;;;;;;;:::i;:::-;;5149:473;;;5208:34;;-1:-1:-1;;;5208:34:0;;6590:2:1;5208:34:0;;;6572:21:1;6629:2;6609:18;;;6602:30;6668:26;6648:18;;;6641:54;6712:18;;5208:34:0;6562:174:1;5149:473:0;5273:35;5264:5;:44;;;;;;;;:::i;:::-;;5260:362;;;5325:41;;-1:-1:-1;;;5325:41:0;;7750:2:1;5325:41:0;;;7732:21:1;7789:2;7769:18;;;7762:30;7828:33;7808:18;;;7801:61;7879:18;;5325:41:0;7722:181:1;5260:362:0;5397:30;5388:5;:39;;;;;;;;:::i;:::-;;5384:238;;;5444:44;;-1:-1:-1;;;5444:44:0;;9685:2:1;5444:44:0;;;9667:21:1;9724:2;9704:18;;;9697:30;9763:34;9743:18;;;9736:62;9834:4;9814:18;;;9807:32;9856:19;;5444:44:0;9657:224:1;5384:238:0;5519:30;5510:5;:39;;;;;;;;:::i;:::-;;5506:116;;;5566:44;;-1:-1:-1;;;5566:44:0;;10088:2:1;5566:44:0;;;10070:21:1;10127:2;10107:18;;;10100:30;10166:34;10146:18;;;10139:62;10237:4;10217:18;;;10210:32;10259:19;;5566:44:0;10060:224:1;14:196;82:20;;142:42;131:54;;121:65;;111:2;;200:1;197;190:12;111:2;63:147;;;:::o;215:186::-;274:6;327:2;315:9;306:7;302:23;298:32;295:2;;;343:1;340;333:12;295:2;366:29;385:9;366:29;:::i;406:260::-;474:6;482;535:2;523:9;514:7;510:23;506:32;503:2;;;551:1;548;541:12;503:2;574:29;593:9;574:29;:::i;:::-;564:39;;622:38;656:2;645:9;641:18;622:38;:::i;:::-;612:48;;493:173;;;;;:::o;671:328::-;748:6;756;764;817:2;805:9;796:7;792:23;788:32;785:2;;;833:1;830;823:12;785:2;856:29;875:9;856:29;:::i;:::-;846:39;;904:38;938:2;927:9;923:18;904:38;:::i;:::-;894:48;;989:2;978:9;974:18;961:32;951:42;;775:224;;;;;:::o;1004:693::-;1115:6;1123;1131;1139;1147;1155;1163;1216:3;1204:9;1195:7;1191:23;1187:33;1184:2;;;1233:1;1230;1223:12;1184:2;1256:29;1275:9;1256:29;:::i;:::-;1246:39;;1304:38;1338:2;1327:9;1323:18;1304:38;:::i;:::-;1294:48;;1389:2;1378:9;1374:18;1361:32;1351:42;;1440:2;1429:9;1425:18;1412:32;1402:42;;1494:3;1483:9;1479:19;1466:33;1539:4;1532:5;1528:16;1521:5;1518:27;1508:2;;1559:1;1556;1549:12;1508:2;1174:523;;;;-1:-1:-1;1174:523:1;;;;1582:5;1634:3;1619:19;;1606:33;;-1:-1:-1;1686:3:1;1671:19;;;1658:33;;1174:523;-1:-1:-1;;1174:523:1:o;1702:254::-;1770:6;1778;1831:2;1819:9;1810:7;1806:23;1802:32;1799:2;;;1847:1;1844;1837:12;1799:2;1870:29;1889:9;1870:29;:::i;:::-;1860:39;1946:2;1931:18;;;;1918:32;;-1:-1:-1;;;1789:167:1:o;1961:180::-;2020:6;2073:2;2061:9;2052:7;2048:23;2044:32;2041:2;;;2089:1;2086;2079:12;2041:2;-1:-1:-1;2112:23:1;;2031:110;-1:-1:-1;2031:110:1:o;2146:254::-;2214:6;2222;2275:2;2263:9;2254:7;2250:23;2246:32;2243:2;;;2291:1;2288;2281:12;2243:2;2327:9;2314:23;2304:33;;2356:38;2390:2;2379:9;2375:18;2356:38;:::i;2405:397::-;2491:6;2499;2507;2515;2568:3;2556:9;2547:7;2543:23;2539:33;2536:2;;;2585:1;2582;2575:12;2536:2;2621:9;2608:23;2598:33;;2650:38;2684:2;2673:9;2669:18;2650:38;:::i;:::-;2640:48;;2707:38;2741:2;2730:9;2726:18;2707:38;:::i;:::-;2526:276;;;;-1:-1:-1;2697:48:1;;2792:2;2777:18;2764:32;;-1:-1:-1;;2526:276:1:o;2807:322::-;2884:6;2892;2900;2953:2;2941:9;2932:7;2928:23;2924:32;2921:2;;;2969:1;2966;2959:12;2921:2;3005:9;2992:23;2982:33;;3034:38;3068:2;3057:9;3053:18;3034:38;:::i;5727:656::-;5839:4;5868:2;5897;5886:9;5879:21;5929:6;5923:13;5972:6;5967:2;5956:9;5952:18;5945:34;5997:1;6007:140;6021:6;6018:1;6015:13;6007:140;;;6116:14;;;6112:23;;6106:30;6082:17;;;6101:2;6078:26;6071:66;6036:10;;6007:140;;;6165:6;6162:1;6159:13;6156:2;;;6235:1;6230:2;6221:6;6210:9;6206:22;6202:31;6195:42;6156:2;-1:-1:-1;6299:2:1;6287:15;6304:66;6283:88;6268:104;;;;6374:2;6264:113;;5848:535;-1:-1:-1;;;5848:535:1:o;13768:128::-;13808:3;13839:1;13835:6;13832:1;13829:13;13826:2;;;13845:18;;:::i;:::-;-1:-1:-1;13881:9:1;;13816:80::o;13901:125::-;13941:4;13969:1;13966;13963:8;13960:2;;;13974:18;;:::i;:::-;-1:-1:-1;14011:9:1;;13950:76::o;14031:437::-;14110:1;14106:12;;;;14153;;;14174:2;;14228:4;14220:6;14216:17;14206:27;;14174:2;14281;14273:6;14270:14;14250:18;14247:38;14244:2;;;14318:77;14315:1;14308:88;14419:4;14416:1;14409:15;14447:4;14444:1;14437:15;14473:184;14525:77;14522:1;14515:88;14622:4;14619:1;14612:15;14646:4;14643:1;14636:15;14662:184;14714:77;14711:1;14704:88;14811:4;14808:1;14801:15;14835:4;14832:1;14825:15

Swarm Source

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