ETH Price: $3,330.64 (-3.85%)

Token

The Ring (RING)
 

Overview

Max Total Supply

1,000,000 RING

Holders

26

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Filtered by Token Holder
ivanphl.eth
Balance
1,300.754108085054461337 RING

Value
$0.00
0x07a2cdeee240e05c3c048dc03ccdae309d657162
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
RING

Compiler Version
v0.8.26+commit.8a97fa7a

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license
/**
 *Submitted for verification at Etherscan.io on 2024-06-11
*/

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.13;
pragma abicoder v2;

/// @notice Modern and gas efficient ERC20 + EIP-2612 implementation.
/// @author Solmate (https://github.com/transmissions11/solmate/blob/main/src/tokens/ERC20.sol)
/// @author Modified from Uniswap (https://github.com/Uniswap/uniswap-v2-core/blob/master/contracts/UniswapV2ERC20.sol)
/// @dev Do not manually set balances without updating totalSupply, as the sum of all user balances must not exceed it.
abstract contract ERC20 {
    /*//////////////////////////////////////////////////////////////
                                 EVENTS
    //////////////////////////////////////////////////////////////*/

    event Transfer(address indexed from, address indexed to, uint256 amount);

    event Approval(address indexed owner, address indexed spender, uint256 amount);

    /*//////////////////////////////////////////////////////////////
                            METADATA STORAGE
    //////////////////////////////////////////////////////////////*/

    string public name;

    string public symbol;

    uint8 public immutable decimals;

    /*//////////////////////////////////////////////////////////////
                              ERC20 STORAGE
    //////////////////////////////////////////////////////////////*/

    uint256 public totalSupply;

    mapping(address => uint256) public balanceOf;

    mapping(address => mapping(address => uint256)) public allowance;

    /*//////////////////////////////////////////////////////////////
                            EIP-2612 STORAGE
    //////////////////////////////////////////////////////////////*/

    uint256 internal immutable INITIAL_CHAIN_ID;

    bytes32 internal immutable INITIAL_DOMAIN_SEPARATOR;

    mapping(address => uint256) public nonces;

    /*//////////////////////////////////////////////////////////////
                               CONSTRUCTOR
    //////////////////////////////////////////////////////////////*/

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

        INITIAL_CHAIN_ID = block.chainid;
        INITIAL_DOMAIN_SEPARATOR = computeDomainSeparator();
    }

    /*//////////////////////////////////////////////////////////////
                               ERC20 LOGIC
    //////////////////////////////////////////////////////////////*/

    function approve(address spender, uint256 amount) public virtual returns (bool) {
        allowance[msg.sender][spender] = amount;

        emit Approval(msg.sender, spender, amount);

        return true;
    }

    function transfer(address to, uint256 amount) public virtual returns (bool) {
        balanceOf[msg.sender] -= amount;

        // Cannot overflow because the sum of all user
        // balances can't exceed the max uint256 value.
        unchecked {
            balanceOf[to] += amount;
        }

        emit Transfer(msg.sender, to, amount);

        return true;
    }

    function transferFrom(
        address from,
        address to,
        uint256 amount
    ) public virtual returns (bool) {
        uint256 allowed = allowance[from][msg.sender]; // Saves gas for limited approvals.

        if (allowed != type(uint256).max) allowance[from][msg.sender] = allowed - amount;

        balanceOf[from] -= amount;

        // Cannot overflow because the sum of all user
        // balances can't exceed the max uint256 value.
        unchecked {
            balanceOf[to] += amount;
        }

        emit Transfer(from, to, amount);

        return true;
    }

    /*//////////////////////////////////////////////////////////////
                             EIP-2612 LOGIC
    //////////////////////////////////////////////////////////////*/

    function permit(
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) public virtual {
        require(deadline >= block.timestamp, "PERMIT_DEADLINE_EXPIRED");

        // Unchecked because the only math done is incrementing
        // the owner's nonce which cannot realistically overflow.
        unchecked {
            address recoveredAddress = ecrecover(
                keccak256(
                    abi.encodePacked(
                        "\x19\x01",
                        DOMAIN_SEPARATOR(),
                        keccak256(
                            abi.encode(
                                keccak256(
                                    "Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)"
                                ),
                                owner,
                                spender,
                                value,
                                nonces[owner]++,
                                deadline
                            )
                        )
                    )
                ),
                v,
                r,
                s
            );

            require(recoveredAddress != address(0) && recoveredAddress == owner, "INVALID_SIGNER");

            allowance[recoveredAddress][spender] = value;
        }

        emit Approval(owner, spender, value);
    }

    function DOMAIN_SEPARATOR() public view virtual returns (bytes32) {
        return block.chainid == INITIAL_CHAIN_ID ? INITIAL_DOMAIN_SEPARATOR : computeDomainSeparator();
    }

    function computeDomainSeparator() internal view virtual returns (bytes32) {
        return
            keccak256(
                abi.encode(
                    keccak256("EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)"),
                    keccak256(bytes(name)),
                    keccak256("1"),
                    block.chainid,
                    address(this)
                )
            );
    }

    /*//////////////////////////////////////////////////////////////
                        INTERNAL MINT/BURN LOGIC
    //////////////////////////////////////////////////////////////*/

    function _mint(address to, uint256 amount) internal virtual {
        totalSupply += amount;

        // Cannot overflow because the sum of all user
        // balances can't exceed the max uint256 value.
        unchecked {
            balanceOf[to] += amount;
        }

        emit Transfer(address(0), to, amount);
    }

    function _burn(address from, uint256 amount) internal virtual {
        balanceOf[from] -= amount;

        // Cannot underflow because a user's balance
        // will never be larger than the total supply.
        unchecked {
            totalSupply -= amount;
        }

        emit Transfer(from, address(0), amount);
    }
}

/// @notice Simple single owner authorization mixin.
/// @author Solmate (https://github.com/transmissions11/solmate/blob/main/src/auth/Owned.sol)
abstract contract Owned {
    /*//////////////////////////////////////////////////////////////
                                 EVENTS
    //////////////////////////////////////////////////////////////*/

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

    /*//////////////////////////////////////////////////////////////
                            OWNERSHIP STORAGE
    //////////////////////////////////////////////////////////////*/

    address public owner;

    modifier onlyOwner() virtual {
        require(msg.sender == owner, "UNAUTHORIZED");

        _;
    }

    /*//////////////////////////////////////////////////////////////
                               CONSTRUCTOR
    //////////////////////////////////////////////////////////////*/

    constructor(address _owner) {
        owner = _owner;

        emit OwnershipTransferred(address(0), _owner);
    }

    /*//////////////////////////////////////////////////////////////
                             OWNERSHIP LOGIC
    //////////////////////////////////////////////////////////////*/

    function transferOwnership(address newOwner) public virtual onlyOwner {
        owner = newOwner;

        emit OwnershipTransferred(msg.sender, newOwner);
    }
}

contract RING is ERC20, Owned {
  constructor(address deployer, uint256 supply) ERC20("The Ring", "RING", 18) Owned(msg.sender) {
    _mint(deployer, supply);
  }

  function renounceOwnership() external onlyOwner {
    transferOwnership(address(0));
  }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"deployer","type":"address"},{"internalType":"uint256","name":"supply","type":"uint256"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"DOMAIN_SEPARATOR","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":"amount","type":"uint256"}],"name":"approve","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":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","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":"owner","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":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","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":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"}]

60e060405234801561000f575f80fd5b50604051610fe5380380610fe583398101604081905261002e91610201565b33604051806040016040528060088152602001675468652052696e6760c01b8152506040518060400160405280600481526020016352494e4760e01b8152506012825f908161007d91906102d0565b50600161008a83826102d0565b5060ff81166080524660a05261009e610100565b60c0525050600680546001600160a01b0319166001600160a01b0384169081179091556040519091505f907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506100f98282610198565b5050610420565b5f7f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f5f604051610130919061038a565b6040805191829003822060208301939093528101919091527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608201524660808201523060a082015260c00160405160208183030381529060405280519060200120905090565b8060025f8282546101a991906103fb565b90915550506001600160a01b0382165f818152600360209081526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b5f8060408385031215610212575f80fd5b82516001600160a01b0381168114610228575f80fd5b6020939093015192949293505050565b634e487b7160e01b5f52604160045260245ffd5b600181811c9082168061026057607f821691505b60208210810361027e57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f8211156102cb57805f5260205f20601f840160051c810160208510156102a95750805b601f840160051c820191505b818110156102c8575f81556001016102b5565b50505b505050565b81516001600160401b038111156102e9576102e9610238565b6102fd816102f7845461024c565b84610284565b6020601f82116001811461032f575f83156103185750848201515b5f19600385901b1c1916600184901b1784556102c8565b5f84815260208120601f198516915b8281101561035e578785015182556020948501946001909201910161033e565b508482101561037b57868401515f19600387901b60f8161c191681555b50505050600190811b01905550565b5f8083546103978161024c565b6001821680156103ae57600181146103c3576103f0565b60ff19831686528115158202860193506103f0565b865f5260205f205f5b838110156103e8578154888201526001909101906020016103cc565b505081860193505b509195945050505050565b8082018082111561041a57634e487b7160e01b5f52601160045260245ffd5b92915050565b60805160a05160c051610b9b61044a5f395f61049a01525f61046501525f6101640152610b9b5ff3fe608060405234801561000f575f80fd5b50600436106100f0575f3560e01c8063715018a611610093578063a9059cbb11610063578063a9059cbb1461021b578063d505accf1461022e578063dd62ed3e14610241578063f2fde38b1461026b575f80fd5b8063715018a6146101bf5780637ecebe00146101c95780638da5cb5b146101e857806395d89b4114610213575f80fd5b806323b872dd116100ce57806323b872dd1461014c578063313ce5671461015f5780633644e5151461019857806370a08231146101a0575f80fd5b806306fdde03146100f4578063095ea7b31461011257806318160ddd14610135575b5f80fd5b6100fc61027e565b6040516101099190610902565b60405180910390f35b610125610120366004610952565b610309565b6040519015158152602001610109565b61013e60025481565b604051908152602001610109565b61012561015a36600461097a565b610375565b6101867f000000000000000000000000000000000000000000000000000000000000000081565b60405160ff9091168152602001610109565b61013e610462565b61013e6101ae3660046109b4565b60036020525f908152604090205481565b6101c76104bc565b005b61013e6101d73660046109b4565b60056020525f908152604090205481565b6006546101fb906001600160a01b031681565b6040516001600160a01b039091168152602001610109565b6100fc610515565b610125610229366004610952565b610522565b6101c761023c3660046109d4565b610598565b61013e61024f366004610a41565b600460209081525f928352604080842090915290825290205481565b6101c76102793660046109b4565b6107d6565b5f805461028a90610a72565b80601f01602080910402602001604051908101604052809291908181526020018280546102b690610a72565b80156103015780601f106102d857610100808354040283529160200191610301565b820191905f5260205f20905b8154815290600101906020018083116102e457829003601f168201915b505050505081565b335f8181526004602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925906103639086815260200190565b60405180910390a35060015b92915050565b6001600160a01b0383165f9081526004602090815260408083203384529091528120545f1981146103ce576103aa8382610aaa565b6001600160a01b0386165f9081526004602090815260408083203384529091529020555b6001600160a01b0385165f90815260036020526040812080548592906103f5908490610aaa565b90915550506001600160a01b038085165f81815260036020526040908190208054870190555190918716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061044f9087815260200190565b60405180910390a3506001949350505050565b5f7f000000000000000000000000000000000000000000000000000000000000000046146104975761049261086a565b905090565b507f000000000000000000000000000000000000000000000000000000000000000090565b6006546001600160a01b0316331461050a5760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b60448201526064015b60405180910390fd5b6105135f6107d6565b565b6001805461028a90610a72565b335f90815260036020526040812080548391908390610542908490610aaa565b90915550506001600160a01b0383165f81815260036020526040908190208054850190555133907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906103639086815260200190565b428410156105e85760405162461bcd60e51b815260206004820152601760248201527f5045524d49545f444541444c494e455f455850495245440000000000000000006044820152606401610501565b5f60016105f3610462565b6001600160a01b038a81165f8181526005602090815260409182902080546001810190915582517f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c98184015280840194909452938d166060840152608083018c905260a083019390935260c08083018b90528151808403909101815260e08301909152805192019190912061190160f01b6101008301526101028201929092526101228101919091526101420160408051601f1981840301815282825280516020918201205f84529083018083525260ff871690820152606081018590526080810184905260a0016020604051602081039080840390855afa1580156106fb573d5f803e3d5ffd5b5050604051601f1901519150506001600160a01b038116158015906107315750876001600160a01b0316816001600160a01b0316145b61076e5760405162461bcd60e51b815260206004820152600e60248201526d24a72b20a624a22fa9a4a3a722a960911b6044820152606401610501565b6001600160a01b039081165f9081526004602090815260408083208a8516808552908352928190208990555188815291928a16917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a350505050505050565b6006546001600160a01b0316331461081f5760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610501565b600680546001600160a01b0319166001600160a01b03831690811790915560405133907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a350565b5f7f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f5f60405161089a9190610ac9565b6040805191829003822060208301939093528101919091527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608201524660808201523060a082015260c00160405160208183030381529060405280519060200120905090565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b80356001600160a01b038116811461094d575f80fd5b919050565b5f8060408385031215610963575f80fd5b61096c83610937565b946020939093013593505050565b5f805f6060848603121561098c575f80fd5b61099584610937565b92506109a360208501610937565b929592945050506040919091013590565b5f602082840312156109c4575f80fd5b6109cd82610937565b9392505050565b5f805f805f805f60e0888a0312156109ea575f80fd5b6109f388610937565b9650610a0160208901610937565b95506040880135945060608801359350608088013560ff81168114610a24575f80fd5b9699959850939692959460a0840135945060c09093013592915050565b5f8060408385031215610a52575f80fd5b610a5b83610937565b9150610a6960208401610937565b90509250929050565b600181811c90821680610a8657607f821691505b602082108103610aa457634e487b7160e01b5f52602260045260245ffd5b50919050565b8181038181111561036f57634e487b7160e01b5f52601160045260245ffd5b5f8083545f8160011c90506001821680610ae457607f821691505b602082108103610b0257634e487b7160e01b5f52602260045260245ffd5b808015610b165760018114610b2b57610b59565b60ff1984168752821515830287019450610b59565b5f888152602090205f5b84811015610b5157815489820152600190910190602001610b35565b505082870194505b5092969550505050505056fea26469706673582212206ec0f4a0e5979e2177736402c2550d73aef4c0237ff314f8699f3ac9030d09dc64736f6c634300081a0033000000000000000000000000281e9cdbc3f8db06e5aecf9ad253ba06318480f800000000000000000000000000000000000000000000d3c21bcecceda1000000

Deployed Bytecode

0x608060405234801561000f575f80fd5b50600436106100f0575f3560e01c8063715018a611610093578063a9059cbb11610063578063a9059cbb1461021b578063d505accf1461022e578063dd62ed3e14610241578063f2fde38b1461026b575f80fd5b8063715018a6146101bf5780637ecebe00146101c95780638da5cb5b146101e857806395d89b4114610213575f80fd5b806323b872dd116100ce57806323b872dd1461014c578063313ce5671461015f5780633644e5151461019857806370a08231146101a0575f80fd5b806306fdde03146100f4578063095ea7b31461011257806318160ddd14610135575b5f80fd5b6100fc61027e565b6040516101099190610902565b60405180910390f35b610125610120366004610952565b610309565b6040519015158152602001610109565b61013e60025481565b604051908152602001610109565b61012561015a36600461097a565b610375565b6101867f000000000000000000000000000000000000000000000000000000000000001281565b60405160ff9091168152602001610109565b61013e610462565b61013e6101ae3660046109b4565b60036020525f908152604090205481565b6101c76104bc565b005b61013e6101d73660046109b4565b60056020525f908152604090205481565b6006546101fb906001600160a01b031681565b6040516001600160a01b039091168152602001610109565b6100fc610515565b610125610229366004610952565b610522565b6101c761023c3660046109d4565b610598565b61013e61024f366004610a41565b600460209081525f928352604080842090915290825290205481565b6101c76102793660046109b4565b6107d6565b5f805461028a90610a72565b80601f01602080910402602001604051908101604052809291908181526020018280546102b690610a72565b80156103015780601f106102d857610100808354040283529160200191610301565b820191905f5260205f20905b8154815290600101906020018083116102e457829003601f168201915b505050505081565b335f8181526004602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925906103639086815260200190565b60405180910390a35060015b92915050565b6001600160a01b0383165f9081526004602090815260408083203384529091528120545f1981146103ce576103aa8382610aaa565b6001600160a01b0386165f9081526004602090815260408083203384529091529020555b6001600160a01b0385165f90815260036020526040812080548592906103f5908490610aaa565b90915550506001600160a01b038085165f81815260036020526040908190208054870190555190918716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061044f9087815260200190565b60405180910390a3506001949350505050565b5f7f000000000000000000000000000000000000000000000000000000000000000146146104975761049261086a565b905090565b507f3a93d8ac64c40ffde636dbf2bb4074e64a24000c7aea18a501a1b7f67a37b62090565b6006546001600160a01b0316331461050a5760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b60448201526064015b60405180910390fd5b6105135f6107d6565b565b6001805461028a90610a72565b335f90815260036020526040812080548391908390610542908490610aaa565b90915550506001600160a01b0383165f81815260036020526040908190208054850190555133907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906103639086815260200190565b428410156105e85760405162461bcd60e51b815260206004820152601760248201527f5045524d49545f444541444c494e455f455850495245440000000000000000006044820152606401610501565b5f60016105f3610462565b6001600160a01b038a81165f8181526005602090815260409182902080546001810190915582517f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c98184015280840194909452938d166060840152608083018c905260a083019390935260c08083018b90528151808403909101815260e08301909152805192019190912061190160f01b6101008301526101028201929092526101228101919091526101420160408051601f1981840301815282825280516020918201205f84529083018083525260ff871690820152606081018590526080810184905260a0016020604051602081039080840390855afa1580156106fb573d5f803e3d5ffd5b5050604051601f1901519150506001600160a01b038116158015906107315750876001600160a01b0316816001600160a01b0316145b61076e5760405162461bcd60e51b815260206004820152600e60248201526d24a72b20a624a22fa9a4a3a722a960911b6044820152606401610501565b6001600160a01b039081165f9081526004602090815260408083208a8516808552908352928190208990555188815291928a16917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a350505050505050565b6006546001600160a01b0316331461081f5760405162461bcd60e51b815260206004820152600c60248201526b15539055551213d49256915160a21b6044820152606401610501565b600680546001600160a01b0319166001600160a01b03831690811790915560405133907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a350565b5f7f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f5f60405161089a9190610ac9565b6040805191829003822060208301939093528101919091527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc660608201524660808201523060a082015260c00160405160208183030381529060405280519060200120905090565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b80356001600160a01b038116811461094d575f80fd5b919050565b5f8060408385031215610963575f80fd5b61096c83610937565b946020939093013593505050565b5f805f6060848603121561098c575f80fd5b61099584610937565b92506109a360208501610937565b929592945050506040919091013590565b5f602082840312156109c4575f80fd5b6109cd82610937565b9392505050565b5f805f805f805f60e0888a0312156109ea575f80fd5b6109f388610937565b9650610a0160208901610937565b95506040880135945060608801359350608088013560ff81168114610a24575f80fd5b9699959850939692959460a0840135945060c09093013592915050565b5f8060408385031215610a52575f80fd5b610a5b83610937565b9150610a6960208401610937565b90509250929050565b600181811c90821680610a8657607f821691505b602082108103610aa457634e487b7160e01b5f52602260045260245ffd5b50919050565b8181038181111561036f57634e487b7160e01b5f52601160045260245ffd5b5f8083545f8160011c90506001821680610ae457607f821691505b602082108103610b0257634e487b7160e01b5f52602260045260245ffd5b808015610b165760018114610b2b57610b59565b60ff1984168752821515830287019450610b59565b5f888152602090205f5b84811015610b5157815489820152600190910190602001610b35565b505082870194505b5092969550505050505056fea26469706673582212206ec0f4a0e5979e2177736402c2550d73aef4c0237ff314f8699f3ac9030d09dc64736f6c634300081a0033

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

000000000000000000000000281e9cdbc3f8db06e5aecf9ad253ba06318480f800000000000000000000000000000000000000000000d3c21bcecceda1000000

-----Decoded View---------------
Arg [0] : deployer (address): 0x281E9CdBc3f8Db06E5aecF9AD253ba06318480f8
Arg [1] : supply (uint256): 1000000000000000000000000

-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 000000000000000000000000281e9cdbc3f8db06e5aecf9ad253ba06318480f8
Arg [1] : 00000000000000000000000000000000000000000000d3c21bcecceda1000000


Deployed Bytecode Sourcemap

8482:264:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;1062:18;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;2539:217;;;;;;:::i;:::-;;:::i;:::-;;;1085:14:1;;1078:22;1060:41;;1048:2;1033:18;2539:217:0;920:187:1;1345:26:0;;;;;;;;;1258:25:1;;;1246:2;1231:18;1345:26:0;1112:177:1;3157:612:0;;;;;;:::i;:::-;;:::i;1118:31::-;;;;;;;;1845:4:1;1833:17;;;1815:36;;1803:2;1788:18;1118:31:0;1673:184:1;5499:179:0;;;:::i;1380:44::-;;;;;;:::i;:::-;;;;;;;;;;;;;;8653:90;;;:::i;:::-;;1806:41;;;;;;:::i;:::-;;;;;;;;;;;;;;7666:20;;;;;-1:-1:-1;;;;;7666:20:0;;;;;;-1:-1:-1;;;;;2399:32:1;;;2381:51;;2369:2;2354:18;7666:20:0;2235:203:1;1089:20:0;;;:::i;2764:385::-;;;;;;:::i;:::-;;:::i;3964:1527::-;;;;;;:::i;:::-;;:::i;1433:64::-;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;8310:165;;;;;;:::i;:::-;;:::i;1062:18::-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;2539:217::-;2640:10;2613:4;2630:21;;;:9;:21;;;;;;;;-1:-1:-1;;;;;2630:30:0;;;;;;;;;;:39;;;2687:37;2613:4;;2630:30;;2687:37;;;;2663:6;1258:25:1;;1246:2;1231:18;;1112:177;2687:37:0;;;;;;;;-1:-1:-1;2744:4:0;2539:217;;;;;:::o;3157:612::-;-1:-1:-1;;;;;3314:15:0;;3279:4;3314:15;;;:9;:15;;;;;;;;3330:10;3314:27;;;;;;;;-1:-1:-1;;3394:28:0;;3390:80;;3454:16;3464:6;3454:7;:16;:::i;:::-;-1:-1:-1;;;;;3424:15:0;;;;;;:9;:15;;;;;;;;3440:10;3424:27;;;;;;;:46;3390:80;-1:-1:-1;;;;;3483:15:0;;;;;;:9;:15;;;;;:25;;3502:6;;3483:15;:25;;3502:6;;3483:25;:::i;:::-;;;;-1:-1:-1;;;;;;;3659:13:0;;;;;;;:9;:13;;;;;;;:23;;;;;;3711:26;3659:13;;3711:26;;;;;;;3676:6;1258:25:1;;1246:2;1231:18;;1112:177;3711:26:0;;;;;;;;-1:-1:-1;3757:4:0;;3157:612;-1:-1:-1;;;;3157:612:0:o;5499:179::-;5556:7;5600:16;5583:13;:33;:87;;5646:24;:22;:24::i;:::-;5576:94;;5499:179;:::o;5583:87::-;-1:-1:-1;5619:24:0;;5499:179::o;8653:90::-;7757:5;;-1:-1:-1;;;;;7757:5:0;7743:10;:19;7735:44;;;;-1:-1:-1;;;7735:44:0;;4433:2:1;7735:44:0;;;4415:21:1;4472:2;4452:18;;;4445:30;-1:-1:-1;;;4491:18:1;;;4484:42;4543:18;;7735:44:0;;;;;;;;;8708:29:::1;8734:1;8708:17;:29::i;:::-;8653:90::o:0;1089:20::-;;;;;;;:::i;2764:385::-;2861:10;2834:4;2851:21;;;:9;:21;;;;;:31;;2876:6;;2851:21;2834:4;;2851:31;;2876:6;;2851:31;:::i;:::-;;;;-1:-1:-1;;;;;;;3033:13:0;;;;;;:9;:13;;;;;;;:23;;;;;;3085:32;3094:10;;3085:32;;;;3050:6;1258:25:1;;1246:2;1231:18;;1112:177;3964:1527:0;4192:15;4180:8;:27;;4172:63;;;;-1:-1:-1;;;4172:63:0;;4774:2:1;4172:63:0;;;4756:21:1;4813:2;4793:18;;;4786:30;4852:25;4832:18;;;4825:53;4895:18;;4172:63:0;4572:347:1;4172:63:0;4405:24;4432:827;4572:18;:16;:18::i;:::-;-1:-1:-1;;;;;5026:13:0;;;;;;;:6;:13;;;;;;;;;:15;;;;;;;;4657:458;;4702:167;4657:458;;;5211:25:1;5252:18;;;5245:60;;;;5341:32;;;5321:18;;;5314:60;5390:18;;;5383:34;;;5433:19;;;5426:35;;;;5477:19;;;;5470:35;;;4657:458:0;;;;;;;;;;5183:19:1;;;4657:458:0;;;4617:525;;;;;;;;-1:-1:-1;;;4492:673:0;;;5774:27:1;5817:11;;;5810:27;;;;5853:12;;;5846:28;;;;5890:12;;4492:673:0;;;-1:-1:-1;;4492:673:0;;;;;;;;;4460:724;;4492:673;4460:724;;;;4432:827;;;;;;;;;6140:25:1;6213:4;6201:17;;6181:18;;;6174:45;6235:18;;;6228:34;;;6278:18;;;6271:34;;;6112:19;;4432:827:0;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;4432:827:0;;-1:-1:-1;;4432:827:0;;;-1:-1:-1;;;;;;;5284:30:0;;;;;;:59;;;5338:5;-1:-1:-1;;;;;5318:25:0;:16;-1:-1:-1;;;;;5318:25:0;;5284:59;5276:86;;;;-1:-1:-1;;;5276:86:0;;6518:2:1;5276:86:0;;;6500:21:1;6557:2;6537:18;;;6530:30;-1:-1:-1;;;6576:18:1;;;6569:44;6630:18;;5276:86:0;6316:338:1;5276:86:0;-1:-1:-1;;;;;5379:27:0;;;;;;;:9;:27;;;;;;;;:36;;;;;;;;;;;;;:44;;;5452:31;1258:25:1;;;5379:36:0;;5452:31;;;;;1231:18:1;5452:31:0;;;;;;;3964:1527;;;;;;;:::o;8310:165::-;7757:5;;-1:-1:-1;;;;;7757:5:0;7743:10;:19;7735:44;;;;-1:-1:-1;;;7735:44:0;;4433:2:1;7735:44:0;;;4415:21:1;4472:2;4452:18;;;4445:30;-1:-1:-1;;;4491:18:1;;;4484:42;4543:18;;7735:44:0;4231:336:1;7735:44:0;8391:5:::1;:16:::0;;-1:-1:-1;;;;;;8391:16:0::1;-1:-1:-1::0;;;;;8391:16:0;::::1;::::0;;::::1;::::0;;;8425:42:::1;::::0;8446:10:::1;::::0;8425:42:::1;::::0;-1:-1:-1;;8425:42:0::1;8310:165:::0;:::o;5686:457::-;5751:7;5852:95;5986:4;5970:22;;;;;;:::i;:::-;;;;;;;;;;5819:301;;;8135:25:1;;;;8176:18;;8169:34;;;;6015:14:0;8219:18:1;;;8212:34;6052:13:0;8262:18:1;;;8255:34;6096:4:0;8305:19:1;;;8298:61;8107:19;;5819:301:0;;;;;;;;;;;;5791:344;;;;;;5771:364;;5686:457;:::o;14:418:1:-;163:2;152:9;145:21;126:4;195:6;189:13;238:6;233:2;222:9;218:18;211:34;297:6;292:2;284:6;280:15;275:2;264:9;260:18;254:50;353:1;348:2;339:6;328:9;324:22;320:31;313:42;423:2;416;412:7;407:2;399:6;395:15;391:29;380:9;376:45;372:54;364:62;;;14:418;;;;:::o;437:173::-;505:20;;-1:-1:-1;;;;;554:31:1;;544:42;;534:70;;600:1;597;590:12;534:70;437:173;;;:::o;615:300::-;683:6;691;744:2;732:9;723:7;719:23;715:32;712:52;;;760:1;757;750:12;712:52;783:29;802:9;783:29;:::i;:::-;773:39;881:2;866:18;;;;853:32;;-1:-1:-1;;;615:300:1:o;1294:374::-;1371:6;1379;1387;1440:2;1428:9;1419:7;1415:23;1411:32;1408:52;;;1456:1;1453;1446:12;1408:52;1479:29;1498:9;1479:29;:::i;:::-;1469:39;;1527:38;1561:2;1550:9;1546:18;1527:38;:::i;:::-;1294:374;;1517:48;;-1:-1:-1;;;1634:2:1;1619:18;;;;1606:32;;1294:374::o;2044:186::-;2103:6;2156:2;2144:9;2135:7;2131:23;2127:32;2124:52;;;2172:1;2169;2162:12;2124:52;2195:29;2214:9;2195:29;:::i;:::-;2185:39;2044:186;-1:-1:-1;;;2044:186:1:o;2443:903::-;2554:6;2562;2570;2578;2586;2594;2602;2655:3;2643:9;2634:7;2630:23;2626:33;2623:53;;;2672:1;2669;2662:12;2623:53;2695:29;2714:9;2695:29;:::i;:::-;2685:39;;2743:38;2777:2;2766:9;2762:18;2743:38;:::i;:::-;2733:48;-1:-1:-1;2850:2:1;2835:18;;2822:32;;-1:-1:-1;2951:2:1;2936:18;;2923:32;;-1:-1:-1;3033:3:1;3018:19;;3005:33;3082:4;3069:18;;3057:31;;3047:59;;3102:1;3099;3092:12;3047:59;2443:903;;;;-1:-1:-1;2443:903:1;;;;3125:7;3205:3;3190:19;;3177:33;;-1:-1:-1;3309:3:1;3294:19;;;3281:33;;2443:903;-1:-1:-1;;2443:903:1:o;3351:260::-;3419:6;3427;3480:2;3468:9;3459:7;3455:23;3451:32;3448:52;;;3496:1;3493;3486:12;3448:52;3519:29;3538:9;3519:29;:::i;:::-;3509:39;;3567:38;3601:2;3590:9;3586:18;3567:38;:::i;:::-;3557:48;;3351:260;;;;;:::o;3616:380::-;3695:1;3691:12;;;;3738;;;3759:61;;3813:4;3805:6;3801:17;3791:27;;3759:61;3866:2;3858:6;3855:14;3835:18;3832:38;3829:161;;3912:10;3907:3;3903:20;3900:1;3893:31;3947:4;3944:1;3937:15;3975:4;3972:1;3965:15;3829:161;;3616:380;;;:::o;4001:225::-;4068:9;;;4089:11;;;4086:134;;;4142:10;4137:3;4133:20;4130:1;4123:31;4177:4;4174:1;4167:15;4205:4;4202:1;4195:15;6788:1083;6918:3;6947:1;6980:6;6974:13;7010:1;7037:9;7034:1;7030:17;7020:27;;7097:1;7086:9;7082:17;7118:18;7108:61;;7162:4;7154:6;7150:17;7140:27;;7108:61;7215:2;7207:6;7204:14;7184:18;7181:38;7178:161;;7261:10;7256:3;7252:20;7249:1;7242:31;7296:4;7293:1;7286:15;7324:4;7321:1;7314:15;7178:161;7355:18;7382:133;;;;7529:1;7524:322;;;;7348:498;;7382:133;-1:-1:-1;;7415:24:1;;7403:37;;7488:14;;7481:22;7469:35;;7460:45;;;-1:-1:-1;7382:133:1;;7524:322;6735:1;6728:14;;;6772:4;6759:18;;7622:1;7636:164;7650:6;7647:1;7644:13;7636:164;;;7728:14;;7715:11;;;7708:35;7784:1;7771:15;;;;7672:2;7665:10;7636:164;;;7640:3;;7829:6;7824:3;7820:16;7813:23;;7348:498;-1:-1:-1;7862:3:1;;6788:1083;-1:-1:-1;;;;;;6788:1083:1:o

Swarm Source

ipfs://6ec0f4a0e5979e2177736402c2550d73aef4c0237ff314f8699f3ac9030d09dc
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

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