Contract 0x62D09Fbec87c7F2Ce09C249eeC3F87bB09268717 2

 
 
Txn Hash
Method
Block
From
To
Value
0x773a9007f22cc1359c7661a518df0b5389f656f0e40f862cd1aad89c5027a7c1Approve163451152023-01-06 3:39:3526 days 18 hrs ago0x1d8c844650c765764e3f315a87c6c2929635457f IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00042831 17.17026388
0xce6fb2028cfcd1c43be9f306476e115525d4bbedd3967f5a22e56e2f7516d73fApprove162141812022-12-18 21:11:2345 days 1 hr ago0x47b392ab1fa33d521975ecf169436c4f3cf9fc43 IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00034545 12.77521712
0x16a13dd0973798a4e7cc56176ca85c7b9e7d79a946a4994f954c7ad6655fac9cApprove162141802022-12-18 21:11:1145 days 1 hr ago0x47b392ab1fa33d521975ecf169436c4f3cf9fc43 IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00061999 13.20806933
0xab02ebc5310dfb10a3bc318a58140ea5da26e5bbc7505751612dcfc4aa717545Approve159834862022-11-16 15:30:1177 days 7 hrs ago0x36d4d4a421852b256c2e1c77968c5c69f89d0c36 IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.0006074 22.54236362
0x915a3edf24af0203f50cab9eddb01789fe1a594659c5fac2708e98d65327ae4dApprove156852082022-10-05 23:32:47118 days 23 hrs agoENS Name koco.tajigen.eth IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00042819 17.16556323
0xf5219f3dc6fd728ce69fce25d201c9435cf12c03be5925d8feccf2491b65766eApprove156506122022-10-01 3:25:35123 days 19 hrs agoENS Name matrams.eth IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00020965 8.40480971
0x9c8bfc3bcb08da552e28f737095344652ad764db62122f6b3e2d0478ba005d44Approve156109452022-09-25 14:20:11129 days 8 hrs ago0x5f9dd045a593134fc3d5df5aa27eb00a100bc34e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00023419 9.38851999
0x51a72aabb292e4dea6ea9f335163ba2625386d91eeb36ef40d81f3e3c6ec3961Approve155515622022-09-17 6:36:47137 days 15 hrs ago0xbbd7859e3dd848bc0928be8b1fc936f3fa1030d7 IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.0002195 4.67614159
0x9701581d87701b98e746b5aaf55b27094098be938d23cac18827c519a00ba662Approve154301522022-08-28 21:23:30157 days 1 hr ago0x7011c2cbbc3b6dedef89021ab6756b1d3128680c IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00020626 7.62768876
0xfc47bebdac7e6e2943353a2f6776bdd0db36b71b64463b51b12b90f3fc6b167fApprove153806452022-08-20 23:55:21164 days 22 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00012905 2.74935247
0x50e16f2f2694b7c14d6d0e23cb6809a02fc5815797bf5e52bb5e8d96f71f913eApprove153311472022-08-13 3:55:38172 days 18 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00040272 8.57941872
0xdf3ee3482ba577a4b555f450840b7afc9496610231ccebfec167758db946ab82Approve153311412022-08-13 3:53:45172 days 18 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00028256 6.01947146
0x344f7a041e557c1d68cd44a061270b0b86da4099a9b5b5070fb97b5bfecc56d6Approve153301152022-08-13 0:05:32172 days 22 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00038714 8.24740386
0x4de0a1b879024995393846d9d6fb5c66eac255116d4c7cef6e9c46688f80e861Approve153300812022-08-12 23:59:13172 days 22 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.0004187 8.91986427
0x9170e7a6f3efaf1cd3a37be8116452aa16c6881a04d3db0ff26001e8cceda9cbApprove153062592022-08-09 5:55:42176 days 16 hrs ago0x5acf7b6e13704f3bd3203e1ea566aa561ba22cf1 IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00054781 11.67023644
0x950c11e6140e6b2208bdc35f3f0573e955706d8cbe9b8d444fb78bb4045742d5Approve152998032022-08-08 5:47:53177 days 16 hrs ago0x7011c2cbbc3b6dedef89021ab6756b1d3128680c IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00028524 10.54856328
0xb3c941d9ad0337617aaffacd2a130690fb8bb39c76d968d40a59a7444fce4b67Approve152998012022-08-08 5:47:31177 days 16 hrs ago0x7011c2cbbc3b6dedef89021ab6756b1d3128680c IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00050955 10.85514616
0x2d4e658d1ece7f133a182e6b4a129cfc7b1c51f253342a2fd827a8f83f988f54Approve152959142022-08-07 15:13:34178 days 7 hrs ago0x0411d1061a8469600f1626a6c1ed9cd8cc63528a IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00047857 10.19518929
0xb3a01576a530e471e195f2e213f9fbe1638d6303995740b1bdd3596668d711caApprove152877992022-08-06 9:00:34179 days 13 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.0003675 7.82913908
0xb9c7748e95c4b1510e4591f038f8b3f34aff454a60331f75f468c6690bae624bApprove152877772022-08-06 8:55:36179 days 13 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00027142 5.78231944
0x555c4af54eed24e7ef650f47dc7975ea0e90da5bcc052a4676a9ee9c3d9ac5c0Approve152848132022-08-05 21:48:00180 days 48 mins agoENS Name hukus.eth IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00058406 12.44261213
0xadf00bd74fca3e93bb0a436778ffcaf21e6e0ea4d7aca9a538f6afefec479c39Approve152565342022-08-01 12:00:02184 days 10 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00042502 9.05455762
0xb9c39d730927601baa17863365935a0cbd09ae568e582dd5a5bb4879404360e7Approve152564982022-08-01 11:53:55184 days 10 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.0005025 10.70509537
0x797f2d7baa57d24b3d330c86148b79d9267d5e9ed1aad28e644b8d73296548abApprove152564542022-08-01 11:44:24184 days 10 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00023827 8.8117053
0xca9e15aac01dec1f15d88f146b21055de02e9322fcbc0e9c633db17e72b12720Approve152564412022-08-01 11:41:49184 days 10 hrs ago0xb8dbe9f24a98014819cdb93ab7197fdbb5cf228e IN  0x62d09fbec87c7f2ce09c249eec3f87bb092687170 Ether0.00043828 9.33689829
[ Download CSV Export 
View more zero value Internal Transactions in Advanced View mode
Loading

Similar Match Source Code
Note: This contract matches the deployed ByteCode of the Source Code for Contract 0x8506E4C1eF5c87689c6Ae2751635156a6F96EfEc

Contract Name:
RyoToken

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion
File 1 of 7 : RyoToken.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.4;

error NotApprovedMinter();


import "@openzeppelin/contracts/token/ERC20/ERC20.sol";
import "@openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol";
import "@openzeppelin/contracts/access/Ownable.sol";

contract RyoToken is ERC20, ERC20Burnable, Ownable {
    constructor() ERC20("Ryo", "RYO") {}

    mapping(address => bool) public approvedMinter;

    
    

    function mint(address to, uint256 amount) public {
        if(!approvedMinter[msg.sender]) revert NotApprovedMinter();
        _mint(to, amount);
    }

    function approveMinter(address _address) public onlyOwner{
        approvedMinter[_address] = true;
    }
    
    function unapproveMinter(address _address) public onlyOwner{
        approvedMinter[_address] = false;
    }

    
}

File 2 of 7 : ERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/ERC20.sol)

pragma solidity ^0.8.0;

import "./IERC20.sol";
import "./extensions/IERC20Metadata.sol";
import "../../utils/Context.sol";

/**
 * @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:
     *
     * - `to` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address to, uint256 amount) public virtual override returns (bool) {
        address owner = _msgSender();
        _transfer(owner, to, 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) {
        address owner = _msgSender();
        _approve(owner, 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:
     *
     * - `from` and `to` cannot be the zero address.
     * - `from` must have a balance of at least `amount`.
     * - the caller must have allowance for ``from``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address from,
        address to,
        uint256 amount
    ) public virtual override returns (bool) {
        address spender = _msgSender();
        _spendAllowance(from, spender, amount);
        _transfer(from, to, 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) {
        address owner = _msgSender();
        _approve(owner, spender, allowance(owner, spender) + addedValue);
        return true;
    }

    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        address owner = _msgSender();
        uint256 currentAllowance = allowance(owner, spender);
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        unchecked {
            _approve(owner, 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:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `from` must have a balance of at least `amount`.
     */
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(from, to, amount);

        uint256 fromBalance = _balances[from];
        require(fromBalance >= amount, "ERC20: transfer amount exceeds balance");
        unchecked {
            _balances[from] = fromBalance - amount;
        }
        _balances[to] += amount;

        emit Transfer(from, to, amount);

        _afterTokenTransfer(from, to, 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 Updates `owner` s allowance for `spender` based on spent `amount`.
     *
     * Does not update the allowance amount in case of infinite allowance.
     * Revert if not enough allowance is available.
     *
     * Might emit an {Approval} event.
     */
    function _spendAllowance(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        uint256 currentAllowance = allowance(owner, spender);
        if (currentAllowance != type(uint256).max) {
            require(currentAllowance >= amount, "ERC20: insufficient allowance");
            unchecked {
                _approve(owner, spender, currentAllowance - 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 3 of 7 : ERC20Burnable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/extensions/ERC20Burnable.sol)

pragma solidity ^0.8.0;

import "../ERC20.sol";
import "../../../utils/Context.sol";

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

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

File 4 of 7 : Ownable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (access/Ownable.sol)

pragma solidity ^0.8.0;

import "../utils/Context.sol";

/**
 * @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 5 of 7 : IERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

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

    /**
     * @dev Returns the 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 `to`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address to, 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 `from` to `to` 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 from,
        address to,
        uint256 amount
    ) external returns (bool);
}

File 6 of 7 : IERC20Metadata.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)

pragma solidity ^0.8.0;

import "../IERC20.sol";

/**
 * @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 7 of 7 : Context.sol
// SPDX-License-Identifier: MIT
// 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;
    }
}

Settings
{
  "optimizer": {
    "enabled": false,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  },
  "libraries": {}
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"NotApprovedMinter","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"approveMinter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"approvedMinter","outputs":[{"internalType":"bool","name":"","type":"bool"}],"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":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burnFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","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":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"unapproveMinter","outputs":[],"stateMutability":"nonpayable","type":"function"}]

60806040523480156200001157600080fd5b506040518060400160405280600381526020017f52796f00000000000000000000000000000000000000000000000000000000008152506040518060400160405280600381526020017f52594f0000000000000000000000000000000000000000000000000000000000815250816003908051906020019062000096929190620001a6565b508060049080519060200190620000af929190620001a6565b505050620000d2620000c6620000d860201b60201c565b620000e060201b60201c565b620002bb565b600033905090565b6000600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600560006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b828054620001b49062000256565b90600052602060002090601f016020900481019282620001d8576000855562000224565b82601f10620001f357805160ff191683800117855562000224565b8280016001018555821562000224579182015b828111156200022357825182559160200191906001019062000206565b5b50905062000233919062000237565b5090565b5b808211156200025257600081600090555060010162000238565b5090565b600060028204905060018216806200026f57607f821691505b602082108114156200028657620002856200028c565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b611f2580620002cb6000396000f3fe608060405234801561001057600080fd5b506004361061012c5760003560e01c8063715018a6116100ad578063a9059cbb11610071578063a9059cbb14610331578063dd62ed3e14610361578063f2fde38b14610391578063fb19c760146103ad578063fcc16464146103dd5761012c565b8063715018a61461029f57806379cc6790146102a95780638da5cb5b146102c557806395d89b41146102e3578063a457c2d7146103015761012c565b806339509351116100f457806339509351146101eb57806340c10f191461021b57806342966c68146102375780634d197a9b1461025357806370a082311461026f5761012c565b806306fdde0314610131578063095ea7b31461014f57806318160ddd1461017f57806323b872dd1461019d578063313ce567146101cd575b600080fd5b6101396103f9565b60405161014691906117d8565b60405180910390f35b61016960048036038101906101649190611524565b61048b565b60405161017691906117bd565b60405180910390f35b6101876104ae565b604051610194919061197a565b60405180910390f35b6101b760048036038101906101b291906114d5565b6104b8565b6040516101c491906117bd565b60405180910390f35b6101d56104e7565b6040516101e29190611995565b60405180910390f35b61020560048036038101906102009190611524565b6104f0565b60405161021291906117bd565b60405180910390f35b61023560048036038101906102309190611524565b610527565b005b610251600480360381019061024c9190611560565b6105b8565b005b61026d60048036038101906102689190611470565b6105cc565b005b61028960048036038101906102849190611470565b6106a3565b604051610296919061197a565b60405180910390f35b6102a76106eb565b005b6102c360048036038101906102be9190611524565b610773565b005b6102cd610793565b6040516102da91906117a2565b60405180910390f35b6102eb6107bd565b6040516102f891906117d8565b60405180910390f35b61031b60048036038101906103169190611524565b61084f565b60405161032891906117bd565b60405180910390f35b61034b60048036038101906103469190611524565b6108c6565b60405161035891906117bd565b60405180910390f35b61037b60048036038101906103769190611499565b6108e9565b604051610388919061197a565b60405180910390f35b6103ab60048036038101906103a69190611470565b610970565b005b6103c760048036038101906103c29190611470565b610a68565b6040516103d491906117bd565b60405180910390f35b6103f760048036038101906103f29190611470565b610a88565b005b60606003805461040890611ade565b80601f016020809104026020016040519081016040528092919081815260200182805461043490611ade565b80156104815780601f1061045657610100808354040283529160200191610481565b820191906000526020600020905b81548152906001019060200180831161046457829003601f168201915b5050505050905090565b600080610496610b5f565b90506104a3818585610b67565b600191505092915050565b6000600254905090565b6000806104c3610b5f565b90506104d0858285610d32565b6104db858585610dbe565b60019150509392505050565b60006012905090565b6000806104fb610b5f565b905061051c81858561050d85896108e9565b61051791906119cc565b610b67565b600191505092915050565b600660003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff166105aa576040517f70b34fc000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6105b4828261103f565b5050565b6105c96105c3610b5f565b8261119f565b50565b6105d4610b5f565b73ffffffffffffffffffffffffffffffffffffffff166105f2610793565b73ffffffffffffffffffffffffffffffffffffffff1614610648576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161063f906118ba565b60405180910390fd5b6001600660008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b60008060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6106f3610b5f565b73ffffffffffffffffffffffffffffffffffffffff16610711610793565b73ffffffffffffffffffffffffffffffffffffffff1614610767576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161075e906118ba565b60405180910390fd5b6107716000611376565b565b6107858261077f610b5f565b83610d32565b61078f828261119f565b5050565b6000600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b6060600480546107cc90611ade565b80601f01602080910402602001604051908101604052809291908181526020018280546107f890611ade565b80156108455780601f1061081a57610100808354040283529160200191610845565b820191906000526020600020905b81548152906001019060200180831161082857829003601f168201915b5050505050905090565b60008061085a610b5f565b9050600061086882866108e9565b9050838110156108ad576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016108a49061193a565b60405180910390fd5b6108ba8286868403610b67565b60019250505092915050565b6000806108d1610b5f565b90506108de818585610dbe565b600191505092915050565b6000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b610978610b5f565b73ffffffffffffffffffffffffffffffffffffffff16610996610793565b73ffffffffffffffffffffffffffffffffffffffff16146109ec576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016109e3906118ba565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610a5c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a539061183a565b60405180910390fd5b610a6581611376565b50565b60066020528060005260406000206000915054906101000a900460ff1681565b610a90610b5f565b73ffffffffffffffffffffffffffffffffffffffff16610aae610793565b73ffffffffffffffffffffffffffffffffffffffff1614610b04576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610afb906118ba565b60405180910390fd5b6000600660008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415610bd7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bce9061191a565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415610c47576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c3e9061185a565b60405180910390fd5b80600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92583604051610d25919061197a565b60405180910390a3505050565b6000610d3e84846108e9565b90507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8114610db85781811015610daa576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610da19061187a565b60405180910390fd5b610db78484848403610b67565b5b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415610e2e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e25906118fa565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415610e9e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e95906117fa565b60405180910390fd5b610ea983838361143c565b60008060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015610f2f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f269061189a565b60405180910390fd5b8181036000808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550816000808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000828254610fc291906119cc565b925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611026919061197a565b60405180910390a3611039848484611441565b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156110af576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110a69061195a565b60405180910390fd5b6110bb6000838361143c565b80600260008282546110cd91906119cc565b92505081905550806000808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825461112291906119cc565b925050819055508173ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611187919061197a565b60405180910390a361119b60008383611441565b5050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16141561120f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611206906118da565b60405180910390fd5b61121b8260008361143c565b60008060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050818110156112a1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112989061181a565b60405180910390fd5b8181036000808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555081600260008282546112f89190611a22565b92505081905550600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161135d919061197a565b60405180910390a361137183600084611441565b505050565b6000600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600560006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b505050565b505050565b60008135905061145581611ec1565b92915050565b60008135905061146a81611ed8565b92915050565b60006020828403121561148257600080fd5b600061149084828501611446565b91505092915050565b600080604083850312156114ac57600080fd5b60006114ba85828601611446565b92505060206114cb85828601611446565b9150509250929050565b6000806000606084860312156114ea57600080fd5b60006114f886828701611446565b935050602061150986828701611446565b925050604061151a8682870161145b565b9150509250925092565b6000806040838503121561153757600080fd5b600061154585828601611446565b92505060206115568582860161145b565b9150509250929050565b60006020828403121561157257600080fd5b60006115808482850161145b565b91505092915050565b61159281611a56565b82525050565b6115a181611a68565b82525050565b60006115b2826119b0565b6115bc81856119bb565b93506115cc818560208601611aab565b6115d581611b6e565b840191505092915050565b60006115ed6023836119bb565b91506115f882611b7f565b604082019050919050565b60006116106022836119bb565b915061161b82611bce565b604082019050919050565b60006116336026836119bb565b915061163e82611c1d565b604082019050919050565b60006116566022836119bb565b915061166182611c6c565b604082019050919050565b6000611679601d836119bb565b915061168482611cbb565b602082019050919050565b600061169c6026836119bb565b91506116a782611ce4565b604082019050919050565b60006116bf6020836119bb565b91506116ca82611d33565b602082019050919050565b60006116e26021836119bb565b91506116ed82611d5c565b604082019050919050565b60006117056025836119bb565b915061171082611dab565b604082019050919050565b60006117286024836119bb565b915061173382611dfa565b604082019050919050565b600061174b6025836119bb565b915061175682611e49565b604082019050919050565b600061176e601f836119bb565b915061177982611e98565b602082019050919050565b61178d81611a94565b82525050565b61179c81611a9e565b82525050565b60006020820190506117b76000830184611589565b92915050565b60006020820190506117d26000830184611598565b92915050565b600060208201905081810360008301526117f281846115a7565b905092915050565b60006020820190508181036000830152611813816115e0565b9050919050565b6000602082019050818103600083015261183381611603565b9050919050565b6000602082019050818103600083015261185381611626565b9050919050565b6000602082019050818103600083015261187381611649565b9050919050565b600060208201905081810360008301526118938161166c565b9050919050565b600060208201905081810360008301526118b38161168f565b9050919050565b600060208201905081810360008301526118d3816116b2565b9050919050565b600060208201905081810360008301526118f3816116d5565b9050919050565b60006020820190508181036000830152611913816116f8565b9050919050565b600060208201905081810360008301526119338161171b565b9050919050565b600060208201905081810360008301526119538161173e565b9050919050565b6000602082019050818103600083015261197381611761565b9050919050565b600060208201905061198f6000830184611784565b92915050565b60006020820190506119aa6000830184611793565b92915050565b600081519050919050565b600082825260208201905092915050565b60006119d782611a94565b91506119e283611a94565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff03821115611a1757611a16611b10565b5b828201905092915050565b6000611a2d82611a94565b9150611a3883611a94565b925082821015611a4b57611a4a611b10565b5b828203905092915050565b6000611a6182611a74565b9050919050565b60008115159050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b600060ff82169050919050565b60005b83811015611ac9578082015181840152602081019050611aae565b83811115611ad8576000848401525b50505050565b60006002820490506001821680611af657607f821691505b60208210811415611b0a57611b09611b3f565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b6000601f19601f8301169050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f206164647260008201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a206275726e20616d6f756e7420657863656564732062616c616e60008201527f6365000000000000000000000000000000000000000000000000000000000000602082015250565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a20617070726f766520746f20746865207a65726f20616464726560008201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a20696e73756666696369656e7420616c6c6f77616e6365000000600082015250565b7f45524332303a207472616e7366657220616d6f756e742065786365656473206260008201527f616c616e63650000000000000000000000000000000000000000000000000000602082015250565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b7f45524332303a206275726e2066726f6d20746865207a65726f2061646472657360008201527f7300000000000000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f7760008201527f207a65726f000000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a206d696e7420746f20746865207a65726f206164647265737300600082015250565b611eca81611a56565b8114611ed557600080fd5b50565b611ee181611a94565b8114611eec57600080fd5b5056fea2646970667358221220fb5292422c531328599edc0dafc436165af50772c565ad6c8a43722b6970ec3b64736f6c63430008040033

Block Transaction Difficulty Gas Used Reward
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.