Contract 0xbb53fcab7a3616c5be33b9c0af612f0462b01734 5

 
 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0xa334ea75378548ba4d0b963001a4382a5e3d3761c75f950f300f3a74ada8b5fdApprove147409092022-01-27 20:40:481 day 4 hrs ago0xe47231e1c690df1b3de04492bd06011e6f75a599 IN  SteakBank: SBF Token0 BNB0.000222035
0x646fa8abd409c6b0dfacd7355c35cebe2266e2fa095c80052a5141ffeba07902Approve146055562022-01-23 3:37:535 days 21 hrs ago0xd93fdf64b7e388489a1d4a63db8ecff58b9f4818 IN  SteakBank: SBF Token0 BNB0.000222035
0xc3cceca3e8560e85ab5700985f655d3a350ee95058330d7a8c3b67d9756b55bdApprove145847552022-01-22 10:16:546 days 14 hrs ago0x3dd2dc358653725db58870018a6cfb8f78b0e4a6 IN  SteakBank: SBF Token0 BNB0.000222035
0x98e13a5f3c02e58550f7a8fb1e6f27394b393b0ce56a689469b0282c35c81183Approve145802952022-01-22 6:30:236 days 18 hrs ago0x0153b25e1be41b794c4f30b4b9c2479e44c3fd01 IN  SteakBank: SBF Token0 BNB0.000222035
0x87982a0486626fe99e99d857f1e5b9a135d6d13228a2c4a546bb7a4dc6bd884dApprove145683122022-01-21 20:28:387 days 4 hrs ago0x5cd9132cc130ff6aff187070c114fa99f57ab27d IN  SteakBank: SBF Token0 BNB0.000266442
0x296a324b6a8046c56c0a99224b49aafa6309a9bc7971b57bfec1893bf4b63b0eApprove145667912022-01-21 19:12:337 days 5 hrs ago0x1a186609adbfe67a75727a32ddaadc0d1f3e5133 IN  SteakBank: SBF Token0 BNB0.000222035
0xfc91ba310bc8a8a111436eefe5320d2d719962de50fdcde7bc02f380bb571369Approve145634042022-01-21 16:22:347 days 8 hrs ago0xa4856b959cf536b2c4dcce088df38dda06107202 IN  SteakBank: SBF Token0 BNB0.0000769136
0xf9cc749a345a16316f8b313c191e4526e394e4e22d7ba8241ec28b551ba81fa0Approve145633702022-01-21 16:20:527 days 8 hrs ago0xa4856b959cf536b2c4dcce088df38dda06107202 IN  SteakBank: SBF Token0 BNB0.000079816
0x00aae5b0c6e79e2fedef1dbd44c086cb8c921c58a35a650083deb0ac4e6e31d4Approve145633682022-01-21 16:20:467 days 8 hrs ago0xa4856b959cf536b2c4dcce088df38dda06107202 IN  SteakBank: SBF Token0 BNB0.000079816
0x9cadd1f950b6d9009cee822b39ce77b8b38b41cdc66bee9f5e934d371a89bfeeTransfer145590202022-01-21 12:42:477 days 12 hrs ago0x0064aaa2001c684efe6307356a58ced5c7015da9 IN  SteakBank: SBF Token0 BNB0.0001267475
0x25632436b1ba5efe0e2bfd169c67ecad311b1b1c3a3af02197dd37632438c369Transfer145288782022-01-20 11:33:318 days 13 hrs ago0x01c3370a1c9b3046ab5e09027061e2c85390cca6 IN  SteakBank: SBF Token0 BNB0.000158684715
0x7361137c17c977817c7f3f231188776438937cfc8d66498a6afccd5bbeb1573fApprove145254672022-01-20 8:42:588 days 16 hrs ago0xbf681aaf898339a3df4dd968571f8d1716266bf0 IN  SteakBank: SBF Token0 BNB0.000222035
0xae7f139d404c297f0a7fc75a0727184f8922dab1722310e50a4ebd58b40a7b8eApprove145055612022-01-19 16:06:529 days 9 hrs ago0x4ba029ea675fc9d69aa5b52533856addbb25a5b2 IN  SteakBank: SBF Token0 BNB0.00026637
0x474d3290f904b33d8fa032b63a47e373f7861d0245f286b615ad1f2377e00c85Approve144810562022-01-18 19:35:0710 days 5 hrs ago0xc978a14f058b400a2e5121111ea1afdd71998d43 IN  SteakBank: SBF Token0 BNB0.000222035
0x4ed8502e602e4d86e555b01b38016bdbdce274edb5435d7a808aaff4c83c4f46Approve144752882022-01-18 14:41:5810 days 10 hrs ago0xd0bea4159cf6466472eb1271908358943328112e IN  SteakBank: SBF Token0 BNB0.00007256
0x99c3d79c8b473baf93eba0483f4e311e33a9cc9a7784f53baf7f11be230fc287Approve144752282022-01-18 14:38:5810 days 10 hrs ago0xd0bea4159cf6466472eb1271908358943328112e IN  SteakBank: SBF Token0 BNB0.00007256
0x9e81d6ca37dfb58d25b7c76a01144ad925e7e681488eacdc1a0906a7625696e0Approve144744662022-01-18 13:59:2910 days 11 hrs ago0xa0fea8a4b3842c9ca44fcb6c3e95c5f19651fabe IN  SteakBank: SBF Token0 BNB0.000630175
0x4bff9f5fa0e0bceb291adf5d2eacc53445c6405a986b7f2a977a518e07b81c8dApprove144744612022-01-18 13:59:1310 days 11 hrs ago0xa0fea8a4b3842c9ca44fcb6c3e95c5f19651fabe IN  SteakBank: SBF Token0 BNB0.001110175
0x855972b18c114bd7b252e901630d5bf9601664e518bdfc90bc6fab5e13312db8Transfer144668252022-01-18 7:27:1910 days 17 hrs ago0xebf0fbdc2507be102845125e124eb306d1490885 IN  SteakBank: SBF Token0 BNB0.000190165
0x9212223780c03f4132e7e8fea9eb8a58d4046e8cd2e0d5f614514f0638e922c9Approve144298472022-01-17 0:18:3112 days 50 mins ago0x234d853e9464146cfb616e9effc81a6e2e100166 IN  SteakBank: SBF Token0 BNB0.001110175
0x75110d065538176f49c991cb60484cc99b55932c2cf4f225189269be6e92f618Approve144239422022-01-16 19:23:1612 days 5 hrs ago0x8ca458591cb99ed942bc9b9a230b39a01bc76159 IN  SteakBank: SBF Token0 BNB0.000222035
0x6ccb05822b5a0695e814d3738c3e9a657880112651e145ff13e2e02774822d8aApprove144168162022-01-16 13:24:0012 days 11 hrs ago0x0691f46553614c93e2d4eff3fc60bff01f84d6ef IN  SteakBank: SBF Token0 BNB0.000087072
0x400f0d05416abf553066ee320c2a2bd6b6b264500e23da421e82b9b1a4695076Approve144166962022-01-16 13:18:0012 days 11 hrs ago0x0691f46553614c93e2d4eff3fc60bff01f84d6ef IN  SteakBank: SBF Token0 BNB0.000087072
0xb2d1b87db360d5c65c501b48c35c50b9f3a1628414d1d1bc7de22772f29f580aApprove143961292022-01-15 20:06:4113 days 5 hrs ago0xdbb49ef5ae35a7d172f943c489603554baaa882c IN  SteakBank: SBF Token0 BNB0.000222035
0x6e1a5dd1742747ff9b7150ee31bd7bc7ca60b4721982eaf94884e4022092f95dApprove143742822022-01-15 1:51:0713 days 23 hrs ago0x9729334add4fe99d116e689ba11ec34e6c214a72 IN  SteakBank: SBF Token0 BNB0.00007256
[ Download CSV Export 

OVERVIEW

SteakBank is a liquid staking platform on Binance Smart Chain where users can earn multiple streams of cashflow.

Parent Txn Hash Block From To Value
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
SBF

Compiler Version
v0.6.12+commit.27d51765

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Apache-2.0 license

Contract Source Code (Solidity)

/**
 *Submitted for verification at BscScan.com on 2021-04-26
*/

// File: openzeppelin-solidity/contracts/utils/Context.sol


pragma solidity >=0.6.0 <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 GSN 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 payable) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes memory) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

// File: openzeppelin-solidity/contracts/GSN/Context.sol


pragma solidity >=0.6.0 <0.8.0;

// File: contracts/lib/Ownable.sol

pragma solidity >=0.4.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.
 */
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() public {}

    function initializeOwner(address ownerAddr) internal {
        _owner = ownerAddr;
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view 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 onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = 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 onlyOwner {
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     */
    function _transferOwnership(address newOwner) internal {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

// File: openzeppelin-solidity/contracts/math/SafeMath.sol


pragma solidity >=0.6.0 <0.8.0;

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        uint256 c = a + b;
        if (c < a) return (false, 0);
        return (true, c);
    }

    /**
     * @dev Returns the substraction of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b > a) return (false, 0);
        return (true, a - b);
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) return (true, 0);
        uint256 c = a * b;
        if (c / a != b) return (false, 0);
        return (true, c);
    }

    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b == 0) return (false, 0);
        return (true, a / b);
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b == 0) return (false, 0);
        return (true, a % b);
    }

    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a, "SafeMath: subtraction overflow");
        return a - b;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) return 0;
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: division by zero");
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: modulo by zero");
        return a % b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        return a - b;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryDiv}.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting with custom message when dividing by zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryMod}.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        return a % b;
    }
}

// File: @pancakeswap/pancake-swap-lib/contracts/token/BEP20/IBEP20.sol

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

pragma solidity >=0.4.0;

interface IBEP20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

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

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

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

    /**
     * @dev Returns the bep token owner.
     */
    function getOwner() external view returns (address);

    /**
     * @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: contracts/SBF.sol

pragma solidity 0.6.12;




interface ApproveAndCallFallBack {
    function receiveApproval(address from, uint256 tokens, address token, bytes memory data) external;
}

contract SBF is IBEP20, Ownable {
    using SafeMath for uint256;

    /// @notice Official record of token balances for each account
    mapping (address => uint256) private _balances;

    /// @notice Allowance amounts on behalf of others
    mapping (address => mapping (address => uint256)) private _allowances;

    /// @notice Total number of tokens in circulation
    uint256 private _totalSupply;

    /// @notice BEP-20 token decimals for this token
    uint8 private _decimals;

    /// @notice BEP-20 token symbol for this token
    string private _symbol;

    /// @notice BEP-20 token name for this token
    string private _name;

    /// @notice A record of each accounts delegate
    mapping (address => address) public delegates;

    /// @notice A checkpoint for marking number of votes from a given block
    struct Checkpoint {
        uint32 fromBlock;
        uint256 votes;
    }

    /// @notice A record of votes checkpoints for each account, by index
    mapping (address => mapping (uint32 => Checkpoint)) public checkpoints;

    /// @notice The number of checkpoints for each account
    mapping (address => uint32) public numCheckpoints;

    /// @notice The EIP-712 typehash for the contract's domain
    bytes32 public constant DOMAIN_TYPEHASH = keccak256("EIP712Domain(string name,uint256 chainId,address verifyingContract)");

    /// @notice The EIP-712 typehash for the delegation struct used by the contract
    bytes32 public constant DELEGATION_TYPEHASH = keccak256("Delegation(address delegatee,uint256 nonce,uint256 expiry)");

    /// @notice A record of states for signing / validating signatures
    mapping (address => uint256) public nonces;

    /// @notice An event thats emitted when an account changes its delegate
    event DelegateChanged(address indexed delegator, address indexed fromDelegate, address indexed toDelegate);

    /// @notice An event thats emitted when a delegate account's vote balance changes
    event DelegateVotesChanged(address indexed delegate, uint256 previousBalance, uint256 newBalance);

    /// @notice The standard BEP-20 transfer event
    event Transfer(address indexed from, address indexed to, uint256 amount);

    /// @notice The standard BEP-20 approval event
    event Approval(address indexed owner, address indexed spender, uint256 amount);

    /**
     * @notice Construct a new SBF token
     * @param account The initial account to grant all the tokens
     */
    constructor(address account) public {
        _name = "Steak Bank Finance";
        _symbol = "SBF";
        _decimals = 18;
        _mint(account, 10000000000e18);
        super.initializeOwner(account);
    }

    /**
     * @dev Returns the bep token owner.
    */
    function getOwner() override external view returns (address) {
        return owner();
    }

    /**
     * @dev Returns the token decimals.
    */
    function decimals() override external view returns (uint8) {
        return _decimals;
    }

    /**
     * @dev Returns the token symbol.
    */
    function symbol() override external view returns (string memory) {
        return _symbol;
    }

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

    /**
     * @dev Returns the total supply.
    */
    function totalSupply() override external view returns (uint256) {
        return _totalSupply;
    }

    /**
     * @notice Get the number of tokens held by the `account`
     * @param account The address of the account to get the balance of
     * @return The number of tokens held
     */
    function balanceOf(address account) override external view returns (uint256) {
        return _balances[account];
    }

    /**
     * @notice Transfer `amount` tokens from `msg.sender` to `dst`
     * @param recipient The address of the destination account
     * @param amount The number of tokens to transfer
     * @return Whether or not the transfer succeeded
     */
    function transfer(address recipient, uint256 amount) override external returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    /**
     * @notice Get the number of tokens `spender` is approved to spend on behalf of `account`
     * @param owner The address of the account holding the funds
     * @param spender The address of the account spending the funds
     * @return The number of tokens approved
     */
    function allowance(address owner, address spender) override external view returns (uint256) {
        return _allowances[owner][spender];
    }

    /**
     * @notice Approve `spender` to transfer up to `amount` from `src`
     * @dev This will overwrite the approval amount for `spender`
     * @param spender The address of the account which may transfer tokens
     * @param amount The number of tokens that are approved (2^256-1 means infinite)
     * @return Whether or not the approval succeeded
     */
    function approve(address spender, uint256 amount) override external   returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    /**
     * @notice Approve the spender to transferFrom(...) with the amount.
     * @dev receiveApproval(...) is executed.
     * @param amount The number of tokens that are approved
     * @param data The data to pass to receiveApproval(...)
     * @return true
     */
    function approveAndCall(address spender, uint256 amount, bytes memory data) public returns (bool) {
        _approve(_msgSender(), spender, amount);
        ApproveAndCallFallBack(spender).receiveApproval(_msgSender(), amount, address(this), data);
        return true;
    }

    /**
     * @notice Transfer `amount` tokens from `src` to `dst`
     * @param sender The address of the source account
     * @param recipient The address of the destination account
     * @param amount The number of tokens to transfer
     * @return Whether or not the transfer succeeded
     */
    function transferFrom(address sender, address recipient, uint256 amount) override external returns (bool) {
        _transfer(sender, recipient, amount);
        address spender = _msgSender();
        uint256 spenderAllowance = _allowances[sender][spender];
        if (spenderAllowance != uint256(-1)) {
            _approve(sender, spender, spenderAllowance.sub(amount));
        }
        return true;
    }

    /**
     * @notice Atomically increases the allowance granted to `spender` by the caller
     * @dev This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {BEP20-approve}.
     * @param spender The address of the account which may transfer tokens
     * @param addedValue The additional number of tokens to allow which may be spent
     * @return Whether or not the approval succeeded
     */
    function increaseAllowance(address spender, uint256 addedValue) public returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
        return true;
    }

    /**
     * @notice Atomically increases the allowance granted to `spender` by the caller
     * @dev This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {BEP20-approve}.
     * @param spender The address of the account which may transfer tokens
     * @param subtractedValue The subtractional number of tokens to allow which may be spent
     * @return Whether or not the approval succeeded
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue));
        return true;
    }

    /**
     * @notice Destroy the amount of tokens from the sender, reducing the total supply.
     * @dev The amount must be greater than balance, total supply.
     * @param amount The number of tokens that are burnt
     * @return true
     */
    function burn(uint256 amount) external   returns (bool) {
        _burn(_msgSender(), amount);
        return true;
    }

    /**
     * @notice Delegate votes from `msg.sender` to `delegatee`
     * @param delegatee The address to delegate votes to
     */
    function delegate(address delegatee) external   {
        return _delegate(_msgSender(), delegatee);
    }

    /**
     * @notice Delegates votes from signatory to `delegatee`
     * @param delegatee The address to delegate votes to
     * @param nonce The contract state required to match the signature
     * @param expiry The time at which to expire the signature
     * @param v The recovery byte of the signature
     * @param r Half of the ECDSA signature pair
     * @param s Half of the ECDSA signature pair
     */
    function delegateBySig(address delegatee, uint256 nonce, uint256 expiry, uint8 v, bytes32 r, bytes32 s) external   {
        bytes32 domainSeparator = keccak256(abi.encode(DOMAIN_TYPEHASH, keccak256(bytes(_name)), getChainId(), address(this)));
        bytes32 structHash = keccak256(abi.encode(DELEGATION_TYPEHASH, delegatee, nonce, expiry));
        bytes32 digest = keccak256(abi.encodePacked("\x19\x01", domainSeparator, structHash));
        address signatory = ecrecover(digest, v, r, s);
        require(signatory != address(0), "Invalid signature");
        require(nonce == nonces[signatory]++, "Invalid nonce");
        require(now <= expiry, "The signature expired");
        return _delegate(signatory, delegatee);
    }

    /**
     * @notice Gets the current votes balance for `account`
     * @param account The address to get votes balance
     * @return The number of current votes for `account`
     */
    function getCurrentVotes(address account) external view returns (uint96) {
        uint32 nCheckpoints = numCheckpoints[account];
        return nCheckpoints > 0 ? ceil96(checkpoints[account][nCheckpoints - 1].votes) : 0;
    }

    /**
     * @notice Determine the prior number of votes for an account as of a block number
     * @dev Block number must be a finalized block or else this function will revert to prevent misinformation.
     * @param account The address of the account to check
     * @param blockNumber The block number to get the vote balance at
     * @return The number of votes the account had as of the given block
     */
    function getPriorVotes(address account, uint256 blockNumber) external view returns (uint96) {
        require(blockNumber < block.number, "Not determined yet");

        uint32 nCheckpoints = numCheckpoints[account];
        if (nCheckpoints == 0) {
            return 0;
        }

        // First check most recent balance
        if (checkpoints[account][nCheckpoints - 1].fromBlock <= blockNumber) {
            return ceil96(checkpoints[account][nCheckpoints - 1].votes);
        }

        // Next check implicit zero balance
        if (checkpoints[account][0].fromBlock > blockNumber) {
            return 0;
        }

        uint32 lower = 0;
        uint32 upper = nCheckpoints - 1;
        while (upper > lower) {
            uint32 center = upper - (upper - lower) / 2; // ceil, avoiding overflow
            Checkpoint memory cp = checkpoints[account][center];
            if (cp.fromBlock == blockNumber) {
                return ceil96(cp.votes);
            } else if (cp.fromBlock < blockNumber) {
                lower = center;
            } else {
                upper = center - 1;
            }
        }
        return ceil96(checkpoints[account][lower].votes);
    }

    function _transfer(address sender, address recipient, uint256 amount) internal {
        require(sender != address(0), "Cannot transfer from the zero address");
        require(recipient != address(0), "Cannot transfer to the zero address");

        _balances[sender] = _balances[sender].sub(amount);
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);

        _moveDelegates(delegates[sender], delegates[recipient], amount);
    }

    function _approve(address owner, address spender, uint256 amount) internal {
        require(owner != address(0), "Cannot approve from the zero address");
        require(spender != address(0), "Cannot approve to the zero address");

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

    function _burn(address account, uint256 amount) internal {
        require(account != address(0), "Cannot burn from the zero address");

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

        _moveDelegates(delegates[account], address(0), amount);
    }

    function _mint(address account, uint256 amount) internal {
        require(account != address(0), "BEP20: mint to the zero address");

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

        _moveDelegates(address(0), delegates[account], amount);
    }

    function _delegate(address delegator, address delegatee) internal {
        address currentDelegate = delegates[delegator];
        uint256 delegatorBalance = _balances[delegator];
        delegates[delegator] = delegatee;

        emit DelegateChanged(delegator, currentDelegate, delegatee);

        _moveDelegates(currentDelegate, delegatee, delegatorBalance);
    }

    function _moveDelegates(address srcRep, address dstRep, uint256 amount) internal {
        if (srcRep != dstRep && amount > 0) {
            if (srcRep != address(0)) {
                uint32 srcRepNum = numCheckpoints[srcRep];
                uint256 srcRepOld = srcRepNum > 0 ? checkpoints[srcRep][srcRepNum - 1].votes : 0;
                uint256 srcRepNew = srcRepOld.sub(amount);
                _writeCheckpoint(srcRep, srcRepNum, srcRepOld, srcRepNew);
            }

            if (dstRep != address(0)) {
                uint32 dstRepNum = numCheckpoints[dstRep];
                uint256 dstRepOld = dstRepNum > 0 ? checkpoints[dstRep][dstRepNum - 1].votes : 0;
                uint256 dstRepNew = dstRepOld.add(amount);
                _writeCheckpoint(dstRep, dstRepNum, dstRepOld, dstRepNew);
            }
        }
    }

    function _writeCheckpoint(address delegatee, uint32 nCheckpoints, uint256 oldVotes, uint256 newVotes) internal {
        uint32 blockNumber = safe32(block.number, "The block number exceeds 32 bits");

        if (nCheckpoints > 0 && checkpoints[delegatee][nCheckpoints - 1].fromBlock == blockNumber) {
            checkpoints[delegatee][nCheckpoints - 1].votes = newVotes;
        } else {
            checkpoints[delegatee][nCheckpoints] = Checkpoint(blockNumber, newVotes);
            numCheckpoints[delegatee] = nCheckpoints + 1;
        }

        emit DelegateVotesChanged(delegatee, oldVotes, newVotes);
    }

    function safe32(uint256 n, string memory errorMessage) internal pure returns (uint32) {
        require(n < 2**32, errorMessage);
        return uint32(n);
    }

    function ceil96(uint256 n) internal pure returns (uint96) {
        if (n >= 2**96) {
            return uint96(-1);
        }
        return uint96(n);
    }

    function getChainId() internal pure returns (uint256) {
        uint256 chainId;
        assembly { chainId := chainid() }
        return chainId;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"account","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":"amount","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"delegator","type":"address"},{"indexed":true,"internalType":"address","name":"fromDelegate","type":"address"},{"indexed":true,"internalType":"address","name":"toDelegate","type":"address"}],"name":"DelegateChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"delegate","type":"address"},{"indexed":false,"internalType":"uint256","name":"previousBalance","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"newBalance","type":"uint256"}],"name":"DelegateVotesChanged","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":"amount","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"DELEGATION_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"DOMAIN_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"approveAndCall","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":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint32","name":"","type":"uint32"}],"name":"checkpoints","outputs":[{"internalType":"uint32","name":"fromBlock","type":"uint32"},{"internalType":"uint256","name":"votes","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":"delegatee","type":"address"}],"name":"delegate","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"delegatee","type":"address"},{"internalType":"uint256","name":"nonce","type":"uint256"},{"internalType":"uint256","name":"expiry","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"delegateBySig","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"delegates","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getCurrentVotes","outputs":[{"internalType":"uint96","name":"","type":"uint96"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getOwner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"blockNumber","type":"uint256"}],"name":"getPriorVotes","outputs":[{"internalType":"uint96","name":"","type":"uint96"}],"stateMutability":"view","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":[],"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":[{"internalType":"address","name":"","type":"address"}],"name":"numCheckpoints","outputs":[{"internalType":"uint32","name":"","type":"uint32"}],"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"}]

60806040523480156200001157600080fd5b506040516200232238038062002322833981810160405260208110156200003757600080fd5b505160408051808201909152601280825271537465616b2042616e6b2046696e616e636560701b6020909201918252620000749160069162000690565b506040805180820190915260038082526229a12360e91b6020909201918252620000a19160059162000690565b506004805460ff19166012179055620000c7816b204fce5e3e25026110000000620000e4565b620000dd816200021060201b620012011760201c565b506200072c565b6001600160a01b03821662000140576040805162461bcd60e51b815260206004820152601f60248201527f42455032303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b6200015c816003546200023260201b620012231790919060201c565b6003556001600160a01b038216600090815260016020908152604090912054620001919183906200122362000232821b17901c565b6001600160a01b03831660008181526001602090815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a36001600160a01b038083166000908152600760205260408120546200020c92168362000294565b5050565b600080546001600160a01b0319166001600160a01b0392909216919091179055565b6000828201838110156200028d576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b816001600160a01b0316836001600160a01b031614158015620002b75750600081115b1562000401576001600160a01b038316156200035f576001600160a01b03831660009081526009602052604081205463ffffffff169081620002fb5760006200032d565b6001600160a01b038516600090815260086020908152604080832063ffffffff60001987011684529091529020600101545b905060006200034b84836200040660201b6200127d1790919060201c565b90506200035b8684848462000464565b5050505b6001600160a01b0382161562000401576001600160a01b03821660009081526009602052604081205463ffffffff1690816200039d576000620003cf565b6001600160a01b038416600090815260086020908152604080832063ffffffff60001987011684529091529020600101545b90506000620003ed84836200023260201b620012231790919060201c565b9050620003fd8584848462000464565b5050505b505050565b6000828211156200045e576040805162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015290519081900360640190fd5b50900390565b6000620004ad436040518060400160405280602081526020017f54686520626c6f636b206e756d62657220657863656564732033322062697473815250620005f160201b60201c565b905060008463ffffffff16118015620004f757506001600160a01b038516600090815260086020908152604080832063ffffffff6000198901811685529252909120548282169116145b1562000536576001600160a01b038516600090815260086020908152604080832063ffffffff60001989011684529091529020600101829055620005a7565b60408051808201825263ffffffff808416825260208083018681526001600160a01b038a166000818152600884528681208b8616825284528681209551865490861663ffffffff19918216178755925160019687015590815260099092529390208054928801909116919092161790555b604080518481526020810184905281516001600160a01b038816927fdec2bacdd2f05b59de34da9b523dff8be42e5e38e818c82fdb0bae774387a724928290030190a25050505050565b6000816401000000008410620006885760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156200064c57818101518382015260200162000632565b50505050905090810190601f1680156200067a5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b509192915050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10620006d357805160ff191683800117855562000703565b8280016001018555821562000703579182015b8281111562000703578251825591602001919060010190620006e6565b506200071192915062000715565b5090565b5b8082111562000711576000815560010162000716565b611be6806200073c6000396000f3fe608060405234801561001057600080fd5b50600436106101a95760003560e01c8063782d6fe1116100f9578063b4b5ea5711610097578063dd62ed3e11610071578063dd62ed3e1461060c578063e7a324dc1461063a578063f1127ed814610642578063f2fde38b14610694576101a9565b8063b4b5ea57146104e4578063c3cda5201461050a578063cae9ca5114610551576101a9565b80638da5cb5b116100d35780638da5cb5b1461047c57806395d89b4114610484578063a457c2d71461048c578063a9059cbb146104b8576101a9565b8063782d6fe1146104015780637ecebe001461044e578063893d20e814610474576101a9565b806339509351116101665780635c19a95c116101405780635c19a95c1461036c5780636fcfff451461039457806370a08231146103d3578063715018a6146103f9576101a9565b806339509351146102e157806342966c681461030d578063587cde1e1461032a576101a9565b806306fdde03146101ae578063095ea7b31461022b57806318160ddd1461026b57806320606b701461028557806323b872dd1461028d578063313ce567146102c3575b600080fd5b6101b66106ba565b6040805160208082528351818301528351919283929083019185019080838360005b838110156101f05781810151838201526020016101d8565b50505050905090810190601f16801561021d5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102576004803603604081101561024157600080fd5b506001600160a01b038135169060200135610750565b604080519115158252519081900360200190f35b61027361076e565b60408051918252519081900360200190f35b610273610774565b610257600480360360608110156102a357600080fd5b506001600160a01b03813581169160208101359091169060400135610798565b6102cb610801565b6040805160ff9092168252519081900360200190f35b610257600480360360408110156102f757600080fd5b506001600160a01b03813516906020013561080a565b6102576004803603602081101561032357600080fd5b5035610858565b6103506004803603602081101561034057600080fd5b50356001600160a01b0316610874565b604080516001600160a01b039092168252519081900360200190f35b6103926004803603602081101561038257600080fd5b50356001600160a01b031661088f565b005b6103ba600480360360208110156103aa57600080fd5b50356001600160a01b03166108a3565b6040805163ffffffff9092168252519081900360200190f35b610273600480360360208110156103e957600080fd5b50356001600160a01b03166108bb565b6103926108d6565b61042d6004803603604081101561041757600080fd5b506001600160a01b03813516906020013561098a565b604080516bffffffffffffffffffffffff9092168252519081900360200190f35b6102736004803603602081101561046457600080fd5b50356001600160a01b0316610bb8565b610350610bca565b610350610bd9565b6101b6610be8565b610257600480360360408110156104a257600080fd5b506001600160a01b038135169060200135610c49565b610257600480360360408110156104ce57600080fd5b506001600160a01b038135169060200135610c97565b61042d600480360360208110156104fa57600080fd5b50356001600160a01b0316610cab565b610392600480360360c081101561052057600080fd5b506001600160a01b038135169060208101359060408101359060ff6060820135169060808101359060a00135610d17565b6102576004803603606081101561056757600080fd5b6001600160a01b038235169160208101359181019060608101604082013564010000000081111561059757600080fd5b8201836020820111156105a957600080fd5b803590602001918460018302840111640100000000831117156105cb57600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250929550611003945050505050565b6102736004803603604081101561062257600080fd5b506001600160a01b0381358116916020013516611112565b61027361113d565b6106746004803603604081101561065857600080fd5b5080356001600160a01b0316906020013563ffffffff16611161565b6040805163ffffffff909316835260208301919091528051918290030190f35b610392600480360360208110156106aa57600080fd5b50356001600160a01b031661118e565b60068054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156107465780601f1061071b57610100808354040283529160200191610746565b820191906000526020600020905b81548152906001019060200180831161072957829003601f168201915b5050505050905090565b600061076461075d6112da565b84846112de565b5060015b92915050565b60035490565b7f8cad95687ba82c2ce50e74f7b754645e5117c3a5bec8151c0726d5857980a86681565b60006107a58484846113ca565b60006107af6112da565b6001600160a01b0380871660009081526002602090815260408083209385168352929052205490915060001981146107f5576107f586836107f0848861127d565b6112de565b50600195945050505050565b60045460ff1690565b60006107646108176112da565b846107f085600260006108286112da565b6001600160a01b03908116825260208083019390935260409182016000908120918c168152925290205490611223565b600061086b6108656112da565b83611534565b5060015b919050565b6007602052600090815260409020546001600160a01b031681565b6108a061089a6112da565b82611630565b50565b60096020526000908152604090205463ffffffff1681565b6001600160a01b031660009081526001602052604090205490565b6108de6112da565b6000546001600160a01b03908116911614610940576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b60004382106109d5576040805162461bcd60e51b8152602060048201526012602482015271139bdd0819195d195c9b5a5b9959081e595d60721b604482015290519081900360640190fd5b6001600160a01b03831660009081526009602052604090205463ffffffff1680610a03576000915050610768565b6001600160a01b038416600090815260086020908152604080832063ffffffff600019860181168552925290912054168310610a7b576001600160a01b038416600090815260086020908152604080832063ffffffff6000198601168452909152902060010154610a73906116b0565b915050610768565b6001600160a01b038416600090815260086020908152604080832083805290915290205463ffffffff16831015610ab6576000915050610768565b600060001982015b8163ffffffff168163ffffffff161115610b7857600282820363ffffffff16048103610ae8611ac4565b506001600160a01b038716600090815260086020908152604080832063ffffffff808616855290835292819020815180830190925280549093168082526001909301549181019190915290871415610b5357610b4781602001516116b0565b95505050505050610768565b805163ffffffff16871115610b6a57819350610b71565b6001820392505b5050610abe565b6001600160a01b038616600090815260086020908152604080832063ffffffff86168452909152902060010154610bae906116b0565b9695505050505050565b600a6020526000908152604090205481565b6000610bd4610bd9565b905090565b6000546001600160a01b031690565b60058054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156107465780601f1061071b57610100808354040283529160200191610746565b6000610764610c566112da565b846107f08560026000610c676112da565b6001600160a01b03908116825260208083019390935260409182016000908120918c16815292529020549061127d565b6000610764610ca46112da565b84846113ca565b6001600160a01b03811660009081526009602052604081205463ffffffff1680610cd6576000610d10565b6001600160a01b038316600090815260086020908152604080832063ffffffff6000198601168452909152902060010154610d10906116b0565b9392505050565b60007f8cad95687ba82c2ce50e74f7b754645e5117c3a5bec8151c0726d5857980a86660066040518082805460018160011615610100020316600290048015610d975780601f10610d75576101008083540402835291820191610d97565b820191906000526020600020905b815481529060010190602001808311610d83575b50509150506040518091039020610dac6116ca565b60408051602080820195909552808201939093526060830191909152306080808401919091528151808403909101815260a0830182528051908401207fe48329057bfd03d55e49b547132e39cffd9c1820ad7b9d4c5307691425d15adf60c08401526001600160a01b038b1660e084015261010083018a90526101208084018a9052825180850390910181526101408401835280519085012061190160f01b6101608501526101628401829052610182808501829052835180860390910181526101a285018085528151918701919091206000918290526101c2860180865281905260ff8b166101e287015261020286018a90526102228601899052935192965090949293909260019261024280840193601f198301929081900390910190855afa158015610edf573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b038116610f3b576040805162461bcd60e51b8152602060048201526011602482015270496e76616c6964207369676e617475726560781b604482015290519081900360640190fd5b6001600160a01b0381166000908152600a602052604090208054600181019091558914610f9f576040805162461bcd60e51b815260206004820152600d60248201526c496e76616c6964206e6f6e636560981b604482015290519081900360640190fd5b87421115610fec576040805162461bcd60e51b8152602060048201526015602482015274151a19481cda59db985d1d5c9948195e1c1a5c9959605a1b604482015290519081900360640190fd5b610ff6818b611630565b505050505b505050505050565b60006110176110106112da565b85856112de565b836001600160a01b0316638f4ffcb161102e6112da565b8530866040518563ffffffff1660e01b815260040180856001600160a01b03168152602001848152602001836001600160a01b0316815260200180602001828103825283818151815260200191508051906020019080838360005b838110156110a1578181015183820152602001611089565b50505050905090810190601f1680156110ce5780820380516001836020036101000a031916815260200191505b5095505050505050600060405180830381600087803b1580156110f057600080fd5b505af1158015611104573d6000803e3d6000fd5b506001979650505050505050565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b7fe48329057bfd03d55e49b547132e39cffd9c1820ad7b9d4c5307691425d15adf81565b60086020908152600092835260408084209091529082529020805460019091015463ffffffff9091169082565b6111966112da565b6000546001600160a01b039081169116146111f8576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6108a0816116ce565b600080546001600160a01b0319166001600160a01b0392909216919091179055565b600082820183811015610d10576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b6000828211156112d4576040805162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015290519081900360640190fd5b50900390565b3390565b6001600160a01b0383166113235760405162461bcd60e51b8152600401808060200182810382526024815260200180611b246024913960400191505060405180910390fd5b6001600160a01b0382166113685760405162461bcd60e51b8152600401808060200182810382526022815260200180611adc6022913960400191505060405180910390fd5b6001600160a01b03808416600081815260026020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6001600160a01b03831661140f5760405162461bcd60e51b8152600401808060200182810382526025815260200180611b486025913960400191505060405180910390fd5b6001600160a01b0382166114545760405162461bcd60e51b8152600401808060200182810382526023815260200180611b6d6023913960400191505060405180910390fd5b6001600160a01b038316600090815260016020526040902054611477908261127d565b6001600160a01b0380851660009081526001602052604080822093909355908416815220546114a69082611223565b6001600160a01b0380841660008181526001602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a36001600160a01b0380841660009081526007602052604080822054858416835291205461152f9291821691168361176e565b505050565b6001600160a01b0382166115795760405162461bcd60e51b8152600401808060200182810382526021815260200180611b906021913960400191505060405180910390fd5b6001600160a01b03821660009081526001602052604090205461159c908261127d565b6001600160a01b0383166000908152600160205260409020556003546115c2908261127d565b6003556040805182815290516000916001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a36001600160a01b0380831660009081526007602052604081205461162c9216908361176e565b5050565b6001600160a01b03808316600081815260076020818152604080842080546001845282862054949093528787166001600160a01b03198416811790915590519190951694919391928592917f3134e8a2e6d97e929a7e54011ea5485d7d196dd5f0ba4d4ef95803e8e3fc257f9190a46116aa82848361176e565b50505050565b6000600160601b82106116c6575060001961086f565b5090565b4690565b6001600160a01b0381166117135760405162461bcd60e51b8152600401808060200182810382526026815260200180611afe6026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b816001600160a01b0316836001600160a01b0316141580156117905750600081115b1561152f576001600160a01b03831615611822576001600160a01b03831660009081526009602052604081205463ffffffff1690816117d0576000611802565b6001600160a01b038516600090815260086020908152604080832063ffffffff60001987011684529091529020600101545b90506000611810828561127d565b905061181e868484846118a7565b5050505b6001600160a01b0382161561152f576001600160a01b03821660009081526009602052604081205463ffffffff16908161185d57600061188f565b6001600160a01b038416600090815260086020908152604080832063ffffffff60001987011684529091529020600101545b9050600061189d8285611223565b9050610ffb858484845b60006118e8436040518060400160405280602081526020017f54686520626c6f636b206e756d62657220657863656564732033322062697473815250611a29565b905060008463ffffffff1611801561193157506001600160a01b038516600090815260086020908152604080832063ffffffff6000198901811685529252909120548282169116145b1561196e576001600160a01b038516600090815260086020908152604080832063ffffffff600019890116845290915290206001018290556119df565b60408051808201825263ffffffff808416825260208083018681526001600160a01b038a166000818152600884528681208b8616825284528681209551865490861663ffffffff19918216178755925160019687015590815260099092529390208054928801909116919092161790555b604080518481526020810184905281516001600160a01b038816927fdec2bacdd2f05b59de34da9b523dff8be42e5e38e818c82fdb0bae774387a724928290030190a25050505050565b6000816401000000008410611abc5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611a81578181015183820152602001611a69565b50505050905090810190601f168015611aae5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b509192915050565b60408051808201909152600080825260208201529056fe43616e6e6f7420617070726f766520746f20746865207a65726f20616464726573734f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737343616e6e6f7420617070726f76652066726f6d20746865207a65726f206164647265737343616e6e6f74207472616e736665722066726f6d20746865207a65726f206164647265737343616e6e6f74207472616e7366657220746f20746865207a65726f206164647265737343616e6e6f74206275726e2066726f6d20746865207a65726f2061646472657373a2646970667358221220252285f137ecbe3ad1ffabfed5cd17fd64dda57cf128ada077729e8b534f452a64736f6c634300060c00330000000000000000000000006083edf1e49969d810794c85dd0e1d2f93f26eb4

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

0000000000000000000000006083edf1e49969d810794c85dd0e1d2f93f26eb4

-----Decoded View---------------
Arg [0] : account (address): 0x6083edf1e49969d810794c85dd0e1d2f93f26eb4

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 0000000000000000000000006083edf1e49969d810794c85dd0e1d2f93f26eb4


Deployed ByteCode Sourcemap

14493:15881:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17776:94;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;19624:165;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;19624:165:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;17934:102;;;:::i;:::-;;;;;;;;;;;;;;;;15766:122;;;:::i;20674:419::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;20674:419:0;;;;;;;;;;;;;;;;;:::i;17458:94::-;;;:::i;:::-;;;;;;;;;;;;;;;;;;;21554:210;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;21554:210:0;;;;;;;;:::i;22715:124::-;;;;;;;;;;;;;;;;-1:-1:-1;22715:124:0;;:::i;15215:45::-;;;;;;;;;;;;;;;;-1:-1:-1;15215:45:0;-1:-1:-1;;;;;15215:45:0;;:::i;:::-;;;;-1:-1:-1;;;;;15215:45:0;;;;;;;;;;;;;;22987:108;;;;;;;;;;;;;;;;-1:-1:-1;22987:108:0;-1:-1:-1;;;;;22987:108:0;;:::i;:::-;;15644:49;;;;;;;;;;;;;;;;-1:-1:-1;15644:49:0;-1:-1:-1;;;;;15644:49:0;;:::i;:::-;;;;;;;;;;;;;;;;;;;18239:121;;;;;;;;;;;;;;;;-1:-1:-1;18239:121:0;-1:-1:-1;;;;;18239:121:0;;:::i;2769:140::-;;;:::i;25132:1226::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;25132:1226:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;16180:42;;;;;;;;;;;;;;;;-1:-1:-1;16180:42:0;-1:-1:-1;;;;;16180:42:0;;:::i;17298:94::-;;;:::i;2127:79::-;;;:::i;17616:98::-;;;:::i;22233:220::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;22233:220:0;;;;;;;;:::i;18627:169::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;18627:169:0;;;;;;;;:::i;24471:230::-;;;;;;;;;;;;;;;;-1:-1:-1;24471:230:0;-1:-1:-1;;;;;24471:230:0;;:::i;23529:741::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;23529:741:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;20079:279::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;20079:279:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;20079:279:0;;-1:-1:-1;20079:279:0;;-1:-1:-1;;;;;20079:279:0:i;19098:145::-;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;19098:145:0;;;;;;;;;;:::i;15982:117::-;;;:::i;15505:70::-;;;;;;;;;;;;;;;;-1:-1:-1;15505:70:0;;-1:-1:-1;;;;;15505:70:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;3064:109;;;;;;;;;;;;;;;;-1:-1:-1;3064:109:0;-1:-1:-1;;;;;3064:109:0;;:::i;17776:94::-;17857:5;17850:12;;;;;;;;-1:-1:-1;;17850:12:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17824:13;;17850:12;;17857:5;;17850:12;;17857:5;17850:12;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17776:94;:::o;19624:165::-;19703:4;19720:39;19729:12;:10;:12::i;:::-;19743:7;19752:6;19720:8;:39::i;:::-;-1:-1:-1;19777:4:0;19624:165;;;;;:::o;17934:102::-;18016:12;;17934:102;:::o;15766:122::-;15808:80;15766:122;:::o;20674:419::-;20774:4;20791:36;20801:6;20809:9;20820:6;20791:9;:36::i;:::-;20838:15;20856:12;:10;:12::i;:::-;-1:-1:-1;;;;;20906:19:0;;;20879:24;20906:19;;;:11;:19;;;;;;;;:28;;;;;;;;;;20838:30;;-1:-1:-1;;;20949:31:0;;20945:119;;20997:55;21006:6;21014:7;21023:28;:16;21044:6;21023:20;:28::i;:::-;20997:8;:55::i;:::-;-1:-1:-1;21081:4:0;;20674:419;-1:-1:-1;;;;;20674:419:0:o;17458:94::-;17535:9;;;;17458:94;:::o;21554:210::-;21634:4;21651:83;21660:12;:10;:12::i;:::-;21674:7;21683:50;21722:10;21683:11;:25;21695:12;:10;:12::i;:::-;-1:-1:-1;;;;;21683:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;21683:25:0;;;:34;;;;;;;;;;;:38;:50::i;22715:124::-;22765:4;22782:27;22788:12;:10;:12::i;:::-;22802:6;22782:5;:27::i;:::-;-1:-1:-1;22827:4:0;22715:124;;;;:::o;15215:45::-;;;;;;;;;;;;-1:-1:-1;;;;;15215:45:0;;:::o;22987:108::-;23053:34;23063:12;:10;:12::i;:::-;23077:9;23053;:34::i;:::-;22987:108;:::o;15644:49::-;;;;;;;;;;;;;;;:::o;18239:121::-;-1:-1:-1;;;;;18334:18:0;18307:7;18334:18;;;:9;:18;;;;;;;18239:121::o;2769:140::-;2349:12;:10;:12::i;:::-;2339:6;;-1:-1:-1;;;;;2339:6:0;;;:22;;;2331:67;;;;;-1:-1:-1;;;2331:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2868:1:::1;2852:6:::0;;2831:40:::1;::::0;-1:-1:-1;;;;;2852:6:0;;::::1;::::0;2831:40:::1;::::0;2868:1;;2831:40:::1;2899:1;2882:19:::0;;-1:-1:-1;;;;;;2882:19:0::1;::::0;;2769:140::o;25132:1226::-;25216:6;25257:12;25243:11;:26;25235:57;;;;;-1:-1:-1;;;25235:57:0;;;;;;;;;;;;-1:-1:-1;;;25235:57:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;25327:23:0;;25305:19;25327:23;;;:14;:23;;;;;;;;25365:17;25361:58;;25406:1;25399:8;;;;;25361:58;-1:-1:-1;;;;;25479:20:0;;;;;;:11;:20;;;;;;;;:38;-1:-1:-1;;25500:16:0;;25479:38;;;;;;;;;:48;;:63;-1:-1:-1;25475:155:0;;-1:-1:-1;;;;;25573:20:0;;;;;;:11;:20;;;;;;;;:38;-1:-1:-1;;25594:16:0;;25573:38;;;;;;;;25609:1;25573:44;;25566:52;;:6;:52::i;:::-;25559:59;;;;;25475:155;-1:-1:-1;;;;;25691:20:0;;;;;;:11;:20;;;;;;;;:23;;;;;;;;:33;:23;:33;:47;-1:-1:-1;25687:88:0;;;25762:1;25755:8;;;;;25687:88;25787:12;-1:-1:-1;;25829:16:0;;25856:436;25871:5;25863:13;;:5;:13;;;25856:436;;;25935:1;25918:13;;;25917:19;;;25909:27;;25978:20;;:::i;:::-;-1:-1:-1;;;;;;26001:20:0;;;;;;:11;:20;;;;;;;;:28;;;;;;;;;;;;;25978:51;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26048:27;;26044:237;;;26103:16;26110:2;:8;;;26103:6;:16::i;:::-;26096:23;;;;;;;;;26044:237;26145:12;;:26;;;-1:-1:-1;26141:140:0;;;26200:6;26192:14;;26141:140;;;26264:1;26255:6;:10;26247:18;;26141:140;25856:436;;;;;-1:-1:-1;;;;;26316:20:0;;;;;;:11;:20;;;;;;;;:27;;;;;;;;;;:33;;;26309:41;;:6;:41::i;:::-;26302:48;25132:1226;-1:-1:-1;;;;;;25132:1226:0:o;16180:42::-;;;;;;;;;;;;;:::o;17298:94::-;17350:7;17377;:5;:7::i;:::-;17370:14;;17298:94;:::o;2127:79::-;2165:7;2192:6;-1:-1:-1;;;;;2192:6:0;2127:79;:::o;17616:98::-;17699:7;17692:14;;;;;;;;-1:-1:-1;;17692:14:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;17666:13;;17692:14;;17699:7;;17692:14;;17699:7;17692:14;;;;;;;;;;;;;;;;;;;;;;;;22233:220;22318:4;22335:88;22344:12;:10;:12::i;:::-;22358:7;22367:55;22406:15;22367:11;:25;22379:12;:10;:12::i;:::-;-1:-1:-1;;;;;22367:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;22367:25:0;;;:34;;;;;;;;;;;:38;:55::i;18627:169::-;18707:4;18724:42;18734:12;:10;:12::i;:::-;18748:9;18759:6;18724:9;:42::i;24471:230::-;-1:-1:-1;;;;;24577:23:0;;24536:6;24577:23;;;:14;:23;;;;;;;;24618:16;:75;;24692:1;24618:75;;;-1:-1:-1;;;;;24644:20:0;;;;;;:11;:20;;;;;;;;:38;-1:-1:-1;;24665:16:0;;24644:38;;;;;;;;24680:1;24644:44;;24637:52;;:6;:52::i;:::-;24611:82;24471:230;-1:-1:-1;;;24471:230:0:o;23529:741::-;23655:23;15808:80;23735:5;23719:23;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23744:12;:10;:12::i;:::-;23691:81;;;;;;;;;;;;;;;;;;;;;;;;;23766:4;23691:81;;;;;;;;;;;;;;;;;;;;;;;23681:92;;;;;;16028:71;23815:57;;;;-1:-1:-1;;;;;23815:57:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23805:68;;;;;;-1:-1:-1;;;23911:57:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23901:68;;;;;;;;;-1:-1:-1;24000:26:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23681:92;;-1:-1:-1;23805:68:0;;23901;;-1:-1:-1;;24000:26:0;;;;;;;-1:-1:-1;;24000:26:0;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;24000:26:0;;-1:-1:-1;;24000:26:0;;;-1:-1:-1;;;;;;;24045:23:0;;24037:53;;;;;-1:-1:-1;;;24037:53:0;;;;;;;;;;;;-1:-1:-1;;;24037:53:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;24118:17:0;;;;;;:6;:17;;;;;:19;;;;;;;;24109:28;;24101:54;;;;;-1:-1:-1;;;24101:54:0;;;;;;;;;;;;-1:-1:-1;;;24101:54:0;;;;;;;;;;;;;;;24181:6;24174:3;:13;;24166:47;;;;;-1:-1:-1;;;24166:47:0;;;;;;;;;;;;-1:-1:-1;;;24166:47:0;;;;;;;;;;;;;;;24231:31;24241:9;24252;24231;:31::i;:::-;24224:38;;;;23529:741;;;;;;;:::o;20079:279::-;20171:4;20188:39;20197:12;:10;:12::i;:::-;20211:7;20220:6;20188:8;:39::i;:::-;20261:7;-1:-1:-1;;;;;20238:47:0;;20286:12;:10;:12::i;:::-;20300:6;20316:4;20323;20238:90;;;;;;;;;;;;;-1:-1:-1;;;;;20238:90:0;;;;;;;;;;;-1:-1:-1;;;;;20238:90:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;20346:4:0;;20079:279;-1:-1:-1;;;;;;;20079:279:0:o;19098:145::-;-1:-1:-1;;;;;19208:18:0;;;19181:7;19208:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;19098:145::o;15982:117::-;16028:71;15982:117;:::o;15505:70::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;3064:109::-;2349:12;:10;:12::i;:::-;2339:6;;-1:-1:-1;;;;;2339:6:0;;;:22;;;2331:67;;;;;-1:-1:-1;;;2331:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3137:28:::1;3156:8;3137:18;:28::i;1956:90::-:0;2020:6;:18;;-1:-1:-1;;;;;;2020:18:0;-1:-1:-1;;;;;2020:18:0;;;;;;;;;;1956:90::o;6318:179::-;6376:7;6408:5;;;6432:6;;;;6424:46;;;;;-1:-1:-1;;;6424:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;6780:158;6838:7;6871:1;6866;:6;;6858:49;;;;;-1:-1:-1;;;6858:49:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;6925:5:0;;;6780:158::o;642:106::-;730:10;642:106;:::o;26879:338::-;-1:-1:-1;;;;;26973:19:0;;26965:68;;;;-1:-1:-1;;;26965:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;27052:21:0;;27044:68;;;;-1:-1:-1;;;27044:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;27125:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;27177:32;;;;;;;;;;;;;;;;;26879:338;;;:::o;26366:505::-;-1:-1:-1;;;;;26464:20:0;;26456:70;;;;-1:-1:-1;;;26456:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;26545:23:0;;26537:71;;;;-1:-1:-1;;;26537:71:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;26641:17:0;;;;;;:9;:17;;;;;;:29;;26663:6;26641:21;:29::i;:::-;-1:-1:-1;;;;;26621:17:0;;;;;;;:9;:17;;;;;;:49;;;;26704:20;;;;;;;:32;;26729:6;26704:24;:32::i;:::-;-1:-1:-1;;;;;26681:20:0;;;;;;;:9;:20;;;;;;;;;:55;;;;26752:35;;;;;;;26681:20;;26752:35;;;;;;;;;;;;;-1:-1:-1;;;;;26815:17:0;;;;;;;:9;:17;;;;;;;26834:20;;;;;;;;26800:63;;26815:17;;;;26834:20;26856:6;26800:14;:63::i;:::-;26366:505;;;:::o;27225:377::-;-1:-1:-1;;;;;27301:21:0;;27293:67;;;;-1:-1:-1;;;27293:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;27394:18:0;;;;;;:9;:18;;;;;;:30;;27417:6;27394:22;:30::i;:::-;-1:-1:-1;;;;;27373:18:0;;;;;;:9;:18;;;;;:51;27450:12;;:24;;27467:6;27450:16;:24::i;:::-;27435:12;:39;27490:37;;;;;;;;27516:1;;-1:-1:-1;;;;;27490:37:0;;;;;;;;;;;;-1:-1:-1;;;;;27555:18:0;;;;;;;:9;:18;;;;;;27540:54;;27555:18;;27587:6;27540:14;:54::i;:::-;27225:377;;:::o;27993:::-;-1:-1:-1;;;;;28096:20:0;;;28070:23;28096:20;;;:9;:20;;;;;;;;;;;28154;;;;;;28185;;;;:32;;;-1:-1:-1;;;;;;28185:32:0;;;;;;;28235:54;;28096:20;;;;;28154;;28185:32;;28096:20;;;28235:54;;28070:23;28235:54;28302:60;28317:15;28334:9;28345:16;28302:14;:60::i;:::-;27993:377;;;;:::o;30044:163::-;30094:6;-1:-1:-1;;;30117:1:0;:10;30113:60;;-1:-1:-1;;;30144:17:0;;30113:60;-1:-1:-1;30197:1:0;30044:163::o;30215:156::-;30328:9;30215:156;:::o;3279:229::-;-1:-1:-1;;;;;3353:22:0;;3345:73;;;;-1:-1:-1;;;3345:73:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3455:6;;;3434:38;;-1:-1:-1;;;;;3434:38:0;;;;3455:6;;;3434:38;;;3483:6;:17;;-1:-1:-1;;;;;;3483:17:0;-1:-1:-1;;;;;3483:17:0;;;;;;;;;;3279:229::o;28378:851::-;28484:6;-1:-1:-1;;;;;28474:16:0;:6;-1:-1:-1;;;;;28474:16:0;;;:30;;;;;28503:1;28494:6;:10;28474:30;28470:752;;;-1:-1:-1;;;;;28525:20:0;;;28521:337;;-1:-1:-1;;;;;28585:22:0;;28566:16;28585:22;;;:14;:22;;;;;;;;;28646:13;:60;;28705:1;28646:60;;;-1:-1:-1;;;;;28662:19:0;;;;;;:11;:19;;;;;;;;:34;-1:-1:-1;;28682:13:0;;28662:34;;;;;;;;28694:1;28662:40;;28646:60;28626:80;-1:-1:-1;28725:17:0;28745:21;28626:80;28759:6;28745:13;:21::i;:::-;28725:41;;28785:57;28802:6;28810:9;28821;28832;28785:16;:57::i;:::-;28521:337;;;;-1:-1:-1;;;;;28878:20:0;;;28874:337;;-1:-1:-1;;;;;28938:22:0;;28919:16;28938:22;;;:14;:22;;;;;;;;;28999:13;:60;;29058:1;28999:60;;;-1:-1:-1;;;;;29015:19:0;;;;;;:11;:19;;;;;;;;:34;-1:-1:-1;;29035:13:0;;29015:34;;;;;;;;29047:1;29015:40;;28999:60;28979:80;-1:-1:-1;29078:17:0;29098:21;28979:80;29112:6;29098:13;:21::i;:::-;29078:41;;29138:57;29155:6;29163:9;29174;29185;29237:627;29359:18;29380:56;29387:12;29380:56;;;;;;;;;;;;;;;;;:6;:56::i;:::-;29359:77;;29468:1;29453:12;:16;;;:85;;;;-1:-1:-1;;;;;;29473:22:0;;;;;;:11;:22;;;;;;;;:65;-1:-1:-1;;29496:16:0;;29473:40;;;;;;;;;:50;:65;;;:50;;:65;29453:85;29449:339;;;-1:-1:-1;;;;;29555:22:0;;;;;;:11;:22;;;;;;;;:40;-1:-1:-1;;29578:16:0;;29555:40;;;;;;;;29593:1;29555:46;:57;;;29449:339;;;29684:33;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;29645:22:0;;-1:-1:-1;29645:22:0;;;:11;:22;;;;;:36;;;;;;;;;;:72;;;;;;;-1:-1:-1;;29645:72:0;;;;;;;;;;;;;29732:25;;;:14;:25;;;;;;:44;;29760:16;;;29732:44;;;;;;;;;;29449:339;29805:51;;;;;;;;;;;;;;-1:-1:-1;;;;;29805:51:0;;;;;;;;;;;29237:627;;;;;:::o;29872:164::-;29950:6;29988:12;29981:5;29977:9;;29969:32;;;;-1:-1:-1;;;29969:32:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;30026:1:0;;29872:164;-1:-1:-1;;29872:164:0:o;-1:-1:-1:-;;;;;;;;;;;;;;;;;;;:::o

Swarm Source

ipfs://252285f137ecbe3ad1ffabfed5cd17fd64dda57cf128ada077729e8b534f452a
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
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.