Contract 0x9C846D808A41328A209e235B5e3c4E626DAb169E 1

Contract Overview

Chikn Farm: Fert Token
Balance:
0 AVAX

AVAX Value:
$0.00

Token:
Txn Hash Method
Block
From
To
Value [Txn Fee]
0x75932e52f7bb4ed37ee7b8d5dce2f60cfffba4fade8147d01b4ca0c803f92ab0Approve279555682023-03-27 6:28:2919 mins ago0xf4941d621f43c0417964f71b973d1748c8d0b548 IN  Chikn Farm: Fert Token0 AVAX0.000743625 25
0x8b4cf94ee2f503061d50cfaff76320fbe3ab26dac323014337d38eb8574df4d9Transfer279532132023-03-27 5:04:141 hr 43 mins ago0x3d1cd05e284a58027ceabc98c11512f77d1f7de6 IN  Chikn Farm: Fert Token0 AVAX0.00088152525
0x0c01308ab219fe7b0de23855b7015540a1b3045a82af2f308360d04152641c06Transfer279532002023-03-27 5:03:471 hr 43 mins ago0x6e895a09f46307d46ced2b5ac7cbc4b7130a419e IN  Chikn Farm: Fert Token0 AVAX0.00088152525
0xfe447eabf8e6a43dba4eb7254e2dd164d87f01dee0c9313df70ec3e79ec24448Transfer279531942023-03-27 5:03:321 hr 44 mins ago0x4105557d7def3d6e878114520ddda6478ebe79cf IN  Chikn Farm: Fert Token0 AVAX0.00088212525
0x4b88a2ac115fb11924be00f8a93f3646a826dd5c6ed7d309b8c21dd045911569Transfer279531812023-03-27 5:03:051 hr 44 mins ago0xfdf8dc397a9bc931c6d7a51975a6b7486319329c IN  Chikn Farm: Fert Token0 AVAX0.00130902525
0x021dce891832166f5252e67731595332c880837730bab87122446c74c61b6cb8Approve279476162023-03-27 1:42:455 hrs 4 mins ago0xe1b774691a4f62d18c15eac8082e7379f3961a02 IN  Chikn Farm: Fert Token0 AVAX0.0012442545 26.5
0x9d8c2ec7b8102e719278cb2fb114e771d3c947c3582c9b6fa370266e41f597afApprove279402662023-03-26 21:17:359 hrs 30 mins ago0x3ba322314ea7751c961e274e0c0f991cd1963a3b IN  Chikn Farm: Fert Token0 AVAX0.00124783861 26.583127973
0x4e763ae75d66687b88923157f06bfea5608daedabb77852ff39d1cd60d74a2c1Approve279402232023-03-26 21:16:009 hrs 31 mins ago0x3ba322314ea7751c961e274e0c0f991cd1963a3b IN  Chikn Farm: Fert Token0 AVAX0.00125526995 26.734605903
0x5ffc155233190a741e51cfa906c1cde78893b1e86bee136617b8328642132fccTransfer279315912023-03-26 15:47:0815 hrs ago0xc52928db2db6f3e4fbc82ac5a8835159c0077019 IN  Chikn Farm: Fert Token0 AVAX0.0013885205 26.5
0xf8b26d4cc07c0be9b355289e20fc2307b345a3fb05185d3db2e60db4dea2e63aTransfer279314242023-03-26 15:40:2615 hrs 7 mins ago0x4ec106b066287fd0acce6a77ec15792354048ae7 IN  Chikn Farm: Fert Token0 AVAX0.00093124301 26.41
0xa5638c3e2b701bef6b8fc3bf9116002e3344443b5409666adbe650060fdb1d19Approve279308612023-03-26 15:18:4915 hrs 28 mins ago0x10e68b4b91faff52cf2a8714b8f581e4503ba61b IN  Chikn Farm: Fert Token0 AVAX0.000797638979 26.72963305
0xd088652e5fc6b55c64e51f90857cb7320172f1a1d87c483e2e90b3a8ebe06edfApprove279297442023-03-26 14:33:5916 hrs 13 mins ago0xc8de710f84903f8e15be6b9e819c1423bf81ce10 IN  Chikn Farm: Fert Token0 AVAX0.0012445725 26.5
0xbd6eba5340431616013aab83eeaa82c64e7a1cc17fd41a84e8f6a4b7b2f80841Transfer279270152023-03-26 12:42:2618 hrs 5 mins ago0x2cfffaee925a4bb7274c15eb484e803244a9c622 IN  Chikn Farm: Fert Token0 AVAX0.0013875665 26.5
0xdbc7d7b91957532f564aebcaae14ae76f17b2a701e5c6164e1621720e4f28a7aTransfer279228982023-03-26 8:54:3821 hrs 53 mins ago0x0f0205d7be94ab5bd3a1ea19f305e6618905cdea IN  Chikn Farm: Fert Token0 AVAX0.001436000425 27.425
0x834476d1ca2a602bcbcfa8724c5ac7b2a1f3e317162a9720fe4aa27f59dbb036Approve279185662023-03-26 6:25:091 day 22 mins ago0x7ad38be4f06615612dedc523d898650a3454125a IN  Chikn Farm: Fert Token0 AVAX0.00132241228
0x45433e38d230f6a0b04383b0a19b6bb56dfd22e6941949803f9861a23a7caf7aTransfer279162762023-03-26 5:04:141 day 1 hr ago0x3d1cd05e284a58027ceabc98c11512f77d1f7de6 IN  Chikn Farm: Fert Token0 AVAX0.00088152525
0x05c0ec64929ef24290f9388424e4996b5ef83786a479bf972ca0f77a9b0b07afTransfer279162632023-03-26 5:03:481 day 1 hr ago0x6e895a09f46307d46ced2b5ac7cbc4b7130a419e IN  Chikn Farm: Fert Token0 AVAX0.00088152525
0x8de8109a961a6bd290899c125fbbffc1c716450348961a600650fd1d2abd8e82Transfer279162552023-03-26 5:03:321 day 1 hr ago0x4105557d7def3d6e878114520ddda6478ebe79cf IN  Chikn Farm: Fert Token0 AVAX0.00088152525
0xd3e570fa04881e8f7605e5e2db1fd8c9522eb1b4b2ccc515579d551c63ab5602Transfer279162422023-03-26 5:03:051 day 1 hr ago0xfdf8dc397a9bc931c6d7a51975a6b7486319329c IN  Chikn Farm: Fert Token0 AVAX0.00130902525
0xe7febb591db069d4917c3b8deeec4233dcab838f8cc58e4be1fbadc7b92e8b15Approve279139272023-03-26 3:38:481 day 3 hrs ago0x3b82d2e900fe62d5ef2a928ee134d0fef6baccf3 IN  Chikn Farm: Fert Token0 AVAX0.0007907865 26.5
0xa23342dcc2aa64cc2c27650d6455794e16273ed4ba3487a137f8402816ef84f9Approve279133502023-03-26 3:18:121 day 3 hrs ago0x8907ed8a8e22b02410444342bdcb31c1bee3e6f7 IN  Chikn Farm: Fert Token0 AVAX0.0007904685 26.5
0x2d038521b17cfccedfd74ffac4d096ea4b25e159c1beccafd7f3b0cf7e0f32d6Approve279107552023-03-26 1:46:051 day 5 hrs ago0x425cbde8001c996ddf1f0e6e7408e5a8b86cd990 IN  Chikn Farm: Fert Token0 AVAX0.0012442545 26.5
0x155b33cb0f28459c694d9d7a28da03e582d087784b37b0497165cdf0a8dd29d2Approve279040372023-03-25 21:54:081 day 8 hrs ago0x24fd35dd183f55a79dd9b8347778bc3ec0118973 IN  Chikn Farm: Fert Token0 AVAX0.001313755888 27.994542572
0x95c128cd0b478720a5da88ec20903944210d5a59a038de7a9521293816acf0ecApprove279026172023-03-25 21:04:551 day 9 hrs ago0x931e976ef3419b62a329341e6ba44936026be3ef IN  Chikn Farm: Fert Token0 AVAX0.0012436185 26.5
0x037a2c998f9579fc0b8335fbd2bc9cb6a42a95e12bac9533a8b4f780910b8a50Approve278990842023-03-25 19:03:501 day 11 hrs ago0x60fc9edde8ba8d742257315dd5664e4545b54a5d IN  Chikn Farm: Fert Token0 AVAX0.000683225 25
[ Download CSV Export 
Parent Txn Hash Block From To Value
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
Fert

Compiler Version
v0.8.3+commit.8d00100c

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion

Contract Source Code (Solidity Standard Json-Input format)

File 1 of 7 : Fert.sol
//SPDX-License-Identifier: MIT

pragma solidity >=0.8.0;
import "@openzeppelin/contracts/token/ERC20/ERC20.sol";
import "./Authorizable.sol";

contract Fert is ERC20, Authorizable {
    string private TOKEN_NAME = "chikn fert";
    string private TOKEN_SYMBOL = "FERT";

    event Minted(address owner, uint256 fertAmt);
    event Burned(address owner, uint256 fertAmt);

    mapping(address => bool) public authorizedToMint;

    modifier onlyAuthorizedToMint() {
        require(authorizedToMint[msg.sender] ||  owner() == msg.sender, "Not authorized to mint");
        _;
    }

     function addAuthorizedToMint(address _toAdd) onlyOwner public {
        require(_toAdd != address(0));
        authorizedToMint[_toAdd] = true;
    }

    function removeAuthorizedToMint(address _toRemove) onlyOwner public {
        require(_toRemove != address(0));
        require(_toRemove != msg.sender);
        authorizedToMint[_toRemove] = false;
    }

    // Constructor
    constructor() ERC20(TOKEN_NAME, TOKEN_SYMBOL) {
    }

    function mint(address to, uint256 amount) external onlyAuthorizedToMint {
        _mint(to, amount);
        emit Minted(to, amount);
    }

    function burn(address sender, uint256 amount) external onlyAuthorized {
        require(balanceOf(sender) >= amount, "NOT ENOUGH FERT");
        _burn(sender, amount);
        emit Burned(sender, amount);
    }
}

File 2 of 7 : ERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.5.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, _allowances[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 = _allowances[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 Spend `amount` form the allowance of `owner` toward `spender`.
     *
     * 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 : Authorizable.sol
//SPDX-License-Identifier: MIT

pragma solidity >=0.8.0;

import "@openzeppelin/contracts/access/Ownable.sol";

contract Authorizable is Ownable {

    mapping(address => bool) public authorized;

    modifier onlyAuthorized() {
        require(authorized[msg.sender] ||  owner() == msg.sender, "Not authorized");
        _;
    }

    function addAuthorized(address _toAdd) onlyOwner public {
        require(_toAdd != address(0));
        authorized[_toAdd] = true;
    }

    function removeAuthorized(address _toRemove) onlyOwner public {
        require(_toRemove != address(0));
        require(_toRemove != msg.sender);
        authorized[_toRemove] = false;
    }

}

File 4 of 7 : IERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.5.0) (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 `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);

    /**
     * @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 5 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 6 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;
    }
}

File 7 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);
    }
}

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

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"owner","type":"address"},{"indexed":false,"internalType":"uint256","name":"fertAmt","type":"uint256"}],"name":"Burned","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"owner","type":"address"},{"indexed":false,"internalType":"uint256","name":"fertAmt","type":"uint256"}],"name":"Minted","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":"_toAdd","type":"address"}],"name":"addAuthorized","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_toAdd","type":"address"}],"name":"addAuthorizedToMint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"authorized","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"authorizedToMint","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":"address","name":"sender","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":"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":[{"internalType":"address","name":"_toRemove","type":"address"}],"name":"removeAuthorized","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_toRemove","type":"address"}],"name":"removeAuthorizedToMint","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":"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"}]

60806040526040518060400160405280600a81526020017f6368696b6e2066657274000000000000000000000000000000000000000000008152506007908051906020019062000051929190620002fc565b506040518060400160405280600481526020017f4645525400000000000000000000000000000000000000000000000000000000815250600890805190602001906200009f929190620002fc565b50348015620000ad57600080fd5b5060078054620000bd90620003ac565b80601f0160208091040260200160405190810160405280929190818152602001828054620000eb90620003ac565b80156200013c5780601f1062000110576101008083540402835291602001916200013c565b820191906000526020600020905b8154815290600101906020018083116200011e57829003601f168201915b5050505050600880546200015090620003ac565b80601f01602080910402602001604051908101604052809291908181526020018280546200017e90620003ac565b8015620001cf5780601f10620001a357610100808354040283529160200191620001cf565b820191906000526020600020905b815481529060010190602001808311620001b157829003601f168201915b50505050508160039080519060200190620001ec929190620002fc565b50806004908051906020019062000205929190620002fc565b505050620002286200021c6200022e60201b60201c565b6200023660201b60201c565b62000411565b600033905090565b6000600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600560006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b8280546200030a90620003ac565b90600052602060002090601f0160209004810192826200032e57600085556200037a565b82601f106200034957805160ff19168380011785556200037a565b828001600101855582156200037a579182015b82811115620003795782518255916020019190600101906200035c565b5b5090506200038991906200038d565b5090565b5b80821115620003a85760008160009055506001016200038e565b5090565b60006002820490506001821680620003c557607f821691505b60208210811415620003dc57620003db620003e2565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b61267f80620004216000396000f3fe608060405234801561001057600080fd5b50600436106101425760003560e01c806395d89b41116100b8578063a4c6c8c51161007c578063a4c6c8c514610377578063a9059cbb14610393578063b9181611146103c3578063cf1c316a146103f3578063dd62ed3e1461040f578063f2fde38b1461043f57610142565b806395d89b41146102c157806396d41116146102df5780639c23bec9146102fb5780639dc29fac1461032b578063a457c2d71461034757610142565b8063395093511161010a578063395093511461020157806340c10f1914610231578063485d7d941461024d57806370a0823114610269578063715018a6146102995780638da5cb5b146102a357610142565b806306fdde0314610147578063095ea7b31461016557806318160ddd1461019557806323b872dd146101b3578063313ce567146101e3575b600080fd5b61014f61045b565b60405161015c9190611e57565b60405180910390f35b61017f600480360381019061017a9190611b3a565b6104ed565b60405161018c9190611e3c565b60405180910390f35b61019d610510565b6040516101aa9190612059565b60405180910390f35b6101cd60048036038101906101c89190611aeb565b61051a565b6040516101da9190611e3c565b60405180910390f35b6101eb610549565b6040516101f89190612074565b60405180910390f35b61021b60048036038101906102169190611b3a565b610552565b6040516102289190611e3c565b60405180910390f35b61024b60048036038101906102469190611b3a565b6105fc565b005b61026760048036038101906102629190611a86565b61070c565b005b610283600480360381019061027e9190611a86565b610856565b6040516102909190612059565b60405180910390f35b6102a161089e565b005b6102ab610926565b6040516102b89190611df8565b60405180910390f35b6102c9610950565b6040516102d69190611e57565b60405180910390f35b6102f960048036038101906102f49190611a86565b6109e2565b005b61031560048036038101906103109190611a86565b610af3565b6040516103229190611e3c565b60405180910390f35b61034560048036038101906103409190611b3a565b610b13565b005b610361600480360381019061035c9190611b3a565b610c6e565b60405161036e9190611e3c565b60405180910390f35b610391600480360381019061038c9190611a86565b610d58565b005b6103ad60048036038101906103a89190611b3a565b610ea2565b6040516103ba9190611e3c565b60405180910390f35b6103dd60048036038101906103d89190611a86565b610ec5565b6040516103ea9190611e3c565b60405180910390f35b61040d60048036038101906104089190611a86565b610ee5565b005b61042960048036038101906104249190611aaf565b610ff6565b6040516104369190612059565b60405180910390f35b61045960048036038101906104549190611a86565b61107d565b005b60606003805461046a906121bd565b80601f0160208091040260200160405190810160405280929190818152602001828054610496906121bd565b80156104e35780601f106104b8576101008083540402835291602001916104e3565b820191906000526020600020905b8154815290600101906020018083116104c657829003601f168201915b5050505050905090565b6000806104f8611175565b905061050581858561117d565b600191505092915050565b6000600254905090565b600080610525611175565b9050610532858285611348565b61053d8585856113d4565b60019150509392505050565b60006012905090565b60008061055d611175565b90506105f1818585600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008973ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020546105ec91906120ab565b61117d565b600191505092915050565b600960003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff168061068657503373ffffffffffffffffffffffffffffffffffffffff1661066e610926565b73ffffffffffffffffffffffffffffffffffffffff16145b6106c5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106bc90611f39565b60405180910390fd5b6106cf8282611655565b7f30385c845b448a36257a6a1716e6ad2e1bc2cbe333cde1e69fe849ad6511adfe8282604051610700929190611e13565b60405180910390a15050565b610714611175565b73ffffffffffffffffffffffffffffffffffffffff16610732610926565b73ffffffffffffffffffffffffffffffffffffffff1614610788576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161077f90611f59565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614156107c257600080fd5b3373ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614156107fb57600080fd5b6000600660008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b60008060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6108a6611175565b73ffffffffffffffffffffffffffffffffffffffff166108c4610926565b73ffffffffffffffffffffffffffffffffffffffff161461091a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161091190611f59565b60405180910390fd5b61092460006117b5565b565b6000600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60606004805461095f906121bd565b80601f016020809104026020016040519081016040528092919081815260200182805461098b906121bd565b80156109d85780601f106109ad576101008083540402835291602001916109d8565b820191906000526020600020905b8154815290600101906020018083116109bb57829003601f168201915b5050505050905090565b6109ea611175565b73ffffffffffffffffffffffffffffffffffffffff16610a08610926565b73ffffffffffffffffffffffffffffffffffffffff1614610a5e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a5590611f59565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610a9857600080fd5b6001600960008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b60096020528060005260406000206000915054906101000a900460ff1681565b600660003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff1680610b9d57503373ffffffffffffffffffffffffffffffffffffffff16610b85610926565b73ffffffffffffffffffffffffffffffffffffffff16145b610bdc576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bd390612019565b60405180910390fd5b80610be683610856565b1015610c27576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c1e90611fb9565b60405180910390fd5b610c31828261187b565b7f696de425f79f4a40bc6d2122ca50507f0efbeabbff86a84871b7196ab8ea8df78282604051610c62929190611e13565b60405180910390a15050565b600080610c79611175565b90506000600160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905083811015610d3f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610d3690611ff9565b60405180910390fd5b610d4c828686840361117d565b60019250505092915050565b610d60611175565b73ffffffffffffffffffffffffffffffffffffffff16610d7e610926565b73ffffffffffffffffffffffffffffffffffffffff1614610dd4576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610dcb90611f59565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610e0e57600080fd5b3373ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610e4757600080fd5b6000600960008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b600080610ead611175565b9050610eba8185856113d4565b600191505092915050565b60066020528060005260406000206000915054906101000a900460ff1681565b610eed611175565b73ffffffffffffffffffffffffffffffffffffffff16610f0b610926565b73ffffffffffffffffffffffffffffffffffffffff1614610f61576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610f5890611f59565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415610f9b57600080fd5b6001600660008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b6000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b611085611175565b73ffffffffffffffffffffffffffffffffffffffff166110a3610926565b73ffffffffffffffffffffffffffffffffffffffff16146110f9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110f090611f59565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415611169576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161116090611eb9565b60405180910390fd5b611172816117b5565b50565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614156111ed576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016111e490611fd9565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16141561125d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161125490611ed9565b60405180910390fd5b80600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9258360405161133b9190612059565b60405180910390a3505050565b60006113548484610ff6565b90507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff81146113ce57818110156113c0576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016113b790611ef9565b60405180910390fd5b6113cd848484840361117d565b5b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415611444576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161143b90611f99565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156114b4576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114ab90611e79565b60405180910390fd5b6114bf838383611a52565b60008060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015611545576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161153c90611f19565b60405180910390fd5b8181036000808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550816000808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546115d891906120ab565b925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161163c9190612059565b60405180910390a361164f848484611a57565b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156116c5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016116bc90612039565b60405180910390fd5b6116d160008383611a52565b80600260008282546116e391906120ab565b92505081905550806000808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825461173891906120ab565b925050819055508173ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8360405161179d9190612059565b60405180910390a36117b160008383611a57565b5050565b6000600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905081600560006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508173ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a35050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156118eb576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016118e290611f79565b60405180910390fd5b6118f782600083611a52565b60008060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205490508181101561197d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161197490611e99565b60405180910390fd5b8181036000808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555081600260008282546119d49190612101565b92505081905550600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051611a399190612059565b60405180910390a3611a4d83600084611a57565b505050565b505050565b505050565b600081359050611a6b8161261b565b92915050565b600081359050611a8081612632565b92915050565b600060208284031215611a9857600080fd5b6000611aa684828501611a5c565b91505092915050565b60008060408385031215611ac257600080fd5b6000611ad085828601611a5c565b9250506020611ae185828601611a5c565b9150509250929050565b600080600060608486031215611b0057600080fd5b6000611b0e86828701611a5c565b9350506020611b1f86828701611a5c565b9250506040611b3086828701611a71565b9150509250925092565b60008060408385031215611b4d57600080fd5b6000611b5b85828601611a5c565b9250506020611b6c85828601611a71565b9150509250929050565b611b7f81612135565b82525050565b611b8e81612147565b82525050565b6000611b9f8261208f565b611ba9818561209a565b9350611bb981856020860161218a565b611bc28161224d565b840191505092915050565b6000611bda60238361209a565b9150611be58261225e565b604082019050919050565b6000611bfd60228361209a565b9150611c08826122ad565b604082019050919050565b6000611c2060268361209a565b9150611c2b826122fc565b604082019050919050565b6000611c4360228361209a565b9150611c4e8261234b565b604082019050919050565b6000611c66601d8361209a565b9150611c718261239a565b602082019050919050565b6000611c8960268361209a565b9150611c94826123c3565b604082019050919050565b6000611cac60168361209a565b9150611cb782612412565b602082019050919050565b6000611ccf60208361209a565b9150611cda8261243b565b602082019050919050565b6000611cf260218361209a565b9150611cfd82612464565b604082019050919050565b6000611d1560258361209a565b9150611d20826124b3565b604082019050919050565b6000611d38600f8361209a565b9150611d4382612502565b602082019050919050565b6000611d5b60248361209a565b9150611d668261252b565b604082019050919050565b6000611d7e60258361209a565b9150611d898261257a565b604082019050919050565b6000611da1600e8361209a565b9150611dac826125c9565b602082019050919050565b6000611dc4601f8361209a565b9150611dcf826125f2565b602082019050919050565b611de381612173565b82525050565b611df28161217d565b82525050565b6000602082019050611e0d6000830184611b76565b92915050565b6000604082019050611e286000830185611b76565b611e356020830184611dda565b9392505050565b6000602082019050611e516000830184611b85565b92915050565b60006020820190508181036000830152611e718184611b94565b905092915050565b60006020820190508181036000830152611e9281611bcd565b9050919050565b60006020820190508181036000830152611eb281611bf0565b9050919050565b60006020820190508181036000830152611ed281611c13565b9050919050565b60006020820190508181036000830152611ef281611c36565b9050919050565b60006020820190508181036000830152611f1281611c59565b9050919050565b60006020820190508181036000830152611f3281611c7c565b9050919050565b60006020820190508181036000830152611f5281611c9f565b9050919050565b60006020820190508181036000830152611f7281611cc2565b9050919050565b60006020820190508181036000830152611f9281611ce5565b9050919050565b60006020820190508181036000830152611fb281611d08565b9050919050565b60006020820190508181036000830152611fd281611d2b565b9050919050565b60006020820190508181036000830152611ff281611d4e565b9050919050565b6000602082019050818103600083015261201281611d71565b9050919050565b6000602082019050818103600083015261203281611d94565b9050919050565b6000602082019050818103600083015261205281611db7565b9050919050565b600060208201905061206e6000830184611dda565b92915050565b60006020820190506120896000830184611de9565b92915050565b600081519050919050565b600082825260208201905092915050565b60006120b682612173565b91506120c183612173565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff038211156120f6576120f56121ef565b5b828201905092915050565b600061210c82612173565b915061211783612173565b92508282101561212a576121296121ef565b5b828203905092915050565b600061214082612153565b9050919050565b60008115159050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b600060ff82169050919050565b60005b838110156121a857808201518184015260208101905061218d565b838111156121b7576000848401525b50505050565b600060028204905060018216806121d557607f821691505b602082108114156121e9576121e861221e565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b6000601f19601f8301169050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f206164647260008201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a206275726e20616d6f756e7420657863656564732062616c616e60008201527f6365000000000000000000000000000000000000000000000000000000000000602082015250565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160008201527f6464726573730000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a20617070726f766520746f20746865207a65726f20616464726560008201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a20696e73756666696369656e7420616c6c6f77616e6365000000600082015250565b7f45524332303a207472616e7366657220616d6f756e742065786365656473206260008201527f616c616e63650000000000000000000000000000000000000000000000000000602082015250565b7f4e6f7420617574686f72697a656420746f206d696e7400000000000000000000600082015250565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572600082015250565b7f45524332303a206275726e2066726f6d20746865207a65726f2061646472657360008201527f7300000000000000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b7f4e4f5420454e4f55474820464552540000000000000000000000000000000000600082015250565b7f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b7f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f7760008201527f207a65726f000000000000000000000000000000000000000000000000000000602082015250565b7f4e6f7420617574686f72697a6564000000000000000000000000000000000000600082015250565b7f45524332303a206d696e7420746f20746865207a65726f206164647265737300600082015250565b61262481612135565b811461262f57600080fd5b50565b61263b81612173565b811461264657600080fd5b5056fea26469706673582212209cfdf0b32f59ddbf0e693504459557b3b5667a9bb133d4ae6645086b75a5555664736f6c63430008030033

Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Block Uncle Number Difficulty Gas Used Reward
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.