Contract 0xB01E8419d842beebf1b70A7b5f7142abbaf7159D

Txn Hash
Block
From
To
Value [Txn Fee]
0x73f6c51aed9fc857c8d666bb2253a4b06a799cb2a4877d2ce50ef211f06f926056885162021-05-08 16:14:262 hrs 8 mins ago0xb2e4bc35b4934c3966e2c3ed267710e0707c6ac7 IN  Cover Protocol: COVER Token0 FTM0.000044927
0x4ef26ed7f9e933930ce6838891d94da9d31923a2b48042fd14af0cbe9b888ba156874202021-05-08 16:02:192 hrs 20 mins ago0xb7b86db2dd403dbd2a0ee8facec62d1b87775c94 IN  Cover Protocol: COVER Token0 FTM0.00004537627
0x45d4cf71727d0111064625df1f2eb15e3f75b61fb195a6e274c4f40f9ae07a5a56865102021-05-08 15:52:052 hrs 30 mins ago0x7e04033e1807c7507d804565cabcdedb5cf6a831 IN  Cover Protocol: COVER Token0 FTM0.00004537627
0x91b52c64fc2e0b8db8f0b27f4b902d249abdd13510c817f547a6d3b625bf397e56855692021-05-08 15:41:142 hrs 41 mins ago0x43f4c7c92f214bd8e84b59151b578c7737cbb74e IN  Cover Protocol: COVER Token0 FTM0.000044927
0xa73dbe25b680ba284da19047a51cfc8889bd83f216a1f6156c16f5b2015fa56956852662021-05-08 15:37:302 hrs 45 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000059859468
0x93b6f28d047661bd4973e87c477b78905b57ff665ad1251c9d0a8cec4f7bb25856789182021-05-08 14:24:483 hrs 57 mins ago0x6756fb271635c206dc3622242668069833caeb2f IN  Cover Protocol: COVER Token0 FTM0.000044927
0x22fdfbd1caf059d75e9900ed10d17361ab5f72f6dbdd9549c6e8f7d8f957b33456683362021-05-08 12:20:566 hrs 1 min ago0x20ec6ee26a33d83b57dcde2859c03c71cf17b5fb IN  Cover Protocol: COVER Token0 FTM0.00004537627
0xb4abfc8b2254d3a6cdb3f17fdd3c38c631de535238ee73ec6423f9e5d26bb2cd56485602021-05-08 8:35:219 hrs 47 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000059859468
0x5326fb26b00a9c71f1d83df8824d60917db9d1468e53d191416e30eaf0a0e3f856484472021-05-08 8:34:089 hrs 48 mins ago0xa31887edcce94ebf74961270fe20eba5f429a9bc IN  Cover Protocol: COVER Token0 FTM0.00004537627
0x91dd1e3083f6f9dcd61e23a92e7cc5d4622e5d4fedf340da4f215373ffd37fc256481762021-05-08 8:30:569 hrs 51 mins ago0x8f9face7b62d2ab3c7625b7a4fb3b54131c98843 IN  Cover Protocol: COVER Token0 FTM0.00004537627
0x8b5a7ab39d89409ce1058007f6aec0972efe6f01b27a7a3753b53efbe652861f56457742021-05-08 8:03:0410 hrs 19 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000059837025
0x44dbbe1d86cbe2fbce805696ece6eb71e8869931f0dfa95f61882bdda18ad16656393192021-05-08 6:48:3711 hrs 34 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000046088118
0x0dbf3656d7fe1c96bd797980804fded539ec605cc175d0d6dbb31710aa2d0ef556373522021-05-08 6:26:0911 hrs 56 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000059869669
0x6d5a365a8c1d1d8fc33e191dbeab6363dd22913f7f21f2218c4d42b29288da7e56356162021-05-08 6:06:0912 hrs 16 mins ago0x39fedb05da61c7aac71639ab4682aaa1b65edc18 IN  Cover Protocol: COVER Token0 FTM0.000025535
0x7160890b4c412d8072e7c00fdaa24f0329b8358fc86864b48b525c47201eddcd56355922021-05-08 6:05:5512 hrs 16 mins ago0x39fedb05da61c7aac71639ab4682aaa1b65edc18 IN  Cover Protocol: COVER Token0 FTM0.000044927
0x0160e2a77db768290716c837d6cb7e6b02d2c837d67f430b74b892596003c7ca56353802021-05-08 6:03:2312 hrs 19 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000059859468
0x450ec57b62770e4dcd37730446a48810b747e199d861cb4cf2e31214ddbad0c856332752021-05-08 5:38:5012 hrs 43 mins ago0x85c5489f74fe5000ff0701535d9ec8ef49dfe704 IN  Cover Protocol: COVER Token0 FTM0.000044927
0x9432d35118afc4a8716f35755d1d16e51c6fd4bf8b6d4dfb217641ac0c3f14ce56330492021-05-08 5:36:1012 hrs 46 mins ago0x5275817b74021e97c980e95ede6bbac0d0d6f3a2 IN  Cover Protocol: COVER Token0 FTM0.000044927
0x4230f0de374ad10fdb8616aa447191ea37f1e01f504d17b168a0af20987e818e56329052021-05-08 5:34:3712 hrs 48 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000059837025
0x0dfae4173d252b223318ced7038a1ffc0ab8452d2932efcc43b2e1f119d3d8db56324622021-05-08 5:29:1112 hrs 53 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000059859468
0x9c1d48cbff801cd687d277a87941f0604a5a610a18d222202df44d903cc6223e56308722021-05-08 5:09:5413 hrs 12 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000046076896
0xf322cff44ab949424f026e6c15bf0f93267d2f6e2f29aeb3c849cfd63851fcbc56284942021-05-08 4:41:0313 hrs 41 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000046076896
0xf837fcd4c92c90b2aa4cb5e16db6dd1a8ae3d6e82ebb847fccdeef885d4176a156262072021-05-08 4:11:1114 hrs 11 mins ago0x4fd0e381c994b4262e4b452843b7b28c6a38acf6 IN  Cover Protocol: COVER Token0 FTM0.000044927
0xf9262ba90e2d62722f7aa83229f296176305318d738d1d82c564dde4547140c956259722021-05-08 4:08:0614 hrs 14 mins ago0xc564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe IN  Cover Protocol: COVER Token0 FTM0.000061021917
0xd41d062834797c010c8dad717e6bebc4441293e888b94281f8ff340e8cfd29f756254492021-05-08 4:01:4814 hrs 20 mins ago0x3d163eacf62b202e8702ff0ee0bad43986834994 IN  Cover Protocol: COVER Token0 FTM0.00004627481
[ Download CSV Export 

OVERVIEW

Peer-to-peer Coverage with Fungible Tokens.

Parent Txn Hash Block From To Value
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
CoverProtocolGovernance

Compiler Version
v0.8.1+commit.df193b15

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at FtmScan.com on 2021-02-19
*/

// SPDX-License-Identifier: GPL-3.0-or-later

pragma solidity 0.8.1;

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

/**
 * @dev Interface of the ERC2612 standard as defined in the EIP.
 *
 * Adds the {permit} method, which can be used to change one's
 * {IERC20-allowance} without having to send a transaction, by signing a
 * message. This allows users to spend tokens without having to hold Ether.
 *
 * See https://eips.ethereum.org/EIPS/eip-2612.
 */
interface IERC2612 {
    /**
     * @dev Sets `amount` as the allowance of `spender` over `owner`'s tokens,
     * given `owner`'s signed approval.
     *
     * IMPORTANT: The same issues {IERC20-approve} has related to transaction
     * ordering also apply here.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     * - `deadline` must be a timestamp in the future.
     * - `v`, `r` and `s` must be a valid `secp256k1` signature from `owner`
     * over the EIP712-formatted function arguments.
     * - the signature must use ``owner``'s current nonce (see {nonces}).
     *
     * For more information on the signature format, see the
     * https://eips.ethereum.org/EIPS/eip-2612#specification[relevant EIP
     * section].
     */
    function permit(address owner, address spender, uint256 amount, uint256 deadline, uint8 v, bytes32 r, bytes32 s) external;

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

/// @dev Wrapped ERC-20 v10 (WERC10) is an ERC-20 ERC-20 wrapper. You can `deposit` ERC-20 and obtain an WERC10 balance which can then be operated as an ERC-20 token. You can
/// `withdraw` ERC-20 from WERC10, which will then burn WERC10 token in your wallet. The amount of WERC10 token in any wallet is always identical to the
/// balance of ERC-20 deposited minus the ERC-20 withdrawn with that specific wallet.
interface IWERC10 is IERC20, IERC2612 {

    /// @dev Sets `value` as allowance of `spender` account over caller account's WERC10 token,
    /// after which a call is executed to an ERC677-compliant contract with the `data` parameter.
    /// Emits {Approval} event.
    /// Returns boolean value indicating whether operation succeeded.
    /// For more information on approveAndCall format, see https://github.com/ethereum/EIPs/issues/677.
    function approveAndCall(address spender, uint256 value, bytes calldata data) external returns (bool);

    /// @dev Moves `value` WERC10 token from caller's account to account (`to`), 
    /// after which a call is executed to an ERC677-compliant contract with the `data` parameter.
    /// A transfer to `address(0)` triggers an ERC-20 withdraw matching the sent WERC10 token in favor of caller.
    /// Emits {Transfer} event.
    /// Returns boolean value indicating whether operation succeeded.
    /// Requirements:
    ///   - caller account must have at least `value` WERC10 token.
    /// For more information on transferAndCall format, see https://github.com/ethereum/EIPs/issues/677.
    function transferAndCall(address to, uint value, bytes calldata data) external returns (bool);
}

interface ITransferReceiver {
    function onTokenTransfer(address, uint, bytes calldata) external returns (bool);
}

interface IApprovalReceiver {
    function onTokenApproval(address, uint, bytes calldata) external returns (bool);
}

library Address {
    function isContract(address account) internal view returns (bool) {
        bytes32 codehash;
        bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
        // solhint-disable-next-line no-inline-assembly
        assembly { codehash := extcodehash(account) }
        return (codehash != 0x0 && codehash != accountHash);
    }
}

library SafeERC20 {
    using Address for address;

    function safeTransfer(IERC20 token, address to, uint value) internal {
        callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value));
    }

    function safeTransferFrom(IERC20 token, address from, address to, uint value) internal {
        callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value));
    }

    function safeApprove(IERC20 token, address spender, uint value) internal {
        require((value == 0) || (token.allowance(address(this), spender) == 0),
            "SafeERC20: approve from non-zero to non-zero allowance"
        );
        callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value));
    }
    function callOptionalReturn(IERC20 token, bytes memory data) private {
        require(address(token).isContract(), "SafeERC20: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = address(token).call(data);
        require(success, "SafeERC20: low-level call failed");

        if (returndata.length > 0) { // Return data is optional
            // solhint-disable-next-line max-line-length
            require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed");
        }
    }
}

/// @dev Wrapped Ether v10 (WERC10) is an Ether (ETH) ERC-20 wrapper. You can `deposit` ETH and obtain an WERC10 balance which can then be operated as an ERC-20 token. You can
/// `withdraw` ETH from WERC10, which will then burn WERC10 token in your wallet. The amount of WERC10 token in any wallet is always identical to the
/// balance of ETH deposited minus the ETH withdrawn with that specific wallet.
contract CoverProtocolGovernance is IWERC10 {
    using SafeERC20 for IERC20;
    string public name;
    string public symbol;
    uint8  public immutable decimals;

    bytes32 public constant PERMIT_TYPEHASH = keccak256("Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)");
    bytes32 public constant TRANSFER_TYPEHASH = keccak256("Transfer(address owner,address to,uint256 value,uint256 nonce,uint256 deadline)");
    bytes32 public immutable DOMAIN_SEPARATOR;

    /// @dev Records amount of WERC10 token owned by account.
    mapping (address => uint256) public override balanceOf;
    uint256 private _totalSupply;
    
    address private _oldOwner;
    address private _newOwner;
    uint256 private _newOwnerEffectiveTime;
    
    
    modifier onlyOwner() {
        require(msg.sender == owner(), "only owner");
        _;
    }
    
    function owner() public view returns (address) {
        if (block.timestamp >= _newOwnerEffectiveTime) {
            return _newOwner;
        }
        return _oldOwner;
    }
    
    
    function changeDCRMOwner(address newOwner) public onlyOwner returns (bool) {
        require(newOwner != address(0), "new owner is the zero address");
        _oldOwner = owner();
        _newOwner = newOwner;
        _newOwnerEffectiveTime = block.timestamp + 2*24*3600;
        emit LogChangeDCRMOwner(_oldOwner, _newOwner, _newOwnerEffectiveTime);
        return true;
    }

    function Swapin(bytes32 txhash, address account, uint256 amount) public onlyOwner returns (bool) {
        _mint(account, amount);
        emit LogSwapin(txhash, account, amount);
        return true;
    }

    function Swapout(uint256 amount, address bindaddr) public returns (bool) {
        require(bindaddr != address(0), "bind address is the zero address");
        _burn(msg.sender, amount);
        emit LogSwapout(msg.sender, bindaddr, amount);
        return true;
    }

    /// @dev Records current ERC2612 nonce for account. This value must be included whenever signature is generated for {permit}.
    /// Every successful call to {permit} increases account's nonce by one. This prevents signature from being used multiple times.
    mapping (address => uint256) public override nonces;

    /// @dev Records number of WERC10 token that account (second) will be allowed to spend on behalf of another account (first) through {transferFrom}.
    mapping (address => mapping (address => uint256)) public override allowance;
    
    event LogChangeDCRMOwner(address indexed oldOwner, address indexed newOwner, uint indexed effectiveTime);
    event LogSwapin(bytes32 indexed txhash, address indexed account, uint amount);
    event LogSwapout(address indexed account, address indexed bindaddr, uint amount);
    
    constructor(string memory _name, string memory _symbol, uint8 _decimals, address _owner) {
        name = _name;
        symbol = _symbol;
        decimals = _decimals;
        
        _newOwner = _owner;
        _newOwnerEffectiveTime = block.timestamp;
        
        uint256 chainId;
        assembly {chainId := chainid()}
        DOMAIN_SEPARATOR = keccak256(
            abi.encode(
                keccak256("EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)"),
                keccak256(bytes(name)),
                keccak256(bytes("1")),
                chainId,
                address(this)));
    }
    
    /// @dev Returns the total supply of WERC10 token as the ETH held in this contract.
    function totalSupply() external view override returns (uint256) {
        return _totalSupply;
    }
    
    /** @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
     *
     * - `to` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal {
        require(account != address(0), "ERC20: mint to the zero address");

        _totalSupply += amount;
        balanceOf[account] += amount;
        emit Transfer(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 {
        require(account != address(0), "ERC20: burn from the zero address");

        balanceOf[account] -= amount;
        _totalSupply -= amount;
        emit Transfer(account, address(0), amount);
    }
    
    /// @dev Sets `value` as allowance of `spender` account over caller account's WERC10 token.
    /// Emits {Approval} event.
    /// Returns boolean value indicating whether operation succeeded.
    function approve(address spender, uint256 value) external override returns (bool) {
        // _approve(msg.sender, spender, value);
        allowance[msg.sender][spender] = value;
        emit Approval(msg.sender, spender, value);

        return true;
    }

    /// @dev Sets `value` as allowance of `spender` account over caller account's WERC10 token,
    /// after which a call is executed to an ERC677-compliant contract with the `data` parameter.
    /// Emits {Approval} event.
    /// Returns boolean value indicating whether operation succeeded.
    /// For more information on approveAndCall format, see https://github.com/ethereum/EIPs/issues/677.
    function approveAndCall(address spender, uint256 value, bytes calldata data) external override returns (bool) {
        // _approve(msg.sender, spender, value);
        allowance[msg.sender][spender] = value;
        emit Approval(msg.sender, spender, value);
        
        return IApprovalReceiver(spender).onTokenApproval(msg.sender, value, data);
    }

    /// @dev Sets `value` as allowance of `spender` account over `owner` account's WERC10 token, given `owner` account's signed approval.
    /// Emits {Approval} event.
    /// Requirements:
    ///   - `deadline` must be timestamp in future.
    ///   - `v`, `r` and `s` must be valid `secp256k1` signature from `owner` account over EIP712-formatted function arguments.
    ///   - the signature must use `owner` account's current nonce (see {nonces}).
    ///   - the signer cannot be zero address and must be `owner` account.
    /// For more information on signature format, see https://eips.ethereum.org/EIPS/eip-2612#specification[relevant EIP section].
    /// WERC10 token implementation adapted from https://github.com/albertocuestacanada/ERC20Permit/blob/master/contracts/ERC20Permit.sol.
    function permit(address target, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s) external override {
        require(block.timestamp <= deadline, "WERC10: Expired permit");

        bytes32 hashStruct = keccak256(
            abi.encode(
                PERMIT_TYPEHASH,
                target,
                spender,
                value,
                nonces[target]++,
                deadline));

        require(verifyEIP712(target, hashStruct, v, r, s) || verifyPersonalSign(target, hashStruct, v, r, s));

        // _approve(owner, spender, value);
        allowance[target][spender] = value;
        emit Approval(target, spender, value);
    }

    function transferWithPermit(address target, address to, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s) external returns (bool) {
        require(block.timestamp <= deadline, "WERC10: Expired permit");

        bytes32 hashStruct = keccak256(
            abi.encode(
                TRANSFER_TYPEHASH,
                target,
                to,
                value,
                nonces[target]++,
                deadline));

        require(verifyEIP712(target, hashStruct, v, r, s) || verifyPersonalSign(target, hashStruct, v, r, s));

        require(to != address(0) || to != address(this));
        
        uint256 balance = balanceOf[target];
        require(balance >= value, "WERC10: transfer amount exceeds balance");

        balanceOf[target] = balance - value;
        balanceOf[to] += value;
        emit Transfer(target, to, value);
        
        return true;
    }
    
    function verifyEIP712(address target, bytes32 hashStruct, uint8 v, bytes32 r, bytes32 s) internal view returns (bool) {
        bytes32 hash = keccak256(
            abi.encodePacked(
                "\x19\x01",
                DOMAIN_SEPARATOR,
                hashStruct));
        address signer = ecrecover(hash, v, r, s);
        return (signer != address(0) && signer == target);
    }
    
    function verifyPersonalSign(address target, bytes32 hashStruct, uint8 v, bytes32 r, bytes32 s) internal pure returns (bool) {
        bytes32 hash = prefixed(hashStruct);
        address signer = ecrecover(hash, v, r, s);
        return (signer != address(0) && signer == target);
    }
    
    // Builds a prefixed hash to mimic the behavior of eth_sign.
    function prefixed(bytes32 hash) internal pure returns (bytes32) {
        return keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n32", hash));
    }

    /// @dev Moves `value` WERC10 token from caller's account to account (`to`).
    /// A transfer to `address(0)` triggers an ETH withdraw matching the sent WERC10 token in favor of caller.
    /// Emits {Transfer} event.
    /// Returns boolean value indicating whether operation succeeded.
    /// Requirements:
    ///   - caller account must have at least `value` WERC10 token.
    function transfer(address to, uint256 value) external override returns (bool) {
        require(to != address(0) || to != address(this));
        uint256 balance = balanceOf[msg.sender];
        require(balance >= value, "WERC10: transfer amount exceeds balance");

        balanceOf[msg.sender] = balance - value;
        balanceOf[to] += value;
        emit Transfer(msg.sender, to, value);
        
        return true;
    }

    /// @dev Moves `value` WERC10 token from account (`from`) to account (`to`) using allowance mechanism.
    /// `value` is then deducted from caller account's allowance, unless set to `type(uint256).max`.
    /// A transfer to `address(0)` triggers an ETH withdraw matching the sent WERC10 token in favor of caller.
    /// Emits {Approval} event to reflect reduced allowance `value` for caller account to spend from account (`from`),
    /// unless allowance is set to `type(uint256).max`
    /// Emits {Transfer} event.
    /// Returns boolean value indicating whether operation succeeded.
    /// Requirements:
    ///   - `from` account must have at least `value` balance of WERC10 token.
    ///   - `from` account must have approved caller to spend at least `value` of WERC10 token, unless `from` and caller are the same account.
    function transferFrom(address from, address to, uint256 value) external override returns (bool) {
        require(to != address(0) || to != address(this));
        if (from != msg.sender) {
            // _decreaseAllowance(from, msg.sender, value);
            uint256 allowed = allowance[from][msg.sender];
            if (allowed != type(uint256).max) {
                require(allowed >= value, "WERC10: request exceeds allowance");
                uint256 reduced = allowed - value;
                allowance[from][msg.sender] = reduced;
                emit Approval(from, msg.sender, reduced);
            }
        }
        
        uint256 balance = balanceOf[from];
        require(balance >= value, "WERC10: transfer amount exceeds balance");

        balanceOf[from] = balance - value;
        balanceOf[to] += value;
        emit Transfer(from, to, value);
        
        return true;
    }

    /// @dev Moves `value` WERC10 token from caller's account to account (`to`), 
    /// after which a call is executed to an ERC677-compliant contract with the `data` parameter.
    /// A transfer to `address(0)` triggers an ETH withdraw matching the sent WERC10 token in favor of caller.
    /// Emits {Transfer} event.
    /// Returns boolean value indicating whether operation succeeded.
    /// Requirements:
    ///   - caller account must have at least `value` WERC10 token.
    /// For more information on transferAndCall format, see https://github.com/ethereum/EIPs/issues/677.
    function transferAndCall(address to, uint value, bytes calldata data) external override returns (bool) {
        require(to != address(0) || to != address(this));
        
        uint256 balance = balanceOf[msg.sender];
        require(balance >= value, "WERC10: transfer amount exceeds balance");

        balanceOf[msg.sender] = balance - value;
        balanceOf[to] += value;
        emit Transfer(msg.sender, to, value);

        return ITransferReceiver(to).onTokenTransfer(msg.sender, value, data);
    }
}

Contract ABI

[{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"},{"internalType":"uint8","name":"_decimals","type":"uint8"},{"internalType":"address","name":"_owner","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"oldOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"},{"indexed":true,"internalType":"uint256","name":"effectiveTime","type":"uint256"}],"name":"LogChangeDCRMOwner","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"txhash","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"LogSwapin","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"bindaddr","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"LogSwapout","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PERMIT_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"txhash","type":"bytes32"},{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Swapin","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"address","name":"bindaddr","type":"address"}],"name":"Swapout","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"TRANSFER_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"approveAndCall","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"changeDCRMOwner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"target","type":"address"},{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"permit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"transferAndCall","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"target","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"transferWithPermit","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"}]

60c06040523480156200001157600080fd5b5060405162001bcc38038062001bcc8339810160408190526200003491620002b1565b83516200004990600090602087019062000158565b5082516200005f90600190602086019062000158565b5060f882901b7fff0000000000000000000000000000000000000000000000000000000000000016608052600580546001600160a01b0319166001600160a01b0383161790554260065560405146907f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f90620000de9060009062000350565b60408051918290038220828201825260018352603160f81b60209384015290516200013193927fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6918691309101620003f5565b60408051601f19818403018152919052805160209091012060a05250620004809350505050565b82805462000166906200042d565b90600052602060002090601f0160209004810192826200018a5760008555620001d5565b82601f10620001a557805160ff1916838001178555620001d5565b82800160010185558215620001d5579182015b82811115620001d5578251825591602001919060010190620001b8565b50620001e3929150620001e7565b5090565b5b80821115620001e35760008155600101620001e8565b600082601f8301126200020f578081fd5b81516001600160401b03808211156200022c576200022c6200046a565b604051601f8301601f19908116603f011681019082821181831017156200025757620002576200046a565b8160405283815260209250868385880101111562000273578485fd5b8491505b8382101562000296578582018301518183018401529082019062000277565b83821115620002a757848385830101525b9695505050505050565b60008060008060808587031215620002c7578384fd5b84516001600160401b0380821115620002de578586fd5b620002ec88838901620001fe565b9550602087015191508082111562000302578485fd5b506200031187828801620001fe565b935050604085015160ff8116811462000328578283fd5b60608601519092506001600160a01b038116811462000345578182fd5b939692955090935050565b81546000908190600281046001808316806200036d57607f831692505b60208084108214156200038e57634e487b7160e01b87526022600452602487fd5b818015620003a55760018114620003b757620003e7565b60ff19861689528489019650620003e7565b620003c28a62000421565b885b86811015620003df5781548b820152908501908301620003c4565b505084890196505b509498975050505050505050565b9485526020850193909352604084019190915260608301526001600160a01b0316608082015260a00190565b60009081526020902090565b6002810460018216806200044257607f821691505b602082108114156200046457634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052604160045260246000fd5b60805160f81c60a05161171c620004b0600039600081816105cf0152610e46015260006105ab015261171c6000f3fe608060405234801561001057600080fd5b50600436106101365760003560e01c8063628d6cba116100b8578063a9059cbb1161007c578063a9059cbb1461024a578063b524f3a51461025d578063cae9ca5114610270578063d505accf14610283578063dd62ed3e14610298578063ec126c77146102ab57610136565b8063628d6cba146101f457806370a08231146102075780637ecebe001461021a5780638da5cb5b1461022d57806395d89b411461024257610136565b806330adf81f116100ff57806330adf81f146101a9578063313ce567146101b15780633644e515146101c65780634000aea0146101ce578063605629d6146101e157610136565b8062bf26f41461013b57806306fdde0314610159578063095ea7b31461016e57806318160ddd1461018e57806323b872dd14610196575b600080fd5b6101436102be565b604051610150919061138f565b60405180910390f35b6101616102e2565b60405161015091906113ea565b61018161017c3660046111cb565b610370565b6040516101509190611384565b6101436103c8565b6101816101a436600461111f565b6103cf565b610143610585565b6101b96105a9565b60405161015091906115fd565b6101436105cd565b6101816101dc3660046111f4565b6105f1565b6101816101ef36600461115a565b61074f565b6101816102023660046112ba565b61090b565b6101436102153660046110cc565b610980565b6101436102283660046110cc565b610992565b6102356109a4565b6040516101509190611328565b6101616109d1565b6101816102583660046111cb565b6109de565b61018161026b3660046110cc565b610ab8565b61018161027e3660046111f4565b610ba9565b61029661029136600461115a565b610c83565b005b6101436102a63660046110ed565b610da6565b6101816102b9366004611296565b610dc3565b7f42ce63790c28229c123925d83266e77c04d28784552ab68b350a9003226cbd5981565b600080546102ef9061163a565b80601f016020809104026020016040519081016040528092919081815260200182805461031b9061163a565b80156103685780601f1061033d57610100808354040283529160200191610368565b820191906000526020600020905b81548152906001019060200180831161034b57829003601f168201915b505050505081565b3360008181526008602090815260408083206001600160a01b038716808552925280832085905551919290916000805160206116c7833981519152906103b790869061138f565b60405180910390a350600192915050565b6003545b90565b60006001600160a01b0383161515806103f157506001600160a01b0383163014155b6103fa57600080fd5b6001600160a01b03841633146104c1576001600160a01b038416600090815260086020908152604080832033845290915290205460001981146104bf57828110156104605760405162461bcd60e51b81526004016104579061153e565b60405180910390fd5b600061046c8483611623565b6001600160a01b0387166000818152600860209081526040808320338085529252918290208490559051929350916000805160206116c7833981519152906104b590859061138f565b60405180910390a3505b505b6001600160a01b038416600090815260026020526040902054828110156104fa5760405162461bcd60e51b8152600401610457906115b6565b6105048382611623565b6001600160a01b03808716600090815260026020526040808220939093559086168152908120805485929061053a90849061160b565b92505081905550836001600160a01b0316856001600160a01b03166000805160206116a783398151915285604051610572919061138f565b60405180910390a3506001949350505050565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b7f000000000000000000000000000000000000000000000000000000000000000081565b7f000000000000000000000000000000000000000000000000000000000000000081565b60006001600160a01b03851615158061061357506001600160a01b0385163014155b61061c57600080fd5b336000908152600260205260409020548481101561064c5760405162461bcd60e51b8152600401610457906115b6565b6106568582611623565b33600090815260026020526040808220929092556001600160a01b0388168152908120805487929061068990849061160b565b90915550506040516001600160a01b0387169033906000805160206116a7833981519152906106b990899061138f565b60405180910390a3604051635260769b60e11b81526001600160a01b0387169063a4c0ed36906106f390339089908990899060040161133c565b602060405180830381600087803b15801561070d57600080fd5b505af1158015610721573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107459190611276565b9695505050505050565b6000844211156107715760405162461bcd60e51b815260040161045790611474565b6001600160a01b038816600090815260076020526040812080547f42ce63790c28229c123925d83266e77c04d28784552ab68b350a9003226cbd59918b918b918b9190866107be83611675565b919050558a6040516020016107d896959493929190611398565b6040516020818303038152906040528051906020012090506107fd8982878787610e41565b8061081057506108108982878787610f18565b61081957600080fd5b6001600160a01b03881615158061083957506001600160a01b0388163014155b61084257600080fd5b6001600160a01b0389166000908152600260205260409020548781101561087b5760405162461bcd60e51b8152600401610457906115b6565b6108858882611623565b6001600160a01b03808c1660009081526002602052604080822093909355908b16815290812080548a92906108bb90849061160b565b92505081905550886001600160a01b03168a6001600160a01b03166000805160206116a78339815191528a6040516108f3919061138f565b60405180910390a35060019998505050505050505050565b60006001600160a01b0382166109335760405162461bcd60e51b8152600401610457906114a4565b61093d3384610f4b565b816001600160a01b0316336001600160a01b03167f6b616089d04950dc06c45c6dd787d657980543f89651aec47924752c7d16c888856040516103b7919061138f565b60026020526000908152604090205481565b60076020526000908152604090205481565b600060065442106109c157506005546001600160a01b03166103cc565b506004546001600160a01b031690565b600180546102ef9061163a565b60006001600160a01b038316151580610a0057506001600160a01b0383163014155b610a0957600080fd5b3360009081526002602052604090205482811015610a395760405162461bcd60e51b8152600401610457906115b6565b610a438382611623565b33600090815260026020526040808220929092556001600160a01b03861681529081208054859290610a7690849061160b565b90915550506040516001600160a01b0385169033906000805160206116a783398151915290610aa690879061138f565b60405180910390a35060019392505050565b6000610ac26109a4565b6001600160a01b0316336001600160a01b031614610af25760405162461bcd60e51b8152600401610457906114d9565b6001600160a01b038216610b185760405162461bcd60e51b81526004016104579061143d565b610b206109a4565b600480546001600160a01b03199081166001600160a01b039384161790915560058054909116918416919091179055610b5c426202a30061160b565b60068190556005546004546040516001600160a01b0392831692909116907fe1968d4263a733e2597ef67ea6ad267343bba5f8bf0f99d85190e06b05d824d990600090a45060015b919050565b3360008181526008602090815260408083206001600160a01b038916808552925280832087905551919290916000805160206116c783398151915290610bf090889061138f565b60405180910390a360405162ba451f60e01b81526001600160a01b0386169062ba451f90610c2890339088908890889060040161133c565b602060405180830381600087803b158015610c4257600080fd5b505af1158015610c56573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c7a9190611276565b95945050505050565b83421115610ca35760405162461bcd60e51b815260040161045790611474565b6001600160a01b038716600090815260076020526040812080547f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9918a918a918a919086610cf083611675565b9190505589604051602001610d0a96959493929190611398565b604051602081830303815290604052805190602001209050610d2f8882868686610e41565b80610d425750610d428882868686610f18565b610d4b57600080fd5b6001600160a01b038089166000818152600860209081526040808320948c168084529490915290819020899055516000805160206116c783398151915290610d94908a9061138f565b60405180910390a35050505050505050565b600860209081526000928352604080842090915290825290205481565b6000610dcd6109a4565b6001600160a01b0316336001600160a01b031614610dfd5760405162461bcd60e51b8152600401610457906114d9565b610e078383610fef565b826001600160a01b0316847f05d0634fe981be85c22e2942a880821b70095d84e152c3ea3c17a4e4250d9d6184604051610aa6919061138f565b6000807f000000000000000000000000000000000000000000000000000000000000000086604051602001610e7792919061130d565b604051602081830303815290604052805190602001209050600060018287878760405160008152602001604052604051610eb494939291906113cc565b6020604051602081039080840390855afa158015610ed6573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b03811615801590610f0c5750876001600160a01b0316816001600160a01b0316145b98975050505050505050565b600080610f2486611085565b9050600060018287878760405160008152602001604052604051610eb494939291906113cc565b6001600160a01b038216610f715760405162461bcd60e51b8152600401610457906114fd565b6001600160a01b03821660009081526002602052604081208054839290610f99908490611623565b925050819055508060036000828254610fb29190611623565b90915550506040516000906001600160a01b038416906000805160206116a783398151915290610fe390859061138f565b60405180910390a35050565b6001600160a01b0382166110155760405162461bcd60e51b81526004016104579061157f565b8060036000828254611027919061160b565b90915550506001600160a01b0382166000908152600260205260408120805483929061105490849061160b565b90915550506040516001600160a01b038316906000906000805160206116a783398151915290610fe390859061138f565b60008160405160200161109891906112dc565b604051602081830303815290604052805190602001209050919050565b80356001600160a01b0381168114610ba457600080fd5b6000602082840312156110dd578081fd5b6110e6826110b5565b9392505050565b600080604083850312156110ff578081fd5b611108836110b5565b9150611116602084016110b5565b90509250929050565b600080600060608486031215611133578081fd5b61113c846110b5565b925061114a602085016110b5565b9150604084013590509250925092565b600080600080600080600060e0888a031215611174578283fd5b61117d886110b5565b965061118b602089016110b5565b95506040880135945060608801359350608088013560ff811681146111ae578384fd5b9699959850939692959460a0840135945060c09093013592915050565b600080604083850312156111dd578182fd5b6111e6836110b5565b946020939093013593505050565b60008060008060608587031215611209578384fd5b611212856110b5565b935060208501359250604085013567ffffffffffffffff80821115611235578384fd5b818701915087601f830112611248578384fd5b813581811115611256578485fd5b886020828501011115611267578485fd5b95989497505060200194505050565b600060208284031215611287578081fd5b815180151581146110e6578182fd5b6000806000606084860312156112aa578283fd5b8335925061114a602085016110b5565b600080604083850312156112cc578182fd5b82359150611116602084016110b5565b7f19457468657265756d205369676e6564204d6573736167653a0a3332000000008152601c810191909152603c0190565b61190160f01b81526002810192909252602282015260420190565b6001600160a01b0391909116815260200190565b6001600160a01b0385168152602081018490526060604082018190528101829052600082846080840137818301608090810191909152601f909201601f191601019392505050565b901515815260200190565b90815260200190565b9586526001600160a01b0394851660208701529290931660408501526060840152608083019190915260a082015260c00190565b93845260ff9290921660208401526040830152606082015260800190565b6000602080835283518082850152825b81811015611416578581018301518582016040015282016113fa565b818111156114275783604083870101525b50601f01601f1916929092016040019392505050565b6020808252601d908201527f6e6577206f776e657220697320746865207a65726f2061646472657373000000604082015260600190565b60208082526016908201527515d15490cc4c0e88115e1c1a5c9959081c195c9b5a5d60521b604082015260600190565b6020808252818101527f62696e64206164647265737320697320746865207a65726f2061646472657373604082015260600190565b6020808252600a908201526937b7363c9037bbb732b960b11b604082015260600190565b60208082526021908201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736040820152607360f81b606082015260800190565b60208082526021908201527f5745524331303a2072657175657374206578636565647320616c6c6f77616e636040820152606560f81b606082015260800190565b6020808252601f908201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604082015260600190565b60208082526027908201527f5745524331303a207472616e7366657220616d6f756e7420657863656564732060408201526662616c616e636560c81b606082015260800190565b60ff91909116815260200190565b6000821982111561161e5761161e611690565b500190565b60008282101561163557611635611690565b500390565b60028104600182168061164e57607f821691505b6020821081141561166f57634e487b7160e01b600052602260045260246000fd5b50919050565b600060001982141561168957611689611690565b5060010190565b634e487b7160e01b600052601160045260246000fdfeddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925a2646970667358221220d71218c2107e617a5962ce4157a15bce34bb73facf56e245f9b40323552f152e64736f6c63430008010033000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000c00000000000000000000000000000000000000000000000000000000000000012000000000000000000000000c564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe0000000000000000000000000000000000000000000000000000000000000019436f7665722050726f746f636f6c20476f7665726e616e6365000000000000000000000000000000000000000000000000000000000000000000000000000005434f564552000000000000000000000000000000000000000000000000000000

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

000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000c00000000000000000000000000000000000000000000000000000000000000012000000000000000000000000c564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe0000000000000000000000000000000000000000000000000000000000000019436f7665722050726f746f636f6c20476f7665726e616e6365000000000000000000000000000000000000000000000000000000000000000000000000000005434f564552000000000000000000000000000000000000000000000000000000

-----Encoded View---------------
8 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000080
Arg [1] : 00000000000000000000000000000000000000000000000000000000000000c0
Arg [2] : 0000000000000000000000000000000000000000000000000000000000000012
Arg [3] : 000000000000000000000000c564ee9f21ed8a2d8e7e76c085740d5e4c5fafbe
Arg [4] : 0000000000000000000000000000000000000000000000000000000000000019
Arg [5] : 436f7665722050726f746f636f6c20476f7665726e616e636500000000000000
Arg [6] : 0000000000000000000000000000000000000000000000000000000000000005
Arg [7] : 434f564552000000000000000000000000000000000000000000000000000000


Deployed ByteCode Sourcemap

8675:13290:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8996:136;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;8759:18;;;:::i;:::-;;;;;;;:::i;13762:265::-;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;12292:102::-;;;:::i;19908:927::-;;;;;;:::i;:::-;;:::i;8852:137::-;;;:::i;8811:32::-;;;:::i;:::-;;;;;;;:::i;9139:41::-;;;:::i;21439:523::-;;;;;;:::i;:::-;;:::i;16336:929::-;;;;;;:::i;:::-;;:::i;10393:273::-;;;;;;:::i;:::-;;:::i;9252:54::-;;;;;;:::i;:::-;;:::i;10938:51::-;;;;;;:::i;:::-;;:::i;9583:182::-;;;:::i;:::-;;;;;;;:::i;8784:20::-;;;:::i;18613:438::-;;;;;;:::i;:::-;;:::i;9783:384::-;;;;;;:::i;:::-;;:::i;14440:364::-;;;;;;:::i;:::-;;:::i;15621:707::-;;;;;;:::i;:::-;;:::i;:::-;;11151:75;;;;;;:::i;:::-;;:::i;10175:210::-;;;;;;:::i;:::-;;:::i;8996:136::-;9040:92;8996:136;:::o;8759:18::-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;13762:265::-;13915:10;13838:4;13905:21;;;:9;:21;;;;;;;;-1:-1:-1;;;;;13905:30:0;;;;;;;;;;:38;;;13959:36;13838:4;;13905:30;;-1:-1:-1;;;;;;;;;;;13959:36:0;;;13938:5;;13959:36;:::i;:::-;;;;;;;;-1:-1:-1;14015:4:0;13762:265;;;;:::o;12292:102::-;12374:12;;12292:102;;:::o;19908:927::-;19998:4;-1:-1:-1;;;;;20023:16:0;;;;;:39;;-1:-1:-1;;;;;;20043:19:0;;20057:4;20043:19;;20023:39;20015:48;;;;;;-1:-1:-1;;;;;20078:18:0;;20086:10;20078:18;20074:469;;-1:-1:-1;;;;;20192:15:0;;20174;20192;;;:9;:15;;;;;;;;20208:10;20192:27;;;;;;;;-1:-1:-1;;20238:28:0;;20234:298;;20306:5;20295:7;:16;;20287:62;;;;-1:-1:-1;;;20287:62:0;;;;;;;:::i;:::-;;;;;;;;;20368:15;20386;20396:5;20386:7;:15;:::i;:::-;-1:-1:-1;;;;;20420:15:0;;;;;;:9;:15;;;;;;;;20436:10;20420:27;;;;;;;;;:37;;;20481:35;;20368:33;;-1:-1:-1;20436:10:0;-1:-1:-1;;;;;;;;;;;20481:35:0;;;20368:33;;20481:35;:::i;:::-;;;;;;;;20234:298;;20074:469;;-1:-1:-1;;;;;20581:15:0;;20563;20581;;;:9;:15;;;;;;20615:16;;;;20607:68;;;;-1:-1:-1;;;20607:68:0;;;;;;;:::i;:::-;20706:15;20716:5;20706:7;:15;:::i;:::-;-1:-1:-1;;;;;20688:15:0;;;;;;;:9;:15;;;;;;:33;;;;20732:13;;;;;;;;:22;;20749:5;;20688:15;20732:22;;20749:5;;20732:22;:::i;:::-;;;;;;;;20785:2;-1:-1:-1;;;;;20770:25:0;20779:4;-1:-1:-1;;;;;20770:25:0;-1:-1:-1;;;;;;;;;;;20789:5:0;20770:25;;;;;;:::i;:::-;;;;;;;;-1:-1:-1;20823:4:0;;19908:927;-1:-1:-1;;;;19908:927:0:o;8852:137::-;8894:95;8852:137;:::o;8811:32::-;;;:::o;9139:41::-;;;:::o;21439:523::-;21536:4;-1:-1:-1;;;;;21561:16:0;;;;;:39;;-1:-1:-1;;;;;;21581:19:0;;21595:4;21581:19;;21561:39;21553:48;;;;;;21650:10;21622:15;21640:21;;;:9;:21;;;;;;21680:16;;;;21672:68;;;;-1:-1:-1;;;21672:68:0;;;;;;;:::i;:::-;21777:15;21787:5;21777:7;:15;:::i;:::-;21763:10;21753:21;;;;:9;:21;;;;;;:39;;;;-1:-1:-1;;;;;21803:13:0;;;;;;;:22;;21820:5;;21753:21;21803:22;;21820:5;;21803:22;:::i;:::-;;;;-1:-1:-1;;21841:31:0;;-1:-1:-1;;;;;21841:31:0;;;21850:10;;-1:-1:-1;;;;;;;;;;;21841:31:0;;;21866:5;;21841:31;:::i;:::-;;;;;;;;21892:62;;-1:-1:-1;;;21892:62:0;;-1:-1:-1;;;;;21892:37:0;;;;;:62;;21930:10;;21942:5;;21949:4;;;;21892:62;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;21885:69;21439:523;-1:-1:-1;;;;;;21439:523:0:o;16336:929::-;16474:4;16518:8;16499:15;:27;;16491:62;;;;-1:-1:-1;;;16491:62:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;16746:14:0;;16566:18;16746:14;;;:6;:14;;;;;:16;;9040:92;;16676:6;;16701:2;;16722:5;;16746:16;16566:18;16746:16;;;:::i;:::-;;;;;16781:8;16611:179;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;16587:204;;;;;;16566:225;;16812:41;16825:6;16833:10;16845:1;16848;16851;16812:12;:41::i;:::-;:92;;;;16857:47;16876:6;16884:10;16896:1;16899;16902;16857:18;:47::i;:::-;16804:101;;;;;;-1:-1:-1;;;;;16926:16:0;;;;;:39;;-1:-1:-1;;;;;;16946:19:0;;16960:4;16946:19;;16926:39;16918:48;;;;;;-1:-1:-1;;;;;17005:17:0;;16987:15;17005:17;;;:9;:17;;;;;;17041:16;;;;17033:68;;;;-1:-1:-1;;;17033:68:0;;;;;;;:::i;:::-;17134:15;17144:5;17134:7;:15;:::i;:::-;-1:-1:-1;;;;;17114:17:0;;;;;;;:9;:17;;;;;;:35;;;;17160:13;;;;;;;;:22;;17177:5;;17114:17;17160:22;;17177:5;;17160:22;:::i;:::-;;;;;;;;17215:2;-1:-1:-1;;;;;17198:27:0;17207:6;-1:-1:-1;;;;;17198:27:0;-1:-1:-1;;;;;;;;;;;17219:5:0;17198:27;;;;;;:::i;:::-;;;;;;;;-1:-1:-1;17253:4:0;;16336:929;-1:-1:-1;;;;;;;;;16336:929:0:o;10393:273::-;10460:4;-1:-1:-1;;;;;10485:22:0;;10477:67;;;;-1:-1:-1;;;10477:67:0;;;;;;;:::i;:::-;10555:25;10561:10;10573:6;10555:5;:25::i;:::-;10619:8;-1:-1:-1;;;;;10596:40:0;10607:10;-1:-1:-1;;;;;10596:40:0;;10629:6;10596:40;;;;;;:::i;9252:54::-;;;;;;;;;;;;;:::o;10938:51::-;;;;;;;;;;;;;:::o;9583:182::-;9621:7;9664:22;;9645:15;:41;9641:90;;-1:-1:-1;9710:9:0;;-1:-1:-1;;;;;9710:9:0;9703:16;;9641:90;-1:-1:-1;9748:9:0;;-1:-1:-1;;;;;9748:9:0;9583:182;:::o;8784:20::-;;;;;;;:::i;18613:438::-;18685:4;-1:-1:-1;;;;;18710:16:0;;;;;:39;;-1:-1:-1;;;;;;18730:19:0;;18744:4;18730:19;;18710:39;18702:48;;;;;;18789:10;18761:15;18779:21;;;:9;:21;;;;;;18819:16;;;;18811:68;;;;-1:-1:-1;;;18811:68:0;;;;;;;:::i;:::-;18916:15;18926:5;18916:7;:15;:::i;:::-;18902:10;18892:21;;;;:9;:21;;;;;;:39;;;;-1:-1:-1;;;;;18942:13:0;;;;;;;:22;;18959:5;;18892:21;18942:22;;18959:5;;18942:22;:::i;:::-;;;;-1:-1:-1;;18980:31:0;;-1:-1:-1;;;;;18980:31:0;;;18989:10;;-1:-1:-1;;;;;;;;;;;18980:31:0;;;19005:5;;18980:31;:::i;:::-;;;;;;;;-1:-1:-1;19039:4:0;;18613:438;-1:-1:-1;;;18613:438:0:o;9783:384::-;9852:4;9529:7;:5;:7::i;:::-;-1:-1:-1;;;;;9515:21:0;:10;-1:-1:-1;;;;;9515:21:0;;9507:44;;;;-1:-1:-1;;;9507:44:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;9877:22:0;::::1;9869:64;;;;-1:-1:-1::0;;;9869:64:0::1;;;;;;;:::i;:::-;9956:7;:5;:7::i;:::-;9944:9;:19:::0;;-1:-1:-1;;;;;;9944:19:0;;::::1;-1:-1:-1::0;;;;;9944:19:0;;::::1;;::::0;;;9974:9:::1;:20:::0;;;;::::1;::::0;;::::1;::::0;;;::::1;::::0;;10030:27:::1;:15;10048:9;10030:27;:::i;:::-;10005:22;:52:::0;;;10103:9:::1;::::0;10092::::1;::::0;10073:64:::1;::::0;-1:-1:-1;;;;;10103:9:0;;::::1;::::0;10092;;::::1;::::0;10073:64:::1;::::0;10103:9:::1;::::0;10073:64:::1;-1:-1:-1::0;10155:4:0::1;9562:1;9783:384:::0;;;:::o;14440:364::-;14621:10;14544:4;14611:21;;;:9;:21;;;;;;;;-1:-1:-1;;;;;14611:30:0;;;;;;;;;;:38;;;14665:36;14544:4;;14611:30;;-1:-1:-1;;;;;;;;;;;14665:36:0;;;14644:5;;14665:36;:::i;:::-;;;;;;;;14729:67;;-1:-1:-1;;;14729:67:0;;-1:-1:-1;;;;;14729:42:0;;;;;:67;;14772:10;;14784:5;;14791:4;;;;14729:67;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;14722:74;14440:364;-1:-1:-1;;;;;14440:364:0:o;15621:707::-;15790:8;15771:15;:27;;15763:62;;;;-1:-1:-1;;;15763:62:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;16021:14:0;;15838:18;16021:14;;;:6;:14;;;;;:16;;8894:95;;15946:6;;15971:7;;15997:5;;16021:16;15838:18;16021:16;;;:::i;:::-;;;;;16056:8;15883:182;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;15859:207;;;;;;15838:228;;16087:41;16100:6;16108:10;16120:1;16123;16126;16087:12;:41::i;:::-;:92;;;;16132:47;16151:6;16159:10;16171:1;16174;16177;16132:18;:47::i;:::-;16079:101;;;;;;-1:-1:-1;;;;;16238:17:0;;;;;;;:9;:17;;;;;;;;:26;;;;;;;;;;;;;;:34;;;16288:32;-1:-1:-1;;;;;;;;;;;16288:32:0;;;16267:5;;16288:32;:::i;:::-;;;;;;;;15621:707;;;;;;;;:::o;11151:75::-;;;;;;;;;;;;;;;;;;;;;;;;:::o;10175:210::-;10266:4;9529:7;:5;:7::i;:::-;-1:-1:-1;;;;;9515:21:0;:10;-1:-1:-1;;;;;9515:21:0;;9507:44;;;;-1:-1:-1;;;9507:44:0;;;;;;;:::i;:::-;10283:22:::1;10289:7;10298:6;10283:5;:22::i;:::-;10339:7;-1:-1:-1::0;;;;;10321:34:0::1;10331:6;10321:34;10348:6;10321:34;;;;;;:::i;17277:399::-:0;17389:4;17406:12;17509:16;17544:10;17445:110;;;;;;;;;:::i;:::-;;;;;;;;;;;;;17421:135;;;;;;17406:150;;17567:14;17584:24;17594:4;17600:1;17603;17606;17584:24;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;17584:24:0;;-1:-1:-1;;17584:24:0;;;-1:-1:-1;;;;;;;17627:20:0;;;;;;:40;;;17661:6;-1:-1:-1;;;;;17651:16:0;:6;-1:-1:-1;;;;;17651:16:0;;17627:40;17619:49;17277:399;-1:-1:-1;;;;;;;;17277:399:0:o;17688:290::-;17806:4;17823:12;17838:20;17847:10;17838:8;:20::i;:::-;17823:35;;17869:14;17886:24;17896:4;17902:1;17905;17908;17886:24;;;;;;;;;;;;;;;;;;:::i;13279:270::-;-1:-1:-1;;;;;13355:21:0;;13347:67;;;;-1:-1:-1;;;13347:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;13427:18:0;;;;;;:9;:18;;;;;:28;;13449:6;;13427:18;:28;;13449:6;;13427:28;:::i;:::-;;;;;;;;13482:6;13466:12;;:22;;;;;;;:::i;:::-;;;;-1:-1:-1;;13504:37:0;;13530:1;;-1:-1:-1;;;;;13504:37:0;;;-1:-1:-1;;;;;;;;;;;13504:37:0;;;13534:6;;13504:37;:::i;:::-;;;;;;;;13279:270;;:::o;12679:268::-;-1:-1:-1;;;;;12755:21:0;;12747:65;;;;-1:-1:-1;;;12747:65:0;;;;;;;:::i;:::-;12841:6;12825:12;;:22;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;;;12858:18:0;;;;;;:9;:18;;;;;:28;;12880:6;;12858:18;:28;;12880:6;;12858:28;:::i;:::-;;;;-1:-1:-1;;12902:37:0;;-1:-1:-1;;;;;12902:37:0;;;12919:1;;-1:-1:-1;;;;;;;;;;;12902:37:0;;;12932:6;;12902:37;:::i;18056:159::-;18111:7;18201:4;18148:58;;;;;;;;:::i;:::-;;;;;;;;;;;;;18138:69;;;;;;18131:76;;18056:159;;;:::o;14:175:1:-;84:20;;-1:-1:-1;;;;;133:31:1;;123:42;;113:2;;179:1;176;169:12;194:198;;306:2;294:9;285:7;281:23;277:32;274:2;;;327:6;319;312:22;274:2;355:31;376:9;355:31;:::i;:::-;345:41;264:128;-1:-1:-1;;;264:128:1:o;397:274::-;;;526:2;514:9;505:7;501:23;497:32;494:2;;;547:6;539;532:22;494:2;575:31;596:9;575:31;:::i;:::-;565:41;;625:40;661:2;650:9;646:18;625:40;:::i;:::-;615:50;;484:187;;;;;:::o;676:342::-;;;;822:2;810:9;801:7;797:23;793:32;790:2;;;843:6;835;828:22;790:2;871:31;892:9;871:31;:::i;:::-;861:41;;921:40;957:2;946:9;942:18;921:40;:::i;:::-;911:50;;1008:2;997:9;993:18;980:32;970:42;;780:238;;;;;:::o;1023:717::-;;;;;;;;1235:3;1223:9;1214:7;1210:23;1206:33;1203:2;;;1257:6;1249;1242:22;1203:2;1285:31;1306:9;1285:31;:::i;:::-;1275:41;;1335:40;1371:2;1360:9;1356:18;1335:40;:::i;:::-;1325:50;;1422:2;1411:9;1407:18;1394:32;1384:42;;1473:2;1462:9;1458:18;1445:32;1435:42;;1527:3;1516:9;1512:19;1499:33;1572:4;1565:5;1561:16;1554:5;1551:27;1541:2;;1597:6;1589;1582:22;1541:2;1193:547;;;;-1:-1:-1;1193:547:1;;;;1625:5;1677:3;1662:19;;1649:33;;-1:-1:-1;1729:3:1;1714:19;;;1701:33;;1193:547;-1:-1:-1;;1193:547:1:o;1745:266::-;;;1874:2;1862:9;1853:7;1849:23;1845:32;1842:2;;;1895:6;1887;1880:22;1842:2;1923:31;1944:9;1923:31;:::i;:::-;1913:41;2001:2;1986:18;;;;1973:32;;-1:-1:-1;;;1832:179:1:o;2016:785::-;;;;;2181:2;2169:9;2160:7;2156:23;2152:32;2149:2;;;2202:6;2194;2187:22;2149:2;2230:31;2251:9;2230:31;:::i;:::-;2220:41;;2308:2;2297:9;2293:18;2280:32;2270:42;;2363:2;2352:9;2348:18;2335:32;2386:18;2427:2;2419:6;2416:14;2413:2;;;2448:6;2440;2433:22;2413:2;2491:6;2480:9;2476:22;2466:32;;2536:7;2529:4;2525:2;2521:13;2517:27;2507:2;;2563:6;2555;2548:22;2507:2;2608;2595:16;2634:2;2626:6;2623:14;2620:2;;;2655:6;2647;2640:22;2620:2;2705:7;2700:2;2691:6;2687:2;2683:15;2679:24;2676:37;2673:2;;;2731:6;2723;2716:22;2673:2;2139:662;;;;-1:-1:-1;;2767:2:1;2759:11;;-1:-1:-1;;;2139:662:1:o;2806:297::-;;2926:2;2914:9;2905:7;2901:23;2897:32;2894:2;;;2947:6;2939;2932:22;2894:2;2984:9;2978:16;3037:5;3030:13;3023:21;3016:5;3013:32;3003:2;;3064:6;3056;3049:22;3108:334;;;;3254:2;3242:9;3233:7;3229:23;3225:32;3222:2;;;3275:6;3267;3260:22;3222:2;3316:9;3303:23;3293:33;;3345:40;3381:2;3370:9;3366:18;3345:40;:::i;3447:266::-;;;3576:2;3564:9;3555:7;3551:23;3547:32;3544:2;;;3597:6;3589;3582:22;3544:2;3638:9;3625:23;3615:33;;3667:40;3703:2;3692:9;3688:18;3667:40;:::i;3718:380::-;3960:66;3948:79;;4052:2;4043:12;;4036:28;;;;4089:2;4080:12;;3938:160::o;4103:392::-;-1:-1:-1;;;4361:27:1;;4413:1;4404:11;;4397:27;;;;4449:2;4440:12;;4433:28;4486:2;4477:12;;4351:144::o;4500:203::-;-1:-1:-1;;;;;4664:32:1;;;;4646:51;;4634:2;4619:18;;4601:102::o;4708:562::-;-1:-1:-1;;;;;4921:32:1;;4903:51;;4985:2;4970:18;;4963:34;;;5033:2;5028;5013:18;;5006:30;;;5052:18;;5045:34;;;4708:562;5072:6;5122;5116:3;5101:19;;5088:49;5157:22;;;5181:3;5153:32;;;5146:46;;;;5253:2;5232:15;;;-1:-1:-1;;5228:29:1;5213:45;5209:55;;4893:377;-1:-1:-1;;;4893:377:1:o;5275:187::-;5440:14;;5433:22;5415:41;;5403:2;5388:18;;5370:92::o;5467:177::-;5613:25;;;5601:2;5586:18;;5568:76::o;5649:591::-;5936:25;;;-1:-1:-1;;;;;6035:15:1;;;6030:2;6015:18;;6008:43;6087:15;;;;6082:2;6067:18;;6060:43;6134:2;6119:18;;6112:34;6177:3;6162:19;;6155:35;;;;5988:3;6206:19;;6199:35;5923:3;5908:19;;5890:350::o;6245:398::-;6472:25;;;6545:4;6533:17;;;;6528:2;6513:18;;6506:45;6582:2;6567:18;;6560:34;6625:2;6610:18;;6603:34;6459:3;6444:19;;6426:217::o;6648:603::-;;6789:2;6818;6807:9;6800:21;6850:6;6844:13;6893:6;6888:2;6877:9;6873:18;6866:34;6918:4;6931:140;6945:6;6942:1;6939:13;6931:140;;;7040:14;;;7036:23;;7030:30;7006:17;;;7025:2;7002:26;6995:66;6960:10;;6931:140;;;7089:6;7086:1;7083:13;7080:2;;;7159:4;7154:2;7145:6;7134:9;7130:22;7126:31;7119:45;7080:2;-1:-1:-1;7235:2:1;7214:15;-1:-1:-1;;7210:29:1;7195:45;;;;7242:2;7191:54;;6769:482;-1:-1:-1;;;6769:482:1:o;7256:353::-;7458:2;7440:21;;;7497:2;7477:18;;;7470:30;7536:31;7531:2;7516:18;;7509:59;7600:2;7585:18;;7430:179::o;7614:346::-;7816:2;7798:21;;;7855:2;7835:18;;;7828:30;-1:-1:-1;;;7889:2:1;7874:18;;7867:52;7951:2;7936:18;;7788:172::o;7965:356::-;8167:2;8149:21;;;8186:18;;;8179:30;8245:34;8240:2;8225:18;;8218:62;8312:2;8297:18;;8139:182::o;8326:334::-;8528:2;8510:21;;;8567:2;8547:18;;;8540:30;-1:-1:-1;;;8601:2:1;8586:18;;8579:40;8651:2;8636:18;;8500:160::o;8665:397::-;8867:2;8849:21;;;8906:2;8886:18;;;8879:30;8945:34;8940:2;8925:18;;8918:62;-1:-1:-1;;;9011:2:1;8996:18;;8989:31;9052:3;9037:19;;8839:223::o;9067:397::-;9269:2;9251:21;;;9308:2;9288:18;;;9281:30;9347:34;9342:2;9327:18;;9320:62;-1:-1:-1;;;9413:2:1;9398:18;;9391:31;9454:3;9439:19;;9241:223::o;9469:355::-;9671:2;9653:21;;;9710:2;9690:18;;;9683:30;9749:33;9744:2;9729:18;;9722:61;9815:2;9800:18;;9643:181::o;9829:403::-;10031:2;10013:21;;;10070:2;10050:18;;;10043:30;10109:34;10104:2;10089:18;;10082:62;-1:-1:-1;;;10175:2:1;10160:18;;10153:37;10222:3;10207:19;;10003:229::o;10419:184::-;10591:4;10579:17;;;;10561:36;;10549:2;10534:18;;10516:87::o;10608:128::-;;10679:1;10675:6;10672:1;10669:13;10666:2;;;10685:18;;:::i;:::-;-1:-1:-1;10721:9:1;;10656:80::o;10741:125::-;;10809:1;10806;10803:8;10800:2;;;10814:18;;:::i;:::-;-1:-1:-1;10851:9:1;;10790:76::o;10871:380::-;10956:1;10946:12;;11003:1;10993:12;;;11014:2;;11068:4;11060:6;11056:17;11046:27;;11014:2;11121;11113:6;11110:14;11090:18;11087:38;11084:2;;;11167:10;11162:3;11158:20;11155:1;11148:31;11202:4;11199:1;11192:15;11230:4;11227:1;11220:15;11084:2;;10926:325;;;:::o;11256:135::-;;-1:-1:-1;;11316:17:1;;11313:2;;;11336:18;;:::i;:::-;-1:-1:-1;11383:1:1;11372:13;;11303:88::o;11396:127::-;11457:10;11452:3;11448:20;11445:1;11438:31;11488:4;11485:1;11478:15;11512:4;11509:1;11502:15

Swarm Source

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