Token RAGNIT

 

Overview [ERC-20]

Max Total Supply:
10,000,000,000 RGT

Holders:
17

Transfers:
-

Loading
[ Download CSV Export  ] 
Loading
[ Download CSV Export  ] 
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
RagnitToken

Compiler Version
v0.4.23+commit.124ca40d

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license
/**
 *Submitted for verification at Etherscan.io on 2019-10-15
*/

pragma solidity ^0.4.23;

library SafeMath {
    /**
     * @dev Multiplies two numbers, throws on overflow.
     **/
    function mul(uint256 a, uint256 b) internal pure returns (uint256 c) {
        if (a == 0) {
            return 0;
        }
        c = a * b;
        assert(c / a == b);
        return c;
    }
    
    /**
     * @dev Integer division of two numbers, truncating the quotient.
     **/
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        // assert(b > 0); // Solidity automatically throws when dividing by 0
/**
 * @title SafeMath
 * @dev Math operations with safety checks that throw on error
 */
        // uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold
        return a / b;
    }
    
    /**
     * @dev Subtracts two numbers, throws on overflow (i.e. if subtrahend is greater than minuend).
     **/
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        assert(b <= a);
        return a - b;
    }
    
    /**
     * @dev Adds two numbers, throws on overflow.
     **/
    function add(uint256 a, uint256 b) internal pure returns (uint256 c) {
        c = a + b;
        assert(c >= a);
        return c;
    }
}

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

    /**
     * @dev The Ownable constructor sets the original `owner` of the contract to the sender account.
     **/
   constructor() public {
      owner = msg.sender;
    }
    
    /**
     * @dev Throws if called by any account other than the owner.
     **/
    modifier onlyOwner() {
      require(msg.sender == owner);
      _;
    }
    
    /**
     * @dev Allows the current owner to transfer control of the contract to a newOwner.
     * @param newOwner The address to transfer ownership to.
     **/
    function transferOwnership(address newOwner) public onlyOwner {
      require(newOwner != address(0));
      emit OwnershipTransferred(owner, newOwner);
      owner = newOwner;
    }
}

/**
 * @title ERC20Basic interface
 * @dev Basic ERC20 interface
 **/
contract ERC20Basic {
    function totalSupply() public view returns (uint256);
    function balanceOf(address who) public view returns (uint256);
    function transfer(address to, uint256 value) public returns (bool);
    event Transfer(address indexed from, address indexed to, uint256 value);
}

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

/**
 * @title Basic token
 * @dev Basic version of StandardToken, with no allowances.
 **/
contract BasicToken is ERC20Basic {
    using SafeMath for uint256;
    mapping(address => uint256) balances;
    uint256 totalSupply_;
    
    /**
     * @dev total number of tokens in existence
     **/
    function totalSupply() public view returns (uint256) {
        return totalSupply_;
    }
    
    /**
     * @dev transfer token for a specified address
     * @param _to The address to transfer to.
     * @param _value The amount to be transferred.
     **/
    function transfer(address _to, uint256 _value) public returns (bool) {
        require(_to != address(0));
        require(_value <= balances[msg.sender]);
        
        balances[msg.sender] = balances[msg.sender].sub(_value);
        balances[_to] = balances[_to].add(_value);
        emit Transfer(msg.sender, _to, _value);
        return true;
    }
    
    /**
     * @dev Gets the balance of the specified address.
     * @param _owner The address to query the the balance of.
     * @return An uint256 representing the amount owned by the passed address.
     **/
    function balanceOf(address _owner) public view returns (uint256) {
        return balances[_owner];
    }
}

contract StandardToken is ERC20, BasicToken {
    mapping (address => mapping (address => uint256)) internal allowed;
    /**
     * @dev Transfer tokens from one address to another
     * @param _from address The address which you want to send tokens from
     * @param _to address The address which you want to transfer to
     * @param _value uint256 the amount of tokens to be transferred
     **/
    function transferFrom(address _from, address _to, uint256 _value) public returns (bool) {
        require(_to != address(0));
        require(_value <= balances[_from]);
        require(_value <= allowed[_from][msg.sender]);
    
        balances[_from] = balances[_from].sub(_value);
        balances[_to] = balances[_to].add(_value);
        allowed[_from][msg.sender] = allowed[_from][msg.sender].sub(_value);
        
        emit Transfer(_from, _to, _value);
        return true;
    }
    
    /**
     * @dev Approve the passed address to spend the specified amount of tokens on behalf of msg.sender.
     *
     * Beware that changing an allowance with this method brings the risk that someone may use both the old
     * and the new allowance by unfortunate transaction ordering. One possible solution to mitigate this
     * race condition is to first reduce the spender's allowance to 0 and set the desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     * @param _spender The address which will spend the funds.
     * @param _value The amount of tokens to be spent.
     **/
    function approve(address _spender, uint256 _value) public returns (bool) {
        allowed[msg.sender][_spender] = _value;
        emit Approval(msg.sender, _spender, _value);
        return true;
    }
    
    /**
     * @dev Function to check the amount of tokens that an owner allowed to a spender.
     * @param _owner address The address which owns the funds.
     * @param _spender address The address which will spend the funds.
     * @return A uint256 specifying the amount of tokens still available for the spender.
     **/
    function allowance(address _owner, address _spender) public view returns (uint256) {
        return allowed[_owner][_spender];
    }
    
    /**
     * @dev Increase the amount of tokens that an owner allowed to a spender.
     *
     * approve should be called when allowed[_spender] == 0. To increment
     * allowed value is better to use this function to avoid 2 calls (and wait until
     * the first transaction is mined)
     * From MonolithDAO Token.sol
     * @param _spender The address which will spend the funds.
     * @param _addedValue The amount of tokens to increase the allowance by.
     **/
    function increaseApproval(address _spender, uint _addedValue) public returns (bool) {
        allowed[msg.sender][_spender] = allowed[msg.sender][_spender].add(_addedValue);
        emit Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
        return true;
    }
    
    /**
     * @dev Decrease the amount of tokens that an owner allowed to a spender.
     *
     * approve should be called when allowed[_spender] == 0. To decrement
     * allowed value is better to use this function to avoid 2 calls (and wait until
     * the first transaction is mined)
     * From MonolithDAO Token.sol
     * @param _spender The address which will spend the funds.
     * @param _subtractedValue The amount of tokens to decrease the allowance by.
     **/
    function decreaseApproval(address _spender, uint _subtractedValue) public returns (bool) {
        uint oldValue = allowed[msg.sender][_spender];
        if (_subtractedValue > oldValue) {
            allowed[msg.sender][_spender] = 0;
        } else {
            allowed[msg.sender][_spender] = oldValue.sub(_subtractedValue);
        }
        emit Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
        return true;
    }
}


/**
 * @title Configurable
 * @dev Configurable varriables of the contract
 **/
contract Configurable {
    uint256 public constant cap = 200000000000000;
    uint256 public constant basePrice = 2120000; // tokens per 1 ether
    uint256 public tokensSold = 0;
    
    uint256 public constant tokenReserve = 100000000000000;
    uint256 public remainingTokens = 0;
}

/**
 * @title CrowdsaleToken 
 * @dev Contract to preform crowd sale with token
 **/
contract CrowdsaleToken is StandardToken, Configurable, Ownable {
    /**
     * @dev enum of current crowd sale state
     **/
     enum Stages {
        none,
        icoStart, 
        icoEnd
    }
    
    Stages currentStage;
  
    /**
     * @dev constructor of CrowdsaleToken
     **/
    constructor() public {
        currentStage = Stages.none;
        balances[owner] = balances[owner].add(tokenReserve);
        totalSupply_ = totalSupply_.add(tokenReserve);
        remainingTokens = cap;
        emit Transfer(address(this), owner, tokenReserve);
    }
    
    /**
     * @dev fallback function to send ether to for Crowd sale
     **/
    function () public payable {
        require(currentStage == Stages.icoStart);
        require(msg.value > 0);
        require(remainingTokens > 0);
        
        
        uint256 weiAmount = msg.value; // Calculate tokens to sell
        uint256 tokens = weiAmount.mul(basePrice).div(1 ether);
        uint256 returnWei = 0;
        
        if(tokensSold.add(tokens) > cap){
            uint256 newTokens = cap.sub(tokensSold);
            uint256 newWei = newTokens.div(basePrice).mul(1 ether);
            returnWei = weiAmount.sub(newWei);
            weiAmount = newWei;
            tokens = newTokens;
        }
        
        tokensSold = tokensSold.add(tokens); // Increment raised amount
        remainingTokens = cap.sub(tokensSold);
        if(returnWei > 0){
            msg.sender.transfer(returnWei);
            emit Transfer(address(this), msg.sender, returnWei);
        }
        
        balances[msg.sender] = balances[msg.sender].add(tokens);
        emit Transfer(address(this), msg.sender, tokens);
        totalSupply_ = totalSupply_.add(tokens);
        owner.transfer(weiAmount);// Send money to owner
    }
    

    /**
     * @dev startIco starts the public ICO
     **/
    function startIco() public onlyOwner {
        require(currentStage != Stages.icoEnd);
        currentStage = Stages.icoStart;
    }
    

    /**
     * @dev endIco closes down the ICO 
     **/
    function endIco() internal {
        currentStage = Stages.icoEnd;
        // Transfer any remaining tokens
        if(remainingTokens > 0)
            balances[owner] = balances[owner].add(remainingTokens);
        // transfer any remaining ETH balance in the contract to the owner
        owner.transfer(address(this).balance); 
    }

    /**
     * @dev finalizeIco closes down the ICO and sets needed varriables
     **/
    function finalizeIco() public onlyOwner {
        require(currentStage != Stages.icoEnd);
        endIco();
    }
    
}

/**
 * @title RagnitToken 
 * @dev Contract to create the Ragnit Token
 **/
contract RagnitToken is CrowdsaleToken {
    string public constant name = "RAGNIT";
    string public constant symbol = "RGT";
    uint32 public constant decimals = 4;
}

Contract Security Audit

Contract ABI

[{"constant":true,"inputs":[],"name":"name","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_value","type":"uint256"}],"name":"approve","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_from","type":"address"},{"name":"_to","type":"address"},{"name":"_value","type":"uint256"}],"name":"transferFrom","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"name":"","type":"uint32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"cap","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"tokensSold","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_subtractedValue","type":"uint256"}],"name":"decreaseApproval","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"}],"name":"balanceOf","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"startIco","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"finalizeIco","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_to","type":"address"},{"name":"_value","type":"uint256"}],"name":"transfer","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"remainingTokens","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"basePrice","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"tokenReserve","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_addedValue","type":"uint256"}],"name":"increaseApproval","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"},{"name":"_spender","type":"address"}],"name":"allowance","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"payable":true,"stateMutability":"payable","type":"fallback"},{"anonymous":false,"inputs":[{"indexed":true,"name":"previousOwner","type":"address"},{"indexed":true,"name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"owner","type":"address"},{"indexed":true,"name":"spender","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"from","type":"address"},{"indexed":true,"name":"to","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Transfer","type":"event"}]

6080604090815260006003819055600481905560058054600160a060020a03191633600160a060020a039081169190911760a060020a60ff021981169092551681526020819052205461006590655af3107a40006401000000006106c66100fe82021704565b600554600160a060020a03166000908152602081905260409020556001546100a090655af3107a40006401000000006106c66100fe82021704565b60015565b5e620f4800060045560055460408051655af3107a400081529051600160a060020a03928316923016917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef919081900360200190a3610111565b8181018281101561010b57fe5b92915050565b610ec3806101206000396000f3006080604052600436106101115763ffffffff7c010000000000000000000000000000000000000000000000000000000060003504166306fdde038114610391578063095ea7b31461041b57806318160ddd1461045357806323b872dd1461047a578063313ce567146104a4578063355274ea146104d2578063518ab2a8146104e757806366188463146104fc57806370a082311461052057806389311e6f146105415780638da5cb5b14610558578063903a3ef61461058957806395d89b411461059e578063a9059cbb146105b3578063bf583903146105d7578063c7876ea4146105ec578063cbcb317114610601578063d73dd62314610616578063dd62ed3e1461063a578063f2fde38b14610661575b600080808080600160055474010000000000000000000000000000000000000000900460ff16600281111561014257fe5b1461014c57600080fd5b6000341161015957600080fd5b60045460001061016857600080fd5b349450610196670de0b6b3a764000061018a876220594063ffffffff61068216565b9063ffffffff6106b116565b93506000925065b5e620f480006101b8856003546106c690919063ffffffff16565b1115610220576003546101d89065b5e620f480009063ffffffff6106d316565b9150610205670de0b6b3a76400006101f9846220594063ffffffff6106b116565b9063ffffffff61068216565b9050610217858263ffffffff6106d316565b92508094508193505b600354610233908563ffffffff6106c616565b600381905561024f9065b5e620f480009063ffffffff6106d316565b60045560008311156102cc57604051600160a060020a0333169084156108fc029085906000818181858888f19350505050158015610291573d6000803e3d6000fd5b5033600160a060020a031630600160a060020a0316600080516020610e78833981519152856040518082815260200191505060405180910390a35b600160a060020a0333166000908152602081905260409020546102f5908563ffffffff6106c616565b600160a060020a0333811660008181526020818152604091829020949094558051888152905191933090931692600080516020610e7883398151915292918290030190a360015461034c908563ffffffff6106c616565b600155600554604051600160a060020a039091169086156108fc029087906000818181858888f19350505050158015610389573d6000803e3d6000fd5b505050505050005b34801561039d57600080fd5b506103a66106e5565b6040805160208082528351818301528351919283929083019185019080838360005b838110156103e05781810151838201526020016103c8565b50505050905090810190601f16801561040d5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34801561042757600080fd5b5061043f600160a060020a036004351660243561071c565b604080519115158252519081900360200190f35b34801561045f57600080fd5b50610468610786565b60408051918252519081900360200190f35b34801561048657600080fd5b5061043f600160a060020a036004358116906024351660443561078c565b3480156104b057600080fd5b506104b96108fa565b6040805163ffffffff9092168252519081900360200190f35b3480156104de57600080fd5b506104686108ff565b3480156104f357600080fd5b50610468610909565b34801561050857600080fd5b5061043f600160a060020a036004351660243561090f565b34801561052c57600080fd5b50610468600160a060020a0360043516610a08565b34801561054d57600080fd5b50610556610a23565b005b34801561056457600080fd5b5061056d610aab565b60408051600160a060020a039092168252519081900360200190f35b34801561059557600080fd5b50610556610aba565b3480156105aa57600080fd5b506103a6610b15565b3480156105bf57600080fd5b5061043f600160a060020a0360043516602435610b4c565b3480156105e357600080fd5b50610468610c33565b3480156105f857600080fd5b50610468610c39565b34801561060d57600080fd5b50610468610c40565b34801561062257600080fd5b5061043f600160a060020a0360043516602435610c4a565b34801561064657600080fd5b50610468600160a060020a0360043581169060243516610cec565b34801561066d57600080fd5b50610556600160a060020a0360043516610d17565b6000821515610693575060006106ab565b508181028183828115156106a357fe5b04146106ab57fe5b92915050565b600081838115156106be57fe5b049392505050565b818101828110156106ab57fe5b6000828211156106df57fe5b50900390565b60408051808201909152600681527f5241474e49540000000000000000000000000000000000000000000000000000602082015281565b600160a060020a03338116600081815260026020908152604080832094871680845294825280832086905580518681529051929493927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a350600192915050565b60015490565b6000600160a060020a03831615156107a357600080fd5b600160a060020a0384166000908152602081905260409020548211156107c857600080fd5b600160a060020a03808516600090815260026020908152604080832033909416835292905220548211156107fb57600080fd5b600160a060020a038416600090815260208190526040902054610824908363ffffffff6106d316565b600160a060020a038086166000908152602081905260408082209390935590851681522054610859908363ffffffff6106c616565b600160a060020a038085166000908152602081815260408083209490945587831682526002815283822033909316825291909152205461089f908363ffffffff6106d316565b600160a060020a03808616600081815260026020908152604080832033861684528252918290209490945580518681529051928716939192600080516020610e78833981519152929181900390910190a35060019392505050565b600481565b65b5e620f4800081565b60035481565b600160a060020a0333811660009081526002602090815260408083209386168352929052908120548083111561096c57600160a060020a0333811660009081526002602090815260408083209388168352929052908120556109a3565b61097c818463ffffffff6106d316565b600160a060020a033381166000908152600260209081526040808320938916835292905220555b600160a060020a0333811660008181526002602090815260408083209489168084529482529182902054825190815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a35060019392505050565b600160a060020a031660009081526020819052604090205490565b60055433600160a060020a03908116911614610a3e57600080fd5b600260055474010000000000000000000000000000000000000000900460ff166002811115610a6957fe5b1415610a7457600080fd5b6005805474ff0000000000000000000000000000000000000000191674010000000000000000000000000000000000000000179055565b600554600160a060020a031681565b60055433600160a060020a03908116911614610ad557600080fd5b600260055474010000000000000000000000000000000000000000900460ff166002811115610b0057fe5b1415610b0b57600080fd5b610b13610db0565b565b60408051808201909152600381527f5247540000000000000000000000000000000000000000000000000000000000602082015281565b6000600160a060020a0383161515610b6357600080fd5b600160a060020a033316600090815260208190526040902054821115610b8857600080fd5b600160a060020a033316600090815260208190526040902054610bb1908363ffffffff6106d316565b600160a060020a033381166000908152602081905260408082209390935590851681522054610be6908363ffffffff6106c616565b600160a060020a0380851660008181526020818152604091829020949094558051868152905191933390931692600080516020610e7883398151915292918290030190a350600192915050565b60045481565b6220594081565b655af3107a400081565b600160a060020a033381166000908152600260209081526040808320938616835292905290812054610c82908363ffffffff6106c616565b600160a060020a0333811660008181526002602090815260408083209489168084529482529182902085905581519485529051929391927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a350600192915050565b600160a060020a03918216600090815260026020908152604080832093909416825291909152205490565b60055433600160a060020a03908116911614610d3257600080fd5b600160a060020a0381161515610d4757600080fd5b600554604051600160a060020a038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a36005805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0392909216919091179055565b6005805474ff000000000000000000000000000000000000000019167402000000000000000000000000000000000000000017905560045460001015610e3957600454600554600160a060020a0316600090815260208190526040902054610e1d9163ffffffff6106c616565b600554600160a060020a03166000908152602081905260409020555b600554604051600160a060020a039182169130163180156108fc02916000818181858888f19350505050158015610e74573d6000803e3d6000fd5b505600ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa165627a7a72305820050aa88eba9038ec7d340586c2748e2bfe919bc3d96b9caf3f539480531a848c0029

Deployed ByteCode Sourcemap

11774:174:0:-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9850:17;;;;;9731:15;9715:12;;;;;;;:31;;;;;;;;;9707:40;;;;;;9778:1;9766:9;:13;9758:22;;;;;;9799:15;;9817:1;-1:-1:-1;9791:28:0;;;;;;9870:9;;-1:-1:-1;9935:37:0;9964:7;9935:24;9870:9;8717:7;9935:24;:13;:24;:::i;:::-;:28;:37;:28;:37;:::i;:::-;9918:54;;10003:1;9983:21;;8659:15;10028:22;10043:6;10028:10;;:14;;:22;;;;:::i;:::-;:28;10025:281;;;10100:10;;10092:19;;8659:15;;10092:19;:7;:19;:::i;:::-;10072:39;-1:-1:-1;10143:37:0;10172:7;10143:24;10072:39;8717:7;10143:24;:13;:24;:::i;:::-;:28;:37;:28;:37;:::i;:::-;10126:54;-1:-1:-1;10207:21:0;:9;10126:54;10207:21;:13;:21;:::i;:::-;10195:33;;10255:6;10243:18;;10285:9;10276:18;;10025:281;10339:10;;:22;;10354:6;10339:22;:14;:22;:::i;:::-;10326:10;:35;;;10417:19;;8659:15;;10417:19;:7;:19;:::i;:::-;10399:15;:37;10462:1;10450:13;;10447:140;;;10479:30;;-1:-1:-1;;;;;10479:10:0;:19;;:30;;;;;10499:9;;10479:30;;;;10499:9;10479:19;:30;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;10479:30:0;10553:10;-1:-1:-1;;;;;10529:46:0;10546:4;-1:-1:-1;;;;;10529:46:0;-1:-1:-1;;;;;;;;;;;10565:9:0;10529:46;;;;;;;;;;;;;;;;;;10447:140;-1:-1:-1;;;;;10639:10:0;10630:20;:8;:20;;;;;;;;;;;:32;;10655:6;10630:32;:24;:32;:::i;:::-;-1:-1:-1;;;;;10616:10:0;10607:20;;:8;:20;;;;;;;;;;;;:55;;;;10678:43;;;;;;;10607:20;;10695:4;10678:43;;;;-1:-1:-1;;;;;;;;;;;10678:43:0;;;;;;;;10747:12;;:24;;10764:6;10747:24;:16;:24;:::i;:::-;10732:12;:39;10782:5;;:25;;-1:-1:-1;;;;;10782:5:0;;;;:25;;;;;10797:9;;10782:5;:25;:5;:25;10797:9;10782:5;:25;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;10782:25:0;9669:1168;;;;;11774:174;11820:38;;8:9:-1;5:2;;;30:1;27;20:12;5:2;11820:38:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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;11820:38:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6094:206;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;6094:206:0;-1:-1:-1;;;;;6094:206:0;;;;;;;;;;;;;;;;;;;;;;;;;3536:91;;8:9:-1;5:2;;;30:1;27;20:12;5:2;3536:91:0;;;;;;;;;;;;;;;;;;;;4930:502;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;4930:502:0;-1:-1:-1;;;;;4930:502:0;;;;;;;;;;;;11909:35;;8:9:-1;5:2;;;30:1;27;20:12;5:2;11909:35:0;;;;;;;;;;;;;;;;;;;;;;;8629:45;;8:9:-1;5:2;;;30:1;27;20:12;5:2;8629:45:0;;;;8753:29;;8:9:-1;5:2;;;30:1;27;20:12;5:2;8753:29:0;;;;8057:450;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;8057:450:0;-1:-1:-1;;;;;8057:450:0;;;;;;;4402:107;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;4402:107:0;-1:-1:-1;;;;;4402:107:0;;;;;10914:135;;8:9:-1;5:2;;;30:1;27;20:12;5:2;10914:135:0;;;;;;1529:20;;8:9:-1;5:2;;;30:1;27;20:12;5:2;1529:20:0;;;;;;;;-1:-1:-1;;;;;1529:20:0;;;;;;;;;;;;;;11565:116;;8:9:-1;5:2;;;30:1;27;20:12;5:2;11565:116:0;;;;11865:37;;8:9:-1;5:2;;;30:1;27;20:12;5:2;11865:37:0;;;;3809:363;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;3809:363:0;-1:-1:-1;;;;;3809:363:0;;;;;;;8856:34;;8:9:-1;5:2;;;30:1;27;20:12;5:2;8856:34:0;;;;8681:43;;8:9:-1;5:2;;;30:1;27;20:12;5:2;8681:43:0;;;;8795:54;;8:9:-1;5:2;;;30:1;27;20:12;5:2;8795:54:0;;;;7276:280;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;7276:280:0;-1:-1:-1;;;;;7276:280:0;;;;;;;6646:134;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;6646:134:0;-1:-1:-1;;;;;6646:134:0;;;;;;;;;;2180:186;;8:9:-1;5:2;;;30:1;27;20:12;5:2;-1:-1;2180:186:0;-1:-1:-1;;;;;2180:186:0;;;;;128:202;186:9;212:6;;208:47;;;-1:-1:-1;242:1:0;235:8;;208:47;-1:-1:-1;269:5:0;;;273:1;269;:5;292;;;;;;;;:10;285:18;;;;128:202;;;;:::o;432:389::-;490:7;812:1;808;:5;;;;;;;;;432:389;-1:-1:-1;;;432:389:0:o;1158:141::-;1242:5;;;1265:6;;;;1258:14;;;953:123;1011:7;1038:6;;;;1031:14;;;;-1:-1:-1;1063:5:0;;;953:123::o;11820:38::-;;;;;;;;;;;;;;;;;;;:::o;6094:206::-;-1:-1:-1;;;;;6186:10:0;6178:19;;6161:4;6178:19;;;:7;:19;;;;;;;;:29;;;;;;;;;;;;:38;;;6232;;;;;;;6161:4;;6178:29;:19;6232:38;;;;;;;;;;;-1:-1:-1;6288:4:0;6094:206;;;;:::o;3536:91::-;3607:12;;3536:91;:::o;4930:502::-;5012:4;-1:-1:-1;;;;;5037:17:0;;;;5029:26;;;;;;-1:-1:-1;;;;;5084:15:0;;:8;:15;;;;;;;;;;;5074:25;;;5066:34;;;;;;-1:-1:-1;;;;;5129:14:0;;;;;;;:7;:14;;;;;;;;5144:10;5129:26;;;;;;;;;;5119:36;;;5111:45;;;;;;-1:-1:-1;;;;;5191:15:0;;:8;:15;;;;;;;;;;;:27;;5211:6;5191:27;:19;:27;:::i;:::-;-1:-1:-1;;;;;5173:15:0;;;:8;:15;;;;;;;;;;;:45;;;;5245:13;;;;;;;:25;;5263:6;5245:25;:17;:25;:::i;:::-;-1:-1:-1;;;;;5229:13:0;;;:8;:13;;;;;;;;;;;:41;;;;5310:14;;;;;:7;:14;;;;;5325:10;5310:26;;;;;;;;;;;:38;;5341:6;5310:38;:30;:38;:::i;:::-;-1:-1:-1;;;;;5281:14:0;;;;;;;:7;:14;;;;;;;;5296:10;5281:26;;;;;;;;;;:67;;;;5374:28;;;;;;;;;;;5281:14;;-1:-1:-1;;;;;;;;;;;5374:28:0;;;;;;;;;;-1:-1:-1;5420:4:0;4930:502;;;;;:::o;11909:35::-;11943:1;11909:35;:::o;8629:45::-;8659:15;8629:45;:::o;8753:29::-;;;;:::o;8057:450::-;-1:-1:-1;;;;;8181:10:0;8173:19;;8140:4;8173:19;;;:7;:19;;;;;;;;:29;;;;;;;;;;;;8217:27;;;8213:188;;;-1:-1:-1;;;;;8269:10:0;8261:19;;8293:1;8261:19;;;:7;:19;;;;;;;;:29;;;;;;;;;;;:33;8213:188;;;8359:30;:8;8372:16;8359:30;:12;:30;:::i;:::-;-1:-1:-1;;;;;8335:10:0;8327:19;;;;;;:7;:19;;;;;;;;:29;;;;;;;;;:62;8213:188;-1:-1:-1;;;;;8425:10:0;8416:61;;8447:19;;;;:7;:19;;;;;;;;8416:61;;;8447:29;;;;;;;;;;;8416:61;;;;;;;;;;;;;;;;;-1:-1:-1;8495:4:0;;8057:450;-1:-1:-1;;;8057:450:0:o;4402:107::-;-1:-1:-1;;;;;4485:16:0;4458:7;4485:16;;;;;;;;;;;;4402:107::o;10914:135::-;1974:5;;1960:10;-1:-1:-1;;;;;1960:19:0;;;1974:5;;1960:19;1952:28;;;;;;10986:13;10970:12;;;;;;;:29;;;;;;;;;;10962:38;;;;;;11011:12;:30;;-1:-1:-1;;11011:30:0;;;;;10914:135::o;1529:20::-;;;-1:-1:-1;;;;;1529:20:0;;:::o;11565:116::-;1974:5;;1960:10;-1:-1:-1;;;;;1960:19:0;;;1974:5;;1960:19;1952:28;;;;;;11640:13;11624:12;;;;;;;:29;;;;;;;;;;11616:38;;;;;;11665:8;:6;:8::i;:::-;11565:116::o;11865:37::-;;;;;;;;;;;;;;;;;;;:::o;3809:363::-;3872:4;-1:-1:-1;;;;;3897:17:0;;;;3889:26;;;;;;-1:-1:-1;;;;;3953:10:0;3944:20;:8;:20;;;;;;;;;;;3934:30;;;3926:39;;;;;;-1:-1:-1;;;;;4018:10:0;4009:20;:8;:20;;;;;;;;;;;:32;;4034:6;4009:32;:24;:32;:::i;:::-;-1:-1:-1;;;;;3995:10:0;3986:20;;:8;:20;;;;;;;;;;;:55;;;;4068:13;;;;;;;:25;;4086:6;4068:25;:17;:25;:::i;:::-;-1:-1:-1;;;;;4052:13:0;;;:8;:13;;;;;;;;;;;;:41;;;;4109:33;;;;;;;4052:13;;4118:10;4109:33;;;;-1:-1:-1;;;;;;;;;;;4109:33:0;;;;;;;;-1:-1:-1;4160:4:0;3809:363;;;;:::o;8856:34::-;;;;:::o;8681:43::-;8717:7;8681:43;:::o;8795:54::-;8834:15;8795:54;:::o;7276:280::-;-1:-1:-1;;;;;7411:10:0;7403:19;;7354:4;7403:19;;;:7;:19;;;;;;;;:29;;;;;;;;;;;;:46;;7437:11;7403:46;:33;:46;:::i;:::-;-1:-1:-1;;;;;7379:10:0;7371:19;;;;;;:7;:19;;;;;;;;:29;;;;;;;;;;;;;:78;;;7465:61;;;;;;;7371:29;;:19;;7465:61;;;;;;;;;;-1:-1:-1;7544:4:0;7276:280;;;;:::o;6646:134::-;-1:-1:-1;;;;;6747:15:0;;;6720:7;6747:15;;;:7;:15;;;;;;;;:25;;;;;;;;;;;;;6646:134::o;2180:186::-;1974:5;;1960:10;-1:-1:-1;;;;;1960:19:0;;;1974:5;;1960:19;1952:28;;;;;;-1:-1:-1;;;;;2259:22:0;;;;2251:31;;;;;;2317:5;;2296:37;;-1:-1:-1;;;;;2296:37:0;;;;2317:5;;2296:37;;2317:5;;2296:37;2342:5;:16;;-1:-1:-1;;2342:16:0;-1:-1:-1;;;;;2342:16:0;;;;;;;;;;2180:186::o;11123:343::-;11161:12;:28;;-1:-1:-1;;11161:28:0;;;;;11245:15;;-1:-1:-1;;11242:91:0;;;11317:15;;11306:5;;-1:-1:-1;;;;;11306:5:0;11297:8;:15;;;;;;;;;;;:36;;;:19;:36;:::i;:::-;11288:5;;-1:-1:-1;;;;;11288:5:0;11279:8;:15;;;;;;;;;;:54;11242:91;11420:5;;:37;;-1:-1:-1;;;;;11420:5:0;;;;11443:4;11435:21;;11420:37;;;;;:5;:37;:5;:37;11435:21;11420:5;:37;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;11420:37:0;11123:343::o

Swarm Source

bzzr://050aa88eba9038ec7d340586c2748e2bfe919bc3d96b9caf3f539480531a848c

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.