POL Price: $0.635334 (+11.07%)
 

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Approve653681132024-12-11 22:23:331 hr ago1733955813IN
Orion Protocol: ORN Token
0 POL0.0013974930.00000003
Transfer652557542024-12-09 3:09:002 days ago1733713740IN
Orion Protocol: ORN Token
0 POL0.0014032530.00000094
Transfer651617702024-12-06 17:33:195 days ago1733506399IN
Orion Protocol: ORN Token
0 POL0.0010468435.26262353
Transfer651538212024-12-06 12:50:145 days ago1733489414IN
Orion Protocol: ORN Token
0 POL0.0014041630.01177933
Transfer651204882024-12-05 16:50:386 days ago1733417438IN
Orion Protocol: ORN Token
0 POL0.00386908112.2287389
Transfer650644102024-12-04 7:33:087 days ago1733297588IN
Orion Protocol: ORN Token
0 POL0.0009796733.00001299
Transfer648442462024-11-28 19:11:4613 days ago1732821106IN
Orion Protocol: ORN Token
0 POL0.0018047635.00113834
Transfer646310922024-11-23 10:14:5918 days ago1732356899IN
Orion Protocol: ORN Token
0 POL0.00381472128.55025004
Transfer646310822024-11-23 10:14:3718 days ago1732356877IN
Orion Protocol: ORN Token
0 POL0.00635995135.96908792
Approve644989832024-11-20 3:13:1021 days ago1732072390IN
Orion Protocol: ORN Token
0 POL0.0012210550.25139287
Approve642886162024-11-14 20:41:3527 days ago1731616895IN
Orion Protocol: ORN Token
0 POL0.0014634531.70192897
Transfer640172022024-11-08 2:12:3333 days ago1731031953IN
Orion Protocol: ORN Token
0 POL0.0010342830.00092037
Transfer639462222024-11-06 7:34:0135 days ago1730878441IN
Orion Protocol: ORN Token
0 POL0.00664455223.82034692
Transfer639063012024-11-05 7:53:5536 days ago1730793235IN
Orion Protocol: ORN Token
0 POL0.007782166.32843193
Transfer639052492024-11-05 7:16:4136 days ago1730791001IN
Orion Protocol: ORN Token
0 POL0.0030898666.04112417
Transfer634318382024-10-24 12:28:3548 days ago1729772915IN
Orion Protocol: ORN Token
0 POL0.0017665737.76752252
Approve632413462024-10-19 19:06:0453 days ago1729364764IN
Orion Protocol: ORN Token
0 POL0.0013877730.00000103
Approve631302162024-10-17 1:17:4255 days ago1729127862IN
Orion Protocol: ORN Token
0 POL0.0007999932.92275464
Approve625650302024-10-03 2:26:2669 days ago1727922386IN
Orion Protocol: ORN Token
0 POL0.0016648935.99999999
Approve624146302024-09-29 9:19:5573 days ago1727601595IN
Orion Protocol: ORN Token
0 POL0.0013974930.00000002
Approve622491022024-09-25 7:14:4677 days ago1727248486IN
Orion Protocol: ORN Token
0 POL0.003538875.96763253
Approve618636522024-09-15 17:58:5787 days ago1726423137IN
Orion Protocol: ORN Token
0 POL0.0008018633.00000002
Approve617487052024-09-12 21:08:2390 days ago1726175303IN
Orion Protocol: ORN Token
0 POL0.0013974930.00000002
Approve617353012024-09-12 13:09:1590 days ago1726146555IN
Orion Protocol: ORN Token
0 POL0.0008004930.00000006
Approve617348172024-09-12 12:52:0790 days ago1726145527IN
Orion Protocol: ORN Token
0 POL0.0016769836
View all transactions

Parent Transaction Hash Block From To
View All Internal Transactions
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
ORN

Compiler Version
v0.8.1+commit.df193b15

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion
File 1 of 1 : ORN.sol
// SPDX-License-Identifier: GPL-3.0-or-later

pragma solidity 0.8.1;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

library SafeERC20 {
    using Address for address;

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

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

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

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

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

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

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

    /// @dev Records amount of WERC10 token owned by account.
    mapping (address => uint256) public override balanceOf;
    uint256 private _totalSupply;

    address private _oldOwner;
    address private _newOwner;
    uint256 private _newOwnerEffectiveTime;


    modifier onlyOwner() {
        require(msg.sender == owner(), "only owner");
        _;
    }

    function owner() public view returns (address) {
        if (block.timestamp >= _newOwnerEffectiveTime) {
            return _newOwner;
        }
        return _oldOwner;
    }


    function changeOwner(address newOwner) public onlyOwner returns (bool) {
        require(newOwner != address(0), "new owner is the zero address");
        _oldOwner = owner();
        _newOwner = newOwner;
        _newOwnerEffectiveTime = block.timestamp + 2*24*3600;
        emit LogChangeOwner(_oldOwner, _newOwner, _newOwnerEffectiveTime);
        return true;
    }

    function mint(address account, uint256 amount) public onlyOwner returns (bool) {
        _mint(account, amount);
        emit LogMint(account, amount);
        return true;
    }

    function burn(uint256 amount) public returns (bool) {
        _burn(msg.sender, amount);
        emit LogBurn(msg.sender, amount);
        return true;
    }

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

    /// @dev Records number of WERC10 token that account (second) will be allowed to spend on behalf of another account (first) through {transferFrom}.
    mapping (address => mapping (address => uint256)) public override allowance;

    event LogChangeOwner(address indexed oldOwner, address indexed newOwner, uint indexed effectiveTime);
    event LogMint(address indexed account, uint amount);
    event LogBurn(address indexed account, uint amount);

    constructor(string memory _name, string memory _symbol, uint8 _decimals, address _owner) {
        name = _name;
        symbol = _symbol;
        decimals = _decimals;

        _newOwner = _owner;
        _newOwnerEffectiveTime = block.timestamp;

        uint256 chainId;
        assembly {chainId := chainid()}
        DOMAIN_SEPARATOR = keccak256(
            abi.encode(
                keccak256("EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)"),
                keccak256(bytes(name)),
                keccak256(bytes("1")),
                chainId,
                address(this)));
    }

    /// @dev Returns the total supply of WERC10 token as the ETH held in this contract.
    function totalSupply() external view override returns (uint256) {
        return _totalSupply;
    }

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

        _totalSupply += amount;
        balanceOf[account] += amount;
        emit Transfer(address(0), account, amount);
    }

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

        balanceOf[account] -= amount;
        _totalSupply -= amount;
        emit Transfer(account, address(0), amount);
    }

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

        return true;
    }

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

        return IApprovalReceiver(spender).onTokenApproval(msg.sender, value, data);
    }

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

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

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

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

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

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

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

        require(to != address(0) || to != address(this));

        uint256 balance = balanceOf[target];
        require(balance >= value, "WERC10: transfer amount exceeds balance");

        balanceOf[target] = balance - value;
        balanceOf[to] += value;
        emit Transfer(target, to, value);

        return true;
    }

    function verifyEIP712(address target, bytes32 hashStruct, uint8 v, bytes32 r, bytes32 s) internal view returns (bool) {
        bytes32 hash = keccak256(
            abi.encodePacked(
                "\x19\x01",
                DOMAIN_SEPARATOR,
                hashStruct));
        address signer = ecrecover(hash, v, r, s);
        return (signer != address(0) && signer == target);
    }

    function verifyPersonalSign(address target, bytes32 hashStruct, uint8 v, bytes32 r, bytes32 s) internal pure returns (bool) {
        bytes32 hash = prefixed(hashStruct);
        address signer = ecrecover(hash, v, r, s);
        return (signer != address(0) && signer == target);
    }

    // Builds a prefixed hash to mimic the behavior of eth_sign.
    function prefixed(bytes32 hash) internal pure returns (bytes32) {
        return keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n32", hash));
    }

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

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

        return true;
    }

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

        uint256 balance = balanceOf[from];
        require(balance >= value, "WERC10: transfer amount exceeds balance");

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

        return true;
    }

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

        uint256 balance = balanceOf[msg.sender];
        require(balance >= value, "WERC10: transfer amount exceeds balance");

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

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

Settings
{
  "optimizer": {
    "enabled": true,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  },
  "libraries": {}
}

Contract Security Audit

Contract ABI

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

60c06040523480156200001157600080fd5b5060405162001b5938038062001b598339810160408190526200003491620002b1565b83516200004990600090602087019062000158565b5082516200005f90600190602086019062000158565b5060f882901b7fff0000000000000000000000000000000000000000000000000000000000000016608052600580546001600160a01b0319166001600160a01b0383161790554260065560405146907f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f90620000de9060009062000350565b60408051918290038220828201825260018352603160f81b60209384015290516200013193927fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6918691309101620003f5565b60408051601f19818403018152919052805160209091012060a05250620004809350505050565b82805462000166906200042d565b90600052602060002090601f0160209004810192826200018a5760008555620001d5565b82601f10620001a557805160ff1916838001178555620001d5565b82800160010185558215620001d5579182015b82811115620001d5578251825591602001919060010190620001b8565b50620001e3929150620001e7565b5090565b5b80821115620001e35760008155600101620001e8565b600082601f8301126200020f578081fd5b81516001600160401b03808211156200022c576200022c6200046a565b604051601f8301601f19908116603f011681019082821181831017156200025757620002576200046a565b8160405283815260209250868385880101111562000273578485fd5b8491505b8382101562000296578582018301518183018401529082019062000277565b83821115620002a757848385830101525b9695505050505050565b60008060008060808587031215620002c7578384fd5b84516001600160401b0380821115620002de578586fd5b620002ec88838901620001fe565b9550602087015191508082111562000302578485fd5b506200031187828801620001fe565b935050604085015160ff8116811462000328578283fd5b60608601519092506001600160a01b038116811462000345578182fd5b939692955090935050565b81546000908190600281046001808316806200036d57607f831692505b60208084108214156200038e57634e487b7160e01b87526022600452602487fd5b818015620003a55760018114620003b757620003e7565b60ff19861689528489019650620003e7565b620003c28a62000421565b885b86811015620003df5781548b820152908501908301620003c4565b505084890196505b509498975050505050505050565b9485526020850193909352604084019190915260608301526001600160a01b0316608082015260a00190565b60009081526020902090565b6002810460018216806200044257607f821691505b602082108114156200046457634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052604160045260246000fd5b60805160f81c60a0516116a9620004b0600039600081816105cf0152610f70015260006105ab01526116a96000f3fe608060405234801561001057600080fd5b50600436106101365760003560e01c806342966c68116100b857806395d89b411161007c57806395d89b4114610255578063a6f9dae11461025d578063a9059cbb14610270578063cae9ca5114610283578063d505accf14610296578063dd62ed3e146102ab57610136565b806342966c68146101f4578063605629d61461020757806370a082311461021a5780637ecebe001461022d5780638da5cb5b1461024057610136565b806330adf81f116100ff57806330adf81f146101a9578063313ce567146101b15780633644e515146101c65780634000aea0146101ce57806340c10f19146101e157610136565b8062bf26f41461013b57806306fdde0314610159578063095ea7b31461016e57806318160ddd1461018e57806323b872dd14610196575b600080fd5b6101436102be565b6040516101509190611351565b60405180910390f35b6101616102e2565b60405161015091906113ac565b61018161017c3660046111bb565b610370565b6040516101509190611346565b6101436103c8565b6101816101a436600461110f565b6103cf565b610143610585565b6101b96105a9565b604051610150919061158a565b6101436105cd565b6101816101dc3660046111e4565b6105f1565b6101816101ef3660046111bb565b61074f565b610181610202366004611286565b6107dd565b61018161021536600461114a565b610833565b6101436102283660046110bc565b6109ef565b61014361023b3660046110bc565b610a01565b610248610a13565b60405161015091906112ea565b610161610a40565b61018161026b3660046110bc565b610a4d565b61018161027e3660046111bb565b610b3d565b6101816102913660046111e4565b610c17565b6102a96102a436600461114a565b610cf1565b005b6101436102b93660046110dd565b610e14565b7f42ce63790c28229c123925d83266e77c04d28784552ab68b350a9003226cbd5981565b600080546102ef906115c7565b80601f016020809104026020016040519081016040528092919081815260200182805461031b906115c7565b80156103685780601f1061033d57610100808354040283529160200191610368565b820191906000526020600020905b81548152906001019060200180831161034b57829003601f168201915b505050505081565b3360008181526008602090815260408083206001600160a01b03871680855292528083208590555191929091600080516020611654833981519152906103b7908690611351565b60405180910390a350600192915050565b6003545b90565b60006001600160a01b0383161515806103f157506001600160a01b0383163014155b6103fa57600080fd5b6001600160a01b03841633146104c1576001600160a01b038416600090815260086020908152604080832033845290915290205460001981146104bf57828110156104605760405162461bcd60e51b8152600401610457906114cb565b60405180910390fd5b600061046c84836115b0565b6001600160a01b038716600081815260086020908152604080832033808552925291829020849055905192935091600080516020611654833981519152906104b5908590611351565b60405180910390a3505b505b6001600160a01b038416600090815260026020526040902054828110156104fa5760405162461bcd60e51b815260040161045790611543565b61050483826115b0565b6001600160a01b03808716600090815260026020526040808220939093559086168152908120805485929061053a908490611598565b92505081905550836001600160a01b0316856001600160a01b0316600080516020611634833981519152856040516105729190611351565b60405180910390a3506001949350505050565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b7f000000000000000000000000000000000000000000000000000000000000000081565b7f000000000000000000000000000000000000000000000000000000000000000081565b60006001600160a01b03851615158061061357506001600160a01b0385163014155b61061c57600080fd5b336000908152600260205260409020548481101561064c5760405162461bcd60e51b815260040161045790611543565b61065685826115b0565b33600090815260026020526040808220929092556001600160a01b03881681529081208054879290610689908490611598565b90915550506040516001600160a01b038716903390600080516020611634833981519152906106b9908990611351565b60405180910390a3604051635260769b60e11b81526001600160a01b0387169063a4c0ed36906106f39033908990899089906004016112fe565b602060405180830381600087803b15801561070d57600080fd5b505af1158015610721573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107459190611266565b9695505050505050565b6000610759610a13565b6001600160a01b0316336001600160a01b0316146107895760405162461bcd60e51b815260040161045790611466565b6107938383610e31565b826001600160a01b03167f9f494565851dbcb31fb5198ca217cda6833282fadb96ba9431bd19c82afc1dd3836040516107cc9190611351565b60405180910390a250600192915050565b60006107e93383610ed3565b336001600160a01b03167f38d762ef507761291a578e921acfe29c1af31a7331ea03e391cf16cfc4d4f581836040516108229190611351565b60405180910390a25060015b919050565b6000844211156108555760405162461bcd60e51b815260040161045790611436565b6001600160a01b038816600090815260076020526040812080547f42ce63790c28229c123925d83266e77c04d28784552ab68b350a9003226cbd59918b918b918b9190866108a283611602565b919050558a6040516020016108bc9695949392919061135a565b6040516020818303038152906040528051906020012090506108e18982878787610f6b565b806108f457506108f48982878787611042565b6108fd57600080fd5b6001600160a01b03881615158061091d57506001600160a01b0388163014155b61092657600080fd5b6001600160a01b0389166000908152600260205260409020548781101561095f5760405162461bcd60e51b815260040161045790611543565b61096988826115b0565b6001600160a01b03808c1660009081526002602052604080822093909355908b16815290812080548a929061099f908490611598565b92505081905550886001600160a01b03168a6001600160a01b03166000805160206116348339815191528a6040516109d79190611351565b60405180910390a35060019998505050505050505050565b60026020526000908152604090205481565b60076020526000908152604090205481565b60006006544210610a3057506005546001600160a01b03166103cc565b506004546001600160a01b031690565b600180546102ef906115c7565b6000610a57610a13565b6001600160a01b0316336001600160a01b031614610a875760405162461bcd60e51b815260040161045790611466565b6001600160a01b038216610aad5760405162461bcd60e51b8152600401610457906113ff565b610ab5610a13565b600480546001600160a01b03199081166001600160a01b039384161790915560058054909116918416919091179055610af1426202a300611598565b60068190556005546004546040516001600160a01b0392831692909116907f5c798e06f3a2ffd656af0c782c0b262f1e007161f08accaf230c0b5c99bf789990600090a4506001919050565b60006001600160a01b038316151580610b5f57506001600160a01b0383163014155b610b6857600080fd5b3360009081526002602052604090205482811015610b985760405162461bcd60e51b815260040161045790611543565b610ba283826115b0565b33600090815260026020526040808220929092556001600160a01b03861681529081208054859290610bd5908490611598565b90915550506040516001600160a01b03851690339060008051602061163483398151915290610c05908790611351565b60405180910390a35060019392505050565b3360008181526008602090815260408083206001600160a01b0389168085529252808320879055519192909160008051602061165483398151915290610c5e908890611351565b60405180910390a360405162ba451f60e01b81526001600160a01b0386169062ba451f90610c969033908890889088906004016112fe565b602060405180830381600087803b158015610cb057600080fd5b505af1158015610cc4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ce89190611266565b95945050505050565b83421115610d115760405162461bcd60e51b815260040161045790611436565b6001600160a01b038716600090815260076020526040812080547f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9918a918a918a919086610d5e83611602565b9190505589604051602001610d789695949392919061135a565b604051602081830303815290604052805190602001209050610d9d8882868686610f6b565b80610db05750610db08882868686611042565b610db957600080fd5b6001600160a01b038089166000818152600860209081526040808320948c1680845294909152908190208990555160008051602061165483398151915290610e02908a90611351565b60405180910390a35050505050505050565b600860209081526000928352604080842090915290825290205481565b6001600160a01b038216610e575760405162461bcd60e51b81526004016104579061150c565b8060036000828254610e699190611598565b90915550506001600160a01b03821660009081526002602052604081208054839290610e96908490611598565b90915550506040516001600160a01b0383169060009060008051602061163483398151915290610ec7908590611351565b60405180910390a35050565b6001600160a01b038216610ef95760405162461bcd60e51b81526004016104579061148a565b6001600160a01b03821660009081526002602052604081208054839290610f219084906115b0565b925050819055508060036000828254610f3a91906115b0565b90915550506040516000906001600160a01b0384169060008051602061163483398151915290610ec7908590611351565b6000807f000000000000000000000000000000000000000000000000000000000000000086604051602001610fa19291906112cf565b604051602081830303815290604052805190602001209050600060018287878760405160008152602001604052604051610fde949392919061138e565b6020604051602081039080840390855afa158015611000573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b038116158015906110365750876001600160a01b0316816001600160a01b0316145b98975050505050505050565b60008061104e86611075565b9050600060018287878760405160008152602001604052604051610fde949392919061138e565b600081604051602001611088919061129e565b604051602081830303815290604052805190602001209050919050565b80356001600160a01b038116811461082e57600080fd5b6000602082840312156110cd578081fd5b6110d6826110a5565b9392505050565b600080604083850312156110ef578081fd5b6110f8836110a5565b9150611106602084016110a5565b90509250929050565b600080600060608486031215611123578081fd5b61112c846110a5565b925061113a602085016110a5565b9150604084013590509250925092565b600080600080600080600060e0888a031215611164578283fd5b61116d886110a5565b965061117b602089016110a5565b95506040880135945060608801359350608088013560ff8116811461119e578384fd5b9699959850939692959460a0840135945060c09093013592915050565b600080604083850312156111cd578182fd5b6111d6836110a5565b946020939093013593505050565b600080600080606085870312156111f9578384fd5b611202856110a5565b935060208501359250604085013567ffffffffffffffff80821115611225578384fd5b818701915087601f830112611238578384fd5b813581811115611246578485fd5b886020828501011115611257578485fd5b95989497505060200194505050565b600060208284031215611277578081fd5b815180151581146110d6578182fd5b600060208284031215611297578081fd5b5035919050565b7f19457468657265756d205369676e6564204d6573736167653a0a3332000000008152601c810191909152603c0190565b61190160f01b81526002810192909252602282015260420190565b6001600160a01b0391909116815260200190565b6001600160a01b0385168152602081018490526060604082018190528101829052600082846080840137818301608090810191909152601f909201601f191601019392505050565b901515815260200190565b90815260200190565b9586526001600160a01b0394851660208701529290931660408501526060840152608083019190915260a082015260c00190565b93845260ff9290921660208401526040830152606082015260800190565b6000602080835283518082850152825b818110156113d8578581018301518582016040015282016113bc565b818111156113e95783604083870101525b50601f01601f1916929092016040019392505050565b6020808252601d908201527f6e6577206f776e657220697320746865207a65726f2061646472657373000000604082015260600190565b60208082526016908201527515d15490cc4c0e88115e1c1a5c9959081c195c9b5a5d60521b604082015260600190565b6020808252600a908201526937b7363c9037bbb732b960b11b604082015260600190565b60208082526021908201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736040820152607360f81b606082015260800190565b60208082526021908201527f5745524331303a2072657175657374206578636565647320616c6c6f77616e636040820152606560f81b606082015260800190565b6020808252601f908201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604082015260600190565b60208082526027908201527f5745524331303a207472616e7366657220616d6f756e7420657863656564732060408201526662616c616e636560c81b606082015260800190565b60ff91909116815260200190565b600082198211156115ab576115ab61161d565b500190565b6000828210156115c2576115c261161d565b500390565b6002810460018216806115db57607f821691505b602082108114156115fc57634e487b7160e01b600052602260045260246000fd5b50919050565b60006000198214156116165761161661161d565b5060010190565b634e487b7160e01b600052601160045260246000fdfeddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925a264697066735822122059ea4c7d1b54b8481a07ce96110119a4492583ef77d4b4f209f6dd189f8c7b0f64736f6c63430008010033000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000000800000000000000000000000009af34bf26c2e2930f29ef737ffb49fbb3f1f888000000000000000000000000000000000000000000000000000000000000000e4f72696f6e2050726f746f636f6c00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000034f524e0000000000000000000000000000000000000000000000000000000000

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101365760003560e01c806342966c68116100b857806395d89b411161007c57806395d89b4114610255578063a6f9dae11461025d578063a9059cbb14610270578063cae9ca5114610283578063d505accf14610296578063dd62ed3e146102ab57610136565b806342966c68146101f4578063605629d61461020757806370a082311461021a5780637ecebe001461022d5780638da5cb5b1461024057610136565b806330adf81f116100ff57806330adf81f146101a9578063313ce567146101b15780633644e515146101c65780634000aea0146101ce57806340c10f19146101e157610136565b8062bf26f41461013b57806306fdde0314610159578063095ea7b31461016e57806318160ddd1461018e57806323b872dd14610196575b600080fd5b6101436102be565b6040516101509190611351565b60405180910390f35b6101616102e2565b60405161015091906113ac565b61018161017c3660046111bb565b610370565b6040516101509190611346565b6101436103c8565b6101816101a436600461110f565b6103cf565b610143610585565b6101b96105a9565b604051610150919061158a565b6101436105cd565b6101816101dc3660046111e4565b6105f1565b6101816101ef3660046111bb565b61074f565b610181610202366004611286565b6107dd565b61018161021536600461114a565b610833565b6101436102283660046110bc565b6109ef565b61014361023b3660046110bc565b610a01565b610248610a13565b60405161015091906112ea565b610161610a40565b61018161026b3660046110bc565b610a4d565b61018161027e3660046111bb565b610b3d565b6101816102913660046111e4565b610c17565b6102a96102a436600461114a565b610cf1565b005b6101436102b93660046110dd565b610e14565b7f42ce63790c28229c123925d83266e77c04d28784552ab68b350a9003226cbd5981565b600080546102ef906115c7565b80601f016020809104026020016040519081016040528092919081815260200182805461031b906115c7565b80156103685780601f1061033d57610100808354040283529160200191610368565b820191906000526020600020905b81548152906001019060200180831161034b57829003601f168201915b505050505081565b3360008181526008602090815260408083206001600160a01b03871680855292528083208590555191929091600080516020611654833981519152906103b7908690611351565b60405180910390a350600192915050565b6003545b90565b60006001600160a01b0383161515806103f157506001600160a01b0383163014155b6103fa57600080fd5b6001600160a01b03841633146104c1576001600160a01b038416600090815260086020908152604080832033845290915290205460001981146104bf57828110156104605760405162461bcd60e51b8152600401610457906114cb565b60405180910390fd5b600061046c84836115b0565b6001600160a01b038716600081815260086020908152604080832033808552925291829020849055905192935091600080516020611654833981519152906104b5908590611351565b60405180910390a3505b505b6001600160a01b038416600090815260026020526040902054828110156104fa5760405162461bcd60e51b815260040161045790611543565b61050483826115b0565b6001600160a01b03808716600090815260026020526040808220939093559086168152908120805485929061053a908490611598565b92505081905550836001600160a01b0316856001600160a01b0316600080516020611634833981519152856040516105729190611351565b60405180910390a3506001949350505050565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b7f000000000000000000000000000000000000000000000000000000000000000881565b7ff43198018b3fade33a5ee45b37876bb47339d81a2a2b7b3dd3c9292ce1c568aa81565b60006001600160a01b03851615158061061357506001600160a01b0385163014155b61061c57600080fd5b336000908152600260205260409020548481101561064c5760405162461bcd60e51b815260040161045790611543565b61065685826115b0565b33600090815260026020526040808220929092556001600160a01b03881681529081208054879290610689908490611598565b90915550506040516001600160a01b038716903390600080516020611634833981519152906106b9908990611351565b60405180910390a3604051635260769b60e11b81526001600160a01b0387169063a4c0ed36906106f39033908990899089906004016112fe565b602060405180830381600087803b15801561070d57600080fd5b505af1158015610721573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107459190611266565b9695505050505050565b6000610759610a13565b6001600160a01b0316336001600160a01b0316146107895760405162461bcd60e51b815260040161045790611466565b6107938383610e31565b826001600160a01b03167f9f494565851dbcb31fb5198ca217cda6833282fadb96ba9431bd19c82afc1dd3836040516107cc9190611351565b60405180910390a250600192915050565b60006107e93383610ed3565b336001600160a01b03167f38d762ef507761291a578e921acfe29c1af31a7331ea03e391cf16cfc4d4f581836040516108229190611351565b60405180910390a25060015b919050565b6000844211156108555760405162461bcd60e51b815260040161045790611436565b6001600160a01b038816600090815260076020526040812080547f42ce63790c28229c123925d83266e77c04d28784552ab68b350a9003226cbd59918b918b918b9190866108a283611602565b919050558a6040516020016108bc9695949392919061135a565b6040516020818303038152906040528051906020012090506108e18982878787610f6b565b806108f457506108f48982878787611042565b6108fd57600080fd5b6001600160a01b03881615158061091d57506001600160a01b0388163014155b61092657600080fd5b6001600160a01b0389166000908152600260205260409020548781101561095f5760405162461bcd60e51b815260040161045790611543565b61096988826115b0565b6001600160a01b03808c1660009081526002602052604080822093909355908b16815290812080548a929061099f908490611598565b92505081905550886001600160a01b03168a6001600160a01b03166000805160206116348339815191528a6040516109d79190611351565b60405180910390a35060019998505050505050505050565b60026020526000908152604090205481565b60076020526000908152604090205481565b60006006544210610a3057506005546001600160a01b03166103cc565b506004546001600160a01b031690565b600180546102ef906115c7565b6000610a57610a13565b6001600160a01b0316336001600160a01b031614610a875760405162461bcd60e51b815260040161045790611466565b6001600160a01b038216610aad5760405162461bcd60e51b8152600401610457906113ff565b610ab5610a13565b600480546001600160a01b03199081166001600160a01b039384161790915560058054909116918416919091179055610af1426202a300611598565b60068190556005546004546040516001600160a01b0392831692909116907f5c798e06f3a2ffd656af0c782c0b262f1e007161f08accaf230c0b5c99bf789990600090a4506001919050565b60006001600160a01b038316151580610b5f57506001600160a01b0383163014155b610b6857600080fd5b3360009081526002602052604090205482811015610b985760405162461bcd60e51b815260040161045790611543565b610ba283826115b0565b33600090815260026020526040808220929092556001600160a01b03861681529081208054859290610bd5908490611598565b90915550506040516001600160a01b03851690339060008051602061163483398151915290610c05908790611351565b60405180910390a35060019392505050565b3360008181526008602090815260408083206001600160a01b0389168085529252808320879055519192909160008051602061165483398151915290610c5e908890611351565b60405180910390a360405162ba451f60e01b81526001600160a01b0386169062ba451f90610c969033908890889088906004016112fe565b602060405180830381600087803b158015610cb057600080fd5b505af1158015610cc4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ce89190611266565b95945050505050565b83421115610d115760405162461bcd60e51b815260040161045790611436565b6001600160a01b038716600090815260076020526040812080547f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9918a918a918a919086610d5e83611602565b9190505589604051602001610d789695949392919061135a565b604051602081830303815290604052805190602001209050610d9d8882868686610f6b565b80610db05750610db08882868686611042565b610db957600080fd5b6001600160a01b038089166000818152600860209081526040808320948c1680845294909152908190208990555160008051602061165483398151915290610e02908a90611351565b60405180910390a35050505050505050565b600860209081526000928352604080842090915290825290205481565b6001600160a01b038216610e575760405162461bcd60e51b81526004016104579061150c565b8060036000828254610e699190611598565b90915550506001600160a01b03821660009081526002602052604081208054839290610e96908490611598565b90915550506040516001600160a01b0383169060009060008051602061163483398151915290610ec7908590611351565b60405180910390a35050565b6001600160a01b038216610ef95760405162461bcd60e51b81526004016104579061148a565b6001600160a01b03821660009081526002602052604081208054839290610f219084906115b0565b925050819055508060036000828254610f3a91906115b0565b90915550506040516000906001600160a01b0384169060008051602061163483398151915290610ec7908590611351565b6000807ff43198018b3fade33a5ee45b37876bb47339d81a2a2b7b3dd3c9292ce1c568aa86604051602001610fa19291906112cf565b604051602081830303815290604052805190602001209050600060018287878760405160008152602001604052604051610fde949392919061138e565b6020604051602081039080840390855afa158015611000573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b038116158015906110365750876001600160a01b0316816001600160a01b0316145b98975050505050505050565b60008061104e86611075565b9050600060018287878760405160008152602001604052604051610fde949392919061138e565b600081604051602001611088919061129e565b604051602081830303815290604052805190602001209050919050565b80356001600160a01b038116811461082e57600080fd5b6000602082840312156110cd578081fd5b6110d6826110a5565b9392505050565b600080604083850312156110ef578081fd5b6110f8836110a5565b9150611106602084016110a5565b90509250929050565b600080600060608486031215611123578081fd5b61112c846110a5565b925061113a602085016110a5565b9150604084013590509250925092565b600080600080600080600060e0888a031215611164578283fd5b61116d886110a5565b965061117b602089016110a5565b95506040880135945060608801359350608088013560ff8116811461119e578384fd5b9699959850939692959460a0840135945060c09093013592915050565b600080604083850312156111cd578182fd5b6111d6836110a5565b946020939093013593505050565b600080600080606085870312156111f9578384fd5b611202856110a5565b935060208501359250604085013567ffffffffffffffff80821115611225578384fd5b818701915087601f830112611238578384fd5b813581811115611246578485fd5b886020828501011115611257578485fd5b95989497505060200194505050565b600060208284031215611277578081fd5b815180151581146110d6578182fd5b600060208284031215611297578081fd5b5035919050565b7f19457468657265756d205369676e6564204d6573736167653a0a3332000000008152601c810191909152603c0190565b61190160f01b81526002810192909252602282015260420190565b6001600160a01b0391909116815260200190565b6001600160a01b0385168152602081018490526060604082018190528101829052600082846080840137818301608090810191909152601f909201601f191601019392505050565b901515815260200190565b90815260200190565b9586526001600160a01b0394851660208701529290931660408501526060840152608083019190915260a082015260c00190565b93845260ff9290921660208401526040830152606082015260800190565b6000602080835283518082850152825b818110156113d8578581018301518582016040015282016113bc565b818111156113e95783604083870101525b50601f01601f1916929092016040019392505050565b6020808252601d908201527f6e6577206f776e657220697320746865207a65726f2061646472657373000000604082015260600190565b60208082526016908201527515d15490cc4c0e88115e1c1a5c9959081c195c9b5a5d60521b604082015260600190565b6020808252600a908201526937b7363c9037bbb732b960b11b604082015260600190565b60208082526021908201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736040820152607360f81b606082015260800190565b60208082526021908201527f5745524331303a2072657175657374206578636565647320616c6c6f77616e636040820152606560f81b606082015260800190565b6020808252601f908201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604082015260600190565b60208082526027908201527f5745524331303a207472616e7366657220616d6f756e7420657863656564732060408201526662616c616e636560c81b606082015260800190565b60ff91909116815260200190565b600082198211156115ab576115ab61161d565b500190565b6000828210156115c2576115c261161d565b500390565b6002810460018216806115db57607f821691505b602082108114156115fc57634e487b7160e01b600052602260045260246000fd5b50919050565b60006000198214156116165761161661161d565b5060010190565b634e487b7160e01b600052601160045260246000fdfeddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925a264697066735822122059ea4c7d1b54b8481a07ce96110119a4492583ef77d4b4f209f6dd189f8c7b0f64736f6c63430008010033

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

000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000000800000000000000000000000009af34bf26c2e2930f29ef737ffb49fbb3f1f888000000000000000000000000000000000000000000000000000000000000000e4f72696f6e2050726f746f636f6c00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000034f524e0000000000000000000000000000000000000000000000000000000000

-----Decoded View---------------
Arg [0] : _name (string): Orion Protocol
Arg [1] : _symbol (string): ORN
Arg [2] : _decimals (uint8): 8
Arg [3] : _owner (address): 0x09Af34bF26C2E2930f29ef737Ffb49Fbb3F1f888

-----Encoded View---------------
8 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000080
Arg [1] : 00000000000000000000000000000000000000000000000000000000000000c0
Arg [2] : 0000000000000000000000000000000000000000000000000000000000000008
Arg [3] : 00000000000000000000000009af34bf26c2e2930f29ef737ffb49fbb3f1f888
Arg [4] : 000000000000000000000000000000000000000000000000000000000000000e
Arg [5] : 4f72696f6e2050726f746f636f6c000000000000000000000000000000000000
Arg [6] : 0000000000000000000000000000000000000000000000000000000000000003
Arg [7] : 4f524e0000000000000000000000000000000000000000000000000000000000


Block Transaction Gas Used Reward
view all blocks produced

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading

OVERVIEW

Orion aggregates the liquidity of the entire crypto market (CEXs, DEXs and liquidity pools) into one decentralized platform providing DeFi with the industry-critical solutions from Orion Terminal to Orion Enterprise solutions for blockchains, 3d party exchanges, and crypto projects.

Loading...
Loading

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
[ Download: CSV Export  ]

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.