ETH Price: $3,328.40 (+2.97%)
Gas: 3.09 Gwei
 

Overview

Max Total Supply

85,240.829004908703826586 GFI

Holders

69

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
27 GFI

Value
$0.00
0x6400e53111fd4b600814fccdb990c8edd18780c3
Loading...
Loading
Loading...
Loading
Loading...
Loading

OVERVIEW

Gauntlet Finance token contract has migrated to 0xad45320077fc7a0f0a43976ac7dbacc65ad21d8f.

# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
Token

Compiler Version
v0.6.7+commit.b8d736ae

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2020-11-20
*/

pragma solidity 0.6.7;


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


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

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

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

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

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

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

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

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

}


interface IUniswapV2Router01 {
  function factory() external pure returns (address);

  function WETH() external pure returns (address);

  function addLiquidity(
    address tokenA,
    address tokenB,
    uint256 amountADesired,
    uint256 amountBDesired,
    uint256 amountAMin,
    uint256 amountBMin,
    address to,
    uint256 deadline
  )
    external
    returns (
      uint256 amountA,
      uint256 amountB,
      uint256 liquidity
    );

  function addLiquidityETH(
    address token,
    uint256 amountTokenDesired,
    uint256 amountTokenMin,
    uint256 amountETHMin,
    address to,
    uint256 deadline
  )
    external
    payable
    returns (
      uint256 amountToken,
      uint256 amountETH,
      uint256 liquidity
    );

  function removeLiquidity(
    address tokenA,
    address tokenB,
    uint256 liquidity,
    uint256 amountAMin,
    uint256 amountBMin,
    address to,
    uint256 deadline
  ) external returns (uint256 amountA, uint256 amountB);

  function removeLiquidityETH(
    address token,
    uint256 liquidity,
    uint256 amountTokenMin,
    uint256 amountETHMin,
    address to,
    uint256 deadline
  ) external returns (uint256 amountToken, uint256 amountETH);

  function removeLiquidityWithPermit(
    address tokenA,
    address tokenB,
    uint256 liquidity,
    uint256 amountAMin,
    uint256 amountBMin,
    address to,
    uint256 deadline,
    bool approveMax,
    uint8 v,
    bytes32 r,
    bytes32 s
  ) external returns (uint256 amountA, uint256 amountB);

  function removeLiquidityETHWithPermit(
    address token,
    uint256 liquidity,
    uint256 amountTokenMin,
    uint256 amountETHMin,
    address to,
    uint256 deadline,
    bool approveMax,
    uint8 v,
    bytes32 r,
    bytes32 s
  ) external returns (uint256 amountToken, uint256 amountETH);

  function swapExactTokensForTokens(
    uint256 amountIn,
    uint256 amountOutMin,
    address[] calldata path,
    address to,
    uint256 deadline
  ) external returns (uint256[] memory amounts);

  function swapTokensForExactTokens(
    uint256 amountOut,
    uint256 amountInMax,
    address[] calldata path,
    address to,
    uint256 deadline
  ) external returns (uint256[] memory amounts);

  function swapExactETHForTokens(
    uint256 amountOutMin,
    address[] calldata path,
    address to,
    uint256 deadline
  ) external payable returns (uint256[] memory amounts);

  function swapTokensForExactETH(
    uint256 amountOut,
    uint256 amountInMax,
    address[] calldata path,
    address to,
    uint256 deadline
  ) external returns (uint256[] memory amounts);

  function swapExactTokensForETH(
    uint256 amountIn,
    uint256 amountOutMin,
    address[] calldata path,
    address to,
    uint256 deadline
  ) external returns (uint256[] memory amounts);

  function swapETHForExactTokens(
    uint256 amountOut,
    address[] calldata path,
    address to,
    uint256 deadline
  ) external payable returns (uint256[] memory amounts);

  function quote(
    uint256 amountA,
    uint256 reserveA,
    uint256 reserveB
  ) external pure returns (uint256 amountB);

  function getAmountOut(
    uint256 amountIn,
    uint256 reserveIn,
    uint256 reserveOut
  ) external pure returns (uint256 amountOut);

  function getAmountIn(
    uint256 amountOut,
    uint256 reserveIn,
    uint256 reserveOut
  ) external pure returns (uint256 amountIn);

  function getAmountsOut(uint256 amountIn, address[] calldata path)
    external
    view
    returns (uint256[] memory amounts);

  function getAmountsIn(uint256 amountOut, address[] calldata path)
    external
    view
    returns (uint256[] memory amounts);
}


interface IUniswapV2Router02 is IUniswapV2Router01 {
  function removeLiquidityETHSupportingFeeOnTransferTokens(
    address token,
    uint256 liquidity,
    uint256 amountTokenMin,
    uint256 amountETHMin,
    address to,
    uint256 deadline
  ) external returns (uint256 amountETH);

  function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
    address token,
    uint256 liquidity,
    uint256 amountTokenMin,
    uint256 amountETHMin,
    address to,
    uint256 deadline,
    bool approveMax,
    uint8 v,
    bytes32 r,
    bytes32 s
  ) external returns (uint256 amountETH);

  function swapExactTokensForTokensSupportingFeeOnTransferTokens(
    uint256 amountIn,
    uint256 amountOutMin,
    address[] calldata path,
    address to,
    uint256 deadline
  ) external;

  function swapExactETHForTokensSupportingFeeOnTransferTokens(
    uint256 amountOutMin,
    address[] calldata path,
    address to,
    uint256 deadline
  ) external payable;

  function swapExactTokensForETHSupportingFeeOnTransferTokens(
    uint256 amountIn,
    uint256 amountOutMin,
    address[] calldata path,
    address to,
    uint256 deadline
  ) external;
}


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


contract ERC20 is IERC20 {
  using SafeMath for uint256;

  mapping(address => uint256) private _balances;

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

  uint256 private _totalSupply;

  string private _name;
  string private _symbol;
  uint8 private _decimals;

  /**
   * @dev Sets the values for {name} and {symbol}, initializes {decimals} with
   * a default value of 18.
   *
   * To select a different value for {decimals}, use {_setupDecimals}.
   *
   * All three of these values are immutable: they can only be set once during
   * construction.
   */
  constructor(string memory name, string memory symbol) public {
    _name = name;
    _symbol = symbol;
    _decimals = 18;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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 virtual 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 virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}


contract Token is IERC20, Ownable {
    using SafeMath for uint256;
    
    
    struct Challenger {
        uint256 acceptance;
        uint256 challenge;
    }
    
    uint256 private constant _BASE = 1 * _DECIMALFACTOR;
    uint32  private constant _TERM = 5 minutes;
    
    uint256 private _prizes;
    uint256 private _challenges;
    
    mapping (address => Challenger) private _challengers;
    
    string  private constant _NAME = "Gauntlet Finance";
    string  private constant _SYMBOL = "GFI";
    uint8   private constant _DECIMALS = 18;
    
    uint256 private constant _DECIMALFACTOR = 10 ** uint256(_DECIMALS);
    
    uint8   private constant _DENOMINATOR = 100;
    uint8   private constant _PRECISION   = 100;

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

    uint256 private immutable _rate;
    uint8   private immutable _penalty;
    uint256 private immutable _requirement;
    
    uint256 private immutable _initialSupply;

    uint256 private _contributors;

    bool    private _paused;
    address private _TDE;
    

    event Penalized(
        address indexed account,
        uint256 amount);
    
    event Boosted(
        address indexed account,
        uint256 amount);
    
    event Deflated(
        uint256 supply,
        uint256 amount);
    
    event Recovered(
        uint256 supply,
        uint256 amount);
    
    event Added(
        address indexed account,
        uint256 time);
        
    event Removed(
        address indexed account,
        uint256 time);
    
    event Accepted(
        address indexed account,
        uint256 amount);

    event Rewarded(
        address indexed account,
        uint256 amount);
    
    event Forfeited(
        address indexed account,
        uint256 amount);
        
    event Unpaused(
        address indexed account,
        uint256 time); 
    
    
    constructor (
        uint256 rate, 
        uint8   penalty,
        uint256 requirement) 
        public {
            
        require(rate > 0, 
        "error: must be larger than zero");
        require(penalty > 0, 
        "error: must be larger than zero");
        require(requirement > 0, 
        "error: must be larger than zero");
            
        _rate = rate;
        _penalty = penalty;
        _requirement = requirement;
        
        uint256 prizes = 10000 * _DECIMALFACTOR;
        uint256 capacity = 25000 * _DECIMALFACTOR;
        uint256 operations = 65000 * _DECIMALFACTOR;

        _mint(_environment(), prizes.add(capacity));
        _mint(_msgSender(), operations);
        
        _prizes = prizes;
        _initialSupply = prizes.add(capacity).add(operations);
        
        _paused = true;
    }
    

    function setTokenDistributionEvent(address TDE) external onlyOwner returns (bool) {
        require(TDE != address(0), 
        "error: must not be the zero address");
        
        require(_TDE == address(0), 
        "error: must not be set already");
    
        _TDE = TDE;
        return true;
    }
    function unpause() external returns (bool) {
        address account = _msgSender();
        
        require(account == owner() || account == _TDE, 
        "error: must be owner or must be token distribution event");

        _paused = false;
        
        emit Unpaused(account, _time());
        return true;
    }
    
    function reward() external returns (bool) {
        uint256 prizes = getPrizesTotal();
        
        require(prizes > 0, 
        "error: must be prizes available");
        
        address account = _msgSender();
        
        require(getReward(account) > 0, 
        "error: must be worthy of a reward");
        
        uint256 amount = getReward(account);
        
        if (_isExcessive(amount, prizes)) {
            
            uint256 excess = amount.sub(prizes);
            amount = amount.sub(excess);
            
            _challengers[account].acceptance = _time();
            _prizes = _prizes.sub(amount);
            _mint(account, amount);
            emit Rewarded(account, amount);
            
        } else {
            _challengers[account].acceptance = _time();
            _prizes = _prizes.sub(amount);
            _mint(account, amount);
            emit Rewarded(account, amount);
        }
        return true;
    }
    function challenge(uint256 amount) external returns (bool) {
        address account = _msgSender();
        uint256 processed = amount.mul(_DECIMALFACTOR);
        
        require(_isEligible(account, processed), 
        "error: must have sufficient holdings");
        
        require(_isContributor(account), 
        "error: must be a contributor");
        
        require(_isAcceptable(processed), 
        "error: must comply with requirement");
        
        _challengers[account].acceptance = _time();
        _challengers[account].challenge = processed;
        
        _challenges = _challenges.add(processed);
        
        emit Accepted(account, processed);
        return true;
    }
    
    function getTerm() public pure returns (uint256) {
        return _TERM;
    }
    function getBase() public pure returns (uint256) {
        return _BASE;
    }
    
    function getAcceptance(address account) public view returns (uint256) {
        return _challengers[account].acceptance;
    }
    function getPeriod(address account) public view returns (uint256) {
        if (getAcceptance(account) > 0) {
            
            uint256 period = _time().sub(_challengers[account].acceptance);
            uint256 term = getTerm();
            
            if (period >= term) {
                return period.div(term);
            } else {
                return 0;
            }
            
        } else { 
            return 0;
        }
    }
    
    function getChallenge(address account) public view returns (uint256) {
        return _challengers[account].challenge;
    }
    function getFerocity(address account) public view returns (uint256) {
        return (getChallenge(account).mul(_PRECISION)).div(getRequirement());
    }
    function getReward(address account) public view returns (uint256) {
       return _getBlock(account).mul((_BASE.mul(getFerocity(account))).div(_PRECISION));
    } 
    
    function getPrizesTotal() public view returns (uint256) {
        return _prizes;
    }
    function getChallengesTotal() public view returns (uint256) {
        return _challenges;
    }   
    
    function getRate() public view returns (uint256) {
        return _rate;
    }
    function getPenalty() public view returns (uint8) {
        return _penalty;
    }
    function getRequirement() public view returns (uint256) {
        return _requirement;
    }

    function getCapacity() public view returns (uint256) {
        return balanceOf(_environment()).sub(getPrizesTotal());
    }
    
    function getContributorsTotal() public view returns (uint256) {
        return _contributors;
    }
    function getContributorsLimit() public view returns (uint256) {
        return getCapacity().div(getRate());
    }

    function name() public pure returns (string memory) {
        return _NAME;
    }
    function symbol() public pure returns (string memory) {
        return _SYMBOL;
    }
    function decimals() public pure returns (uint8) {
        return _DECIMALS;
    }

    function totalSupply() public view override returns (uint256) {
        return _totalSupply;
    }
    function initialSupply() public view returns (uint256) {
        return _initialSupply;
    }
    
    function balanceOf(address account) public view override returns (uint256) {
        return _balances[account];
    }

    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        address sender = _msgSender();

        require(_isNotPaused() || recipient == _TDE || sender == _TDE, 
        "error: must not be paused else must be token distribution event recipient or sender");

        _checkReactiveness(sender, recipient, amount);
        _checkChallenger(sender, amount);
        
        _transfer(sender, recipient, amount);

        return true;
    }
    function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {
        require(_isNotPaused() || recipient == _TDE || sender == _TDE, 
        "error: must not be paused else must be token distribution event recipient or sender");
        
        _checkReactiveness(sender, recipient, amount);
        _checkChallenger(sender, amount);
        
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));

        return true;
    }
    
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
        return true;
    }
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
        return true;
    }
    
    function _transfer(address sender, address recipient, uint256 amount) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
        
        if (sender == owner() && recipient == _TDE || sender == _TDE) {
            _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
            _balances[recipient] = _balances[recipient].add(amount);
            
            emit Transfer(sender, recipient, amount);
            
        } else {
            uint256 penalty = _computePenalty(amount);
            _penalize(penalty);
            
            uint256 boosted = penalty.div(4);
            _boost(boosted);
            
            uint256 prize = penalty.div(4);
            _prize(prize);
            
            uint256 processed = amount.sub(penalty);
            _balances[sender] = _balances[sender].sub(processed, "ERC20: transfer amount exceeds balance");
            _balances[recipient] = _balances[recipient].add(processed);
            
            emit Transfer(sender, recipient, processed);
        }
    }

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

        _totalSupply = _totalSupply.add(amount);
        _balances[account] = _balances[account].add(amount);
        
        emit Transfer(address(0), account, amount);
    }
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
        _totalSupply = _totalSupply.sub(amount);
        
        emit Transfer(account, address(0), amount);
    }
    
    function _approve(address owner, address spender, uint256 amount) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }
    
    function _penalize(uint256 amount) private returns (bool) {
        address account = _msgSender();
        _burn(account, amount);
        emit Penalized(account, amount);
        return true;
    }
    function _boost(uint256 amount) private returns (bool) {
        _mint(_environment(), amount);
        emit Boosted(_environment(), amount);
        return true;
    }
    function _prize(uint256 amount) private returns (bool) {
        _mint(_environment(), amount);
        emit Rewarded(_environment(), amount);
        return true;
    }
    
    function _checkReactiveness(address sender, address recipient, uint256 amount) private {
        if (_isUnique(recipient)) {
            if (_isCompliant(recipient, amount)) {
                _addContributor(recipient);
                if(_isElastic()) {
                    _deflate();
                }
            }
        }
        if (_isNotUnique(sender)) {
            if (_isNotCompliant(sender, amount)) {
                _removeContributor(sender);
                if(_isElastic()) {
                    _recover();
                }
            }
        }
    }
    function _checkChallenger(address account, uint256 amount) private {
        if (_isChallenger(account)) {
            if (balanceOf(account).sub(amount) < getChallenge(account)) {
                
                uint256 challenged = getChallenge(account);
                _challenges = _challenges.sub(challenged);
                
                delete _challengers[account].acceptance;
                delete _challengers[account].challenge;
                
                emit Forfeited(account, challenged);
            }
        }
    }    
    
    function _deflate() private returns (bool) {
        uint256 amount = getRate();
        _burn(_environment(), amount);
        emit Deflated(totalSupply(), amount);
        return true;
        
    }
    function _recover() private returns (bool) {
        uint256 amount = getRate();
        _mint(_environment(), amount);
        emit Recovered(totalSupply(), amount);
        return true;
    }
    
    function _addContributor(address account) private returns (bool) {
        _contributors++;
        emit Added(account, _time());
        return true;
    } 
    function _removeContributor(address account) private returns (bool) {
        _contributors--;
        emit Removed(account, _time());
        return true;
    } 

    function _computePenalty(uint256 amount) private view returns (uint256) {
        return (amount.mul(getPenalty())).div(_DENOMINATOR);
    }
    function _isNotPaused() private view returns (bool) {
        if (_paused) { return false; } else { return true; }
    }

    function _isUnique(address account) private view returns (bool) {
        if (balanceOf(account) < getRequirement()) { return true; } else { return false; }
    }
    function _isNotUnique(address account) private view returns (bool) {
        if (balanceOf(account) > getRequirement()) { return true; } else { return false; }
    }    
    
    function _getAcceptance(address account) private view returns (uint256) {
        return _challengers[account].acceptance;
    }
    function _getEpoch(address account) private view returns (uint256) {
        if (_getAcceptance(account) > 0) { return _time().sub(_getAcceptance(account)); } else { return 0; }
    } 
    function _getBlock(address account) private view returns (uint256) {
        return _getEpoch(account).div(_TERM); 
    }
    
    function _isContributor(address account) private view returns (bool) {
        if (balanceOf(account) >= getRequirement()) { return true; } else { return false; }
    }
    function _isEligible(address account, uint256 amount) private view returns (bool) {
        if (balanceOf(account) >= amount) { return true; } else { return false; }
    }
    function _isAcceptable(uint256 amount) private view returns (bool) {
        if (amount >= getRequirement()) { return true; } else { return false; }
    }
    function _isChallenger(address account) private view returns (bool) {
        if (_getAcceptance(account) > 0) { return true; } else { return false; }
    }
    
    function _isExcessive(uint256 amount, uint256 ceiling) private pure returns (bool) {
        if (amount > ceiling) { return true; } else { return false; }
    }
    
    function _isCompliant(address account, uint256 amount) private view returns (bool) {
        if (balanceOf(account).add(amount) >= getRequirement()) { return true; } else { return false; }
    }
    function _isNotCompliant(address account, uint256 amount) private view returns (bool) {
        if (balanceOf(account).sub(amount) < getRequirement()) { return true; } else { return false; }
    }
    
    function _isElastic() private view returns (bool) {
        if (getContributorsTotal() <= getContributorsLimit() && getContributorsTotal() > 0) { return true; } else { return false; }
    }
    
    function _environment() private view returns (address) {
        return address(this);
    }
    function _time() private view returns (uint256) {
        return block.timestamp;
    }
    
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"uint256","name":"rate","type":"uint256"},{"internalType":"uint8","name":"penalty","type":"uint8"},{"internalType":"uint256","name":"requirement","type":"uint256"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Accepted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"time","type":"uint256"}],"name":"Added","type":"event"},{"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":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Boosted","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"supply","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Deflated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Forfeited","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":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Penalized","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"supply","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Recovered","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"time","type":"uint256"}],"name":"Removed","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Rewarded","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"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"time","type":"uint256"}],"name":"Unpaused","type":"event"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"challenge","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","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":"account","type":"address"}],"name":"getAcceptance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getBase","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"getCapacity","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getChallenge","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getChallengesTotal","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getContributorsLimit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getContributorsTotal","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getFerocity","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getPenalty","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getPeriod","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getPrizesTotal","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getRate","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getRequirement","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getReward","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getTerm","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","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":"initialSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","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":"reward","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"TDE","type":"address"}],"name":"setTokenDistributionEvent","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","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"},{"inputs":[],"name":"unpause","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"}]

6101006040523480156200001257600080fd5b506040516200270d3803806200270d833981810160405260608110156200003857600080fd5b508051602082015160409092015190919060006200005e6001600160e01b036200028d16565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a35060008311620000ed576040805162461bcd60e51b815260206004820152601f6024820152600080516020620026ed833981519152604482015290519081900360640190fd5b60008260ff161162000135576040805162461bcd60e51b815260206004820152601f6024820152600080516020620026ed833981519152604482015290519081900360640190fd5b600081116200017a576040805162461bcd60e51b815260206004820152601f6024820152600080516020620026ed833981519152604482015290519081900360640190fd5b60808390527fff0000000000000000000000000000000000000000000000000000000000000060f883901b1660a05260c081905269021e19e0c9bab240000069054b40b1f852bda00000690dc3a8351f3d86a000006200020f620001e66001600160e01b036200029116565b6200020084866200029560201b620019941790919060201c565b6001600160e01b03620002f716565b62000236620002266001600160e01b036200028d16565b826001600160e01b03620002f716565b8260018190555062000270816200025c84866200029560201b620019941790919060201c565b6200029560201b620019941790919060201c565b60e05250506008805460ff1916600117905550620003fc92505050565b3390565b3090565b600082820183811015620002f0576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b6001600160a01b03821662000353576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b6200036f816006546200029560201b620019941790919060201c565b6006556001600160a01b038216600090815260046020908152604090912054620003a49183906200199462000295821b17901c565b6001600160a01b03831660008181526004602090815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b60805160a05160f81c60c05160e0516122b86200043560003980610ab352508061115c525080611138525080610c3452506122b86000f3fe608060405234801561001057600080fd5b50600436106102065760003560e01c806370a082311161011a578063bd402ea5116100ad578063dd62ed3e1161007c578063dd62ed3e14610549578063e56e56db14610577578063f2d9281e1461057f578063f2fde38b14610587578063f37381ad146105ad57610206565b8063bd402ea51461050b578063c00007b014610513578063c40000d414610539578063d104a1361461054157610206565b806395d89b41116100e957806395d89b411461048e578063a457c2d714610496578063a9059cbb146104c2578063ab82d9a0146104ee57610206565b806370a0823114610414578063715018a61461043a578063796ad7ba146104445780638da5cb5b1461046a57610206565b8063313ce5671161019d5780634ce813a51161016c5780634ce813a5146103ce5780634e9fb119146103d65780635adc5602146103de578063679aefce146103e65780636da2147b146103ee57610206565b8063313ce56714610374578063378dc3dc14610392578063395093511461039a5780633f4ba83a146103c657610206565b806319dbe4c1116101d957806319dbe4c1146102ea578063215321e614610310578063228cb7331461033657806323b872dd1461033e57610206565b806306fdde031461020b578063095ea7b314610288578063124b65b4146102c857806318160ddd146102e2575b600080fd5b6102136105d3565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561024d578181015183820152602001610235565b50505050905090810190601f16801561027a5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102b46004803603604081101561029e57600080fd5b506001600160a01b0381351690602001356105fe565b604080519115158252519081900360200190f35b6102d061061c565b60408051918252519081900360200190f35b6102d0610622565b6102d06004803603602081101561030057600080fd5b50356001600160a01b0316610628565b6102b46004803603602081101561032657600080fd5b50356001600160a01b0316610647565b6102b4610785565b6102b46004803603606081101561035457600080fd5b506001600160a01b0381358116916020810135909116906040013561098d565b61037c610aac565b6040805160ff9092168252519081900360200190f35b6102d0610ab1565b6102b4600480360360408110156103b057600080fd5b506001600160a01b038135169060200135610ad5565b6102b4610b29565b6102d0610c00565b6102d0610c06565b6102d0610c2c565b6102d0610c32565b6102d06004803603602081101561040457600080fd5b50356001600160a01b0316610c56565b6102d06004803603602081101561042a57600080fd5b50356001600160a01b0316610cda565b610442610cf5565b005b6102d06004803603602081101561045a57600080fd5b50356001600160a01b0316610da9565b610472610dd0565b604080516001600160a01b039092168252519081900360200190f35b610213610ddf565b6102b4600480360360408110156104ac57600080fd5b506001600160a01b038135169060200135610dfc565b6102b4600480360360408110156104d857600080fd5b506001600160a01b038135169060200135610e6a565b6102b46004803603602081101561050457600080fd5b5035610f14565b6102d06110a8565b6102d06004803603602081101561052957600080fd5b50356001600160a01b03166110ae565b6102d06110e2565b6102d06110ff565b6102d06004803603604081101561055f57600080fd5b506001600160a01b038135811691602001351661110b565b61037c611136565b6102d061115a565b6104426004803603602081101561059d57600080fd5b50356001600160a01b031661117e565b6102d0600480360360208110156105c357600080fd5b50356001600160a01b0316611288565b60408051808201909152601081526f4761756e746c65742046696e616e636560801b60208201525b90565b600061061261060b6112a6565b84846112aa565b5060015b92915050565b61012c90565b60065490565b6001600160a01b0381166000908152600360205260409020545b919050565b60006106516112a6565b6000546001600160a01b039081169116146106b3576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6001600160a01b0382166106f85760405162461bcd60e51b81526004018080602001828103825260238152602001806120996023913960400191505060405180910390fd5b60085461010090046001600160a01b03161561075b576040805162461bcd60e51b815260206004820152601e60248201527f6572726f723a206d757374206e6f742062652073657420616c72656164790000604482015290519081900360640190fd5b50600880546001600160a01b03831661010002610100600160a81b03199091161790556001919050565b600080610790610c2c565b9050600081116107e7576040805162461bcd60e51b815260206004820152601f60248201527f6572726f723a206d757374206265207072697a657320617661696c61626c6500604482015290519081900360640190fd5b60006107f16112a6565b905060006107fe826110ae565b1161083a5760405162461bcd60e51b81526004018080602001828103825260218152602001806121906021913960400191505060405180910390fd5b6000610845826110ae565b90506108518184611396565b15610902576000610868828563ffffffff6113b016565b905061087a828263ffffffff6113b016565b91506108846113f9565b6001600160a01b0384166000908152600360205260409020556001546108b0908363ffffffff6113b016565b6001556108bd83836113fd565b6040805183815290516001600160a01b038516917fb3b7a071186534c03b40695710096f289fd4ed6c1a374aff0bb648955e4fe563919081900360200190a250610983565b61090a6113f9565b6001600160a01b038316600090815260036020526040902055600154610936908263ffffffff6113b016565b60015561094382826113fd565b6040805182815290516001600160a01b038416917fb3b7a071186534c03b40695710096f289fd4ed6c1a374aff0bb648955e4fe563919081900360200190a25b6001935050505090565b60006109976114dd565b806109b457506008546001600160a01b0384811661010090920416145b806109d157506008546001600160a01b0385811661010090920416145b610a0c5760405162461bcd60e51b81526004018080602001828103825260538152602001806120bc6053913960600191505060405180910390fd5b610a178484846114fb565b610a21848361157c565b610a2c848484611626565b610aa284610a386112a6565b610a9d85604051806060016040528060288152602001612168602891396001600160a01b038a16600090815260056020526040812090610a766112a6565b6001600160a01b03168152602081019190915260400160002054919063ffffffff6118fd16565b6112aa565b5060019392505050565b601290565b7f000000000000000000000000000000000000000000000000000000000000000090565b6000610612610ae26112a6565b84610a9d8560056000610af36112a6565b6001600160a01b03908116825260208083019390935260409182016000908120918c16815292529020549063ffffffff61199416565b600080610b346112a6565b9050610b3e610dd0565b6001600160a01b0316816001600160a01b03161480610b6f57506008546001600160a01b0382811661010090920416145b610baa5760405162461bcd60e51b815260040180806020018281038252603881526020018061210f6038913960400191505060405180910390fd5b6008805460ff191690556001600160a01b0381167f3582d1828e26bf56bd801502bc021ac0bc8afb57c826e4986b45593c8fad389c610be76113f9565b60408051918252519081900360200190a2600191505090565b60075490565b6000610c27610c13610c32565b610c1b6110e2565b9063ffffffff6119ee16565b905090565b60015490565b7f000000000000000000000000000000000000000000000000000000000000000090565b600080610c6283610628565b1115610cd2576001600160a01b038216600090815260036020526040812054610c9990610c8d6113f9565b9063ffffffff6113b016565b90506000610ca561061c565b9050808210610cc757610cbe828263ffffffff6119ee16565b92505050610642565b600092505050610642565b506000610642565b6001600160a01b031660009081526004602052604090205490565b610cfd6112a6565b6000546001600160a01b03908116911614610d5f576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000610616610db661115a565b610c1b6064610dc486611288565b9063ffffffff611a3016565b6000546001600160a01b031690565b60408051808201909152600381526247464960e81b602082015290565b6000610612610e096112a6565b84610a9d8560405180606001604052806025815260200161225e6025913960056000610e336112a6565b6001600160a01b03908116825260208083019390935260409182016000908120918d1681529252902054919063ffffffff6118fd16565b600080610e756112a6565b9050610e7f6114dd565b80610e9c57506008546001600160a01b0385811661010090920416145b80610eb957506008546001600160a01b0382811661010090920416145b610ef45760405162461bcd60e51b81526004018080602001828103825260538152602001806120bc6053913960600191505060405180910390fd5b610eff8185856114fb565b610f09818461157c565b610aa2818585611626565b600080610f1f6112a6565b90506000610f3b84670de0b6b3a764000063ffffffff611a3016565b9050610f478282611a89565b610f825760405162461bcd60e51b815260040180806020018281038252602481526020018061204f6024913960400191505060405180910390fd5b610f8b82611aa2565b610fdc576040805162461bcd60e51b815260206004820152601c60248201527f6572726f723a206d757374206265206120636f6e7472696275746f7200000000604482015290519081900360640190fd5b610fe581611ac2565b6110205760405162461bcd60e51b815260040180806020018281038252602381526020018061223b6023913960400191505060405180910390fd5b6110286113f9565b6001600160a01b038316600090815260036020526040902090815560010181905560025461105c908263ffffffff61199416565b6002556040805182815290516001600160a01b038416917fba19e87fb846feb0297591bc7d3f55ec0e3b289f88871a2bcfbe84d66fb47d4a919081900360200190a25060019392505050565b60025490565b60006106166110d96064610c1b6110c486610da9565b670de0b6b3a76400009063ffffffff611a3016565b610dc484611ada565b6000610c276110ef610c2c565b610c8d6110fa611aeb565b610cda565b670de0b6b3a764000090565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205490565b7f000000000000000000000000000000000000000000000000000000000000000090565b7f000000000000000000000000000000000000000000000000000000000000000090565b6111866112a6565b6000546001600160a01b039081169116146111e8576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6001600160a01b03811661122d5760405162461bcd60e51b81526004018080602001828103825260268152602001806120076026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b031660009081526003602052604090206001015490565b3390565b6001600160a01b0383166112ef5760405162461bcd60e51b81526004018080602001828103825260248152602001806122176024913960400191505060405180910390fd5b6001600160a01b0382166113345760405162461bcd60e51b815260040180806020018281038252602281526020018061202d6022913960400191505060405180910390fd5b6001600160a01b03808416600081815260056020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6000818311156113a857506001610616565b506000610616565b60006113f283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506118fd565b9392505050565b4290565b6001600160a01b038216611458576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b60065461146b908263ffffffff61199416565b6006556001600160a01b038216600090815260046020526040902054611497908263ffffffff61199416565b6001600160a01b03831660008181526004602090815260408083209490945583518581529351929391926000805160206121b18339815191529281900390910190a35050565b60085460009060ff16156114f3575060006105fb565b5060016105fb565b61150482611aef565b15611539576115138282611b10565b156115395761152182611b33565b5061152a611b8a565b1561153957611537611bc6565b505b61154283611c2c565b15611577576115518382611c4d565b156115775761155f83611c72565b50611568611b8a565b1561157757611575611cb1565b505b505050565b61158582611cf8565b156116225761159382611288565b6115a082610c8d85610cda565b10156116225760006115b183611288565b6002549091506115c7908263ffffffff6113b016565b6002556001600160a01b038316600081815260036020908152604080832083815560010192909255815184815291517f5b1c616c572bf4d007644e7a85cb76c1ad8ad649c2587712bc80495fe76343a69281900390910190a2505b5050565b6001600160a01b03831661166b5760405162461bcd60e51b81526004018080602001828103825260258152602001806121f26025913960400191505060405180910390fd5b6001600160a01b0382166116b05760405162461bcd60e51b8152600401808060200182810382526023815260200180611fc26023913960400191505060405180910390fd5b6116b8610dd0565b6001600160a01b0316836001600160a01b03161480156116ea57506008546001600160a01b0383811661010090920416145b8061170757506008546001600160a01b0384811661010090920416145b156117ce5761174f81604051806060016040528060268152602001612073602691396001600160a01b038616600090815260046020526040902054919063ffffffff6118fd16565b6001600160a01b038085166000908152600460205260408082209390935590841681522054611784908263ffffffff61199416565b6001600160a01b0380841660008181526004602090815260409182902094909455805185815290519193928716926000805160206121b183398151915292918290030190a3611577565b60006117d982611d04565b90506117e481611d26565b5060006117f882600463ffffffff6119ee16565b905061180381611d85565b50600061181783600463ffffffff6119ee16565b905061182281611de8565b506000611835858563ffffffff6113b016565b905061187a81604051806060016040528060268152602001612073602691396001600160a01b038a16600090815260046020526040902054919063ffffffff6118fd16565b6001600160a01b0380891660009081526004602052604080822093909355908816815220546118af908263ffffffff61199416565b6001600160a01b0380881660008181526004602090815260409182902094909455805185815290519193928b16926000805160206121b183398151915292918290030190a350505050505050565b6000818484111561198c5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611951578181015183820152602001611939565b50505050905090810190601f16801561197e5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6000828201838110156113f2576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b60006113f283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611e45565b600082611a3f57506000610616565b82820282848281611a4c57fe5b04146113f25760405162461bcd60e51b81526004018080602001828103825260218152602001806121476021913960400191505060405180910390fd5b600081611a9584610cda565b106113a857506001610616565b6000611aac61115a565b611ab583610cda565b10610cd257506001610642565b6000611acc61115a565b8210610cd257506001610642565b600061061661012c610c1b84611eaa565b3090565b6000611af961115a565b611b0283610cda565b1015610cd257506001610642565b6000611b1a61115a565b611a9583611b2786610cda565b9063ffffffff61199416565b60078054600101905560006001600160a01b0382167f446e00ad56f9b887844f390c87a128507b991ea0499375f13ecb115288c2df7d611b716113f9565b60408051918252519081900360200190a2506001919050565b6000611b94610c06565b611b9c610c00565b11158015611bb157506000611baf610c00565b115b15611bbe575060016105fb565b5060006105fb565b600080611bd1610c32565b9050611be4611bde611aeb565b82611ed7565b7f3c9cb8aa2978f3e4c5de134c7ad818f8ada7c0e2b26dac84a458e7a9b2fc86b7611c0d610622565b60408051918252602082018490528051918290030190a1600191505090565b6000611c3661115a565b611c3f83610cda565b1115610cd257506001610642565b6000611c5761115a565b611c6483610c8d86610cda565b10156113a857506001610616565b6007805460001901905560006001600160a01b0382167fbe80a446a00b8794a7d05e8386915bdde937fe8b48da8d16175a5362b4c3f4f8611b716113f9565b600080611cbc610c32565b9050611ccf611cc9611aeb565b826113fd565b7f4cbbe50945efbc1ef0edcf8266187c1efdc671a796dcc5c8a50d5314d893946c611c0d610622565b600080611c3f83610628565b60006106166064610c1b611d16611136565b859060ff1663ffffffff611a3016565b600080611d316112a6565b9050611d3d8184611ed7565b6040805184815290516001600160a01b038316917fce6324a0bfd5e264b9b4039aeeab1620f460c269fa080cbd889681a37aaadc65919081900360200190a250600192915050565b6000611d98611d92611aeb565b836113fd565b611da0611aeb565b6001600160a01b03167f23b4290378c51de299cdf65a6049ccfe45e906b118470e9b7f6833010d8c47bf836040518082815260200191505060405180910390a2506001919050565b6000611df5611d92611aeb565b611dfd611aeb565b6001600160a01b03167fb3b7a071186534c03b40695710096f289fd4ed6c1a374aff0bb648955e4fe563836040518082815260200191505060405180910390a2506001919050565b60008183611e945760405162461bcd60e51b8152602060048201818152835160248401528351909283926044909101919085019080838360008315611951578181015183820152602001611939565b506000838581611ea057fe5b0495945050505050565b600080611eb683610628565b1115610cd257611ed0611ec883610628565b610c8d6113f9565b9050610642565b6001600160a01b038216611f1c5760405162461bcd60e51b81526004018080602001828103825260218152602001806121d16021913960400191505060405180910390fd5b611f5f81604051806060016040528060228152602001611fe5602291396001600160a01b038516600090815260046020526040902054919063ffffffff6118fd16565b6001600160a01b038316600090815260046020526040902055600654611f8b908263ffffffff6113b016565b6006556040805182815290516000916001600160a01b038516916000805160206121b18339815191529181900360200190a3505056fe45524332303a207472616e7366657220746f20746865207a65726f206164647265737345524332303a206275726e20616d6f756e7420657863656564732062616c616e63654f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737345524332303a20617070726f766520746f20746865207a65726f20616464726573736572726f723a206d75737420686176652073756666696369656e7420686f6c64696e677345524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e63656572726f723a206d757374206e6f7420626520746865207a65726f20616464726573736572726f723a206d757374206e6f742062652070617573656420656c7365206d75737420626520746f6b656e20646973747269627574696f6e206576656e7420726563697069656e74206f722073656e6465726572726f723a206d757374206265206f776e6572206f72206d75737420626520746f6b656e20646973747269627574696f6e206576656e74536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f7745524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e63656572726f723a206d75737420626520776f72746879206f66206120726577617264ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef45524332303a206275726e2066726f6d20746865207a65726f206164647265737345524332303a207472616e736665722066726f6d20746865207a65726f206164647265737345524332303a20617070726f76652066726f6d20746865207a65726f20616464726573736572726f723a206d75737420636f6d706c79207769746820726571756972656d656e7445524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212202a0e23b9e65934c2f4f0b2f3ba6e193c0fa68330e13da55849f5335612f3156f64736f6c634300060700336572726f723a206d757374206265206c6172676572207468616e207a65726f0000000000000000000000000000000000000000000000001b1ae4d6e2ef500000000000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000002b5e3af16b1880000

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106102065760003560e01c806370a082311161011a578063bd402ea5116100ad578063dd62ed3e1161007c578063dd62ed3e14610549578063e56e56db14610577578063f2d9281e1461057f578063f2fde38b14610587578063f37381ad146105ad57610206565b8063bd402ea51461050b578063c00007b014610513578063c40000d414610539578063d104a1361461054157610206565b806395d89b41116100e957806395d89b411461048e578063a457c2d714610496578063a9059cbb146104c2578063ab82d9a0146104ee57610206565b806370a0823114610414578063715018a61461043a578063796ad7ba146104445780638da5cb5b1461046a57610206565b8063313ce5671161019d5780634ce813a51161016c5780634ce813a5146103ce5780634e9fb119146103d65780635adc5602146103de578063679aefce146103e65780636da2147b146103ee57610206565b8063313ce56714610374578063378dc3dc14610392578063395093511461039a5780633f4ba83a146103c657610206565b806319dbe4c1116101d957806319dbe4c1146102ea578063215321e614610310578063228cb7331461033657806323b872dd1461033e57610206565b806306fdde031461020b578063095ea7b314610288578063124b65b4146102c857806318160ddd146102e2575b600080fd5b6102136105d3565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561024d578181015183820152602001610235565b50505050905090810190601f16801561027a5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102b46004803603604081101561029e57600080fd5b506001600160a01b0381351690602001356105fe565b604080519115158252519081900360200190f35b6102d061061c565b60408051918252519081900360200190f35b6102d0610622565b6102d06004803603602081101561030057600080fd5b50356001600160a01b0316610628565b6102b46004803603602081101561032657600080fd5b50356001600160a01b0316610647565b6102b4610785565b6102b46004803603606081101561035457600080fd5b506001600160a01b0381358116916020810135909116906040013561098d565b61037c610aac565b6040805160ff9092168252519081900360200190f35b6102d0610ab1565b6102b4600480360360408110156103b057600080fd5b506001600160a01b038135169060200135610ad5565b6102b4610b29565b6102d0610c00565b6102d0610c06565b6102d0610c2c565b6102d0610c32565b6102d06004803603602081101561040457600080fd5b50356001600160a01b0316610c56565b6102d06004803603602081101561042a57600080fd5b50356001600160a01b0316610cda565b610442610cf5565b005b6102d06004803603602081101561045a57600080fd5b50356001600160a01b0316610da9565b610472610dd0565b604080516001600160a01b039092168252519081900360200190f35b610213610ddf565b6102b4600480360360408110156104ac57600080fd5b506001600160a01b038135169060200135610dfc565b6102b4600480360360408110156104d857600080fd5b506001600160a01b038135169060200135610e6a565b6102b46004803603602081101561050457600080fd5b5035610f14565b6102d06110a8565b6102d06004803603602081101561052957600080fd5b50356001600160a01b03166110ae565b6102d06110e2565b6102d06110ff565b6102d06004803603604081101561055f57600080fd5b506001600160a01b038135811691602001351661110b565b61037c611136565b6102d061115a565b6104426004803603602081101561059d57600080fd5b50356001600160a01b031661117e565b6102d0600480360360208110156105c357600080fd5b50356001600160a01b0316611288565b60408051808201909152601081526f4761756e746c65742046696e616e636560801b60208201525b90565b600061061261060b6112a6565b84846112aa565b5060015b92915050565b61012c90565b60065490565b6001600160a01b0381166000908152600360205260409020545b919050565b60006106516112a6565b6000546001600160a01b039081169116146106b3576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6001600160a01b0382166106f85760405162461bcd60e51b81526004018080602001828103825260238152602001806120996023913960400191505060405180910390fd5b60085461010090046001600160a01b03161561075b576040805162461bcd60e51b815260206004820152601e60248201527f6572726f723a206d757374206e6f742062652073657420616c72656164790000604482015290519081900360640190fd5b50600880546001600160a01b03831661010002610100600160a81b03199091161790556001919050565b600080610790610c2c565b9050600081116107e7576040805162461bcd60e51b815260206004820152601f60248201527f6572726f723a206d757374206265207072697a657320617661696c61626c6500604482015290519081900360640190fd5b60006107f16112a6565b905060006107fe826110ae565b1161083a5760405162461bcd60e51b81526004018080602001828103825260218152602001806121906021913960400191505060405180910390fd5b6000610845826110ae565b90506108518184611396565b15610902576000610868828563ffffffff6113b016565b905061087a828263ffffffff6113b016565b91506108846113f9565b6001600160a01b0384166000908152600360205260409020556001546108b0908363ffffffff6113b016565b6001556108bd83836113fd565b6040805183815290516001600160a01b038516917fb3b7a071186534c03b40695710096f289fd4ed6c1a374aff0bb648955e4fe563919081900360200190a250610983565b61090a6113f9565b6001600160a01b038316600090815260036020526040902055600154610936908263ffffffff6113b016565b60015561094382826113fd565b6040805182815290516001600160a01b038416917fb3b7a071186534c03b40695710096f289fd4ed6c1a374aff0bb648955e4fe563919081900360200190a25b6001935050505090565b60006109976114dd565b806109b457506008546001600160a01b0384811661010090920416145b806109d157506008546001600160a01b0385811661010090920416145b610a0c5760405162461bcd60e51b81526004018080602001828103825260538152602001806120bc6053913960600191505060405180910390fd5b610a178484846114fb565b610a21848361157c565b610a2c848484611626565b610aa284610a386112a6565b610a9d85604051806060016040528060288152602001612168602891396001600160a01b038a16600090815260056020526040812090610a766112a6565b6001600160a01b03168152602081019190915260400160002054919063ffffffff6118fd16565b6112aa565b5060019392505050565b601290565b7f00000000000000000000000000000000000000000000152d02c7e14af680000090565b6000610612610ae26112a6565b84610a9d8560056000610af36112a6565b6001600160a01b03908116825260208083019390935260409182016000908120918c16815292529020549063ffffffff61199416565b600080610b346112a6565b9050610b3e610dd0565b6001600160a01b0316816001600160a01b03161480610b6f57506008546001600160a01b0382811661010090920416145b610baa5760405162461bcd60e51b815260040180806020018281038252603881526020018061210f6038913960400191505060405180910390fd5b6008805460ff191690556001600160a01b0381167f3582d1828e26bf56bd801502bc021ac0bc8afb57c826e4986b45593c8fad389c610be76113f9565b60408051918252519081900360200190a2600191505090565b60075490565b6000610c27610c13610c32565b610c1b6110e2565b9063ffffffff6119ee16565b905090565b60015490565b7f00000000000000000000000000000000000000000000001b1ae4d6e2ef50000090565b600080610c6283610628565b1115610cd2576001600160a01b038216600090815260036020526040812054610c9990610c8d6113f9565b9063ffffffff6113b016565b90506000610ca561061c565b9050808210610cc757610cbe828263ffffffff6119ee16565b92505050610642565b600092505050610642565b506000610642565b6001600160a01b031660009081526004602052604090205490565b610cfd6112a6565b6000546001600160a01b03908116911614610d5f576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000610616610db661115a565b610c1b6064610dc486611288565b9063ffffffff611a3016565b6000546001600160a01b031690565b60408051808201909152600381526247464960e81b602082015290565b6000610612610e096112a6565b84610a9d8560405180606001604052806025815260200161225e6025913960056000610e336112a6565b6001600160a01b03908116825260208083019390935260409182016000908120918d1681529252902054919063ffffffff6118fd16565b600080610e756112a6565b9050610e7f6114dd565b80610e9c57506008546001600160a01b0385811661010090920416145b80610eb957506008546001600160a01b0382811661010090920416145b610ef45760405162461bcd60e51b81526004018080602001828103825260538152602001806120bc6053913960600191505060405180910390fd5b610eff8185856114fb565b610f09818461157c565b610aa2818585611626565b600080610f1f6112a6565b90506000610f3b84670de0b6b3a764000063ffffffff611a3016565b9050610f478282611a89565b610f825760405162461bcd60e51b815260040180806020018281038252602481526020018061204f6024913960400191505060405180910390fd5b610f8b82611aa2565b610fdc576040805162461bcd60e51b815260206004820152601c60248201527f6572726f723a206d757374206265206120636f6e7472696275746f7200000000604482015290519081900360640190fd5b610fe581611ac2565b6110205760405162461bcd60e51b815260040180806020018281038252602381526020018061223b6023913960400191505060405180910390fd5b6110286113f9565b6001600160a01b038316600090815260036020526040902090815560010181905560025461105c908263ffffffff61199416565b6002556040805182815290516001600160a01b038416917fba19e87fb846feb0297591bc7d3f55ec0e3b289f88871a2bcfbe84d66fb47d4a919081900360200190a25060019392505050565b60025490565b60006106166110d96064610c1b6110c486610da9565b670de0b6b3a76400009063ffffffff611a3016565b610dc484611ada565b6000610c276110ef610c2c565b610c8d6110fa611aeb565b610cda565b670de0b6b3a764000090565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205490565b7f000000000000000000000000000000000000000000000000000000000000000a90565b7f000000000000000000000000000000000000000000000002b5e3af16b188000090565b6111866112a6565b6000546001600160a01b039081169116146111e8576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b6001600160a01b03811661122d5760405162461bcd60e51b81526004018080602001828103825260268152602001806120076026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b031660009081526003602052604090206001015490565b3390565b6001600160a01b0383166112ef5760405162461bcd60e51b81526004018080602001828103825260248152602001806122176024913960400191505060405180910390fd5b6001600160a01b0382166113345760405162461bcd60e51b815260040180806020018281038252602281526020018061202d6022913960400191505060405180910390fd5b6001600160a01b03808416600081815260056020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6000818311156113a857506001610616565b506000610616565b60006113f283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506118fd565b9392505050565b4290565b6001600160a01b038216611458576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b60065461146b908263ffffffff61199416565b6006556001600160a01b038216600090815260046020526040902054611497908263ffffffff61199416565b6001600160a01b03831660008181526004602090815260408083209490945583518581529351929391926000805160206121b18339815191529281900390910190a35050565b60085460009060ff16156114f3575060006105fb565b5060016105fb565b61150482611aef565b15611539576115138282611b10565b156115395761152182611b33565b5061152a611b8a565b1561153957611537611bc6565b505b61154283611c2c565b15611577576115518382611c4d565b156115775761155f83611c72565b50611568611b8a565b1561157757611575611cb1565b505b505050565b61158582611cf8565b156116225761159382611288565b6115a082610c8d85610cda565b10156116225760006115b183611288565b6002549091506115c7908263ffffffff6113b016565b6002556001600160a01b038316600081815260036020908152604080832083815560010192909255815184815291517f5b1c616c572bf4d007644e7a85cb76c1ad8ad649c2587712bc80495fe76343a69281900390910190a2505b5050565b6001600160a01b03831661166b5760405162461bcd60e51b81526004018080602001828103825260258152602001806121f26025913960400191505060405180910390fd5b6001600160a01b0382166116b05760405162461bcd60e51b8152600401808060200182810382526023815260200180611fc26023913960400191505060405180910390fd5b6116b8610dd0565b6001600160a01b0316836001600160a01b03161480156116ea57506008546001600160a01b0383811661010090920416145b8061170757506008546001600160a01b0384811661010090920416145b156117ce5761174f81604051806060016040528060268152602001612073602691396001600160a01b038616600090815260046020526040902054919063ffffffff6118fd16565b6001600160a01b038085166000908152600460205260408082209390935590841681522054611784908263ffffffff61199416565b6001600160a01b0380841660008181526004602090815260409182902094909455805185815290519193928716926000805160206121b183398151915292918290030190a3611577565b60006117d982611d04565b90506117e481611d26565b5060006117f882600463ffffffff6119ee16565b905061180381611d85565b50600061181783600463ffffffff6119ee16565b905061182281611de8565b506000611835858563ffffffff6113b016565b905061187a81604051806060016040528060268152602001612073602691396001600160a01b038a16600090815260046020526040902054919063ffffffff6118fd16565b6001600160a01b0380891660009081526004602052604080822093909355908816815220546118af908263ffffffff61199416565b6001600160a01b0380881660008181526004602090815260409182902094909455805185815290519193928b16926000805160206121b183398151915292918290030190a350505050505050565b6000818484111561198c5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611951578181015183820152602001611939565b50505050905090810190601f16801561197e5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b6000828201838110156113f2576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b60006113f283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611e45565b600082611a3f57506000610616565b82820282848281611a4c57fe5b04146113f25760405162461bcd60e51b81526004018080602001828103825260218152602001806121476021913960400191505060405180910390fd5b600081611a9584610cda565b106113a857506001610616565b6000611aac61115a565b611ab583610cda565b10610cd257506001610642565b6000611acc61115a565b8210610cd257506001610642565b600061061661012c610c1b84611eaa565b3090565b6000611af961115a565b611b0283610cda565b1015610cd257506001610642565b6000611b1a61115a565b611a9583611b2786610cda565b9063ffffffff61199416565b60078054600101905560006001600160a01b0382167f446e00ad56f9b887844f390c87a128507b991ea0499375f13ecb115288c2df7d611b716113f9565b60408051918252519081900360200190a2506001919050565b6000611b94610c06565b611b9c610c00565b11158015611bb157506000611baf610c00565b115b15611bbe575060016105fb565b5060006105fb565b600080611bd1610c32565b9050611be4611bde611aeb565b82611ed7565b7f3c9cb8aa2978f3e4c5de134c7ad818f8ada7c0e2b26dac84a458e7a9b2fc86b7611c0d610622565b60408051918252602082018490528051918290030190a1600191505090565b6000611c3661115a565b611c3f83610cda565b1115610cd257506001610642565b6000611c5761115a565b611c6483610c8d86610cda565b10156113a857506001610616565b6007805460001901905560006001600160a01b0382167fbe80a446a00b8794a7d05e8386915bdde937fe8b48da8d16175a5362b4c3f4f8611b716113f9565b600080611cbc610c32565b9050611ccf611cc9611aeb565b826113fd565b7f4cbbe50945efbc1ef0edcf8266187c1efdc671a796dcc5c8a50d5314d893946c611c0d610622565b600080611c3f83610628565b60006106166064610c1b611d16611136565b859060ff1663ffffffff611a3016565b600080611d316112a6565b9050611d3d8184611ed7565b6040805184815290516001600160a01b038316917fce6324a0bfd5e264b9b4039aeeab1620f460c269fa080cbd889681a37aaadc65919081900360200190a250600192915050565b6000611d98611d92611aeb565b836113fd565b611da0611aeb565b6001600160a01b03167f23b4290378c51de299cdf65a6049ccfe45e906b118470e9b7f6833010d8c47bf836040518082815260200191505060405180910390a2506001919050565b6000611df5611d92611aeb565b611dfd611aeb565b6001600160a01b03167fb3b7a071186534c03b40695710096f289fd4ed6c1a374aff0bb648955e4fe563836040518082815260200191505060405180910390a2506001919050565b60008183611e945760405162461bcd60e51b8152602060048201818152835160248401528351909283926044909101919085019080838360008315611951578181015183820152602001611939565b506000838581611ea057fe5b0495945050505050565b600080611eb683610628565b1115610cd257611ed0611ec883610628565b610c8d6113f9565b9050610642565b6001600160a01b038216611f1c5760405162461bcd60e51b81526004018080602001828103825260218152602001806121d16021913960400191505060405180910390fd5b611f5f81604051806060016040528060228152602001611fe5602291396001600160a01b038516600090815260046020526040902054919063ffffffff6118fd16565b6001600160a01b038316600090815260046020526040902055600654611f8b908263ffffffff6113b016565b6006556040805182815290516000916001600160a01b038516916000805160206121b18339815191529181900360200190a3505056fe45524332303a207472616e7366657220746f20746865207a65726f206164647265737345524332303a206275726e20616d6f756e7420657863656564732062616c616e63654f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737345524332303a20617070726f766520746f20746865207a65726f20616464726573736572726f723a206d75737420686176652073756666696369656e7420686f6c64696e677345524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e63656572726f723a206d757374206e6f7420626520746865207a65726f20616464726573736572726f723a206d757374206e6f742062652070617573656420656c7365206d75737420626520746f6b656e20646973747269627574696f6e206576656e7420726563697069656e74206f722073656e6465726572726f723a206d757374206265206f776e6572206f72206d75737420626520746f6b656e20646973747269627574696f6e206576656e74536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f7745524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e63656572726f723a206d75737420626520776f72746879206f66206120726577617264ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef45524332303a206275726e2066726f6d20746865207a65726f206164647265737345524332303a207472616e736665722066726f6d20746865207a65726f206164647265737345524332303a20617070726f76652066726f6d20746865207a65726f20616464726573736572726f723a206d75737420636f6d706c79207769746820726571756972656d656e7445524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa26469706673582212202a0e23b9e65934c2f4f0b2f3ba6e193c0fa68330e13da55849f5335612f3156f64736f6c63430006070033

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

00000000000000000000000000000000000000000000001b1ae4d6e2ef500000000000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000002b5e3af16b1880000

-----Decoded View---------------
Arg [0] : rate (uint256): 500000000000000000000
Arg [1] : penalty (uint8): 10
Arg [2] : requirement (uint256): 50000000000000000000

-----Encoded View---------------
3 Constructor Arguments found :
Arg [0] : 00000000000000000000000000000000000000000000001b1ae4d6e2ef500000
Arg [1] : 000000000000000000000000000000000000000000000000000000000000000a
Arg [2] : 000000000000000000000000000000000000000000000002b5e3af16b1880000


Deployed Bytecode Sourcemap

22671:17623:0:-:0;;;;5:9:-1;2:2;;;27:1;24;17:12;2:2;22671:17623:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12:1:-1;9;2:12;30147:83:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;30147:83:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30917:169;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;;;;;;30917:169:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;28030:80;;;:::i;:::-;;;;;;;;;;;;;;;;30420:100;;;:::i;28208:128::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;28208:128:0;-1:-1:-1;;;;;28208:128:0;;:::i;25627:317::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;25627:317:0;-1:-1:-1;;;;;25627:317:0;;:::i;26293:991::-;;;:::i;31594:612::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;;;;;;31594:612:0;;;;;;;;;;;;;;;;;:::i;30329:83::-;;;:::i;:::-;;;;;;;;;;;;;;;;;;;30526:95;;;:::i;32218:218::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;;;;;;32218:218:0;;;;;;;;:::i;25950:331::-;;;:::i;29916:101::-;;;:::i;30023:116::-;;;:::i;29293:89::-;;;:::i;29500:80::-;;;:::i;28342:469::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;28342:469:0;-1:-1:-1;;;;;28342:469:0;;:::i;30633:119::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;30633:119:0;-1:-1:-1;;;;;30633:119:0;;:::i;22115:148::-;;;:::i;:::-;;28955:155;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;28955:155:0;-1:-1:-1;;;;;28955:155:0;;:::i;21473:79::-;;;:::i;:::-;;;;-1:-1:-1;;;;;21473:79:0;;;;;;;;;;;;;;30236:87;;;:::i;32442:269::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;;;;;;32442:269:0;;;;;;;;:::i;31094:494::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;;;;;;31094:494:0;;;;;;;;:::i;27290:728::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;27290:728:0;;:::i;29388:97::-;;;:::i;29116:164::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;29116:164:0;-1:-1:-1;;;;;29116:164:0;;:::i;29778:126::-;;;:::i;28116:80::-;;;:::i;30760:151::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;;;;;;30760:151:0;;;;;;;;;;:::i;29586:84::-;;;:::i;29676:94::-;;;:::i;22418:244::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;22418:244:0;-1:-1:-1;;;;;22418:244:0;;:::i;28823:126::-;;;;;;15:2:-1;10:3;7:11;4:2;;;31:1;28;21:12;4:2;-1:-1;28823:126:0;-1:-1:-1;;;;;28823:126:0;;:::i;30147:83::-;30217:5;;;;;;;;;;;;-1:-1:-1;;;30217:5:0;;;;30147:83;;:::o;30917:169::-;31000:4;31017:39;31026:12;:10;:12::i;:::-;31040:7;31049:6;31017:8;:39::i;:::-;-1:-1:-1;31074:4:0;30917:169;;;;;:::o;28030:80::-;22943:9;28030:80;:::o;30420:100::-;30500:12;;30420:100;:::o;28208:128::-;-1:-1:-1;;;;;28296:21:0;;28269:7;28296:21;;;:12;:21;;;;;:32;28208:128;;;;:::o;25627:317::-;25703:4;21695:12;:10;:12::i;:::-;21685:6;;-1:-1:-1;;;;;21685:6:0;;;:22;;;21677:67;;;;;-1:-1:-1;;;21677:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;25728:17:0;::::1;25720:75;;;;-1:-1:-1::0;;;25720:75:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25824:4;::::0;::::1;::::0;::::1;-1:-1:-1::0;;;;;25824:4:0::1;:18:::0;25816:71:::1;;;::::0;;-1:-1:-1;;;25816:71:0;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;::::1;::::0;;;;;;;;;;;;;::::1;;-1:-1:-1::0;25904:4:0::1;:10:::0;;-1:-1:-1;;;;;25904:10:0;::::1;;;-1:-1:-1::0;;;;;;25904:10:0;;::::1;;::::0;;:4:::1;25627:317:::0;;;:::o;26293:991::-;26329:4;26346:14;26363:16;:14;:16::i;:::-;26346:33;;26417:1;26408:6;:10;26400:64;;;;;-1:-1:-1;;;26400:64:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;26485:15;26503:12;:10;:12::i;:::-;26485:30;;26565:1;26544:18;26554:7;26544:9;:18::i;:::-;:22;26536:78;;;;-1:-1:-1;;;26536:78:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26635:14;26652:18;26662:7;26652:9;:18::i;:::-;26635:35;;26695:28;26708:6;26716;26695:12;:28::i;:::-;26691:564;;;26754:14;26771:18;:6;26782;26771:18;:10;:18;:::i;:::-;26754:35;-1:-1:-1;26813:18:0;:6;26754:35;26813:18;:10;:18;:::i;:::-;26804:27;;26895:7;:5;:7::i;:::-;-1:-1:-1;;;;;26860:21:0;;;;;;:12;:21;;;;;:42;26927:7;;:19;;26939:6;26927:19;:11;:19;:::i;:::-;26917:7;:29;26961:22;26967:7;26976:6;26961:5;:22::i;:::-;27003:25;;;;;;;;-1:-1:-1;;;;;27003:25:0;;;;;;;;;;;;;26691:564;;;;27110:7;:5;:7::i;:::-;-1:-1:-1;;;;;27075:21:0;;;;;;:12;:21;;;;;:42;27142:7;;:19;;27154:6;27142:19;:11;:19;:::i;:::-;27132:7;:29;27176:22;27182:7;27191:6;27176:5;:22::i;:::-;27218:25;;;;;;;;-1:-1:-1;;;;;27218:25:0;;;;;;;;;;;;;26691:564;27272:4;27265:11;;;;;26293:991;:::o;31594:612::-;31700:4;31725:14;:12;:14::i;:::-;:35;;;-1:-1:-1;31756:4:0;;-1:-1:-1;;;;;31743:17:0;;;31756:4;;;;;31743:17;31725:35;:53;;;-1:-1:-1;31774:4:0;;-1:-1:-1;;;;;31764:14:0;;;31774:4;;;;;31764:14;31725:53;31717:159;;;;-1:-1:-1;;;31717:159:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31897:45;31916:6;31924:9;31935:6;31897:18;:45::i;:::-;31953:32;31970:6;31978;31953:16;:32::i;:::-;32006:36;32016:6;32024:9;32035:6;32006:9;:36::i;:::-;32053:121;32062:6;32070:12;:10;:12::i;:::-;32084:89;32122:6;32084:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;32084:19:0;;;;;;:11;:19;;;;;;32104:12;:10;:12::i;:::-;-1:-1:-1;;;;;32084:33:0;;;;;;;;;;;;-1:-1:-1;32084:33:0;;;:89;;:37;:89;:::i;:::-;32053:8;:121::i;:::-;-1:-1:-1;32194:4:0;31594:612;;;;;:::o;30329:83::-;23242:2;30329:83;:::o;30526:95::-;30599:14;30526:95;:::o;32218:218::-;32306:4;32323:83;32332:12;:10;:12::i;:::-;32346:7;32355:50;32394:10;32355:11;:25;32367:12;:10;:12::i;:::-;-1:-1:-1;;;;;32355:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;32355:25:0;;;:34;;;;;;;;;;;:50;:38;:50;:::i;25950:331::-;25987:4;26004:15;26022:12;:10;:12::i;:::-;26004:30;;26074:7;:5;:7::i;:::-;-1:-1:-1;;;;;26063:18:0;:7;-1:-1:-1;;;;;26063:18:0;;:37;;;-1:-1:-1;26096:4:0;;-1:-1:-1;;;;;26085:15:0;;;26096:4;;;;;26085:15;26063:37;26055:116;;;;-1:-1:-1;;;26055:116:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26184:7;:15;;-1:-1:-1;;26184:15:0;;;-1:-1:-1;;;;;26225:26:0;;;26243:7;:5;:7::i;:::-;26225:26;;;;;;;;;;;;;;;26269:4;26262:11;;;25950:331;:::o;29916:101::-;29996:13;;29916:101;:::o;30023:116::-;30076:7;30103:28;30121:9;:7;:9::i;:::-;30103:13;:11;:13::i;:::-;:17;:28;:17;:28;:::i;:::-;30096:35;;30023:116;:::o;29293:89::-;29367:7;;29293:89;:::o;29500:80::-;29567:5;29500:80;:::o;28342:469::-;28399:7;28448:1;28423:22;28437:7;28423:13;:22::i;:::-;:26;28419:385;;;-1:-1:-1;;;;;28509:21:0;;28480:14;28509:21;;;:12;:21;;;;;:32;28497:45;;:7;:5;:7::i;:::-;:11;:45;:11;:45;:::i;:::-;28480:62;;28557:12;28572:9;:7;:9::i;:::-;28557:24;;28624:4;28614:6;:14;28610:127;;28656:16;:6;28667:4;28656:16;:10;:16;:::i;:::-;28649:23;;;;;;28610:127;28720:1;28713:8;;;;;;28419:385;-1:-1:-1;28791:1:0;28784:8;;30633:119;-1:-1:-1;;;;;30726:18:0;30699:7;30726:18;;;:9;:18;;;;;;;30633:119::o;22115:148::-;21695:12;:10;:12::i;:::-;21685:6;;-1:-1:-1;;;;;21685:6:0;;;:22;;;21677:67;;;;;-1:-1:-1;;;21677:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22222:1:::1;22206:6:::0;;22185:40:::1;::::0;-1:-1:-1;;;;;22206:6:0;;::::1;::::0;22185:40:::1;::::0;22222:1;;22185:40:::1;22253:1;22236:19:::0;;-1:-1:-1;;;;;;22236:19:0::1;::::0;;22115:148::o;28955:155::-;29014:7;29041:61;29085:16;:14;:16::i;:::-;29042:37;23426:3;29042:21;29055:7;29042:12;:21::i;:::-;:25;:37;:25;:37;:::i;21473:79::-;21511:7;21538:6;-1:-1:-1;;;;;21538:6:0;21473:79;:::o;30236:87::-;30308:7;;;;;;;;;;;;-1:-1:-1;;;30308:7:0;;;;30236:87;:::o;32442:269::-;32535:4;32552:129;32561:12;:10;:12::i;:::-;32575:7;32584:96;32623:15;32584:96;;;;;;;;;;;;;;;;;:11;:25;32596:12;:10;:12::i;:::-;-1:-1:-1;;;;;32584:25:0;;;;;;;;;;;;;;;;;-1:-1:-1;32584:25:0;;;:34;;;;;;;;;;;:96;;:38;:96;:::i;31094:494::-;31180:4;31197:14;31214:12;:10;:12::i;:::-;31197:29;;31247:14;:12;:14::i;:::-;:35;;;-1:-1:-1;31278:4:0;;-1:-1:-1;;;;;31265:17:0;;;31278:4;;;;;31265:17;31247:35;:53;;;-1:-1:-1;31296:4:0;;-1:-1:-1;;;;;31286:14:0;;;31296:4;;;;;31286:14;31247:53;31239:159;;;;-1:-1:-1;;;31239:159:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31411:45;31430:6;31438:9;31449:6;31411:18;:45::i;:::-;31467:32;31484:6;31492;31467:16;:32::i;:::-;31520:36;31530:6;31538:9;31549:6;31520:9;:36::i;27290:728::-;27343:4;27360:15;27378:12;:10;:12::i;:::-;27360:30;-1:-1:-1;27401:17:0;27421:26;:6;23299:24;27421:26;:10;:26;:::i;:::-;27401:46;;27476:31;27488:7;27497:9;27476:11;:31::i;:::-;27468:90;;;;-1:-1:-1;;;27468:90:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27587:23;27602:7;27587:14;:23::i;:::-;27579:74;;;;;-1:-1:-1;;;27579:74:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;27682:24;27696:9;27682:13;:24::i;:::-;27674:82;;;;-1:-1:-1;;;27674:82:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27812:7;:5;:7::i;:::-;-1:-1:-1;;;;;27777:21:0;;;;;;:12;:21;;;;;:42;;;27830:31;;:43;;;27908:11;;:26;;27864:9;27908:26;:15;:26;:::i;:::-;27894:11;:40;27960:28;;;;;;;;-1:-1:-1;;;;;27960:28:0;;;;;;;;;;;;;-1:-1:-1;28006:4:0;;27290:728;-1:-1:-1;;;27290:728:0:o;29388:97::-;29466:11;;29388:97;:::o;29116:164::-;29173:7;29199:73;29222:49;23426:3;29223:31;29233:20;29245:7;29233:11;:20::i;:::-;23299:24;;29223:31;:9;:31;:::i;29222:49::-;29199:18;29209:7;29199:9;:18::i;29778:126::-;29822:7;29849:47;29879:16;:14;:16::i;:::-;29849:25;29859:14;:12;:14::i;:::-;29849:9;:25::i;28116:80::-;23299:24;28116:80;:::o;30760:151::-;-1:-1:-1;;;;;30876:18:0;;;30849:7;30876:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;30760:151::o;29586:84::-;29654:8;29586:84;:::o;29676:94::-;29750:12;29676:94;:::o;22418:244::-;21695:12;:10;:12::i;:::-;21685:6;;-1:-1:-1;;;;;21685:6:0;;;:22;;;21677:67;;;;;-1:-1:-1;;;21677:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;22507:22:0;::::1;22499:73;;;;-1:-1:-1::0;;;22499:73:0::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22609:6;::::0;;22588:38:::1;::::0;-1:-1:-1;;;;;22588:38:0;;::::1;::::0;22609:6;::::1;::::0;22588:38:::1;::::0;::::1;22637:6;:17:::0;;-1:-1:-1;;;;;;22637:17:0::1;-1:-1:-1::0;;;;;22637:17:0;;;::::1;::::0;;;::::1;::::0;;22418:244::o;28823:126::-;-1:-1:-1;;;;;28910:21:0;28883:7;28910:21;;;:12;:21;;;;;:31;;;;28823:126::o;12463:106::-;12551:10;12463:106;:::o;34659:346::-;-1:-1:-1;;;;;34761:19:0;;34753:68;;;;-1:-1:-1;;;34753:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;34840:21:0;;34832:68;;;;-1:-1:-1;;;34832:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;34913:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;34965:32;;;;;;;;;;;;;;;;;34659:346;;;:::o;39307:162::-;39384:4;39414:7;39405:6;:16;39401:61;;;-1:-1:-1;39432:4:0;39425:11;;39401:61;-1:-1:-1;39454:5:0;39447:12;;755:136;813:7;840:43;844:1;847;840:43;;;;;;;;;;;;;;;;;:3;:43::i;:::-;833:50;755:136;-1:-1:-1;;;755:136:0:o;40196:89::-;40262:15;40196:89;:::o;33949:326::-;-1:-1:-1;;;;;34033:21:0;;34025:65;;;;;-1:-1:-1;;;34025:65:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;34118:12;;:24;;34135:6;34118:24;:16;:24;:::i;:::-;34103:12;:39;-1:-1:-1;;;;;34174:18:0;;;;;;:9;:18;;;;;;:30;;34197:6;34174:30;:22;:30;:::i;:::-;-1:-1:-1;;;;;34153:18:0;;;;;;:9;:18;;;;;;;;:51;;;;34230:37;;;;;;;34153:18;;;;-1:-1:-1;;;;;;;;;;;34230:37:0;;;;;;;;;33949:326;;:::o;37674:122::-;37741:7;;37720:4;;37741:7;;37737:52;;;-1:-1:-1;37759:5:0;37752:12;;37737:52;-1:-1:-1;37782:4:0;37775:11;;35590:591;35692:20;35702:9;35692;:20::i;:::-;35688:238;;;35733:31;35746:9;35757:6;35733:12;:31::i;:::-;35729:186;;;35785:26;35801:9;35785:15;:26::i;:::-;;35833:12;:10;:12::i;:::-;35830:70;;;35870:10;:8;:10::i;:::-;;35830:70;35940:20;35953:6;35940:12;:20::i;:::-;35936:238;;;35981:31;35997:6;36005;35981:15;:31::i;:::-;35977:186;;;36033:26;36052:6;36033:18;:26::i;:::-;;36081:12;:10;:12::i;:::-;36078:70;;;36118:10;:8;:10::i;:::-;;36078:70;35590:591;;;:::o;36187:559::-;36269:22;36283:7;36269:13;:22::i;:::-;36265:474;;;36345:21;36358:7;36345:12;:21::i;:::-;36312:30;36335:6;36312:18;36322:7;36312:9;:18::i;:30::-;:54;36308:420;;;36405:18;36426:21;36439:7;36426:12;:21::i;:::-;36480:11;;36405:42;;-1:-1:-1;36480:27:0;;36405:42;36480:27;:15;:27;:::i;:::-;36466:11;:41;-1:-1:-1;;;;;36551:21:0;;;;;;:12;:21;;;;;;;;36544:39;;;36609:31;;36602:38;;;;36682:30;;;;;;;;;;;;;;;;;36308:420;;36187:559;;:::o;32723:1218::-;-1:-1:-1;;;;;32829:20:0;;32821:70;;;;-1:-1:-1;;;32821:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;32910:23:0;;32902:71;;;;-1:-1:-1;;;32902:71:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33008:7;:5;:7::i;:::-;-1:-1:-1;;;;;32998:17:0;:6;-1:-1:-1;;;;;32998:17:0;;:38;;;;-1:-1:-1;33032:4:0;;-1:-1:-1;;;;;33019:17:0;;;33032:4;;;;;33019:17;32998:38;:56;;;-1:-1:-1;33050:4:0;;-1:-1:-1;;;;;33040:14:0;;;33050:4;;;;;33040:14;32998:56;32994:940;;;33091:71;33113:6;33091:71;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;33091:17:0;;;;;;:9;:17;;;;;;;:71;;:21;:71;:::i;:::-;-1:-1:-1;;;;;33071:17:0;;;;;;;:9;:17;;;;;;:91;;;;33200:20;;;;;;;:32;;33225:6;33200:32;:24;:32;:::i;:::-;-1:-1:-1;;;;;33177:20:0;;;;;;;:9;:20;;;;;;;;;:55;;;;33266:35;;;;;;;33177:20;;33266:35;;;;-1:-1:-1;;;;;;;;;;;33266:35:0;;;;;;;;32994:940;;;33348:15;33366:23;33382:6;33366:15;:23::i;:::-;33348:41;;33404:18;33414:7;33404:9;:18::i;:::-;-1:-1:-1;33451:15:0;33469:14;:7;33481:1;33469:14;:11;:14;:::i;:::-;33451:32;;33498:15;33505:7;33498:6;:15::i;:::-;-1:-1:-1;33542:13:0;33558:14;:7;33570:1;33558:14;:11;:14;:::i;:::-;33542:30;;33587:13;33594:5;33587:6;:13::i;:::-;-1:-1:-1;33629:17:0;33649:19;:6;33660:7;33649:19;:10;:19;:::i;:::-;33629:39;;33703:74;33725:9;33703:74;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;33703:17:0;;;;;;:9;:17;;;;;;;:74;;:21;:74;:::i;:::-;-1:-1:-1;;;;;33683:17:0;;;;;;;:9;:17;;;;;;:94;;;;33815:20;;;;;;;:35;;33840:9;33815:35;:24;:35;:::i;:::-;-1:-1:-1;;;;;33792:20:0;;;;;;;:9;:20;;;;;;;;;:58;;;;33884:38;;;;;;;33792:20;;33884:38;;;;-1:-1:-1;;;;;;;;;;;33884:38:0;;;;;;;;32994:940;;;;32723:1218;;;:::o;1194:192::-;1280:7;1316:12;1308:6;;;;1300:29;;;;-1:-1:-1;;;1300:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;1300:29:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;1352:5:0;;;1194:192::o;291:181::-;349:7;381:5;;;405:6;;;;397:46;;;;;-1:-1:-1;;;397:46:0;;;;;;;;;;;;;;;;;;;;;;;;;;;2592:132;2650:7;2677:39;2681:1;2684;2677:39;;;;;;;;;;;;;;;;;:3;:39::i;1645:471::-;1703:7;1948:6;1944:47;;-1:-1:-1;1978:1:0;1971:8;;1944:47;2015:5;;;2019:1;2015;:5;:1;2039:5;;;;;:10;2031:56;;;;-1:-1:-1;;;2031:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;38796:173;38872:4;38915:6;38893:18;38903:7;38893:9;:18::i;:::-;:28;38889:73;;-1:-1:-1;38932:4:0;38925:11;;38620:170;38683:4;38726:16;:14;:16::i;:::-;38704:18;38714:7;38704:9;:18::i;:::-;:38;38700:83;;-1:-1:-1;38753:4:0;38746:11;;38975:156;39036:4;39067:16;:14;:16::i;:::-;39057:6;:26;39053:71;;-1:-1:-1;39094:4:0;39087:11;;38485:123;38543:7;38570:29;22943:9;38570:18;38580:7;38570:9;:18::i;40096:94::-;40177:4;40096:94;:::o;37804:164::-;37862:4;37904:16;:14;:16::i;:::-;37883:18;37893:7;37883:9;:18::i;:::-;:37;37879:82;;;-1:-1:-1;37931:4:0;37924:11;;39481:196;39558:4;39613:16;:14;:16::i;:::-;39579:30;39602:6;39579:18;39589:7;39579:9;:18::i;:::-;:22;:30;:22;:30;:::i;37185:160::-;37261:13;:15;;;;;;37244:4;-1:-1:-1;;;;;37292:23:0;;;37307:7;:5;:7::i;:::-;37292:23;;;;;;;;;;;;;;;-1:-1:-1;37333:4:0;37185:160;;;:::o;39893:191::-;39937:4;39984:22;:20;:22::i;:::-;39958;:20;:22::i;:::-;:48;;:78;;;;;40035:1;40010:22;:20;:22::i;:::-;:26;39958:78;39954:123;;;-1:-1:-1;40047:4:0;40040:11;;39954:123;-1:-1:-1;40069:5:0;40062:12;;36762:207;36799:4;36816:14;36833:9;:7;:9::i;:::-;36816:26;;36853:29;36859:14;:12;:14::i;:::-;36875:6;36853:5;:29::i;:::-;36898:31;36907:13;:11;:13::i;:::-;36898:31;;;;;;;;;;;;;;;;;;;;;36947:4;36940:11;;;36762:207;:::o;37974:167::-;38035:4;38077:16;:14;:16::i;:::-;38056:18;38066:7;38056:9;:18::i;:::-;:37;38052:82;;;-1:-1:-1;38104:4:0;38097:11;;39683:198;39763:4;39817:16;:14;:16::i;:::-;39784:30;39807:6;39784:18;39794:7;39784:9;:18::i;:30::-;:49;39780:94;;;-1:-1:-1;39844:4:0;39837:11;;37352:165;37431:13;:15;;-1:-1:-1;;37431:15:0;;;37414:4;-1:-1:-1;;;;;37462:25:0;;;37479:7;:5;:7::i;36975:198::-;37012:4;37029:14;37046:9;:7;:9::i;:::-;37029:26;;37066:29;37072:14;:12;:14::i;:::-;37088:6;37066:5;:29::i;:::-;37111:32;37121:13;:11;:13::i;39137:158::-;39199:4;39246:1;39220:23;39235:7;39220:14;:23::i;37526:142::-;37589:7;37616:44;23376:3;37617:24;37628:12;:10;:12::i;:::-;37617:6;;:24;;;:10;:24;:::i;35017:204::-;35069:4;35086:15;35104:12;:10;:12::i;:::-;35086:30;;35127:22;35133:7;35142:6;35127:5;:22::i;:::-;35165:26;;;;;;;;-1:-1:-1;;;;;35165:26:0;;;;;;;;;;;;;-1:-1:-1;35209:4:0;;35017:204;-1:-1:-1;;35017:204:0:o;35227:172::-;35276:4;35293:29;35299:14;:12;:14::i;:::-;35315:6;35293:5;:29::i;:::-;35346:14;:12;:14::i;:::-;-1:-1:-1;;;;;35338:31:0;;35362:6;35338:31;;;;;;;;;;;;;;;;;;-1:-1:-1;35387:4:0;35227:172;;;:::o;35405:173::-;35454:4;35471:29;35477:14;:12;:14::i;35471:29::-;35525:14;:12;:14::i;:::-;-1:-1:-1;;;;;35516:32:0;;35541:6;35516:32;;;;;;;;;;;;;;;;;;-1:-1:-1;35566:4:0;35405:173;;;:::o;3220:278::-;3306:7;3341:12;3334:5;3326:28;;;;-1:-1:-1;;;3326:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27:10:-1;;8:100;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;3326:28:0;;3365:9;3381:1;3377;:5;;;;;;;3220:278;-1:-1:-1;;;;;3220:278:0:o;38293:185::-;38351:7;38401:1;38375:23;38390:7;38375:14;:23::i;:::-;:27;38371:100;;;38413:36;38425:23;38440:7;38425:14;:23::i;:::-;38413:7;:5;:7::i;:36::-;38406:43;;;;34281:366;-1:-1:-1;;;;;34365:21:0;;34357:67;;;;-1:-1:-1;;;34357:67:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34458:68;34481:6;34458:68;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;34458:18:0;;;;;;:9;:18;;;;;;;:68;;:22;:68;:::i;:::-;-1:-1:-1;;;;;34437:18:0;;;;;;:9;:18;;;;;:89;34552:12;;:24;;34569:6;34552:24;:16;:24;:::i;:::-;34537:12;:39;34602:37;;;;;;;;34628:1;;-1:-1:-1;;;;;34602:37:0;;;-1:-1:-1;;;;;;;;;;;34602:37:0;;;;;;;;34281:366;;:::o

Swarm Source

ipfs://2a0e23b9e65934c2f4f0b2f3ba6e193c0fa68330e13da55849f5335612f3156f
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.