Contract 0x19314Dfa75CfC1E5154f95daFaB217646bdb79AC

 

Contract Overview

Balance:
0 BNB

BNB Value:
$0.00

Token:
 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0x17f81352eda767747b206752dfcfe2d69e6a53080fb22e8cce7a55fd6244bab0Approve132808432021-12-07 20:59:2815 hrs 15 mins ago0x2f0d2aa1eff216f369fcbb22c6dce47d63efc304 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x4091aa3039d211aafc76f195963663ad9303b3bd540b6f6bba57daf974050c82Approve132466592021-12-06 15:00:571 day 21 hrs ago0xe856df1ebad83bd4164c2c0b9d061c2460e60629 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.000274896
0xa19fe0671cfc7ed720a726abca5e78822de7e6476fc324c6608ad399fa5cce6eApprove132441012021-12-06 12:43:391 day 23 hrs ago0x77378845ec7ccccb281174f27c44aff3132e2dfb IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x1a66743fae3766ed69acd3adb802133e8086bec5d6a79da4619eee0b8b89eca6Approve132315062021-12-06 1:55:072 days 10 hrs ago0x8911faec1bd4a845f3a40bf135ece15febaa5675 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0xebdc443f31097a672dba8fc5d24b10cb9622ab6d48f38127178a72e297da701dApprove132159972021-12-05 12:32:322 days 23 hrs ago0x13053c17f8ae53446e4df42b604cde16f3886eb0 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x422640abde47bd711b31baa87c19eef4b760d6d2382d8a5ec636053785499e0cApprove131612052021-12-03 14:25:364 days 21 hrs ago0x89caf8a05225bc30575ed80fd803c8b1708a0502 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.000274896
0x3bac29eb9d07e29ae4219cb3666ceb9b18bb85c71d5f586af921da0ef306efabApprove131467082021-12-03 2:05:205 days 10 hrs ago0x1074f899851887bf1dbececc4dee3bc2e5f98a23 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x9f031a6bc9ac65548a4a0f5cef533396191f19eeff6174cb552fb0f095137447Approve131040092021-12-01 13:15:376 days 22 hrs ago0xaf186945ddf80855cd0c460f14e855fb57157460 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0xe379ceb37456fd0157a512e1e936287c8aa1b616054878d870d86579207c0970Approve131011172021-12-01 10:20:477 days 1 hr ago0xb1b9b4bbe8a92d535f5df2368e7fd2ecfb3a1950 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022841
0x8cb4c38038eac47e02eef47d97c15c24f51949deb4207c830087eb3fb7e1cde1Approve131001162021-12-01 9:23:587 days 2 hrs ago0x0eaa6c42a4dd0ae8f68383a5f4310578574202c2 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0xfaf86a0a98cbb82904b891260cb15ebdd50c5e79562de1dbed38a35b41905830Approve130996432021-12-01 8:54:307 days 3 hrs ago0x5157d5bd17dd52bddd22a51021175fbaec117783 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00013308
0x80a76955adf1d101d80712faf3539c1fe45986048f1cd2261e68e878c98f88d7Approve130995842021-12-01 8:50:397 days 3 hrs ago0x5157d5bd17dd52bddd22a51021175fbaec117783 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x6b80e00d71204cbdb530ec85e473338d8eed98ef4ab452c4bee0f7dd098e426cApprove130989582021-12-01 8:08:407 days 4 hrs ago0xfe432e13a7e476f1989e0eb09cdd47acb85ee73b IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x38043da84857da5e287359aadf6c418e3da482f43f8aa40a3292e5d8a6d8900eApprove130952712021-12-01 4:56:307 days 7 hrs ago0x2601cc5f9dc08a38b22e2ab86f1741dc0c3db1cc IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x7a172597c0d80349364865a8f2ae6d11a9f306dc97b811dc06eec102e597c74eApprove130816942021-11-30 17:10:327 days 19 hrs ago0xd5382e8b5140a8d862ced9dfcba16e1b13cf189a IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x3b5a70e1fb8747cf4a2bbeba5298eaaa87f86a0abf7f880338d8b940dc22c000Approve130770152021-11-30 13:01:377 days 23 hrs ago0x2641e267e154dd0b431a55a4f71843072665d3b2 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0xef00303ed714acbf46f61a5db6034b613a462fcf0f99af4a2243db18fb7c0a84Approve130648402021-11-30 2:04:358 days 10 hrs ago0x74ad0a8c82ddb2093207329cdcff2218b37677d6 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.000274896
0x31d600c6ffe1f715f701ae37baa08ded7f3b5c3b14c142b935fc158dd38aa430Approve130486112021-11-29 11:15:599 days 58 mins ago0x0a01291cee53598d6f389d501ed3aba34acbf283 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x17983b7f9aa6ae59e8d4a32a2eb8ac05137b6b80940e8b48942cae2d3f63b0d7Approve130470952021-11-29 9:48:529 days 2 hrs ago0xa8f6543a45c2c8fcacc63a1e1155c43cd61f2dd2 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0xd9789a963bafef3decd4e724e0b4ca7f860a5b1c53220a9fec531b9d0a401190Approve130432092021-11-29 6:09:569 days 6 hrs ago0x7413be29f8cfe0d879e792f346b5107b9683026c IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x0709b1b6d24b2d3eaab50e963b24626bba683c8397ffdc8d4621ace8a1bfadedApprove130412662021-11-29 4:24:049 days 7 hrs ago0xa4aff77b67002a904fa8714095614708b2dd6b64 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.000320712
0x9efa121d15e44e9360afcb5dc2f5bb79137cd42507eea16dfb8e79496bbc4583Approve130360702021-11-28 23:40:249 days 12 hrs ago0x17cb7aed898d3ff796a114e80c195ad4f43c060a IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x9678e53c3cd7a1fa69cc834c9f02070b0e2fbbc7abdb0cb03dd97fd37d09a540Approve130350942021-11-28 22:48:239 days 13 hrs ago0x81cb1d6ece6cb4a0451176d26eef07c0e4744b95 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.000274896
0x3adb75065900494af747c87559353e2cbe2a697fec2384503d9aa25581e64e51Approve130349802021-11-28 22:42:149 days 13 hrs ago0xcd4e87766ff6bc9fbe578c796c74cd37373e6c14 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
0x96d6a83f8239474e15f8b98a06569195bd5aea7f76ee742925c2837771f3a5d5Approve130349532021-11-28 22:40:539 days 13 hrs ago0xb53550658466a899c574d5b0651e1f16841b98c1 IN  0x19314dfa75cfc1e5154f95dafab217646bdb79ac0 BNB0.00022908
[ Download CSV Export 
Parent Txn Hash Block From To Value
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
CompBSC

Compiler Version
v0.5.16+commit.9c3226ce

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion

Contract Source Code (Solidity Standard Json-Input format)

File 1 of 1 : CompBSC.sol
pragma solidity ^0.5.16;
pragma experimental ABIEncoderV2;

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

/*
 * @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.
 */
contract Context {
  // Empty internal constructor, to prevent people from mistakenly deploying
  // an instance of this contract, which should be used via inheritance.
  constructor () internal { }

  function _msgSender() internal view returns (address payable) {
    return msg.sender;
  }

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

/**
 * @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, 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) {
    return sub(a, b, "SafeMath: subtraction overflow");
  }

  /**
   * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
   * overflow (when the result is negative).
   *
   * 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);
    uint256 c = a - b;

    return c;
  }

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

    uint256 c = a * b;
    require(c / a == b, "SafeMath: multiplication overflow");

    return c;
  }

  /**
   * @dev Returns the integer division of two unsigned integers. Reverts 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) {
    return div(a, b, "SafeMath: division by zero");
  }

  /**
   * @dev Returns the integer division of two unsigned integers. Reverts with custom message 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, string memory errorMessage) internal pure returns (uint256) {
    // Solidity only automatically asserts when dividing by 0
    require(b > 0, errorMessage);
    uint256 c = a / b;
    // assert(a == b * c + a % b); // There is no case in which this doesn't hold

    return c;
  }

  /**
   * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
   * Reverts 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) {
    return mod(a, b, "SafeMath: modulo by zero");
  }

  /**
   * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
   * Reverts with custom message 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, string memory errorMessage) internal pure returns (uint256) {
    require(b != 0, errorMessage);
    return a % b;
  }
}

/**
 * @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 () internal {
    address msgSender = _msgSender();
    _owner = msgSender;
    emit OwnershipTransferred(address(0), msgSender);
  }

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

contract CompBSC is Context, IBEP20, Ownable {
    using SafeMath for uint256;

    /// @notice EIP-20 token name for this token
    string public constant _name = "Xolo";

    /// @notice EIP-20 token symbol for this token
    string public constant _symbol = "XOLO";

    /// @notice EIP-20 token decimals for this token
    uint8 public constant _decimals = 18;

    /// @notice Total number of tokens in circulation
    uint public _totalSupply = 0;

    uint256 public _cap = 120000000e18;

    /// @notice Allowance amounts on behalf of others
    mapping (address => mapping (address => uint96)) internal allowances;

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

    /// @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;
        uint96 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 => uint) 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, uint previousBalance, uint newBalance);

    /**
     * @notice Construct a new Comp token
     * @param account The initial account to grant all the tokens
     */
    constructor(address account) public {
        _balances[account] = uint96(_totalSupply);
        emit Transfer(address(0), account, _totalSupply);
    }

    /**
   * @dev Returns the cap on the token's total supply.
   */
    function cap() public view returns (uint256) {
        return _cap;
    }

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

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

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

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

    /**
    * @dev See {BEP20-totalSupply}.
    */
    function totalSupply() external view 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(uint256 rawAmount) public onlyOwner returns (bool) {
        require(_msgSender() != address(0), "BEP20: mint to the zero address");
        require(_totalSupply.add(rawAmount) <= cap(), "Cannot mint more than cap");

        uint96 amount = safe96(rawAmount, "Comp::mint: amount exceeds 96 bits");

        _totalSupply = _totalSupply.add(amount);
        _balances[_msgSender()] = add96(_balances[_msgSender()], amount, "BEP20: mint amount exceeds capped");
        emit Transfer(address(0), _msgSender(), amount);
        return true;
    }

    /**
    * @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(uint256 rawAmount) public onlyOwner returns (bool) {
        require(_msgSender() != address(0), "BEP20: burn from the zero address");

        uint96 amount = safe96(rawAmount, "Comp::burn: amount exceeds 96 bits");

        _balances[_msgSender()] = sub96(_balances[_msgSender()], amount, "BEP20: burn amount exceeds balance");
        _totalSupply = _totalSupply.sub(amount);
        emit Transfer(_msgSender(), address(0), amount);
        return true;
    }

    /**
     * @notice Get the number of tokens `spender` is approved to spend on behalf of `account`
     * @param account 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 account, address spender) external view returns (uint) {
        return allowances[account][spender];
    }

    /**
     * @notice Approve `spender` to transfer up to `amount` from `src`
     * @dev This will overwrite the approval amount for `spender`
     *  and is subject to issues noted [here](https://eips.ethereum.org/EIPS/eip-20#approve)
     * @param spender The address of the account which may transfer tokens
     * @param rawAmount The number of tokens that are approved (2^256-1 means infinite)
     * @return Whether or not the approval succeeded
     */
    function approve(address spender, uint rawAmount) external returns (bool) {
        uint96 amount;
        if (rawAmount == uint(-1)) {
            amount = uint96(-1);
        } else {
            amount = safe96(rawAmount, "Comp::approve: amount exceeds 96 bits");
        }

        allowances[msg.sender][spender] = amount;

        emit Approval(msg.sender, spender, amount);
        return true;
    }

    /**
     * @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) external view returns (uint) {
        return _balances[account];
    }

    /**
     * @notice Transfer `amount` tokens from `msg.sender` to `dst`
     * @param dst The address of the destination account
     * @param rawAmount The number of tokens to transfer
     * @return Whether or not the transfer succeeded
     */
    function transfer(address dst, uint rawAmount) external returns (bool) {
        uint96 amount = safe96(rawAmount, "Comp::transfer: amount exceeds 96 bits");
        _transferTokens(msg.sender, dst, amount);
        return true;
    }

    /**
     * @notice Transfer `amount` tokens from `src` to `dst`
     * @param src The address of the source account
     * @param dst The address of the destination account
     * @param rawAmount The number of tokens to transfer
     * @return Whether or not the transfer succeeded
     */
    function transferFrom(address src, address dst, uint rawAmount) external returns (bool) {
        address spender = msg.sender;
        uint96 spenderAllowance = allowances[src][spender];
        uint96 amount = safe96(rawAmount, "Comp::approve: amount exceeds 96 bits");

        if (spender != src && spenderAllowance != uint96(-1)) {
            uint96 newAllowance = sub96(spenderAllowance, amount, "Comp::transferFrom: transfer amount exceeds spender allowance");
            allowances[src][spender] = newAllowance;

            emit Approval(src, spender, newAllowance);
        }

        _transferTokens(src, dst, amount);
        return true;
    }

    /**
     * @notice Delegate votes from `msg.sender` to `delegatee`
     * @param delegatee The address to delegate votes to
     */
    function delegate(address delegatee) public {
        return _delegate(msg.sender, 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, uint nonce, uint expiry, uint8 v, bytes32 r, bytes32 s) public {
        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), "Comp::delegateBySig: invalid signature");
        require(nonce == nonces[signatory]++, "Comp::delegateBySig: invalid nonce");
        require(now <= expiry, "Comp::delegateBySig: 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 ? 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, uint blockNumber) public view returns (uint96) {
        require(blockNumber < block.number, "Comp::getPriorVotes: not yet determined");

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

        // First check most recent balance
        if (checkpoints[account][nCheckpoints - 1].fromBlock <= blockNumber) {
            return 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 cp.votes;
            } else if (cp.fromBlock < blockNumber) {
                lower = center;
            } else {
                upper = center - 1;
            }
        }
        return checkpoints[account][lower].votes;
    }

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

        emit DelegateChanged(delegator, currentDelegate, delegatee);

        _moveDelegates(currentDelegate, delegatee, delegatorBalance);
    }

    function _transferTokens(address src, address dst, uint96 amount) internal {
        require(src != address(0), "Comp::_transferTokens: cannot transfer from the zero address");
        require(dst != address(0), "Comp::_transferTokens: cannot transfer to the zero address");

        _balances[src] = sub96(_balances[src], amount, "Comp::_transferTokens: transfer amount exceeds balance");
        _balances[dst] = add96(_balances[dst], amount, "Comp::_transferTokens: transfer amount overflows");
        emit Transfer(src, dst, amount);

        _moveDelegates(delegates[src], delegates[dst], amount);
    }

    function _moveDelegates(address srcRep, address dstRep, uint96 amount) internal {
        if (srcRep != dstRep && amount > 0) {
            if (srcRep != address(0)) {
                uint32 srcRepNum = numCheckpoints[srcRep];
                uint96 srcRepOld = srcRepNum > 0 ? checkpoints[srcRep][srcRepNum - 1].votes : 0;
                uint96 srcRepNew = sub96(srcRepOld, amount, "Comp::_moveVotes: vote amount underflows");
                _writeCheckpoint(srcRep, srcRepNum, srcRepOld, srcRepNew);
            }

            if (dstRep != address(0)) {
                uint32 dstRepNum = numCheckpoints[dstRep];
                uint96 dstRepOld = dstRepNum > 0 ? checkpoints[dstRep][dstRepNum - 1].votes : 0;
                uint96 dstRepNew = add96(dstRepOld, amount, "Comp::_moveVotes: vote amount overflows");
                _writeCheckpoint(dstRep, dstRepNum, dstRepOld, dstRepNew);
            }
        }
    }

    function _writeCheckpoint(address delegatee, uint32 nCheckpoints, uint96 oldVotes, uint96 newVotes) internal {
      uint32 blockNumber = safe32(block.number, "Comp::_writeCheckpoint: 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(uint n, string memory errorMessage) internal pure returns (uint32) {
        require(n < 2**32, errorMessage);
        return uint32(n);
    }

    function safe96(uint n, string memory errorMessage) internal pure returns (uint96) {
        require(n < 2**96, errorMessage);
        return uint96(n);
    }

    function add96(uint96 a, uint96 b, string memory errorMessage) internal pure returns (uint96) {
        uint96 c = a + b;
        require(c >= a, errorMessage);
        return c;
    }

    function sub96(uint96 a, uint96 b, string memory errorMessage) internal pure returns (uint96) {
        require(b <= a, errorMessage);
        return a - b;
    }

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

Settings
{
  "remappings": [],
  "optimizer": {
    "enabled": true,
    "runs": 200
  },
  "evmVersion": "istanbul",
  "libraries": {},
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "abi"
      ]
    }
  }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"account","type":"address"}],"payable":false,"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":"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":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"constant":true,"inputs":[],"name":"DELEGATION_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"DOMAIN_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"_cap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"_decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"_name","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"_symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"_totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"rawAmount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"rawAmount","type":"uint256"}],"name":"burn","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"cap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint32","name":"","type":"uint32"}],"name":"checkpoints","outputs":[{"internalType":"uint32","name":"fromBlock","type":"uint32"},{"internalType":"uint96","name":"votes","type":"uint96"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"delegatee","type":"address"}],"name":"delegate","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"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":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"delegates","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getCurrentVotes","outputs":[{"internalType":"uint96","name":"","type":"uint96"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"getOwner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"blockNumber","type":"uint256"}],"name":"getPriorVotes","outputs":[{"internalType":"uint96","name":"","type":"uint96"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"rawAmount","type":"uint256"}],"name":"mint","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"numCheckpoints","outputs":[{"internalType":"uint32","name":"","type":"uint32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"dst","type":"address"},{"internalType":"uint256","name":"rawAmount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"src","type":"address"},{"internalType":"address","name":"dst","type":"address"},{"internalType":"uint256","name":"rawAmount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"}]

608060405260006001556a6342fd08f00f63780000006002553480156200002557600080fd5b50604051620025ad380380620025ad83398101604081905262000048916200013d565b60006200005d6001600160e01b036200012616565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600180546001600160a01b03831660008181526004602052604080822080546001600160601b0319166001600160601b0390951694909417909355925491519092917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9162000117919062000177565b60405180910390a350620001b6565b3390565b805162000137816200019c565b92915050565b6000602082840312156200015057600080fd5b60006200015e84846200012a565b949350505050565b620001718162000199565b82525050565b6020810162000137828462000166565b60006001600160a01b03821662000137565b90565b620001a78162000187565b8114620001b357600080fd5b50565b6123e780620001c66000396000f3fe608060405234801561001057600080fd5b50600436106101e55760003560e01c8063715018a61161010f578063b09f1266116100a2578063dd62ed3e11610071578063dd62ed3e146103b7578063e7a324dc146103ca578063f1127ed8146103d2578063f2fde38b146103f3576101e5565b8063b09f126614610381578063b4b5ea5714610389578063c3cda5201461039c578063d28d8852146103af576101e5565b80638da5cb5b116100de5780638da5cb5b1461034b57806395d89b4114610353578063a0712d681461035b578063a9059cbb1461036e576101e5565b8063715018a614610308578063782d6fe1146103105780637ecebe0014610330578063893d20e814610343576101e5565b806332424aa311610187578063587cde1e11610156578063587cde1e146102a05780635c19a95c146102c05780636fcfff45146102d557806370a08231146102f5576101e5565b806332424aa314610275578063355274ea1461027d5780633eaaf86b1461028557806342966c681461028d576101e5565b806318160ddd116101c357806318160ddd1461023d57806320606b701461024557806323b872dd1461024d578063313ce56714610260576101e5565b8063060cf4e8146101ea57806306fdde0314610208578063095ea7b31461021d575b600080fd5b6101f2610406565b6040516101ff9190611f15565b60405180910390f35b61021061040c565b6040516101ff9190611fb1565b61023061022b3660046118ed565b61042a565b6040516101ff9190611f07565b6101f26104e9565b6101f26104ef565b61023061025b3660046118a0565b610506565b61026861064f565b6040516101ff91906120ab565b610268610654565b6101f2610659565b6101f261065f565b61023061029b3660046119d4565b610665565b6102b36102ae366004611840565b610801565b6040516101ff9190611ef9565b6102d36102ce366004611840565b61081c565b005b6102e86102e3366004611840565b610829565b6040516101ff9190612082565b6101f2610303366004611840565b610841565b6102d3610865565b61032361031e3660046118ed565b6108e4565b6040516101ff91906120c7565b6101f261033e366004611840565b610af2565b6102b3610b04565b6102b3610b13565b610210610b22565b6102306103693660046119d4565b610b40565b61023061037c3660046118ed565b610d17565b610210610d53565b610323610397366004611840565b610d73565b6102d36103aa36600461191d565b610de3565b610210610fc9565b6101f26103c5366004611866565b610fe9565b6101f261101d565b6103e56103e03660046119a4565b611029565b6040516101ff929190612090565b6102d3610401366004611840565b61105e565b60025481565b604080518082019091526004815263586f6c6f60e01b602082015290565b6000806000198314156104405750600019610465565b610462836040518060600160405280602581526020016122266025913961109c565b90505b3360008181526003602090815260408083206001600160a01b03891680855292529182902080546001600160601b0319166001600160601b03861617905590519091907f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925906104d59085906120b9565b60405180910390a360019150505b92915050565b60015490565b6040516104fb90611ee3565b604051809103902081565b6001600160a01b03831660009081526003602090815260408083203380855290835281842054825160608101909352602580845291936001600160601b0390911692859261055e92889291906122269083013961109c565b9050866001600160a01b0316836001600160a01b03161415801561058b57506001600160601b0382811614155b156106355760006105b583836040518060600160405280603d815260200161231f603d91396110cb565b6001600160a01b038981166000818152600360209081526040808320948a16808452949091529081902080546001600160601b0319166001600160601b0386161790555192935090917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259061062b9085906120b9565b60405180910390a3505b61064087878361110a565b600193505050505b9392505050565b601290565b601281565b60025490565b60015481565b600061066f6112b5565b6000546001600160a01b039081169116146106a55760405162461bcd60e51b815260040161069c90612052565b60405180910390fd5b60006106af6112b5565b6001600160a01b031614156106d65760405162461bcd60e51b815260040161069c90612072565b60006106fa836040518060600160405280602281526020016122fd6022913961109c565b905061075e6004600061070b6112b5565b6001600160a01b03166001600160a01b0316815260200190815260200160002060009054906101000a90046001600160601b031682604051806060016040528060228152602001612383602291396110cb565b6004600061076a6112b5565b6001600160a01b03168152602081019190915260400160002080546001600160601b0319166001600160601b039283161790556001546107ab9183166112b9565b60015560006107b86112b5565b6001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516107f091906120b9565b60405180910390a350600192915050565b6005602052600090815260409020546001600160a01b031681565b61082633826112fb565b50565b60076020526000908152604090205463ffffffff1681565b6001600160a01b03166000908152600460205260409020546001600160601b031690565b61086d6112b5565b6000546001600160a01b0390811691161461089a5760405162461bcd60e51b815260040161069c90612052565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b60004382106109055760405162461bcd60e51b815260040161069c90612002565b6001600160a01b03831660009081526007602052604090205463ffffffff16806109335760009150506104e3565b6001600160a01b038416600090815260066020908152604080832063ffffffff6000198601811685529252909120541683106109af576001600160a01b03841660009081526006602090815260408083206000199490940163ffffffff1683529290522054600160201b90046001600160601b031690506104e3565b6001600160a01b038416600090815260066020908152604080832083805290915290205463ffffffff168310156109ea5760009150506104e3565b600060001982015b8163ffffffff168163ffffffff161115610aad57600282820363ffffffff16048103610a1c6117fd565b506001600160a01b038716600090815260066020908152604080832063ffffffff858116855290835292819020815180830190925254928316808252600160201b9093046001600160601b03169181019190915290871415610a88576020015194506104e39350505050565b805163ffffffff16871115610a9f57819350610aa6565b6001820392505b50506109f2565b506001600160a01b038516600090815260066020908152604080832063ffffffff909416835292905220546001600160601b03600160201b9091041691505092915050565b60086020526000908152604090205481565b6000610b0e610b13565b905090565b6000546001600160a01b031690565b604080518082019091526004815263584f4c4f60e01b602082015290565b6000610b4a6112b5565b6000546001600160a01b03908116911614610b775760405162461bcd60e51b815260040161069c90612052565b6000610b816112b5565b6001600160a01b03161415610ba85760405162461bcd60e51b815260040161069c90612042565b610bb0610659565b600154610bc3908463ffffffff61138516565b1115610be15760405162461bcd60e51b815260040161069c90612022565b6000610c05836040518060600160405280602281526020016121ad6022913961109c565b600154909150610c24906001600160601b03831663ffffffff61138516565b600155610c8960046000610c366112b5565b6001600160a01b03166001600160a01b0316815260200190815260200160002060009054906101000a90046001600160601b0316826040518060600160405280602181526020016121cf602191396113aa565b60046000610c956112b5565b6001600160a01b03168152602081019190915260400160002080546001600160601b0319166001600160601b0392909216919091179055610cd46112b5565b6001600160a01b031660006001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516107f091906120b9565b600080610d3c8360405180606001604052806026815260200161224b6026913961109c565b9050610d4933858361110a565b5060019392505050565b60405180604001604052806004815260200163584f4c4f60e01b81525081565b6001600160a01b03811660009081526007602052604081205463ffffffff1680610d9e576000610648565b6001600160a01b0383166000908152600660209081526040808320600019850163ffffffff168452909152902054600160201b90046001600160601b03169392505050565b6000604051610df190611ee3565b604080519182900382208282019091526004825263586f6c6f60e01b6020909201919091527f112a2c36c5ebda81f6531b2f47b9b976014a8851ddc1e6408d6517d5be4806d2610e3f6113e6565b30604051602001610e539493929190611f61565b6040516020818303038152906040528051906020012090506000604051610e7990611eee565b604051908190038120610e94918a908a908a90602001611f23565b60405160208183030381529060405280519060200120905060008282604051602001610ec1929190611eb2565b604051602081830303815290604052805190602001209050600060018288888860405160008152602001604052604051610efe9493929190611f96565b6020604051602081039080840390855afa158015610f20573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b038116610f535760405162461bcd60e51b815260040161069c90611fd2565b6001600160a01b03811660009081526008602052604090208054600181019091558914610f925760405162461bcd60e51b815260040161069c90612012565b87421115610fb25760405162461bcd60e51b815260040161069c90611fe2565b610fbc818b6112fb565b505050505b505050505050565b60405180604001604052806004815260200163586f6c6f60e01b81525081565b6001600160a01b0391821660009081526003602090815260408083209390941682529190915220546001600160601b031690565b6040516104fb90611eee565b600660209081526000928352604080842090915290825290205463ffffffff811690600160201b90046001600160601b031682565b6110666112b5565b6000546001600160a01b039081169116146110935760405162461bcd60e51b815260040161069c90612052565b610826816113ea565b600081600160601b84106110c35760405162461bcd60e51b815260040161069c9190611fb1565b509192915050565b6000836001600160601b0316836001600160601b0316111582906111025760405162461bcd60e51b815260040161069c9190611fb1565b505050900390565b6001600160a01b0383166111305760405162461bcd60e51b815260040161069c90612062565b6001600160a01b0382166111565760405162461bcd60e51b815260040161069c90612032565b6001600160a01b0383166000908152600460209081526040918290205482516060810190935260368084526111a1936001600160601b0390921692859291906121f0908301396110cb565b6001600160a01b03848116600090815260046020908152604080832080546001600160601b0319166001600160601b0396871617905592861682529082902054825160608101909352603080845261120994919091169285929091906122cd908301396113aa565b6001600160a01b038381166000818152600460205260409081902080546001600160601b0319166001600160601b0395909516949094179093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906112769085906120b9565b60405180910390a36001600160a01b038084166000908152600560205260408082205485841683529120546112b09291821691168361146b565b505050565b3390565b600061064883836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506115fd565b6001600160a01b03808316600081815260056020818152604080842080546004845282862054949093528787166001600160a01b031984168117909155905191909516946001600160601b039092169391928592917f3134e8a2e6d97e929a7e54011ea5485d7d196dd5f0ba4d4ef95803e8e3fc257f9190a461137f82848361146b565b50505050565b6000828201838110156106485760405162461bcd60e51b815260040161069c90611ff2565b6000838301826001600160601b0380871690831610156113dd5760405162461bcd60e51b815260040161069c9190611fb1565b50949350505050565b4690565b6001600160a01b0381166114105760405162461bcd60e51b815260040161069c90611fc2565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b816001600160a01b0316836001600160a01b03161415801561149657506000816001600160601b0316115b156112b0576001600160a01b0383161561154e576001600160a01b03831660009081526007602052604081205463ffffffff1690816114d6576000611515565b6001600160a01b0385166000908152600660209081526040808320600019860163ffffffff168452909152902054600160201b90046001600160601b03165b9050600061153c82856040518060600160405280602881526020016122a5602891396110cb565b905061154a86848484611621565b5050505b6001600160a01b038216156112b0576001600160a01b03821660009081526007602052604081205463ffffffff1690816115895760006115c8565b6001600160a01b0384166000908152600660209081526040808320600019860163ffffffff168452909152902054600160201b90046001600160601b03165b905060006115ef828560405180606001604052806027815260200161235c602791396113aa565b9050610fc185848484611621565b600081848411156111025760405162461bcd60e51b815260040161069c9190611fb1565b600061164543604051806060016040528060348152602001612271603491396117d6565b905060008463ffffffff1611801561168e57506001600160a01b038516600090815260066020908152604080832063ffffffff6000198901811685529252909120548282169116145b156116ed576001600160a01b0385166000908152600660209081526040808320600019880163ffffffff168452909152902080546fffffffffffffffffffffffff000000001916600160201b6001600160601b0385160217905561178c565b60408051808201825263ffffffff80841682526001600160601b0380861660208085019182526001600160a01b038b166000818152600683528781208c871682528352878120965187549451909516600160201b026fffffffffffffffffffffffff000000001995871663ffffffff19958616179590951694909417909555938252600790935292909220805460018801909316929091169190911790555b846001600160a01b03167fdec2bacdd2f05b59de34da9b523dff8be42e5e38e818c82fdb0bae774387a72484846040516117c79291906120d5565b60405180910390a25050505050565b600081600160201b84106110c35760405162461bcd60e51b815260040161069c9190611fb1565b604080518082019091526000808252602082015290565b80356104e38161217d565b80356104e381612191565b80356104e38161219a565b80356104e3816121a3565b60006020828403121561185257600080fd5b600061185e8484611814565b949350505050565b6000806040838503121561187957600080fd5b60006118858585611814565b925050602061189685828601611814565b9150509250929050565b6000806000606084860312156118b557600080fd5b60006118c18686611814565b93505060206118d286828701611814565b92505060406118e38682870161181f565b9150509250925092565b6000806040838503121561190057600080fd5b600061190c8585611814565b92505060206118968582860161181f565b60008060008060008060c0878903121561193657600080fd5b60006119428989611814565b965050602061195389828a0161181f565b955050604061196489828a0161181f565b945050606061197589828a01611835565b935050608061198689828a0161181f565b92505060a061199789828a0161181f565b9150509295509295509295565b600080604083850312156119b757600080fd5b60006119c38585611814565b92505060206118968582860161182a565b6000602082840312156119e657600080fd5b600061185e848461181f565b6119fb81612102565b82525050565b6119fb8161210d565b6119fb81612112565b6119fb611a1f82612112565b612112565b6000611a2f826120f0565b611a3981856120f4565b9350611a49818560208601612147565b611a5281612173565b9093019392505050565b6000611a696026836120f4565b7f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206181526564647265737360d01b602082015260400192915050565b6000611ab16026836120f4565b7f436f6d703a3a64656c656761746542795369673a20696e76616c6964207369678152656e617475726560d01b602082015260400192915050565b6000611af96026836120f4565b7f436f6d703a3a64656c656761746542795369673a207369676e617475726520658152651e1c1a5c995960d21b602082015260400192915050565b6000611b416002836120fd565b61190160f01b815260020192915050565b6000611b5f601b836120f4565b7f536166654d6174683a206164646974696f6e206f766572666c6f770000000000815260200192915050565b6000611b986027836120f4565b7f436f6d703a3a6765745072696f72566f7465733a206e6f742079657420646574815266195c9b5a5b995960ca1b602082015260400192915050565b6000611be16022836120f4565b7f436f6d703a3a64656c656761746542795369673a20696e76616c6964206e6f6e815261636560f01b602082015260400192915050565b6000611c256019836120f4565b7f43616e6e6f74206d696e74206d6f7265207468616e2063617000000000000000815260200192915050565b6000611c5e603a836120f4565b7f436f6d703a3a5f7472616e73666572546f6b656e733a2063616e6e6f7420747281527f616e7366657220746f20746865207a65726f2061646472657373000000000000602082015260400192915050565b6000611cbd6043836120fd565b7f454950373132446f6d61696e28737472696e67206e616d652c75696e7432353681527f20636861696e49642c6164647265737320766572696679696e67436f6e74726160208201526263742960e81b604082015260430192915050565b6000611d28601f836120f4565b7f42455032303a206d696e7420746f20746865207a65726f206164647265737300815260200192915050565b6000611d616020836120f4565b7f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572815260200192915050565b6000611d9a603c836120f4565b7f436f6d703a3a5f7472616e73666572546f6b656e733a2063616e6e6f7420747281527f616e736665722066726f6d20746865207a65726f206164647265737300000000602082015260400192915050565b6000611df96021836120f4565b7f42455032303a206275726e2066726f6d20746865207a65726f206164647265738152607360f81b602082015260400192915050565b6000611e3c603a836120fd565b7f44656c65676174696f6e28616464726573732064656c6567617465652c75696e81527f74323536206e6f6e63652c75696e7432353620657870697279290000000000006020820152603a0192915050565b6119fb81612121565b6119fb8161212a565b6119fb8161213c565b6119fb81612130565b6000611ebd82611b34565b9150611ec98285611a13565b602082019150611ed98284611a13565b5060200192915050565b60006104e382611cb0565b60006104e382611e2f565b602081016104e382846119f2565b602081016104e38284611a01565b602081016104e38284611a0a565b60808101611f318287611a0a565b611f3e60208301866119f2565b611f4b6040830185611a0a565b611f586060830184611a0a565b95945050505050565b60808101611f6f8287611a0a565b611f7c6020830186611a0a565b611f896040830185611a0a565b611f5860608301846119f2565b60808101611fa48287611a0a565b611f3e6020830186611e97565b602080825281016106488184611a24565b602080825281016104e381611a5c565b602080825281016104e381611aa4565b602080825281016104e381611aec565b602080825281016104e381611b52565b602080825281016104e381611b8b565b602080825281016104e381611bd4565b602080825281016104e381611c18565b602080825281016104e381611c51565b602080825281016104e381611d1b565b602080825281016104e381611d54565b602080825281016104e381611d8d565b602080825281016104e381611dec565b602081016104e38284611e8e565b6040810161209e8285611e8e565b6106486020830184611ea9565b602081016104e38284611e97565b602081016104e38284611ea0565b602081016104e38284611ea9565b604081016120e38285611ea0565b6106486020830184611ea0565b5190565b90815260200190565b919050565b60006104e382612115565b151590565b90565b6001600160a01b031690565b63ffffffff1690565b60ff1690565b6001600160601b031690565b60006104e382612130565b60005b8381101561216257818101518382015260200161214a565b8381111561137f5750506000910152565b601f01601f191690565b61218681612102565b811461082657600080fd5b61218681612112565b61218681612121565b6121868161212a56fe436f6d703a3a6d696e743a20616d6f756e742065786365656473203936206269747342455032303a206d696e7420616d6f756e74206578636565647320636170706564436f6d703a3a5f7472616e73666572546f6b656e733a207472616e7366657220616d6f756e7420657863656564732062616c616e6365436f6d703a3a617070726f76653a20616d6f756e7420657863656564732039362062697473436f6d703a3a7472616e736665723a20616d6f756e7420657863656564732039362062697473436f6d703a3a5f7772697465436865636b706f696e743a20626c6f636b206e756d62657220657863656564732033322062697473436f6d703a3a5f6d6f7665566f7465733a20766f746520616d6f756e7420756e646572666c6f7773436f6d703a3a5f7472616e73666572546f6b656e733a207472616e7366657220616d6f756e74206f766572666c6f7773436f6d703a3a6275726e3a20616d6f756e7420657863656564732039362062697473436f6d703a3a7472616e7366657246726f6d3a207472616e7366657220616d6f756e742065786365656473207370656e64657220616c6c6f77616e6365436f6d703a3a5f6d6f7665566f7465733a20766f746520616d6f756e74206f766572666c6f777342455032303a206275726e20616d6f756e7420657863656564732062616c616e6365a365627a7a723158207832c0d9f03b7cd3d40b3c1b0bc854aa547bf269895bd52c2a24a5a8c1ef6bab6c6578706572696d656e74616cf564736f6c634300051000400000000000000000000000001f24d0206e356659f2910ed1facd0756c8568116

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

0000000000000000000000001f24d0206e356659f2910ed1facd0756c8568116

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

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 0000000000000000000000001f24d0206e356659f2910ed1facd0756c8568116


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.