Contract 0xf24bcf4d1e507740041c9cfd2dddb29585adce1e 4

Txn Hash Method
Block
From
To
Value [Txn Fee]
0x12a92da20ffe6332e6dae1bdf097e3b33ed4ee30542df7e87f1d6d101cd92241Approve384328422022-05-17 9:49:572 mins ago0xaa76baa8d2a6483b2b2cd337552a27c60456a60c IN  Beethoven X: BEETS Token0 FTM0.015595111555
0x0e6c10d83ebd9aeff32b1200510c57a58299699f50aa820f3460bf97aa0718efApprove384324552022-05-17 9:42:3010 mins ago0x54b2d9aef22d594b26e7f61bb51548066e137270 IN  Beethoven X: BEETS Token0 FTM0.016716060763
0x187cffa77039a9c54249d989f0a7ddb490799f8d6b0ac7757d7a627c4daa604aApprove384323652022-05-17 9:40:4912 mins ago0xff44fac23ed2f58b7ebe18e000a417910b385ba0 IN  Beethoven X: BEETS Token0 FTM0.009510950321
0xf68c929b9cf7ad54c827d9f24132580211c13a3994a7ed22e7580cedf6ab4d8aApprove384321912022-05-17 9:37:2015 mins ago0xff44fac23ed2f58b7ebe18e000a417910b385ba0 IN  Beethoven X: BEETS Token0 FTM0.009608918957
0xec2b7b6449e9f435390222902691aa1c2165a4041e85dcc426e49953e8fe28f1Approve384305112022-05-17 9:05:4847 mins ago0x3a9c81fa92136c8062cf4fc838e9032c54ad2356 IN  Beethoven X: BEETS Token0 FTM0.0131816859
0x5db7db36248bd9df21c36c48d6bdd3285fe2953822caebf5d9c26ac77d14fdc0Transfer384301192022-05-17 8:58:3754 mins ago0x0467fff226395f1e188e9a43a913deb363dc795b IN  Beethoven X: BEETS Token0 FTM0.01469478383
0xb15b8f83a2abe8a86e9f56bf10fc543e827253639d5264ecad1a1390d1c40a43Approve384301172022-05-17 8:58:3654 mins ago0x9298588865ad835bbae8668ffa1619bd6547e8f6 IN  Beethoven X: BEETS Token0 FTM0.014821245
0xad3e2adffb6c5a859686625a0a1a91b56a3ef0f41fcda4cca8d6cccbfeb36fd1Approve384299862022-05-17 8:56:2356 mins ago0x9298588865ad835bbae8668ffa1619bd6547e8f6 IN  Beethoven X: BEETS Token0 FTM0.009394515
0xe4167996e124945bbcac64b68361418b0e165544225ce87cf65858c2ac74dfaeApprove384297832022-05-17 8:52:5259 mins ago0x94bb64f974b5cc1aeeafaf66ac43c6195d6e7bb2 IN  Beethoven X: BEETS Token0 FTM0.015236537956
0xfd396b4e341549a4fe320afe9e81a7adbc39ed9e12e84463588983cdbe08452bTransfer384296462022-05-17 8:50:411 hr 2 mins ago0x8fd8a5ce974e8bed586d8f00df73cf43a8533070 IN  Beethoven X: BEETS Token0 FTM0.01644446497
0x26eba09c6d60d025f00cb85fcc1bf4dd81dadc9915ec742e29fe543bb0a09706Approve384296382022-05-17 8:50:301 hr 2 mins ago0x9298588865ad835bbae8668ffa1619bd6547e8f6 IN  Beethoven X: BEETS Token0 FTM0.01614195
0x22dec50b4e64ef2c3cef58ed63268060b5d5b3131f210ac01704b348ad75c7a8Approve384286752022-05-17 8:33:241 hr 19 mins ago0xf29d3f5061b5910a6f7723dddfe991f28e4da5bd IN  Beethoven X: BEETS Token0 FTM0.019486065785
0x40275672e6289901adda387b4f2a7f11762c36bb6e5324a2a175a45d453dc3a7Transfer384283662022-05-17 8:28:041 hr 24 mins ago0xa1fca2207cec8a4d2538b2df0a0009abf4af25f6 IN  Beethoven X: BEETS Token0 FTM0.020204495991
0xd29877efb4df504c1bd601ef42cea879a42e06bc44e146eb2603d8276ed1c5d0Transfer384264072022-05-17 7:48:142 hrs 4 mins ago0xddd75df073742bf91bf68fffabdfbc2f75ca37ab IN  Beethoven X: BEETS Token0 FTM0.019188331279
0x9da077240b68753b9538cd51bbefa7df2c3e3be5f0408e27ab011fcccf09a3beApprove384252302022-05-17 7:23:292 hrs 29 mins ago0x8241bfd60f5d4180bd91ab7ad2f7eaa614401f0f IN  Beethoven X: BEETS Token0 FTM0.01360450199
0x920205ec66be8d360ad220c642a7e30855ee56775b2f68d88bd82f2804f12b7dApprove384245812022-05-17 7:11:022 hrs 41 mins ago0x28fe4d27cf0ec8bd71ddc10a79732a161d8bf862 IN  Beethoven X: BEETS Token0 FTM0.015109573691
0xe63b3603d60446c7087f2e4ba5e84f9c350d7ed71c7bdbc91c8b504509809bb6Approve384242592022-05-17 7:03:532 hrs 48 mins ago0x91960c1cc552525ad5bbba85f10c8651863a5e62 IN  Beethoven X: BEETS Token0 FTM0.016540028722
0x39acaf6eed25c1b1e0352f69541eb2aa6a5de70efc737294529047c874073b19Approve384239642022-05-17 6:57:202 hrs 55 mins ago0xfca45c72e1acf1dcb2658ab37db16fb179e5740a IN  Beethoven X: BEETS Token0 FTM0.015555768584
0x7c2e46427806419e2a11f6b978629dab261082868a69bd1cd8e215a049e43bebApprove384235642022-05-17 6:47:353 hrs 5 mins ago0x07a92f07b414157f1b51dc6363c4e41483c9ae30 IN  Beethoven X: BEETS Token0 FTM0.014130260937
0x057ec17357a72c70f6de3b68d7e1d69f6e4f9261b6431f59a81d19aa67468173Approve384220252022-05-17 6:18:133 hrs 34 mins ago0x9b34a2ed9a4283ea884e9e18db30f0910a707ec0 IN  Beethoven X: BEETS Token0 FTM0.01624279685
0x14178aabad165d1efc5a0940755348dfeb85bb024ffc92c90d435ff640c93dcaApprove384213342022-05-17 6:06:143 hrs 46 mins ago0x72afa00c1e700d73a8459ae8599742f9ce3d33fe IN  Beethoven X: BEETS Token0 FTM0.019865450084
0x5642615b9698059633b17f605f4179ece2db612697e1251f09f421075e7f3d32Approve384211132022-05-17 6:02:223 hrs 50 mins ago0xc2f7e3852ca0bc34e3500e199fd6e2b7d4f4c1bf IN  Beethoven X: BEETS Token0 FTM0.020193627628
0x8f6a659406f0d084b777035c9112e8542fb43462993946d6ea79f295e284fc19Approve384202392022-05-17 5:46:054 hrs 6 mins ago0x82ec79c2d1b24e5d1fa858682cf5a673ed21310e IN  Beethoven X: BEETS Token0 FTM0.018671819496
0x3e7eae45d0de0bed89f6353553fdce78c5e3f89a708e8eebc46740af9993aef7Approve384201072022-05-17 5:43:514 hrs 9 mins ago0x22334608cff04330168dbde32fdde0213dcf7568 IN  Beethoven X: BEETS Token0 FTM0.019219333726
0xd498d01c7dca7e5cf034be399f48b7ddd0d9b55fbc7afed8e955b33fb6eca352Approve384200392022-05-17 5:42:364 hrs 10 mins ago0xdc1c6b4452bc7a3aef02320250c67974aa700220 IN  Beethoven X: BEETS Token0 FTM0.03267522
[ Download CSV Export 

OVERVIEW

Beethoven X aims to be a one-stop decentralized investment platform on Fantom Opera. Beethoven X is the first next-generation AMM protocol on Fantom.

Latest 4 internal transactions
Parent Txn Hash Block From To Value
0x2048a5570d57f9716d7c684916dd5a9b091cc9af650a9b3a37f02566cb1c69f9277368692022-01-12 11:17:31124 days 22 hrs ago 0xebf4fbb9c81b84dd5cf89bc75588e5d0018501b3 Beethoven X: BEETS Token399.99 FTM
0xf7aa9468f1a86c77f173c7d6e76079b9e2b8f4e5c903b685b89ac55ba3265982274510432022-01-09 11:49:44127 days 22 hrs ago 0x3d7b4c8676cebe1c108cd905d3bfa6fae8a1ef54 Beethoven X: BEETS Token1 FTM
0x4081f392f0301cc59e365950175a37dab10250b5d85fe443ad8452c0914444cf233911362021-11-28 15:21:26169 days 18 hrs ago 0x6faa4a0b9374ad46f1ff48b4e7e1df1136ceb53e Beethoven X: BEETS Token6 FTM
0x05d20e9bcb784e0887ac9a432a4cf80516393dff1e074976dd7a89c2e5400b0a184202952021-10-06 8:06:26223 days 1 hr ago Beethoven X: Deployer  Contract Creation0 FTM
[ Download CSV Export 
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
BeethovenxToken

Compiler Version
v0.8.7+commit.e28d00a7

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, GNU LGPLv3 license
/**
 *Submitted for verification at FtmScan.com on 2021-10-06
*/

// SPDX-License-Identifier: MIXED

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

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

// License-Identifier: MIT

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

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

// License-Identifier: MIT

pragma solidity ^0.8.0;

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

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

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

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

// License-Identifier: MIT

pragma solidity ^0.8.0;

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

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

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

// License-Identifier: MIT

pragma solidity ^0.8.0;

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

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

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

        return true;
    }

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

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

        return true;
    }

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

        _beforeTokenTransfer(sender, recipient, amount);

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

        emit Transfer(sender, recipient, amount);

        _afterTokenTransfer(sender, recipient, amount);
    }

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

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

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

        _afterTokenTransfer(address(0), account, amount);
    }

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

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

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

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

        _afterTokenTransfer(account, address(0), amount);
    }

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

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

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

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

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

// License-Identifier: MIT

pragma solidity ^0.8.0;

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

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _setOwner(_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 {
        _setOwner(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"
        );
        _setOwner(newOwner);
    }

    function _setOwner(address newOwner) private {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

// File contracts_unflattened/token/BeethovenxToken.sol

// License-Identifier: MIT

pragma solidity 0.8.7;

contract BeethovenxToken is ERC20("BeethovenxToken", "BEETS"), Ownable {
    uint256 public constant MAX_SUPPLY = 250_000_000e18; // 250 million beets

    /// @notice Creates `_amount` token to `_to`. Must only be called by the owner (MasterChef).
    function mint(address _to, uint256 _amount) public onlyOwner {
        require(
            totalSupply() + _amount <= MAX_SUPPLY,
            "BEETS::mint: cannot exceed max supply"
        );
        _mint(_to, _amount);
    }
}

Contract Security Audit

Contract ABI

[{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"MAX_SUPPLY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"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":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]

60806040523480156200001157600080fd5b50604080518082018252600f81526e2132b2ba3437bb32b73c2a37b5b2b760891b602080830191825283518085019094526005845264424545545360d81b9084015281519192916200006691600391620000f5565b5080516200007c906004906020840190620000f5565b50505062000099620000936200009f60201b60201c565b620000a3565b620001d8565b3390565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b82805462000103906200019b565b90600052602060002090601f01602090048101928262000127576000855562000172565b82601f106200014257805160ff191683800117855562000172565b8280016001018555821562000172579182015b828111156200017257825182559160200191906001019062000155565b506200018092915062000184565b5090565b5b8082111562000180576000815560010162000185565b600181811c90821680620001b057607f821691505b60208210811415620001d257634e487b7160e01b600052602260045260246000fd5b50919050565b610c6380620001e86000396000f3fe608060405234801561001057600080fd5b50600436106101005760003560e01c806370a0823111610097578063a457c2d711610066578063a457c2d714610208578063a9059cbb1461021b578063dd62ed3e1461022e578063f2fde38b1461026757600080fd5b806370a08231146101b4578063715018a6146101dd5780638da5cb5b146101e557806395d89b411461020057600080fd5b8063313ce567116100d3578063313ce5671461016b57806332cb6b0c1461017a578063395093511461018c57806340c10f191461019f57600080fd5b806306fdde0314610105578063095ea7b31461012357806318160ddd1461014657806323b872dd14610158575b600080fd5b61010d61027a565b60405161011a9190610b42565b60405180910390f35b610136610131366004610b18565b61030c565b604051901515815260200161011a565b6002545b60405190815260200161011a565b610136610166366004610adc565b610322565b6040516012815260200161011a565b61014a6acecb8f27f4200f3a00000081565b61013661019a366004610b18565b6103d1565b6101b26101ad366004610b18565b61040d565b005b61014a6101c2366004610a87565b6001600160a01b031660009081526020819052604090205490565b6101b26104c1565b6005546040516001600160a01b03909116815260200161011a565b61010d6104f7565b610136610216366004610b18565b610506565b610136610229366004610b18565b61059f565b61014a61023c366004610aa9565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6101b2610275366004610a87565b6105ac565b60606003805461028990610bf2565b80601f01602080910402602001604051908101604052809291908181526020018280546102b590610bf2565b80156103025780601f106102d757610100808354040283529160200191610302565b820191906000526020600020905b8154815290600101906020018083116102e557829003601f168201915b5050505050905090565b6000610319338484610647565b50600192915050565b600061032f84848461076b565b6001600160a01b0384166000908152600160209081526040808320338452909152902054828110156103b95760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b6103c68533858403610647565b506001949350505050565b3360008181526001602090815260408083206001600160a01b03871684529091528120549091610319918590610408908690610bcc565b610647565b6005546001600160a01b031633146104375760405162461bcd60e51b81526004016103b090610b97565b6acecb8f27f4200f3a0000008161044d60025490565b6104579190610bcc565b11156104b35760405162461bcd60e51b815260206004820152602560248201527f42454554533a3a6d696e743a2063616e6e6f7420657863656564206d617820736044820152647570706c7960d81b60648201526084016103b0565b6104bd828261093a565b5050565b6005546001600160a01b031633146104eb5760405162461bcd60e51b81526004016103b090610b97565b6104f56000610a19565b565b60606004805461028990610bf2565b3360009081526001602090815260408083206001600160a01b0386168452909152812054828110156105885760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016103b0565b6105953385858403610647565b5060019392505050565b600061031933848461076b565b6005546001600160a01b031633146105d65760405162461bcd60e51b81526004016103b090610b97565b6001600160a01b03811661063b5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016103b0565b61064481610a19565b50565b6001600160a01b0383166106a95760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103b0565b6001600160a01b03821661070a5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103b0565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166107cf5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103b0565b6001600160a01b0382166108315760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103b0565b6001600160a01b038316600090815260208190526040902054818110156108a95760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016103b0565b6001600160a01b038085166000908152602081905260408082208585039055918516815290812080548492906108e0908490610bcc565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161092c91815260200190565b60405180910390a350505050565b6001600160a01b0382166109905760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064016103b0565b80600260008282546109a29190610bcc565b90915550506001600160a01b038216600090815260208190526040812080548392906109cf908490610bcc565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b80356001600160a01b0381168114610a8257600080fd5b919050565b600060208284031215610a9957600080fd5b610aa282610a6b565b9392505050565b60008060408385031215610abc57600080fd5b610ac583610a6b565b9150610ad360208401610a6b565b90509250929050565b600080600060608486031215610af157600080fd5b610afa84610a6b565b9250610b0860208501610a6b565b9150604084013590509250925092565b60008060408385031215610b2b57600080fd5b610b3483610a6b565b946020939093013593505050565b600060208083528351808285015260005b81811015610b6f57858101830151858201604001528201610b53565b81811115610b81576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60008219821115610bed57634e487b7160e01b600052601160045260246000fd5b500190565b600181811c90821680610c0657607f821691505b60208210811415610c2757634e487b7160e01b600052602260045260246000fd5b5091905056fea2646970667358221220830c27ded9b70dd0f2e4f35b0abf737d225a5b9b2250866103c029e2146b8b3f64736f6c63430008070033

Deployed ByteCode Sourcemap

19559:494:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6706:100;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;9014:210;;;;;;:::i;:::-;;:::i;:::-;;;1613:14:1;;1606:22;1588:41;;1576:2;1561:18;9014:210:0;1448:187:1;7826:108:0;7914:12;;7826:108;;;6762:25:1;;;6750:2;6735:18;7826:108:0;6616:177:1;9706:529:0;;;;;;:::i;:::-;;:::i;7668:93::-;;;7751:2;6940:36:1;;6928:2;6913:18;7668:93:0;6798:184:1;19637:51:0;;19674:14;19637:51;;10644:297;;;;;;:::i;:::-;;:::i;19816:234::-;;;;;;:::i;:::-;;:::i;:::-;;7997:177;;;;;;:::i;:::-;-1:-1:-1;;;;;8148:18:0;8116:7;8148:18;;;;;;;;;;;;7997:177;18778:94;;;:::i;18127:87::-;18200:6;;18127:87;;-1:-1:-1;;;;;18200:6:0;;;1386:51:1;;1374:2;1359:18;18127:87:0;1240:203:1;6925:104:0;;;:::i;11444:482::-;;;;;;:::i;:::-;;:::i;8387:216::-;;;;;;:::i;:::-;;:::i;8666:201::-;;;;;;:::i;:::-;-1:-1:-1;;;;;8832:18:0;;;8800:7;8832:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;8666:201;19027:229;;;;;;:::i;:::-;;:::i;6706:100::-;6760:13;6793:5;6786:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6706:100;:::o;9014:210::-;9133:4;9155:39;4473:10;9178:7;9187:6;9155:8;:39::i;:::-;-1:-1:-1;9212:4:0;9014:210;;;;:::o;9706:529::-;9846:4;9863:36;9873:6;9881:9;9892:6;9863:9;:36::i;:::-;-1:-1:-1;;;;;9939:19:0;;9912:24;9939:19;;;:11;:19;;;;;;;;4473:10;9939:33;;;;;;;;10005:26;;;;9983:116;;;;-1:-1:-1;;;9983:116:0;;4065:2:1;9983:116:0;;;4047:21:1;4104:2;4084:18;;;4077:30;4143:34;4123:18;;;4116:62;-1:-1:-1;;;4194:18:1;;;4187:38;4242:19;;9983:116:0;;;;;;;;;10135:57;10144:6;4473:10;10185:6;10166:16;:25;10135:8;:57::i;:::-;-1:-1:-1;10223:4:0;;9706:529;-1:-1:-1;;;;9706:529:0:o;10644:297::-;4473:10;10759:4;10853:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;10853:34:0;;;;;;;;;;10759:4;;10781:130;;10831:7;;10853:47;;10890:10;;10853:47;:::i;:::-;10781:8;:130::i;19816:234::-;18200:6;;-1:-1:-1;;;;;18200:6:0;4473:10;18347:23;18339:68;;;;-1:-1:-1;;;18339:68:0;;;;;;;:::i;:::-;19674:14:::1;19926:7;19910:13;7914:12:::0;;;7826:108;19910:13:::1;:23;;;;:::i;:::-;:37;;19888:124;;;::::0;-1:-1:-1;;;19888:124:0;;6052:2:1;19888:124:0::1;::::0;::::1;6034:21:1::0;6091:2;6071:18;;;6064:30;6130:34;6110:18;;;6103:62;-1:-1:-1;;;6181:18:1;;;6174:35;6226:19;;19888:124:0::1;5850:401:1::0;19888:124:0::1;20023:19;20029:3;20034:7;20023:5;:19::i;:::-;19816:234:::0;;:::o;18778:94::-;18200:6;;-1:-1:-1;;;;;18200:6:0;4473:10;18347:23;18339:68;;;;-1:-1:-1;;;18339:68:0;;;;;;;:::i;:::-;18843:21:::1;18861:1;18843:9;:21::i;:::-;18778:94::o:0;6925:104::-;6981:13;7014:7;7007:14;;;;;:::i;11444:482::-;4473:10;11564:4;11613:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;11613:34:0;;;;;;;;;;11680:35;;;;11658:122;;;;-1:-1:-1;;;11658:122:0;;5646:2:1;11658:122:0;;;5628:21:1;5685:2;5665:18;;;5658:30;5724:34;5704:18;;;5697:62;-1:-1:-1;;;5775:18:1;;;5768:35;5820:19;;11658:122:0;5444:401:1;11658:122:0;11816:67;4473:10;11839:7;11867:15;11848:16;:34;11816:8;:67::i;:::-;-1:-1:-1;11914:4:0;;11444:482;-1:-1:-1;;;11444:482:0:o;8387:216::-;8509:4;8531:42;4473:10;8555:9;8566:6;8531:9;:42::i;19027:229::-;18200:6;;-1:-1:-1;;;;;18200:6:0;4473:10;18347:23;18339:68;;;;-1:-1:-1;;;18339:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;19130:22:0;::::1;19108:110;;;::::0;-1:-1:-1;;;19108:110:0;;2848:2:1;19108:110:0::1;::::0;::::1;2830:21:1::0;2887:2;2867:18;;;2860:30;2926:34;2906:18;;;2899:62;-1:-1:-1;;;2977:18:1;;;2970:36;3023:19;;19108:110:0::1;2646:402:1::0;19108:110:0::1;19229:19;19239:8;19229:9;:19::i;:::-;19027:229:::0;:::o;15234:380::-;-1:-1:-1;;;;;15370:19:0;;15362:68;;;;-1:-1:-1;;;15362:68:0;;5241:2:1;15362:68:0;;;5223:21:1;5280:2;5260:18;;;5253:30;5319:34;5299:18;;;5292:62;-1:-1:-1;;;5370:18:1;;;5363:34;5414:19;;15362:68:0;5039:400:1;15362:68:0;-1:-1:-1;;;;;15449:21:0;;15441:68;;;;-1:-1:-1;;;15441:68:0;;3255:2:1;15441:68:0;;;3237:21:1;3294:2;3274:18;;;3267:30;3333:34;3313:18;;;3306:62;-1:-1:-1;;;3384:18:1;;;3377:32;3426:19;;15441:68:0;3053:398:1;15441:68:0;-1:-1:-1;;;;;15522:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15574:32;;6762:25:1;;;15574:32:0;;6735:18:1;15574:32:0;;;;;;;15234:380;;;:::o;12416:770::-;-1:-1:-1;;;;;12556:20:0;;12548:70;;;;-1:-1:-1;;;12548:70:0;;4835:2:1;12548:70:0;;;4817:21:1;4874:2;4854:18;;;4847:30;4913:34;4893:18;;;4886:62;-1:-1:-1;;;4964:18:1;;;4957:35;5009:19;;12548:70:0;4633:401:1;12548:70:0;-1:-1:-1;;;;;12637:23:0;;12629:71;;;;-1:-1:-1;;;12629:71:0;;2444:2:1;12629:71:0;;;2426:21:1;2483:2;2463:18;;;2456:30;2522:34;2502:18;;;2495:62;-1:-1:-1;;;2573:18:1;;;2566:33;2616:19;;12629:71:0;2242:399:1;12629:71:0;-1:-1:-1;;;;;12797:17:0;;12773:21;12797:17;;;;;;;;;;;12847:23;;;;12825:111;;;;-1:-1:-1;;;12825:111:0;;3658:2:1;12825:111:0;;;3640:21:1;3697:2;3677:18;;;3670:30;3736:34;3716:18;;;3709:62;-1:-1:-1;;;3787:18:1;;;3780:36;3833:19;;12825:111:0;3456:402:1;12825:111:0;-1:-1:-1;;;;;12972:17:0;;;:9;:17;;;;;;;;;;;12992:22;;;12972:42;;13036:20;;;;;;;;:30;;13008:6;;12972:9;13036:30;;13008:6;;13036:30;:::i;:::-;;;;;;;;13101:9;-1:-1:-1;;;;;13084:35:0;13093:6;-1:-1:-1;;;;;13084:35:0;;13112:6;13084:35;;;;6762:25:1;;6750:2;6735:18;;6616:177;13084:35:0;;;;;;;;12537:649;12416:770;;;:::o;13473:399::-;-1:-1:-1;;;;;13557:21:0;;13549:65;;;;-1:-1:-1;;;13549:65:0;;6458:2:1;13549:65:0;;;6440:21:1;6497:2;6477:18;;;6470:30;6536:33;6516:18;;;6509:61;6587:18;;13549:65:0;6256:355:1;13549:65:0;13705:6;13689:12;;:22;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;;;13722:18:0;;:9;:18;;;;;;;;;;:28;;13744:6;;13722:9;:28;;13744:6;;13722:28;:::i;:::-;;;;-1:-1:-1;;13766:37:0;;6762:25:1;;;-1:-1:-1;;;;;13766:37:0;;;13783:1;;13766:37;;6750:2:1;6735:18;13766:37:0;;;;;;;19816:234;;:::o;19264:173::-;19339:6;;;-1:-1:-1;;;;;19356:17:0;;;-1:-1:-1;;;;;;19356:17:0;;;;;;;19389:40;;19339:6;;;19356:17;19339:6;;19389:40;;19320:16;;19389:40;19309:128;19264:173;:::o;14::1:-;82:20;;-1:-1:-1;;;;;131:31:1;;121:42;;111:70;;177:1;174;167:12;111:70;14:173;;;:::o;192:186::-;251:6;304:2;292:9;283:7;279:23;275:32;272:52;;;320:1;317;310:12;272:52;343:29;362:9;343:29;:::i;:::-;333:39;192:186;-1:-1:-1;;;192:186:1:o;383:260::-;451:6;459;512:2;500:9;491:7;487:23;483:32;480:52;;;528:1;525;518:12;480:52;551:29;570:9;551:29;:::i;:::-;541:39;;599:38;633:2;622:9;618:18;599:38;:::i;:::-;589:48;;383:260;;;;;:::o;648:328::-;725:6;733;741;794:2;782:9;773:7;769:23;765:32;762:52;;;810:1;807;800:12;762:52;833:29;852:9;833:29;:::i;:::-;823:39;;881:38;915:2;904:9;900:18;881:38;:::i;:::-;871:48;;966:2;955:9;951:18;938:32;928:42;;648:328;;;;;:::o;981:254::-;1049:6;1057;1110:2;1098:9;1089:7;1085:23;1081:32;1078:52;;;1126:1;1123;1116:12;1078:52;1149:29;1168:9;1149:29;:::i;:::-;1139:39;1225:2;1210:18;;;;1197:32;;-1:-1:-1;;;981:254:1:o;1640:597::-;1752:4;1781:2;1810;1799:9;1792:21;1842:6;1836:13;1885:6;1880:2;1869:9;1865:18;1858:34;1910:1;1920:140;1934:6;1931:1;1928:13;1920:140;;;2029:14;;;2025:23;;2019:30;1995:17;;;2014:2;1991:26;1984:66;1949:10;;1920:140;;;2078:6;2075:1;2072:13;2069:91;;;2148:1;2143:2;2134:6;2123:9;2119:22;2115:31;2108:42;2069:91;-1:-1:-1;2221:2:1;2200:15;-1:-1:-1;;2196:29:1;2181:45;;;;2228:2;2177:54;;1640:597;-1:-1:-1;;;1640:597:1:o;4272:356::-;4474:2;4456:21;;;4493:18;;;4486:30;4552:34;4547:2;4532:18;;4525:62;4619:2;4604:18;;4272:356::o;6987:225::-;7027:3;7058:1;7054:6;7051:1;7048:13;7045:136;;;7103:10;7098:3;7094:20;7091:1;7084:31;7138:4;7135:1;7128:15;7166:4;7163:1;7156:15;7045:136;-1:-1:-1;7197:9:1;;6987:225::o;7217:380::-;7296:1;7292:12;;;;7339;;;7360:61;;7414:4;7406:6;7402:17;7392:27;;7360:61;7467:2;7459:6;7456:14;7436:18;7433:38;7430:161;;;7513:10;7508:3;7504:20;7501:1;7494:31;7548:4;7545:1;7538:15;7576:4;7573:1;7566:15;7430:161;;7217:380;;;:::o

Swarm Source

ipfs://830c27ded9b70dd0f2e4f35b0abf737d225a5b9b2250866103c029e2146b8b3f
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
Validator ID :
0 FTM

Amount Staked
0

Amount Delegated
0

Staking Total
0

Staking Start Epoch
0

Staking Start Time
0

Proof of Importance
0

Origination Score
0

Validation Score
0

Active
0

Online
0

Downtime
0 s
Address Amount claimed Rewards Created On Epoch Created On
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.