ETH Price: $3,373.88 (-6.94%)
Gas: 28 Gwei

Token

Cyclone Protocol (CYC)
 

Overview

Max Total Supply

7,176.631019468061767989 CYC

Holders

193 (0.00%)

Total Transfers

-

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Loading...
Loading
Loading...
Loading
Loading...
Loading

OVERVIEW

Cyclone is a protocol that applies zkSNARKs to enable transactional privacy by breaking the on-chain link between depositor and recipient addresses.

# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
CycloneToken

Compiler Version
v0.5.17+commit.d19bba13

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, GNU GPLv3 license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2021-02-11
*/

// File: contracts/token/IERC20Basic.sol

pragma solidity ^0.5.17;


/**
 * @title ERC20Basic
 * @dev Simpler version of ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/179
 */
contract IERC20Basic {
  function totalSupply() public view returns (uint256);
  function balanceOf(address who) public view returns (uint256);
  function transfer(address to, uint256 value) public returns (bool);
  event Transfer(address indexed from, address indexed to, uint256 value);
}

// File: contracts/token/IERC20.sol

pragma solidity ^0.5.17;



/**
 * @title ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/20
 */
contract IERC20 is IERC20Basic {
  function name() external view returns (string memory);
  function symbol() external view returns (string memory);
  function allowance(address owner, address spender) public view returns (uint256);
  function transferFrom(address from, address to, uint256 value) public returns (bool);
  function approve(address spender, uint256 value) public returns (bool);
  event Approval(address indexed owner, address indexed spender, uint256 value);
}

// File: contracts/token/IMintableToken.sol

pragma solidity ^0.5.17;


contract IMintableToken is IERC20 {
    function mint(address, uint) external returns (bool);
    function burn(uint) external returns (bool);

    event Minted(address indexed to, uint256 amount);
    event Burned(address indexed from, uint256 amount);
    event MinterAdded(address indexed minter);
    event MinterRemoved(address indexed minter);
}

// File: contracts/math/SafeMath.sol

pragma solidity ^0.5.17;


/**
 * @title SafeMath
 * @dev Math operations with safety checks that throw on error
 */
library SafeMath {

  /**
  * @dev Multiplies two numbers, throws on overflow.
  */

  /*@CTK SafeMath_mul
    @tag spec
    @post __reverted == __has_assertion_failure
    @post __has_assertion_failure == __has_overflow
    @post __reverted == false -> c == a * b
    @post msg == msg__post
   */
  /* CertiK Smart Labelling, for more details visit: https://certik.org */
  function mul(uint256 a, uint256 b) internal pure returns (uint256 c) {
    if (a == 0) {
      return 0;
    }
    c = a * b;
    assert(c / a == b);
    return c;
  }

  /**
  * @dev Integer division of two numbers, truncating the quotient.
  */
  /*@CTK SafeMath_div
    @tag spec
    @pre b != 0
    @post __reverted == __has_assertion_failure
    @post __has_overflow == true -> __has_assertion_failure == true
    @post __reverted == false -> __return == a / b
    @post msg == msg__post
   */
  /* CertiK Smart Labelling, for more details visit: https://certik.org */
  function div(uint256 a, uint256 b) internal pure returns (uint256) {
    // assert(b > 0); // Solidity automatically throws when dividing by 0
    // uint256 c = a / b;
    // assert(a == b * c + a % b); // There is no case in which this doesn't hold
    return a / b;
  }

  /**
  * @dev Subtracts two numbers, throws on overflow (i.e. if subtrahend is greater than minuend).
  */
  /*@CTK SafeMath_sub
    @tag spec
    @post __reverted == __has_assertion_failure
    @post __has_overflow == true -> __has_assertion_failure == true
    @post __reverted == false -> __return == a - b
    @post msg == msg__post
   */
  /* CertiK Smart Labelling, for more details visit: https://certik.org */
  function sub(uint256 a, uint256 b) internal pure returns (uint256) {
    assert(b <= a);
    return a - b;
  }

  /**
  * @dev Adds two numbers, throws on overflow.
  */
  /*@CTK SafeMath_add
    @tag spec
    @post __reverted == __has_assertion_failure
    @post __has_assertion_failure == __has_overflow
    @post __reverted == false -> c == a + b
    @post msg == msg__post
   */
  /* CertiK Smart Labelling, for more details visit: https://certik.org */
  function add(uint256 a, uint256 b) internal pure returns (uint256 c) {
    c = a + b;
    assert(c >= a);
    return c;
  }
}

// File: contracts/token/BasicToken.sol

pragma solidity ^0.5.17;




/**
 * @title Basic token
 * @dev Basic version of StandardToken, with no allowances.
 */
contract BasicToken is IERC20Basic {
  using SafeMath for uint256;

  mapping(address => uint256) balances;

  uint256 totalSupply_;

  /**
  * @dev total number of tokens in existence
  */
  function totalSupply() public view returns (uint256) {
    return totalSupply_;
  }

  /**
  * @dev transfer token for a specified address
  * @param _to The address to transfer to.
  * @param _value The amount to be transferred.
  */
  /*@CTK transfer_success
    @pre _to != address(0)
    @pre balances[msg.sender] >= _value
    @pre __reverted == false
    @post __reverted == false
    @post __return == true
   */
  /*@CTK transfer_same_address
    @tag no_overflow
    @pre _to == msg.sender
    @post this == __post
   */
  /*@CTK transfer_conditions
    @tag assume_completion
    @pre _to != msg.sender
    @post __post.balances[_to] == balances[_to] + _value
    @post __post.balances[msg.sender] == balances[msg.sender] - _value
   */
  /* CertiK Smart Labelling, for more details visit: https://certik.org */
  function transfer(address _to, uint256 _value) public returns (bool) {
    require(_to != address(0));
    require(_value <= balances[msg.sender]);

    balances[msg.sender] = balances[msg.sender].sub(_value);
    balances[_to] = balances[_to].add(_value);
    emit Transfer(msg.sender, _to, _value);
    return true;
  }

  /**
  * @dev Gets the balance of the specified address.
  * @param _owner The address to query the the balance of.
  * @return An uint256 representing the amount owned by the passed address.
  */
  /*@CTK balanceOf
    @post __reverted == false
    @post __return == balances[_owner]
   */
  /* CertiK Smart Labelling, for more details visit: https://certik.org */
  function balanceOf(address _owner) public view returns (uint256) {
    return balances[_owner];
  }
}

// File: contracts/token/StandardToken.sol

pragma solidity ^0.5.17;




/**
 * @title Standard ERC20 token
 *
 * @dev Implementation of the basic standard token.
 * @dev https://github.com/ethereum/EIPs/issues/20
 * @dev Based on code by FirstBlood: https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol
 */
contract StandardToken is IERC20, BasicToken {

  mapping (address => mapping (address => uint256)) internal allowed;


  /**
   * @dev Transfer tokens from one address to another
   * @param _from address The address which you want to send tokens from
   * @param _to address The address which you want to transfer to
   * @param _value uint256 the amount of tokens to be transferred
   */
  /*@CTK transferFrom
    @tag assume_completion
    @pre _from != _to
    @post __return == true
    @post __post.balances[_to] == balances[_to] + _value
    @post __post.balances[_from] == balances[_from] - _value
    @post __has_overflow == false
   */
  /* CertiK Smart Labelling, for more details visit: https://certik.org */
  function transferFrom(address _from, address _to, uint256 _value) public returns (bool) {
    require(_to != address(0));
    require(_value <= balances[_from]);
    require(_value <= allowed[_from][msg.sender]);

    balances[_from] = balances[_from].sub(_value);
    balances[_to] = balances[_to].add(_value);
    allowed[_from][msg.sender] = allowed[_from][msg.sender].sub(_value);
    emit Transfer(_from, _to, _value);
    return true;
  }

  /**
   * @dev Approve the passed address to spend the specified amount of tokens on behalf of msg.sender.
   *
   * 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
   * @param _spender The address which will spend the funds.
   * @param _value The amount of tokens to be spent.
   */
  /*@CTK approve_success
    @post _value == 0 -> __reverted == false
    @post allowed[msg.sender][_spender] == 0 -> __reverted == false
   */
  /*@CTK approve
    @tag assume_completion
    @post __post.allowed[msg.sender][_spender] == _value
   */
  /* CertiK Smart Labelling, for more details visit: https://certik.org */
  function approve(address _spender, uint256 _value) public returns (bool) {
    allowed[msg.sender][_spender] = _value;
    emit Approval(msg.sender, _spender, _value);
    return true;
  }

  /**
   * @dev Function to check the amount of tokens that an owner allowed to a spender.
   * @param _owner address The address which owns the funds.
   * @param _spender address The address which will spend the funds.
   * @return A uint256 specifying the amount of tokens still available for the spender.
   */
  function allowance(address _owner, address _spender) public view returns (uint256) {
    return allowed[_owner][_spender];
  }

  /**
   * @dev Increase the amount of tokens that an owner allowed to a spender.
   *
   * approve should be called when allowed[_spender] == 0. To increment
   * allowed value is better to use this function to avoid 2 calls (and wait until
   * the first transaction is mined)
   * From MonolithDAO Token.sol
   * @param _spender The address which will spend the funds.
   * @param _addedValue The amount of tokens to increase the allowance by.
   */
  /*@CTK CtkIncreaseApprovalEffect
    @tag assume_completion
    @post __post.allowed[msg.sender][_spender] == allowed[msg.sender][_spender] + _addedValue
    @post __has_overflow == false
   */
  /* CertiK Smart Labelling, for more details visit: https://certik.org */
  function increaseApproval(address _spender, uint _addedValue) public returns (bool) {
    allowed[msg.sender][_spender] = allowed[msg.sender][_spender].add(_addedValue);
    emit Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
    return true;
  }

  /**
   * @dev Decrease the amount of tokens that an owner allowed to a spender.
   *
   * approve should be called when allowed[_spender] == 0. To decrement
   * allowed value is better to use this function to avoid 2 calls (and wait until
   * the first transaction is mined)
   * From MonolithDAO Token.sol
   * @param _spender The address which will spend the funds.
   * @param _subtractedValue The amount of tokens to decrease the allowance by.
   */
  /*@CTK CtkDecreaseApprovalEffect_1
    @pre allowed[msg.sender][_spender] >= _subtractedValue
    @tag assume_completion
    @post __post.allowed[msg.sender][_spender] == allowed[msg.sender][_spender] - _subtractedValue
    @post __has_overflow == false
   */
   /*@CTK CtkDecreaseApprovalEffect_2
    @pre allowed[msg.sender][_spender] < _subtractedValue
    @tag assume_completion
    @post __post.allowed[msg.sender][_spender] == 0
    @post __has_overflow == false
   */
  /* CertiK Smart Labelling, for more details visit: https://certik.org */
  function decreaseApproval(address _spender, uint _subtractedValue) public returns (bool) {
    uint oldValue = allowed[msg.sender][_spender];
    if (_subtractedValue > oldValue) {
      allowed[msg.sender][_spender] = 0;
    } else {
      allowed[msg.sender][_spender] = oldValue.sub(_subtractedValue);
    }
    emit Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
    return true;
  }

}

// File: contracts/ownership/Ownable.sol

pragma solidity ^0.5.17;


/**
 * @title Ownable
 * @dev The Ownable contract has an owner address, and provides basic authorization control
 * functions, this simplifies the implementation of "user permissions".
 */
contract Ownable {
  address public owner;


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


  /**
   * @dev The Ownable constructor sets the original `owner` of the contract to the sender
   * account.
   */
  constructor() public {
    owner = msg.sender;
  }

  /**
   * @dev Throws if called by any account other than the owner.
   */
  modifier onlyOwner() {
    require(msg.sender == owner);
    _;
  }

  /**
   * @dev Allows the current owner to transfer control of the contract to a newOwner.
   * @param newOwner The address to transfer ownership to.
   */
  function transferOwnership(address newOwner) public onlyOwner {
    require(newOwner != address(0));
    emit OwnershipTransferred(owner, newOwner);
    owner = newOwner;
  }

}

// File: contracts/lifecycle/Pausable.sol

pragma solidity ^0.5.17;


/**
 * @title Pausable
 * @dev Base contract which allows children to implement an emergency stop mechanism.
 */
contract Pausable is Ownable {
  event Pause();
  event Unpause();

  bool public paused = false;


  /**
   * @dev Modifier to make a function callable only when the contract is not paused.
   */
  modifier whenNotPaused() {
    require(!paused);
    _;
  }

  /**
   * @dev Modifier to make a function callable only when the contract is paused.
   */
  modifier whenPaused() {
    require(paused);
    _;
  }

  /**
   * @dev called by the owner to pause, triggers stopped state
   */
  function pause() onlyOwner whenNotPaused public {
    paused = true;
    emit Pause();
  }

  /**
   * @dev called by the owner to unpause, returns to normal state
   */
  function unpause() onlyOwner whenPaused public {
    paused = false;
    emit Unpause();
  }
}

// File: contracts/token/ShadowToken.sol

pragma solidity ^0.5.17;




contract ShadowToken is StandardToken, IMintableToken, Pausable {
    event Minted(address indexed to, uint256 amount);
    event Burned(address indexed from, uint256 amount);
    event MinterAdded(address indexed minter);
    event MinterRemoved(address indexed minter);

    modifier onlyMinter() {
        require(minter == msg.sender, "not the minter");
        _;
    }

    address public coToken;
    address public minter;
    string public name;
    string public symbol;
    uint8 public decimals;

    constructor(address _minter, address _coToken, string memory _name, string memory _symbol, uint8 _decimals) public {
        minter = _minter;
        coToken = _coToken;
        name = _name;
        symbol = _symbol;
        decimals = _decimals;
        emit MinterAdded(_minter);
    }

    function mint(address _to, uint256 _amount) public onlyMinter whenNotPaused returns (bool) {
        totalSupply_ = totalSupply_.add(_amount);
        balances[_to] = balances[_to].add(_amount);
        emit Minted(_to, _amount);
        emit Transfer(address(0), _to, _amount);
        return true;
    }

    // user can also burn by sending token to address(0), but this function will emit Burned event
    function burn(uint256 _amount) public returns (bool) {
        require(balances[msg.sender] >= _amount);
        totalSupply_ = totalSupply_.sub(_amount);
        balances[msg.sender] = balances[msg.sender].sub(_amount);
        emit Burned(msg.sender, _amount);
        emit Transfer(msg.sender, address(0), _amount);
        return true;
    }
}

// File: contracts/token/CycloneToken.sol

pragma solidity ^0.5.17;





contract CycloneToken is StandardToken, IMintableToken, Pausable {

    modifier onlyOperator() {
        require(operator == msg.sender, "not the operator");
        _;
    }

    // Minters include Aeolus (liquidity mining) and CoinCyclone/ERC20Cyclone (anonymity mining)
    modifier onlyMinters() {
        require(minters[msg.sender] == true, "not the minter");
        _;
    }

    address public operator;
    mapping (address => bool) public minters;
    string public constant name = "Cyclone Protocol";
    string public constant symbol = "CYC";
    uint8 public constant decimals = 18;

    constructor(address _operator, address _lp) public {
        require (_operator != address(0), "invalid address");
        if (_lp != address(0)) {
            // mint 2021 CYC for community
            totalSupply_ = totalSupply_.add(2021 * 1000000000000000000);	
            balances[_lp] = balances[_lp].add(2021 * 1000000000000000000);
            _moveDelegates(address(0), delegates[_lp], 2021 * 1000000000000000000);
        }
        operator = _operator;
    }

    function addMinter(address _minter) external onlyOperator {
        minters[_minter] = true;
        emit MinterAdded(_minter);
    }

    function removeMinter(address _minter) external onlyOperator {
        minters[_minter] = false;
        emit MinterRemoved(_minter);
    }

    function updateOperator(address _operator) external onlyOperator {
        require (_operator != address(0), "invalid operator address");
        operator = _operator;
    }

    function mint(address _to, uint256 _amount) public onlyMinters whenNotPaused returns (bool) {
        require (_to != address(0), "invalid address for mint");
        require (_amount != 0, "mint amount should not be zero");
        totalSupply_ = totalSupply_.add(_amount);
        balances[_to] = balances[_to].add(_amount);
        emit Minted(_to, _amount);
        emit Transfer(address(0), _to, _amount);
        _moveDelegates(address(0), delegates[_to], _amount);
        return true;
    }

    // user can also burn by sending token to address(0), but this function will emit Burned event
    function burn(uint256 _amount) public returns (bool) {
        require (_amount != 0, "burn amount should not be zero");
        require(balances[msg.sender] >= _amount);
        totalSupply_ = totalSupply_.sub(_amount);
        balances[msg.sender] = balances[msg.sender].sub(_amount);
        emit Burned(msg.sender, _amount);
        emit Transfer(msg.sender, address(0), _amount);
        _moveDelegates(delegates[msg.sender], address(0), _amount);
        return true;
    }
  
    // Which is copied and modified from COMPOUND:
    // https://github.com/compound-finance/compound-protocol/blob/master/contracts/Governance/Comp.sol
    
    /// @notice A checkpoint for marking number of votes from a given block
    struct Checkpoint {
        uint32 fromBlock;
        uint256 votes;
    }

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

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

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

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

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

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

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

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

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

    /**
     * @notice Transfer `amount` tokens from `src` to `dst`
     * @param src The address of the source account
     * @param dst The address of the destination account
     * @param amount The number of tokens to transfer
     * @return Whether or not the transfer succeeded
     */
    function transferFrom(address src, address dst, uint256 amount) public returns (bool) {
        address spender = msg.sender;
        uint256 spenderAllowance = allowed[src][spender];

        if (spender != src) {
            uint256 newAllowance = spenderAllowance.sub(amount);
            allowed[src][spender] = newAllowance;

            emit Approval(src, spender, newAllowance);
        }

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

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

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

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

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

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

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

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

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

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

        emit DelegateChanged(delegator, currentDelegate, delegatee);

        _moveDelegates(currentDelegate, delegatee, delegatorBalance);
    }

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

        balances[src] = balances[src].sub(amount);
        balances[dst] = balances[dst].add(amount);
        emit Transfer(src, dst, amount);

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

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

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

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

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

      emit DelegateVotesChanged(delegatee, oldVotes, newVotes);
    }

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

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_operator","type":"address"},{"internalType":"address","name":"_lp","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Burned","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"delegator","type":"address"},{"indexed":true,"internalType":"address","name":"fromDelegate","type":"address"},{"indexed":true,"internalType":"address","name":"toDelegate","type":"address"}],"name":"DelegateChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"delegate","type":"address"},{"indexed":false,"internalType":"uint256","name":"previousBalance","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"newBalance","type":"uint256"}],"name":"DelegateVotesChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Minted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"minter","type":"address"}],"name":"MinterAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"minter","type":"address"}],"name":"MinterRemoved","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":[],"name":"Pause","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":[],"name":"Unpause","type":"event"},{"constant":true,"inputs":[],"name":"DELEGATION_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"DOMAIN_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_minter","type":"address"}],"name":"addMinter","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"_owner","type":"address"},{"internalType":"address","name":"_spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_spender","type":"address"},{"internalType":"uint256","name":"_value","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"burn","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint32","name":"","type":"uint32"}],"name":"checkpoints","outputs":[{"internalType":"uint32","name":"fromBlock","type":"uint32"},{"internalType":"uint256","name":"votes","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_spender","type":"address"},{"internalType":"uint256","name":"_subtractedValue","type":"uint256"}],"name":"decreaseApproval","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"delegatee","type":"address"}],"name":"delegate","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"delegatee","type":"address"},{"internalType":"uint256","name":"nonce","type":"uint256"},{"internalType":"uint256","name":"expiry","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"delegateBySig","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"delegates","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getCurrentVotes","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"blockNumber","type":"uint256"}],"name":"getPriorVotes","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_spender","type":"address"},{"internalType":"uint256","name":"_addedValue","type":"uint256"}],"name":"increaseApproval","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"mint","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"minters","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"numCheckpoints","outputs":[{"internalType":"uint32","name":"","type":"uint32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"operator","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"pause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_minter","type":"address"}],"name":"removeMinter","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"dst","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"src","type":"address"},{"internalType":"address","name":"dst","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"unpause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_operator","type":"address"}],"name":"updateOperator","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"}]

60806040526003805460ff60a01b191690553480156200001e57600080fd5b506040516200239638038062002396833981810160405260408110156200004457600080fd5b508051602090910151600380546001600160a01b031916331790556001600160a01b038216620000ad576040805162461bcd60e51b815260206004820152600f60248201526e696e76616c6964206164647265737360881b604482015290519081900360640190fd5b6001600160a01b038116156200016457620000e2686d8f025848787400006001546200018b60201b620018981790919060201c565b6001556001600160a01b038116600090815260208181526040909120546200011e91686d8f0258487874000090620018986200018b821b17901c565b6001600160a01b0380831660009081526020818152604080832094909455600890529182205462000164929116686d8f025848787400006001600160e01b036200019f16565b50600480546001600160a01b0319166001600160a01b039290921691909117905562000549565b818101828110156200019957fe5b92915050565b816001600160a01b0316836001600160a01b031614158015620001c25750600081115b156200031e576001600160a01b0383161562000273576001600160a01b03831660009081526007602052604081205463ffffffff1690816200020657600062000238565b6001600160a01b038516600090815260066020908152604080832063ffffffff60001987011684529091529020600101545b905060006200025684836200032360201b620017121790919060201c565b90506200026f868484846001600160e01b036200033616565b5050505b6001600160a01b038216156200031e576001600160a01b03821660009081526007602052604081205463ffffffff169081620002b1576000620002e3565b6001600160a01b038416600090815260066020908152604080832063ffffffff60001987011684529091529020600101545b905060006200030184836200018b60201b620018981790919060201c565b90506200031a858484846001600160e01b036200033616565b5050505b505050565b6000828211156200033057fe5b50900390565b600062000366436040518060600160405280602e815260200162002368602e91396001600160e01b03620004aa16565b905060008463ffffffff16118015620003b057506001600160a01b038516600090815260066020908152604080832063ffffffff6000198901811685529252909120548282169116145b15620003ef576001600160a01b038516600090815260066020908152604080832063ffffffff6000198901168452909152902060010182905562000460565b60408051808201825263ffffffff808416825260208083018681526001600160a01b038a166000818152600684528681208b8616825284528681209551865490861663ffffffff19918216178755925160019687015590815260079092529390208054928801909116919092161790555b604080518481526020810184905281516001600160a01b038816927fdec2bacdd2f05b59de34da9b523dff8be42e5e38e818c82fdb0bae774387a724928290030190a25050505050565b6000816401000000008410620005415760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101562000505578181015183820152602001620004eb565b50505050905090810190601f168015620005335780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b509192915050565b611e0f80620005596000396000f3fe608060405234801561001057600080fd5b50600436106101fb5760003560e01c806370a082311161011a578063ac7475ed116100ad578063dd62ed3e1161007c578063dd62ed3e14610630578063e7a324dc1461065e578063f1127ed814610666578063f2fde38b146106b8578063f46eccc4146106de576101fb565b8063ac7475ed14610571578063b4b5ea5714610597578063c3cda520146105bd578063d73dd62314610604576101fb565b80638da5cb5b116100e95780638da5cb5b1461050f57806395d89b4114610517578063983b2d561461051f578063a9059cbb14610545576101fb565b806370a082311461048f578063782d6fe1146104b55780637ecebe00146104e15780638456cb5914610507576101fb565b806340c10f19116101925780635c19a95c116101615780635c19a95c146103f65780635c975abb1461041c57806366188463146104245780636fcfff4514610450576101fb565b806340c10f191461036357806342966c681461038f578063570ca735146103ac578063587cde1e146103d0576101fb565b806323b872dd116101ce57806323b872dd146102df5780633092afd514610315578063313ce5671461033d5780633f4ba83a1461035b576101fb565b806306fdde0314610200578063095ea7b31461027d57806318160ddd146102bd57806320606b70146102d7575b600080fd5b610208610704565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561024257818101518382015260200161022a565b50505050905090810190601f16801561026f5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102a96004803603604081101561029357600080fd5b506001600160a01b038135169060200135610730565b604080519115158252519081900360200190f35b6102c5610785565b60408051918252519081900360200190f35b6102c561078b565b6102a9600480360360608110156102f557600080fd5b506001600160a01b038135811691602081013590911690604001356107a6565b61033b6004803603602081101561032b57600080fd5b50356001600160a01b0316610851565b005b6103456108ec565b6040805160ff9092168252519081900360200190f35b61033b6108f1565b6102a96004803603604081101561037957600080fd5b506001600160a01b038135169060200135610956565b6102a9600480360360208110156103a557600080fd5b5035610b72565b6103b4610cc5565b604080516001600160a01b039092168252519081900360200190f35b6103b4600480360360208110156103e657600080fd5b50356001600160a01b0316610cd4565b61033b6004803603602081101561040c57600080fd5b50356001600160a01b0316610cef565b6102a9610cfc565b6102a96004803603604081101561043a57600080fd5b506001600160a01b038135169060200135610d0c565b6104766004803603602081101561046657600080fd5b50356001600160a01b0316610dea565b6040805163ffffffff9092168252519081900360200190f35b6102c5600480360360208110156104a557600080fd5b50356001600160a01b0316610e02565b6102c5600480360360408110156104cb57600080fd5b506001600160a01b038135169060200135610e1d565b6102c5600480360360208110156104f757600080fd5b50356001600160a01b0316611025565b61033b611037565b6103b46110a3565b6102086110b2565b61033b6004803603602081101561053557600080fd5b50356001600160a01b03166110d1565b6102a96004803603604081101561055b57600080fd5b506001600160a01b03813516906020013561116f565b61033b6004803603602081101561058757600080fd5b50356001600160a01b031661117c565b6102c5600480360360208110156105ad57600080fd5b50356001600160a01b031661124b565b61033b600480360360c08110156105d357600080fd5b506001600160a01b038135169060208101359060408101359060ff6060820135169060808101359060a001356112af565b6102a96004803603604081101561061a57600080fd5b506001600160a01b03813516906020013561157d565b6102c56004803603604081101561064657600080fd5b506001600160a01b0381358116916020013516611604565b6102c561162f565b6106986004803603604081101561067c57600080fd5b5080356001600160a01b0316906020013563ffffffff1661164a565b6040805163ffffffff909316835260208301919091528051918290030190f35b61033b600480360360208110156106ce57600080fd5b50356001600160a01b0316611677565b6102a9600480360360208110156106f457600080fd5b50356001600160a01b03166116fd565b6040518060400160405280601081526020016f10de58db1bdb9948141c9bdd1bd8dbdb60821b81525081565b3360008181526002602090815260408083206001600160a01b03871680855290835281842086905581518681529151939490939092600080516020611d81833981519152928290030190a35060015b92915050565b60015490565b604051806043611ca682396043019050604051809103902081565b6001600160a01b03831660008181526002602090815260408083203380855292528220549192909190821461083a5760006107e7828663ffffffff61171216565b6001600160a01b038089166000818152600260209081526040808320948916808452948252918290208590558151858152915194955092939192600080516020611d8183398151915292918290030190a3505b610845868686611724565b50600195945050505050565b6004546001600160a01b031633146108a3576040805162461bcd60e51b815260206004820152601060248201526f3737ba103a34329037b832b930ba37b960811b604482015290519081900360640190fd5b6001600160a01b038116600081815260056020526040808220805460ff19169055517fe94479a9f7e1952cc78f2d6baab678adc1b772d936c6583def489e524cb666929190a250565b601281565b6003546001600160a01b0316331461090857600080fd5b600354600160a01b900460ff1661091e57600080fd5b6003805460ff60a01b191690556040517f7805862f689e2f13df9f062ff482ad3ad112aca9e0847911ed832e158c525b3390600090a1565b3360009081526005602052604081205460ff1615156001146109b0576040805162461bcd60e51b815260206004820152600e60248201526d3737ba103a34329036b4b73a32b960911b604482015290519081900360640190fd5b600354600160a01b900460ff16156109c757600080fd5b6001600160a01b038316610a22576040805162461bcd60e51b815260206004820152601860248201527f696e76616c6964206164647265737320666f72206d696e740000000000000000604482015290519081900360640190fd5b81610a74576040805162461bcd60e51b815260206004820152601e60248201527f6d696e7420616d6f756e742073686f756c64206e6f74206265207a65726f0000604482015290519081900360640190fd5b600154610a87908363ffffffff61189816565b6001556001600160a01b038316600090815260208190526040902054610ab3908363ffffffff61189816565b6001600160a01b03841660008181526020818152604091829020939093558051858152905191927f30385c845b448a36257a6a1716e6ad2e1bc2cbe333cde1e69fe849ad6511adfe92918290030190a26040805183815290516001600160a01b038516916000917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a36001600160a01b03808416600090815260086020526040812054610b699216846118a5565b50600192915050565b600081610bc6576040805162461bcd60e51b815260206004820152601e60248201527f6275726e20616d6f756e742073686f756c64206e6f74206265207a65726f0000604482015290519081900360640190fd5b33600090815260208190526040902054821115610be257600080fd5b600154610bf5908363ffffffff61171216565b60015533600090815260208190526040902054610c18908363ffffffff61171216565b3360008181526020818152604091829020939093558051858152905191927f696de425f79f4a40bc6d2122ca50507f0efbeabbff86a84871b7196ab8ea8df792918290030190a260408051838152905160009133917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a333600090815260086020526040812054610cbd916001600160a01b0390911690846118a5565b506001919050565b6004546001600160a01b031681565b6008602052600090815260409020546001600160a01b031681565b610cf933826119ee565b50565b600354600160a01b900460ff1681565b3360009081526002602090815260408083206001600160a01b038616845290915281205480831115610d61573360009081526002602090815260408083206001600160a01b0388168452909152812055610d96565b610d71818463ffffffff61171216565b3360009081526002602090815260408083206001600160a01b03891684529091529020555b3360008181526002602090815260408083206001600160a01b038916808552908352928190205481519081529051929392600080516020611d81833981519152929181900390910190a35060019392505050565b60076020526000908152604090205463ffffffff1681565b6001600160a01b031660009081526020819052604090205490565b6000438210610e5d5760405162461bcd60e51b8152600401808060200182810382526021815260200180611c856021913960400191505060405180910390fd5b6001600160a01b03831660009081526007602052604090205463ffffffff1680610e8b57600091505061077f565b6001600160a01b038416600090815260066020908152604080832063ffffffff600019860181168552925290912054168310610efa576001600160a01b03841660009081526006602090815260408083206000199490940163ffffffff1683529290522060010154905061077f565b6001600160a01b038416600090815260066020908152604080832083805290915290205463ffffffff16831015610f3557600091505061077f565b600060001982015b8163ffffffff168163ffffffff161115610fee57600282820363ffffffff16048103610f67611c6d565b506001600160a01b038716600090815260066020908152604080832063ffffffff808616855290835292819020815180830190925280549093168082526001909301549181019190915290871415610fc95760200151945061077f9350505050565b805163ffffffff16871115610fe057819350610fe7565b6001820392505b5050610f3d565b506001600160a01b038516600090815260066020908152604080832063ffffffff9094168352929052206001015491505092915050565b60096020526000908152604090205481565b6003546001600160a01b0316331461104e57600080fd5b600354600160a01b900460ff161561106557600080fd5b6003805460ff60a01b1916600160a01b1790556040517f6985a02210a168e66602d3235cb6db0e70f92b3ba4d376a33c0f3d9434bff62590600090a1565b6003546001600160a01b031681565b6040518060400160405280600381526020016243594360e81b81525081565b6004546001600160a01b03163314611123576040805162461bcd60e51b815260206004820152601060248201526f3737ba103a34329037b832b930ba37b960811b604482015290519081900360640190fd5b6001600160a01b038116600081815260056020526040808220805460ff19166001179055517f6ae172837ea30b801fbfcdd4108aa1d5bf8ff775444fd70256b44e6bf3dfc3f69190a250565b6000610b69338484611724565b6004546001600160a01b031633146111ce576040805162461bcd60e51b815260206004820152601060248201526f3737ba103a34329037b832b930ba37b960811b604482015290519081900360640190fd5b6001600160a01b038116611229576040805162461bcd60e51b815260206004820152601860248201527f696e76616c6964206f70657261746f7220616464726573730000000000000000604482015290519081900360640190fd5b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b03811660009081526007602052604081205463ffffffff16806112765760006112a8565b6001600160a01b038316600090815260066020908152604080832063ffffffff60001986011684529091529020600101545b9392505050565b60006040518080611ca660439139604080519182900360430182208282018252601083526f10de58db1bdb9948141c9bdd1bd8dbdb60821b6020938401528151808401919091527f2b864030ed85b6ce9d972b623265c944c666a1d2f7baa2e5853ac0cb91e4f5c181830152600060608201819052306080808401919091528351808403909101815260a09092019283905281519190930120935090915080603a611da182396040805191829003603a0182206020808401919091526001600160a01b038c1683830152606083018b905260808084018b90528251808503909101815260a08401835280519082012061190160f01b60c085015260c2840187905260e2808501829052835180860390910181526101028501808552815191840191909120600091829052610122860180865281905260ff8c1661014287015261016286018b905261018286018a9052935191965092945091926001926101a28083019392601f198301929081900390910190855afa158015611435573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b03811661149d576040805162461bcd60e51b815260206004820181905260248201527f64656c656761746542795369673a20696e76616c6964207369676e6174757265604482015290519081900360640190fd5b6001600160a01b03811660009081526009602052604090208054600181019091558914611511576040805162461bcd60e51b815260206004820152601c60248201527f64656c656761746542795369673a20696e76616c6964206e6f6e636500000000604482015290519081900360640190fd5b87421115611566576040805162461bcd60e51b815260206004820181905260248201527f64656c656761746542795369673a207369676e61747572652065787069726564604482015290519081900360640190fd5b611570818b6119ee565b505050505b505050505050565b3360009081526002602090815260408083206001600160a01b03861684529091528120546115b1908363ffffffff61189816565b3360008181526002602090815260408083206001600160a01b038916808552908352928190208590558051948552519193600080516020611d81833981519152929081900390910190a350600192915050565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b60405180603a611da18239603a019050604051809103902081565b60066020908152600092835260408084209091529082529020805460019091015463ffffffff9091169082565b6003546001600160a01b0316331461168e57600080fd5b6001600160a01b0381166116a157600080fd5b6003546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600380546001600160a01b0319166001600160a01b0392909216919091179055565b60056020526000908152604090205460ff1681565b60008282111561171e57fe5b50900390565b6001600160a01b0383166117695760405162461bcd60e51b8152600401808060200182810382526036815260200180611ce96036913960400191505060405180910390fd5b6001600160a01b0382166117ae5760405162461bcd60e51b8152600401808060200182810382526034815260200180611d1f6034913960400191505060405180910390fd5b6001600160a01b0383166000908152602081905260409020546117d7908263ffffffff61171216565b6001600160a01b03808516600090815260208190526040808220939093559084168152205461180c908263ffffffff61189816565b6001600160a01b038084166000818152602081815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a36001600160a01b03808416600090815260086020526040808220548584168352912054611893929182169116836118a5565b505050565b8181018281101561077f57fe5b816001600160a01b0316836001600160a01b0316141580156118c75750600081115b15611893576001600160a01b0383161561195f576001600160a01b03831660009081526007602052604081205463ffffffff169081611907576000611939565b6001600160a01b038516600090815260066020908152604080832063ffffffff60001987011684529091529020600101545b9050600061194d828563ffffffff61171216565b905061195b86848484611a6d565b5050505b6001600160a01b03821615611893576001600160a01b03821660009081526007602052604081205463ffffffff16908161199a5760006119cc565b6001600160a01b038416600090815260066020908152604080832063ffffffff60001987011684529091529020600101545b905060006119e0828563ffffffff61189816565b905061157585848484611a6d565b6001600160a01b038083166000818152600860208181526040808420805485845282862054949093528787166001600160a01b03198416811790915590519190951694919391928592917f3134e8a2e6d97e929a7e54011ea5485d7d196dd5f0ba4d4ef95803e8e3fc257f9190a4611a678284836118a5565b50505050565b6000611a91436040518060600160405280602e8152602001611d53602e9139611bd2565b905060008463ffffffff16118015611ada57506001600160a01b038516600090815260066020908152604080832063ffffffff6000198901811685529252909120548282169116145b15611b17576001600160a01b038516600090815260066020908152604080832063ffffffff60001989011684529091529020600101829055611b88565b60408051808201825263ffffffff808416825260208083018681526001600160a01b038a166000818152600684528681208b8616825284528681209551865490861663ffffffff19918216178755925160019687015590815260079092529390208054928801909116919092161790555b604080518481526020810184905281516001600160a01b038816927fdec2bacdd2f05b59de34da9b523dff8be42e5e38e818c82fdb0bae774387a724928290030190a25050505050565b6000816401000000008410611c655760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611c2a578181015183820152602001611c12565b50505050905090810190601f168015611c575780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b509192915050565b60408051808201909152600080825260208201529056fe6765745072696f72566f7465733a206e6f74207965742064657465726d696e6564454950373132446f6d61696e28737472696e67206e616d652c75696e7432353620636861696e49642c6164647265737320766572696679696e67436f6e7472616374295f7472616e73666572546f6b656e733a2063616e6e6f74207472616e736665722066726f6d20746865207a65726f20616464726573735f7472616e73666572546f6b656e733a2063616e6e6f74207472616e7366657220746f20746865207a65726f20616464726573735f7772697465436865636b706f696e743a20626c6f636b206e756d626572206578636565647320333220626974738c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92544656c65676174696f6e28616464726573732064656c6567617465652c75696e74323536206e6f6e63652c75696e743235362065787069727929a265627a7a72315820f89363764affb5a8655959f3107c1cac23d7b482537d8a7262b2fd241c99f95d64736f6c634300051100325f7772697465436865636b706f696e743a20626c6f636b206e756d6265722065786365656473203332206269747300000000000000000000000088b8bfc7cc3f05579e2c0cdbd8488846e463684c0000000000000000000000000000000000000000000000000000000000000000

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101fb5760003560e01c806370a082311161011a578063ac7475ed116100ad578063dd62ed3e1161007c578063dd62ed3e14610630578063e7a324dc1461065e578063f1127ed814610666578063f2fde38b146106b8578063f46eccc4146106de576101fb565b8063ac7475ed14610571578063b4b5ea5714610597578063c3cda520146105bd578063d73dd62314610604576101fb565b80638da5cb5b116100e95780638da5cb5b1461050f57806395d89b4114610517578063983b2d561461051f578063a9059cbb14610545576101fb565b806370a082311461048f578063782d6fe1146104b55780637ecebe00146104e15780638456cb5914610507576101fb565b806340c10f19116101925780635c19a95c116101615780635c19a95c146103f65780635c975abb1461041c57806366188463146104245780636fcfff4514610450576101fb565b806340c10f191461036357806342966c681461038f578063570ca735146103ac578063587cde1e146103d0576101fb565b806323b872dd116101ce57806323b872dd146102df5780633092afd514610315578063313ce5671461033d5780633f4ba83a1461035b576101fb565b806306fdde0314610200578063095ea7b31461027d57806318160ddd146102bd57806320606b70146102d7575b600080fd5b610208610704565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561024257818101518382015260200161022a565b50505050905090810190601f16801561026f5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102a96004803603604081101561029357600080fd5b506001600160a01b038135169060200135610730565b604080519115158252519081900360200190f35b6102c5610785565b60408051918252519081900360200190f35b6102c561078b565b6102a9600480360360608110156102f557600080fd5b506001600160a01b038135811691602081013590911690604001356107a6565b61033b6004803603602081101561032b57600080fd5b50356001600160a01b0316610851565b005b6103456108ec565b6040805160ff9092168252519081900360200190f35b61033b6108f1565b6102a96004803603604081101561037957600080fd5b506001600160a01b038135169060200135610956565b6102a9600480360360208110156103a557600080fd5b5035610b72565b6103b4610cc5565b604080516001600160a01b039092168252519081900360200190f35b6103b4600480360360208110156103e657600080fd5b50356001600160a01b0316610cd4565b61033b6004803603602081101561040c57600080fd5b50356001600160a01b0316610cef565b6102a9610cfc565b6102a96004803603604081101561043a57600080fd5b506001600160a01b038135169060200135610d0c565b6104766004803603602081101561046657600080fd5b50356001600160a01b0316610dea565b6040805163ffffffff9092168252519081900360200190f35b6102c5600480360360208110156104a557600080fd5b50356001600160a01b0316610e02565b6102c5600480360360408110156104cb57600080fd5b506001600160a01b038135169060200135610e1d565b6102c5600480360360208110156104f757600080fd5b50356001600160a01b0316611025565b61033b611037565b6103b46110a3565b6102086110b2565b61033b6004803603602081101561053557600080fd5b50356001600160a01b03166110d1565b6102a96004803603604081101561055b57600080fd5b506001600160a01b03813516906020013561116f565b61033b6004803603602081101561058757600080fd5b50356001600160a01b031661117c565b6102c5600480360360208110156105ad57600080fd5b50356001600160a01b031661124b565b61033b600480360360c08110156105d357600080fd5b506001600160a01b038135169060208101359060408101359060ff6060820135169060808101359060a001356112af565b6102a96004803603604081101561061a57600080fd5b506001600160a01b03813516906020013561157d565b6102c56004803603604081101561064657600080fd5b506001600160a01b0381358116916020013516611604565b6102c561162f565b6106986004803603604081101561067c57600080fd5b5080356001600160a01b0316906020013563ffffffff1661164a565b6040805163ffffffff909316835260208301919091528051918290030190f35b61033b600480360360208110156106ce57600080fd5b50356001600160a01b0316611677565b6102a9600480360360208110156106f457600080fd5b50356001600160a01b03166116fd565b6040518060400160405280601081526020016f10de58db1bdb9948141c9bdd1bd8dbdb60821b81525081565b3360008181526002602090815260408083206001600160a01b03871680855290835281842086905581518681529151939490939092600080516020611d81833981519152928290030190a35060015b92915050565b60015490565b604051806043611ca682396043019050604051809103902081565b6001600160a01b03831660008181526002602090815260408083203380855292528220549192909190821461083a5760006107e7828663ffffffff61171216565b6001600160a01b038089166000818152600260209081526040808320948916808452948252918290208590558151858152915194955092939192600080516020611d8183398151915292918290030190a3505b610845868686611724565b50600195945050505050565b6004546001600160a01b031633146108a3576040805162461bcd60e51b815260206004820152601060248201526f3737ba103a34329037b832b930ba37b960811b604482015290519081900360640190fd5b6001600160a01b038116600081815260056020526040808220805460ff19169055517fe94479a9f7e1952cc78f2d6baab678adc1b772d936c6583def489e524cb666929190a250565b601281565b6003546001600160a01b0316331461090857600080fd5b600354600160a01b900460ff1661091e57600080fd5b6003805460ff60a01b191690556040517f7805862f689e2f13df9f062ff482ad3ad112aca9e0847911ed832e158c525b3390600090a1565b3360009081526005602052604081205460ff1615156001146109b0576040805162461bcd60e51b815260206004820152600e60248201526d3737ba103a34329036b4b73a32b960911b604482015290519081900360640190fd5b600354600160a01b900460ff16156109c757600080fd5b6001600160a01b038316610a22576040805162461bcd60e51b815260206004820152601860248201527f696e76616c6964206164647265737320666f72206d696e740000000000000000604482015290519081900360640190fd5b81610a74576040805162461bcd60e51b815260206004820152601e60248201527f6d696e7420616d6f756e742073686f756c64206e6f74206265207a65726f0000604482015290519081900360640190fd5b600154610a87908363ffffffff61189816565b6001556001600160a01b038316600090815260208190526040902054610ab3908363ffffffff61189816565b6001600160a01b03841660008181526020818152604091829020939093558051858152905191927f30385c845b448a36257a6a1716e6ad2e1bc2cbe333cde1e69fe849ad6511adfe92918290030190a26040805183815290516001600160a01b038516916000917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a36001600160a01b03808416600090815260086020526040812054610b699216846118a5565b50600192915050565b600081610bc6576040805162461bcd60e51b815260206004820152601e60248201527f6275726e20616d6f756e742073686f756c64206e6f74206265207a65726f0000604482015290519081900360640190fd5b33600090815260208190526040902054821115610be257600080fd5b600154610bf5908363ffffffff61171216565b60015533600090815260208190526040902054610c18908363ffffffff61171216565b3360008181526020818152604091829020939093558051858152905191927f696de425f79f4a40bc6d2122ca50507f0efbeabbff86a84871b7196ab8ea8df792918290030190a260408051838152905160009133917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a333600090815260086020526040812054610cbd916001600160a01b0390911690846118a5565b506001919050565b6004546001600160a01b031681565b6008602052600090815260409020546001600160a01b031681565b610cf933826119ee565b50565b600354600160a01b900460ff1681565b3360009081526002602090815260408083206001600160a01b038616845290915281205480831115610d61573360009081526002602090815260408083206001600160a01b0388168452909152812055610d96565b610d71818463ffffffff61171216565b3360009081526002602090815260408083206001600160a01b03891684529091529020555b3360008181526002602090815260408083206001600160a01b038916808552908352928190205481519081529051929392600080516020611d81833981519152929181900390910190a35060019392505050565b60076020526000908152604090205463ffffffff1681565b6001600160a01b031660009081526020819052604090205490565b6000438210610e5d5760405162461bcd60e51b8152600401808060200182810382526021815260200180611c856021913960400191505060405180910390fd5b6001600160a01b03831660009081526007602052604090205463ffffffff1680610e8b57600091505061077f565b6001600160a01b038416600090815260066020908152604080832063ffffffff600019860181168552925290912054168310610efa576001600160a01b03841660009081526006602090815260408083206000199490940163ffffffff1683529290522060010154905061077f565b6001600160a01b038416600090815260066020908152604080832083805290915290205463ffffffff16831015610f3557600091505061077f565b600060001982015b8163ffffffff168163ffffffff161115610fee57600282820363ffffffff16048103610f67611c6d565b506001600160a01b038716600090815260066020908152604080832063ffffffff808616855290835292819020815180830190925280549093168082526001909301549181019190915290871415610fc95760200151945061077f9350505050565b805163ffffffff16871115610fe057819350610fe7565b6001820392505b5050610f3d565b506001600160a01b038516600090815260066020908152604080832063ffffffff9094168352929052206001015491505092915050565b60096020526000908152604090205481565b6003546001600160a01b0316331461104e57600080fd5b600354600160a01b900460ff161561106557600080fd5b6003805460ff60a01b1916600160a01b1790556040517f6985a02210a168e66602d3235cb6db0e70f92b3ba4d376a33c0f3d9434bff62590600090a1565b6003546001600160a01b031681565b6040518060400160405280600381526020016243594360e81b81525081565b6004546001600160a01b03163314611123576040805162461bcd60e51b815260206004820152601060248201526f3737ba103a34329037b832b930ba37b960811b604482015290519081900360640190fd5b6001600160a01b038116600081815260056020526040808220805460ff19166001179055517f6ae172837ea30b801fbfcdd4108aa1d5bf8ff775444fd70256b44e6bf3dfc3f69190a250565b6000610b69338484611724565b6004546001600160a01b031633146111ce576040805162461bcd60e51b815260206004820152601060248201526f3737ba103a34329037b832b930ba37b960811b604482015290519081900360640190fd5b6001600160a01b038116611229576040805162461bcd60e51b815260206004820152601860248201527f696e76616c6964206f70657261746f7220616464726573730000000000000000604482015290519081900360640190fd5b600480546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b03811660009081526007602052604081205463ffffffff16806112765760006112a8565b6001600160a01b038316600090815260066020908152604080832063ffffffff60001986011684529091529020600101545b9392505050565b60006040518080611ca660439139604080519182900360430182208282018252601083526f10de58db1bdb9948141c9bdd1bd8dbdb60821b6020938401528151808401919091527f2b864030ed85b6ce9d972b623265c944c666a1d2f7baa2e5853ac0cb91e4f5c181830152600060608201819052306080808401919091528351808403909101815260a09092019283905281519190930120935090915080603a611da182396040805191829003603a0182206020808401919091526001600160a01b038c1683830152606083018b905260808084018b90528251808503909101815260a08401835280519082012061190160f01b60c085015260c2840187905260e2808501829052835180860390910181526101028501808552815191840191909120600091829052610122860180865281905260ff8c1661014287015261016286018b905261018286018a9052935191965092945091926001926101a28083019392601f198301929081900390910190855afa158015611435573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b03811661149d576040805162461bcd60e51b815260206004820181905260248201527f64656c656761746542795369673a20696e76616c6964207369676e6174757265604482015290519081900360640190fd5b6001600160a01b03811660009081526009602052604090208054600181019091558914611511576040805162461bcd60e51b815260206004820152601c60248201527f64656c656761746542795369673a20696e76616c6964206e6f6e636500000000604482015290519081900360640190fd5b87421115611566576040805162461bcd60e51b815260206004820181905260248201527f64656c656761746542795369673a207369676e61747572652065787069726564604482015290519081900360640190fd5b611570818b6119ee565b505050505b505050505050565b3360009081526002602090815260408083206001600160a01b03861684529091528120546115b1908363ffffffff61189816565b3360008181526002602090815260408083206001600160a01b038916808552908352928190208590558051948552519193600080516020611d81833981519152929081900390910190a350600192915050565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b60405180603a611da18239603a019050604051809103902081565b60066020908152600092835260408084209091529082529020805460019091015463ffffffff9091169082565b6003546001600160a01b0316331461168e57600080fd5b6001600160a01b0381166116a157600080fd5b6003546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600380546001600160a01b0319166001600160a01b0392909216919091179055565b60056020526000908152604090205460ff1681565b60008282111561171e57fe5b50900390565b6001600160a01b0383166117695760405162461bcd60e51b8152600401808060200182810382526036815260200180611ce96036913960400191505060405180910390fd5b6001600160a01b0382166117ae5760405162461bcd60e51b8152600401808060200182810382526034815260200180611d1f6034913960400191505060405180910390fd5b6001600160a01b0383166000908152602081905260409020546117d7908263ffffffff61171216565b6001600160a01b03808516600090815260208190526040808220939093559084168152205461180c908263ffffffff61189816565b6001600160a01b038084166000818152602081815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a36001600160a01b03808416600090815260086020526040808220548584168352912054611893929182169116836118a5565b505050565b8181018281101561077f57fe5b816001600160a01b0316836001600160a01b0316141580156118c75750600081115b15611893576001600160a01b0383161561195f576001600160a01b03831660009081526007602052604081205463ffffffff169081611907576000611939565b6001600160a01b038516600090815260066020908152604080832063ffffffff60001987011684529091529020600101545b9050600061194d828563ffffffff61171216565b905061195b86848484611a6d565b5050505b6001600160a01b03821615611893576001600160a01b03821660009081526007602052604081205463ffffffff16908161199a5760006119cc565b6001600160a01b038416600090815260066020908152604080832063ffffffff60001987011684529091529020600101545b905060006119e0828563ffffffff61189816565b905061157585848484611a6d565b6001600160a01b038083166000818152600860208181526040808420805485845282862054949093528787166001600160a01b03198416811790915590519190951694919391928592917f3134e8a2e6d97e929a7e54011ea5485d7d196dd5f0ba4d4ef95803e8e3fc257f9190a4611a678284836118a5565b50505050565b6000611a91436040518060600160405280602e8152602001611d53602e9139611bd2565b905060008463ffffffff16118015611ada57506001600160a01b038516600090815260066020908152604080832063ffffffff6000198901811685529252909120548282169116145b15611b17576001600160a01b038516600090815260066020908152604080832063ffffffff60001989011684529091529020600101829055611b88565b60408051808201825263ffffffff808416825260208083018681526001600160a01b038a166000818152600684528681208b8616825284528681209551865490861663ffffffff19918216178755925160019687015590815260079092529390208054928801909116919092161790555b604080518481526020810184905281516001600160a01b038816927fdec2bacdd2f05b59de34da9b523dff8be42e5e38e818c82fdb0bae774387a724928290030190a25050505050565b6000816401000000008410611c655760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015611c2a578181015183820152602001611c12565b50505050905090810190601f168015611c575780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b509192915050565b60408051808201909152600080825260208201529056fe6765745072696f72566f7465733a206e6f74207965742064657465726d696e6564454950373132446f6d61696e28737472696e67206e616d652c75696e7432353620636861696e49642c6164647265737320766572696679696e67436f6e7472616374295f7472616e73666572546f6b656e733a2063616e6e6f74207472616e736665722066726f6d20746865207a65726f20616464726573735f7472616e73666572546f6b656e733a2063616e6e6f74207472616e7366657220746f20746865207a65726f20616464726573735f7772697465436865636b706f696e743a20626c6f636b206e756d626572206578636565647320333220626974738c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92544656c65676174696f6e28616464726573732064656c6567617465652c75696e74323536206e6f6e63652c75696e743235362065787069727929a265627a7a72315820f89363764affb5a8655959f3107c1cac23d7b482537d8a7262b2fd241c99f95d64736f6c63430005110032

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

00000000000000000000000088b8bfc7cc3f05579e2c0cdbd8488846e463684c0000000000000000000000000000000000000000000000000000000000000000

-----Decoded View---------------
Arg [0] : _operator (address): 0x88b8Bfc7cC3F05579e2c0CDbd8488846e463684c
Arg [1] : _lp (address): 0x0000000000000000000000000000000000000000

-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 00000000000000000000000088b8bfc7cc3f05579e2c0cdbd8488846e463684c
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000000


Deployed Bytecode Sourcemap

15610:11555:0:-;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;15610:11555:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16089:48;;;:::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;16089:48:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8638:192;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;8638:192:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;4444:85;;;:::i;:::-;;;;;;;;;;;;;;;;19074:122;;;:::i;20625:479::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;20625:479:0;;;;;;;;;;;;;;;;;:::i;16862:142::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;16862:142:0;-1:-1:-1;;;;;16862:142:0;;:::i;:::-;;16188:35;;;:::i;:::-;;;;;;;;;;;;;;;;;;;13737:95;;;:::i;17196:507::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;17196:507:0;;;;;;;;:::i;17811:488::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;17811:488:0;;:::i;16012:23::-;;;:::i;:::-;;;;-1:-1:-1;;;;;16012:23:0;;;;;;;;;;;;;;18956:45;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;18956:45:0;-1:-1:-1;;;;;18956:45:0;;:::i;21252:102::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;21252:102:0;-1:-1:-1;;;;;21252:102:0;;:::i;13116:26::-;;;:::i;11336:412::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;11336:412:0;;;;;;;;:::i;18846:49::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;18846:49:0;-1:-1:-1;;;;;18846:49:0;;:::i;:::-;;;;;;;;;;;;;;;;;;;6008:101;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;6008:101:0;-1:-1:-1;;;;;6008:101:0;;:::i;23409:1213::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;23409:1213:0;;;;;;;;:::i;19488:39::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;19488:39:0;-1:-1:-1;;;;;19488:39:0;;:::i;13557:93::-;;;:::i;12048:20::-;;;:::i;16144:37::-;;;:::i;16718:136::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;16718:136:0;-1:-1:-1;;;;;16718:136:0;;:::i;20168:150::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;20168:150:0;;;;;;;;:::i;17012:176::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;17012:176:0;-1:-1:-1;;;;;17012:176:0;;:::i;22755:223::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;22755:223:0;-1:-1:-1;;;;;22755:223:0;;:::i;21788:766::-;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;-1:-1;;;;;;21788:766:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;10031:266::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;10031:266:0;;;;;;;;:::i;9157:128::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;9157:128:0;;;;;;;;;;:::i;19290:117::-;;;:::i;18707:70::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;18707:70:0;;-1:-1:-1;;;;;18707:70:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;12663:178;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;12663:178:0;-1:-1:-1;;;;;12663:178:0;;:::i;16042:40::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;16042:40:0;-1:-1:-1;;;;;16042:40:0;;:::i;16089:48::-;;;;;;;;;;;;;;-1:-1:-1;;;16089:48:0;;;;:::o;8638:192::-;8726:10;8705:4;8718:19;;;:7;:19;;;;;;;;-1:-1:-1;;;;;8718:29:0;;;;;;;;;;;:38;;;8768;;;;;;;8705:4;;8718:29;;8726:10;;-1:-1:-1;;;;;;;;;;;8768:38:0;;;;;;;-1:-1:-1;8820:4:0;8638:192;;;;;:::o;4444:85::-;4511:12;;4444:85;:::o;19074:122::-;19116:80;;;;;;;;;;;;;;;;;;19074:122;:::o;20625:479::-;-1:-1:-1;;;;;20788:12:0;;20705:4;20788:12;;;:7;:12;;;;;;;;20740:10;20788:21;;;;;;;;20705:4;;20740:10;;20788:21;20826:14;;20822:207;;20857:20;20880:28;:16;20901:6;20880:28;:20;:28;:::i;:::-;-1:-1:-1;;;;;20923:12:0;;;;;;;:7;:12;;;;;;;;:21;;;;;;;;;;;;;:36;;;20981;;;;;;;20857:51;;-1:-1:-1;20923:21:0;;:12;;-1:-1:-1;;;;;;;;;;;20981:36:0;;;;;;;;20822:207;;21041:33;21057:3;21062;21067:6;21041:15;:33::i;:::-;-1:-1:-1;21092:4:0;;20625:479;-1:-1:-1;;;;;20625:479:0:o;16862:142::-;15727:8;;-1:-1:-1;;;;;15727:8:0;15739:10;15727:22;15719:51;;;;;-1:-1:-1;;;15719:51:0;;;;;;;;;;;;-1:-1:-1;;;15719:51:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;16934:16:0;;16953:5;16934:16;;;:7;:16;;;;;;:24;;-1:-1:-1;;16934:24:0;;;16974:22;;;16953:5;16974:22;16862:142;:::o;16188:35::-;16221:2;16188:35;:::o;13737:95::-;12476:5;;-1:-1:-1;;;;;12476:5:0;12462:10;:19;12454:28;;;;;;13452:6;;-1:-1:-1;;;13452:6:0;;;;13444:15;;;;;;13791:6;:14;;-1:-1:-1;;;;13791:14:0;;;13817:9;;;;13800:5;;13817:9;13737:95::o;17196:507::-;15946:10;17282:4;15938:19;;;:7;:19;;;;;;;;:27;;:19;:27;15930:54;;;;;-1:-1:-1;;;15930:54:0;;;;;;;;;;;;-1:-1:-1;;;15930:54:0;;;;;;;;;;;;;;;13292:6;;-1:-1:-1;;;13292:6:0;;;;13291:7;13283:16;;;;;;-1:-1:-1;;;;;17308:17:0;;17299:55;;;;;-1:-1:-1;;;17299:55:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;17374:12;17365:56;;;;;-1:-1:-1;;;17365:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;17447:12;;:25;;17464:7;17447:25;:16;:25;:::i;:::-;17432:12;:40;-1:-1:-1;;;;;17499:13:0;;:8;:13;;;;;;;;;;;:26;;17517:7;17499:26;:17;:26;:::i;:::-;-1:-1:-1;;;;;17483:13:0;;:8;:13;;;;;;;;;;;;:42;;;;17541:20;;;;;;;17483:13;;17541:20;;;;;;;;;17577:34;;;;;;;;-1:-1:-1;;;;;17577:34:0;;;17594:1;;17577:34;;;;;;;;;-1:-1:-1;;;;;17649:14:0;;;17645:1;17649:14;;;:9;:14;;;;;;17622:51;;17649:14;17665:7;17622:14;:51::i;:::-;-1:-1:-1;17691:4:0;17196:507;;;;:::o;17811:488::-;17858:4;17884:12;17875:56;;;;;-1:-1:-1;;;17875:56:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;17959:10;17950:8;:20;;;;;;;;;;;:31;-1:-1:-1;17950:31:0;17942:40;;;;;;18008:12;;:25;;18025:7;18008:25;:16;:25;:::i;:::-;17993:12;:40;18076:10;18067:8;:20;;;;;;;;;;;:33;;18092:7;18067:33;:24;:33;:::i;:::-;18053:10;18044:8;:20;;;;;;;;;;;;:56;;;;18116:27;;;;;;;18053:10;;18116:27;;;;;;;;;18159:41;;;;;;;;18188:1;;18168:10;;18159:41;;;;;;;;;18236:10;18226:21;;;;:9;:21;;;;;;18211:58;;-1:-1:-1;;;;;18226:21:0;;;;18261:7;18211:14;:58::i;:::-;-1:-1:-1;18287:4:0;17811:488;;;:::o;16012:23::-;;;-1:-1:-1;;;;;16012:23:0;;:::o;18956:45::-;;;;;;;;;;;;-1:-1:-1;;;;;18956:45:0;;:::o;21252:102::-;21314:32;21324:10;21336:9;21314;:32::i;:::-;21252:102;:::o;13116:26::-;;;-1:-1:-1;;;13116:26:0;;;;;:::o;11336:412::-;11456:10;11419:4;11448:19;;;:7;:19;;;;;;;;-1:-1:-1;;;;;11448:29:0;;;;;;;;;;11488:27;;;11484:168;;;11534:10;11558:1;11526:19;;;:7;:19;;;;;;;;-1:-1:-1;;;;;11526:29:0;;;;;;;;;:33;11484:168;;;11614:30;:8;11627:16;11614:30;:12;:30;:::i;:::-;11590:10;11582:19;;;;:7;:19;;;;;;;;-1:-1:-1;;;;;11582:29:0;;;;;;;;;:62;11484:168;11672:10;11694:19;;;;:7;:19;;;;;;;;-1:-1:-1;;;;;11663:61:0;;11694:29;;;;;;;;;;;11663:61;;;;;;;;;11672:10;-1:-1:-1;;;;;;;;;;;11663:61:0;;;;;;;;;;-1:-1:-1;11738:4:0;;11336:412;-1:-1:-1;;;11336:412:0:o;18846:49::-;;;;;;;;;;;;;;;:::o;6008:101::-;-1:-1:-1;;;;;6087:16:0;6064:7;6087:16;;;;;;;;;;;;6008:101::o;23409:1213::-;23488:7;23530:12;23516:11;:26;23508:72;;;;-1:-1:-1;;;23508:72:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;23615:23:0;;23593:19;23615:23;;;:14;:23;;;;;;;;23653:17;23649:58;;23694:1;23687:8;;;;;23649:58;-1:-1:-1;;;;;23767:20:0;;;;;;:11;:20;;;;;;;;:38;-1:-1:-1;;23788:16:0;;23767:38;;;;;;;;;:48;;:63;-1:-1:-1;23763:147:0;;-1:-1:-1;;;;;23854:20:0;;;;;;:11;:20;;;;;;;;-1:-1:-1;;23875:16:0;;;;23854:38;;;;;;;;23890:1;23854:44;;;-1:-1:-1;23847:51:0;;23763:147;-1:-1:-1;;;;;23971:20:0;;;;;;:11;:20;;;;;;;;:23;;;;;;;;:33;:23;:33;:47;-1:-1:-1;23967:88:0;;;24042:1;24035:8;;;;;23967:88;24067:12;-1:-1:-1;;24109:16:0;;24136:428;24151:5;24143:13;;:5;:13;;;24136:428;;;24215:1;24198:13;;;24197:19;;;24189:27;;24258:20;;:::i;:::-;-1:-1:-1;;;;;;24281:20:0;;;;;;:11;:20;;;;;;;;:28;;;;;;;;;;;;;24258:51;;;;;;;;;;;;;;;;;;;;;;;;;;;;;24328:27;;24324:229;;;24383:8;;;;-1:-1:-1;24376:15:0;;-1:-1:-1;;;;24376:15:0;24324:229;24417:12;;:26;;;-1:-1:-1;24413:140:0;;;24472:6;24464:14;;24413:140;;;24536:1;24527:6;:10;24519:18;;24413:140;24136:428;;;;;-1:-1:-1;;;;;;24581:20:0;;;;;;:11;:20;;;;;;;;:27;;;;;;;;;;:33;;;;-1:-1:-1;;23409:1213:0;;;;:::o;19488:39::-;;;;;;;;;;;;;:::o;13557:93::-;12476:5;;-1:-1:-1;;;;;12476:5:0;12462:10;:19;12454:28;;;;;;13292:6;;-1:-1:-1;;;13292:6:0;;;;13291:7;13283:16;;;;;;13612:6;:13;;-1:-1:-1;;;;13612:13:0;-1:-1:-1;;;13612:13:0;;;13637:7;;;;13612:13;;13637:7;13557:93::o;12048:20::-;;;-1:-1:-1;;;;;12048:20:0;;:::o;16144:37::-;;;;;;;;;;;;;;-1:-1:-1;;;16144:37:0;;;;:::o;16718:136::-;15727:8;;-1:-1:-1;;;;;15727:8:0;15739:10;15727:22;15719:51;;;;;-1:-1:-1;;;15719:51:0;;;;;;;;;;;;-1:-1:-1;;;15719:51:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;16787:16:0;;;;;;:7;:16;;;;;;:23;;-1:-1:-1;;16787:23:0;16806:4;16787:23;;;16826:20;;;16787:16;16826:20;16718:136;:::o;20168:150::-;20231:4;20248:40;20264:10;20276:3;20281:6;20248:15;:40::i;17012:176::-;15727:8;;-1:-1:-1;;;;;15727:8:0;15739:10;15727:22;15719:51;;;;;-1:-1:-1;;;15719:51:0;;;;;;;;;;;;-1:-1:-1;;;15719:51:0;;;;;;;;;;;;;;;-1:-1:-1;;;;;17097:23:0;;17088:61;;;;;-1:-1:-1;;;17088:61:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;17160:8;:20;;-1:-1:-1;;;;;;17160:20:0;-1:-1:-1;;;;;17160:20:0;;;;;;;;;;17012:176::o;22755:223::-;-1:-1:-1;;;;;22862:23:0;;22820:7;22862:23;;;:14;:23;;;;;;;;22903:16;:67;;22969:1;22903:67;;;-1:-1:-1;;;;;22922:20:0;;;;;;:11;:20;;;;;;;;:38;-1:-1:-1;;22943:16:0;;22922:38;;;;;;;;22958:1;22922:44;;22903:67;22896:74;22755:223;-1:-1:-1;;;22755:223:0:o;21788:766::-;21904:23;19116:80;;;;;;;;;;;;;;;;;;;21984:4;;;;;;;;-1:-1:-1;;;21984:4:0;;;;;21940:75;;;;;;;;;21968:22;21940:75;;;;-1:-1:-1;21940:75:0;;;;;;22009:4;21940:75;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;21940:75:0;;;;;;;;21930:86;;;;;;;;-1:-1:-1;;;;21940:75:0;19336:71;;21940:75;19336:71;;;;;;;;;;;;22058:57;;;;;;;;-1:-1:-1;;;;;22058:57:0;;;;;;;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;22058:57:0;;;;;22048:68;;;;;;-1:-1:-1;;;22154:57:0;;;;;;;;;;;;;;;;;;;26:21:-1;;;22:32;;;6:49;;22154:57:0;;;;;;22144:68;;;;;;;;;-1:-1:-1;22243:26:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22048:68;;-1:-1:-1;22144:68:0;;-1:-1:-1;;;22243:26:0;;;;;;;22058:57;-1:-1:-1;;22243:26:0;;;;;;;;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;-1:-1;;22243:26:0;;-1:-1:-1;;22243:26:0;;;-1:-1:-1;;;;;;;22288:23:0;;22280:68;;;;;-1:-1:-1;;;22280:68:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;22376:17:0;;;;;;:6;:17;;;;;:19;;;;;;;;22367:28;;22359:69;;;;;-1:-1:-1;;;22359:69:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;22454:6;22447:3;:13;;22439:58;;;;;-1:-1:-1;;;22439:58:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22515:31;22525:9;22536;22515;:31::i;:::-;22508:38;;;;21788:766;;;;;;;:::o;10031:266::-;10162:10;10109:4;10154:19;;;:7;:19;;;;;;;;-1:-1:-1;;;;;10154:29:0;;;;;;;;;;:46;;10188:11;10154:46;:33;:46;:::i;:::-;10130:10;10122:19;;;;:7;:19;;;;;;;;-1:-1:-1;;;;;10122:29:0;;;;;;;;;;;;:78;;;10212:61;;;;;;10122:29;;-1:-1:-1;;;;;;;;;;;10212:61:0;;;;;;;;;;-1:-1:-1;10287:4:0;10031:266;;;;:::o;9157:128::-;-1:-1:-1;;;;;9254:15:0;;;9231:7;9254:15;;;:7;:15;;;;;;;;:25;;;;;;;;;;;;;9157:128::o;19290:117::-;19336:71;;;;;;;;;;;;;;;;;;19290:117;:::o;18707:70::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;12663:178::-;12476:5;;-1:-1:-1;;;;;12476:5:0;12462:10;:19;12454:28;;;;;;-1:-1:-1;;;;;12740:22:0;;12732:31;;;;;;12796:5;;12775:37;;-1:-1:-1;;;;;12775:37:0;;;;12796:5;;12775:37;;12796:5;;12775:37;12819:5;:16;;-1:-1:-1;;;;;;12819:16:0;-1:-1:-1;;;;;12819:16:0;;;;;;;;;;12663:178::o;16042:40::-;;;;;;;;;;;;;;;:::o;3461:113::-;3519:7;3547:1;3542;:6;;3535:14;;;;-1:-1:-1;3563:5:0;;;3461:113::o;25014:487::-;-1:-1:-1;;;;;25109:17:0;;25101:84;;;;-1:-1:-1;;;25101:84:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;25204:17:0;;25196:82;;;;-1:-1:-1;;;25196:82:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;25307:13:0;;:8;:13;;;;;;;;;;;:25;;25325:6;25307:25;:17;:25;:::i;:::-;-1:-1:-1;;;;;25291:13:0;;;:8;:13;;;;;;;;;;;:41;;;;25359:13;;;;;;;:25;;25377:6;25359:25;:17;:25;:::i;:::-;-1:-1:-1;;;;;25343:13:0;;;:8;:13;;;;;;;;;;;;:41;;;;25400:26;;;;;;;25343:13;;25400:26;;;;;;;;;;;;;-1:-1:-1;;;;;25454:14:0;;;;;;;:9;:14;;;;;;;25470;;;;;;;;25439:54;;25454:14;;;;25470;25486:6;25439:14;:54::i;:::-;25014:487;;;:::o;3937:127::-;4017:5;;;4036:6;;;;4029:14;;;25509:851;25615:6;-1:-1:-1;;;;;25605:16:0;:6;-1:-1:-1;;;;;25605:16:0;;;:30;;;;;25634:1;25625:6;:10;25605:30;25601:752;;;-1:-1:-1;;;;;25656:20:0;;;25652:337;;-1:-1:-1;;;;;25716:22:0;;25697:16;25716:22;;;:14;:22;;;;;;;;;25777:13;:60;;25836:1;25777:60;;;-1:-1:-1;;;;;25793:19:0;;;;;;:11;:19;;;;;;;;:34;-1:-1:-1;;25813:13:0;;25793:34;;;;;;;;25825:1;25793:40;;25777:60;25757:80;-1:-1:-1;25856:17:0;25876:21;25757:80;25890:6;25876:21;:13;:21;:::i;:::-;25856:41;;25916:57;25933:6;25941:9;25952;25963;25916:16;:57::i;:::-;25652:337;;;;-1:-1:-1;;;;;26009:20:0;;;26005:337;;-1:-1:-1;;;;;26069:22:0;;26050:16;26069:22;;;:14;:22;;;;;;;;;26130:13;:60;;26189:1;26130:60;;;-1:-1:-1;;;;;26146:19:0;;;;;;:11;:19;;;;;;;;:34;-1:-1:-1;;26166:13:0;;26146:34;;;;;;;;26178:1;26146:40;;26130:60;26110:80;-1:-1:-1;26209:17:0;26229:21;26110:80;26243:6;26229:21;:13;:21;:::i;:::-;26209:41;;26269:57;26286:6;26294:9;26305;26316;26269:16;:57::i;24630:376::-;-1:-1:-1;;;;;24733:20:0;;;24707:23;24733:20;;;:9;:20;;;;;;;;;;24791:19;;;;;;;24821:20;;;;:32;;;-1:-1:-1;;;;;;24821:32:0;;;;;;;24871:54;;24733:20;;;;;24791:19;;24821:32;;24733:20;;;24871:54;;24707:23;24871:54;24938:60;24953:15;24970:9;24981:16;24938:14;:60::i;:::-;24630:376;;;;:::o;26368:625::-;26488:18;26509:70;26516:12;26509:70;;;;;;;;;;;;;;;;;:6;:70::i;:::-;26488:91;;26609:1;26594:12;:16;;;:85;;;;-1:-1:-1;;;;;;26614:22:0;;;;;;:11;:22;;;;;;;;:65;-1:-1:-1;;26637:16:0;;26614:40;;;;;;;;;:50;:65;;;:50;;:65;26594:85;26590:329;;;-1:-1:-1;;;;;26694:22:0;;;;;;:11;:22;;;;;;;;:40;-1:-1:-1;;26717:16:0;;26694:40;;;;;;;;26732:1;26694:46;:57;;;26590:329;;;26819:33;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;26780:22:0;;-1:-1:-1;26780:22:0;;;:11;:22;;;;;:36;;;;;;;;;;:72;;;;;;;-1:-1:-1;;26780:72:0;;;;;;;;;;;;;26865:25;;;:14;:25;;;;;;:44;;26893:16;;;26865:44;;;;;;;;;;26590:329;26934:51;;;;;;;;;;;;;;-1:-1:-1;;;;;26934:51:0;;;;;;;;;;;26368:625;;;;;:::o;27001:161::-;27076:6;27114:12;27107:5;27103:9;;27095:32;;;;-1:-1:-1;;;27095:32: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;27095:32:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;27152:1:0;;27001:161;-1:-1:-1;;27001:161:0:o;15610:11555::-;;;;;;;;;;-1:-1:-1;15610:11555:0;;;;;;;;:::o

Swarm Source

bzzr://f89363764affb5a8655959f3107c1cac23d7b482537d8a7262b2fd241c99f95d
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.