ETH Price: $3,274.76 (+0.92%)

Token

WisePlat Token (WISE)
 

Overview

Max Total Supply

10,000,000 WISE

Holders

39,968

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Filtered by Token Holder
butlins.eth
Balance
0.001 WISE

Value
$0.00
0x15caac6fd6517a6e1deb8a888b53299418b07454
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:
WisePlat

Compiler Version
v0.4.16+commit.d7661dd9

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2017-10-21
*/

pragma solidity ^0.4.16;

/**
 * @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;


  /**
   * @dev The Ownable constructor sets the original `owner` of the contract to the sender
   * account.
   */
  function Ownable() {
    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) onlyOwner {
    if (newOwner != address(0)) {
      owner = newOwner;
    }
  }

}

/**
 * @title SafeMath
 * @dev Math operations with safety checks that throw on error
 */
library SafeMath {
  function mul(uint256 a, uint256 b) internal constant returns (uint256) {
    uint256 c = a * b;
    assert(a == 0 || c / a == b);
    return c;
  }

  function div(uint256 a, uint256 b) internal constant returns (uint256) {
    // assert(b > 0); // Solidity automatically throws when dividing by 0
    uint256 c = a / b;
    // assert(a == b * c + a % b); // There is no case in which this doesn't hold
    return c;
  }

  function sub(uint256 a, uint256 b) internal constant returns (uint256) {
    assert(b <= a);
    return a - b;
  }

  function add(uint256 a, uint256 b) internal constant returns (uint256) {
    uint256 c = a + b;
    assert(c >= a);
    return c;
  }
}

/**
 * @title ERC20Basic
 * @dev Simpler version of ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/179
 */
contract ERC20Basic {
  uint256 public totalSupply;
  function balanceOf(address who) constant returns (uint256);
  function transfer(address to, uint256 value) returns (bool);
  event Transfer(address indexed from, address indexed to, 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;

  /**
  * @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) returns (bool) {
    balances[msg.sender] = balances[msg.sender].sub(_value);
    balances[_to] = balances[_to].add(_value);
    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) constant returns (uint256 balance) {
    return balances[_owner];
  }

}

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

contract StandardToken is ERC20, BasicToken {

   mapping (address => mapping (address => uint256)) 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 amout of tokens to be transfered
    */
   function transferFrom(address _from, address _to, uint256 _value) returns (bool) {
     var _allowance = allowed[_from][msg.sender];

     // Check is not needed because sub(_allowance, _value) will already throw if this condition is not met
     // require (_value <= _allowance);

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

   /**
    * @dev Aprove the passed address to spend the specified amount of tokens on behalf of msg.sender.
    * @param _spender The address which will spend the funds.
    * @param _value The amount of tokens to be spent.
    */
   function approve(address _spender, uint256 _value) returns (bool) {

     // To change the approve amount you first have to reduce the addresses`
     //  allowance to zero by calling `approve(_spender, 0)` if it is not
     //  already 0 to mitigate the race condition described here:
     //  https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     require((_value == 0) || (allowed[msg.sender][_spender] == 0));

     allowed[msg.sender][_spender] = _value;
     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 specifing the amount of tokens still avaible for the spender.
    */
   function allowance(address _owner, address _spender) constant returns (uint256 remaining) {
     return allowed[_owner][_spender];
   }

 }

contract MintableToken is StandardToken, Ownable {
  event MintFinished();

  bool public mintingFinished = false;


  modifier canMint() {
    require(!mintingFinished);
    _;
  }

  /**
   * @dev Function to mint tokens
   * @param _to The address that will recieve the minted tokens.
   * @param _amount The amount of tokens to mint.
   * @return A boolean that indicates if the operation was successful.
   */
  function mint(address _to, uint256 _amount) onlyOwner canMint returns (bool) {
    totalSupply = totalSupply.add(_amount);
    balances[_to] = balances[_to].add(_amount);
    Transfer(0X0, _to, _amount);
    return true;
  }

  /**
   * @dev Function to stop minting new tokens.
   * @return True if the operation was successful.
   */
  function finishMinting() onlyOwner returns (bool) {
    mintingFinished = true;
    MintFinished();
    return true;
  }
}

contract WisePlat is MintableToken {
  string public name = "WisePlat Token";
  string public symbol = "WISE";
  uint256 public decimals = 18;
  address public bountyWallet = 0x0;

  bool public transferStatus = false;

  /**
   * @dev modifier that throws if trading has not started yet
   */
  modifier hasStartedTransfer() {
    require(transferStatus || msg.sender == bountyWallet);
    _;
  }

  /**
   * @dev Allows the owner to enable transfer.
   */
  function startTransfer() public onlyOwner {
    transferStatus = true;
  }
  /**
   * @dev Allows the owner to stop transfer.
   */
  function stopTransfer() public onlyOwner {
    transferStatus = false;
  }

  function setbountyWallet(address _bountyWallet) public onlyOwner {
    bountyWallet = _bountyWallet;
  }

  /**
   * @dev Allows anyone to transfer the WISE tokens once transfer has started
   * @param _to the recipient address of the tokens.
   * @param _value number of tokens to be transfered.
   */
  function transfer(address _to, uint _value) hasStartedTransfer returns (bool){
    return super.transfer(_to, _value);
  }

  /**
   * @dev Allows anyone to transfer the WISE tokens once transfer has started
   * @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 uint the amout of tokens to be transfered
   */
  function transferFrom(address _from, address _to, uint _value) hasStartedTransfer returns (bool){
    return super.transferFrom(_from, _to, _value);
  }
}

contract WisePlatSale is Ownable {
  using SafeMath for uint256;

  // The token being offered
  WisePlat public token;

  // start and end block where investments are allowed (both inclusive)
  uint256 public constant startTimestamp	= 1509274800;		//Pre-ICO start						2017/10/29 @ 11:00:00 (UTC)
  uint256 public constant middleTimestamp	= 1511607601;		//Pre-ICO finish and ICO start		2017/11/25 @ 11:00:01 (UTC)
  uint256 public constant endTimestamp		= 1514764799;		//ICO finish						2017/12/31 @ 23:59:59 (UTC)

  // address where funds are collected
  address public constant devWallet 		= 0x00d6F1eA4238e8d9f1C33B7500CB89EF3e91190c;
  address public constant proWallet 		= 0x6501BDA688e8AC6C9cD96dc2DFBd6bDF3e886C05;
  address public constant bountyWallet 		= 0x354FFa86F138883b880C282000B5005E867E8eE4;
  address public constant remainderWallet	= 0x656C64D5C8BADe2a56A564B12706eE89bbe486EA;
  address public constant fundsWallet		= 0x06D49e8aA90b1413A641D69c6B8AC154f5c9FE92;
 
  // how many token units a buyer gets per wei
  uint256 public rate						= 10;
  uint256 public constant ratePreICO		= 20;	//on Pre-ICO it is 20 WISE for 1 ETH
  uint256 public constant rateICO			= 15;	//on ICO it is 15 WISE for 1 ETH
  
  // amount of raised money in wei
  uint256 public weiRaised;

  // minimum contribution to participate in token offer
  uint256 public constant minContribution 		= 0.1 ether;
  uint256 public constant minContribution_mBTC 	= 10;
  uint256 public rateBTCxETH 					= 17;

  // WISE tokens
  uint256 public constant tokensTotal		=	 10000000 * 1e18;		//WISE Total tokens				10,000,000.00
  uint256 public constant tokensCrowdsale	=	  7000000 * 1e18;		//WISE tokens for Crowdsale		 7,000,000.00
  uint256 public constant tokensDevelopers  =	  1900000 * 1e18;		//WISE tokens for Developers	 1,900,000.00
  uint256 public constant tokensPromotion	=	  1000000 * 1e18;		//WISE tokens for Promotion		 1,000,000.00
  uint256 public constant tokensBounty      = 	   100000 * 1e18;		//WISE tokens for Bounty		   100,000.00
  uint256 public tokensRemainder;  
  
  event TokenPurchase(address indexed purchaser, address indexed beneficiary, uint256 value, uint256 amount);
  event TokenClaim4BTC(address indexed purchaser_evt, address indexed beneficiary_evt, uint256 value_evt, uint256 amount_evt, uint256 btc_evt, uint256 rateBTCxETH_evt);
  event SaleClosed();

  function WisePlatSale() {
    token = new WisePlat();
	token.mint(devWallet, tokensDevelopers);
	token.mint(proWallet, tokensPromotion);
	token.mint(bountyWallet, tokensBounty);
	token.setbountyWallet(bountyWallet);		//allow transfer for bountyWallet
    require(startTimestamp >= now);
    require(endTimestamp >= startTimestamp);
  }

  // check if valid purchase
  modifier validPurchase {
    require(now >= startTimestamp);
    require(now <= endTimestamp);
    require(msg.value >= minContribution);
    require(tokensTotal > token.totalSupply());
    _;
  }
  // check if valid claim for BTC
  modifier validPurchase4BTC {
    require(now >= startTimestamp);
    require(now <= endTimestamp);
    require(tokensTotal > token.totalSupply());
    _;
  }

  // @return true if crowdsale event has ended
  function hasEnded() public constant returns (bool) {
    bool timeLimitReached = now > endTimestamp;
    bool allOffered = tokensTotal <= token.totalSupply();
    return timeLimitReached || allOffered;
  }

  // low level token purchase function
  function buyTokens(address beneficiary) payable validPurchase {
    require(beneficiary != 0x0);

    uint256 weiAmount = msg.value;

    // calculate token amount to be created
	if (now < middleTimestamp) {rate = ratePreICO;} else {rate = rateICO;}
    uint256 tokens = weiAmount.mul(rate);
    
	require(token.totalSupply().add(tokens) <= tokensTotal);
	
    // update state
    weiRaised = weiRaised.add(weiAmount);
    
    token.mint(beneficiary, tokens);
    TokenPurchase(msg.sender, beneficiary, weiAmount, tokens);
    fundsWallet.transfer(msg.value);	//transfer funds to fundsWallet
  }
  
  //claim tokens buyed for mBTC
  function claimTokens4mBTC(address beneficiary, uint256 mBTC) validPurchase4BTC public onlyOwner {
    require(beneficiary != 0x0);
	require(mBTC >= minContribution_mBTC);

	//uint256 _BTC = mBTC.div(1000);			//convert mBTC	to BTC
	//uint256 _ETH = _BTC.mul(rateBTCxETH);		//convert BTC	to ETH
    //uint256 weiAmount = _ETH * 1e18;			//convert ETH	to wei
	uint256 weiAmount = mBTC.mul(rateBTCxETH) * 1e15;	//all convert in one line mBTC->BTC->ETH->wei

    // calculate token amount to be created
	if (now < middleTimestamp) {rate = ratePreICO;} else {rate = rateICO;}
    uint256 tokens = weiAmount.mul(rate);
    
	require(token.totalSupply().add(tokens) <= tokensTotal);
	
    // update state
    weiRaised = weiRaised.add(weiAmount);
    
    token.mint(beneficiary, tokens);
    TokenClaim4BTC(msg.sender, beneficiary, weiAmount, tokens, mBTC, rateBTCxETH);
    //fundsWallet.transfer(msg.value);	//transfer funds to fundsWallet	- already should be transfered to BTC wallet
  }

  // to enable transfer
  function startTransfers() public onlyOwner {
	token.startTransfer();
  }
  
  // to stop transfer
  function stopTransfers() public onlyOwner {
	token.stopTransfer();
  }
  
  // to correct exchange rate ETH for BTC
  function correctExchangeRateBTCxETH(uint256 _rateBTCxETH) public onlyOwner {
	require(_rateBTCxETH != 0);
	rateBTCxETH = _rateBTCxETH;
  }
  
  // finish mining coins and transfer ownership of WISE token to owner
  function finishMinting() public onlyOwner {
    require(hasEnded());
    uint issuedTokenSupply = token.totalSupply();			
	tokensRemainder = tokensTotal.sub(issuedTokenSupply);
	if (tokensRemainder > 0) {token.mint(remainderWallet, tokensRemainder);}
    token.finishMinting();
    token.transferOwnership(owner);
    SaleClosed();
  }

  // fallback function can be used to buy tokens
  function () payable {
    buyTokens(msg.sender);
  }
  
  /**
  * @dev Reclaim all ERC20Basic compatible tokens
  * @param tokenAddr address The address of the token contract
  */
  function reclaimToken(address tokenAddr) external onlyOwner {
	require(!isTokenOfferedToken(tokenAddr));
    ERC20Basic tokenInst = ERC20Basic(tokenAddr);
    uint256 balance = tokenInst.balanceOf(this);
    tokenInst.transfer(msg.sender, balance);
  }
  function isTokenOfferedToken(address tokenAddr) returns(bool) {
        return token == tokenAddr;
  }
 
}

Contract Security Audit

Contract ABI

[{"constant":true,"inputs":[],"name":"mintingFinished","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"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":false,"inputs":[{"name":"_bountyWallet","type":"address"}],"name":"setbountyWallet","outputs":[],"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":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_to","type":"address"},{"name":"_amount","type":"uint256"}],"name":"mint","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"}],"name":"balanceOf","outputs":[{"name":"balance","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"finishMinting","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"startTransfer","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","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":"_owner","type":"address"},{"name":"_spender","type":"address"}],"name":"allowance","outputs":[{"name":"remaining","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"bountyWallet","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"stopTransfer","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"transferStatus","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"anonymous":false,"inputs":[],"name":"MintFinished","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"}]

606060409081526003805460a060020a60ff02191690558051908101604052600e81527f57697365506c617420546f6b656e0000000000000000000000000000000000006020820152600490805161005b9291602001906100db565b5060408051908101604052600481527f5749534500000000000000000000000000000000000000000000000000000000602082015260059080516100a39291602001906100db565b50601260065560078054600160a860020a03191690555b60038054600160a060020a03191633600160a060020a03161790555b61017b565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f1061011c57805160ff1916838001178555610149565b82800160010185558215610149579182015b8281111561014957825182559160200191906001019061012e565b5b5061015692915061015a565b5090565b61017891905b808211156101565760008155600101610160565b5090565b90565b610c928061018a6000396000f300606060405236156101045763ffffffff7c010000000000000000000000000000000000000000000000000000000060003504166305d2035b811461010957806306fdde0314610130578063095ea7b3146101bb5780630e330106146101f157806318160ddd1461021257806323b872dd14610237578063313ce5671461027357806340c10f191461029857806370a08231146102ce5780637d64bcb4146102ff578063829c3428146103265780638da5cb5b1461033b57806395d89b411461036a578063a9059cbb146103f5578063dd62ed3e1461042b578063e576052014610462578063e7f9e40814610491578063f2fde38b146104a6578063f4880b22146104c7575b600080fd5b341561011457600080fd5b61011c6104ee565b604051901515815260200160405180910390f35b341561013b57600080fd5b6101436104fe565b60405160208082528190810183818151815260200191508051906020019080838360005b838110156101805780820151818401525b602001610167565b50505050905090810190601f1680156101ad5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34156101c657600080fd5b61011c600160a060020a036004351660243561059c565b604051901515815260200160405180910390f35b34156101fc57600080fd5b610210600160a060020a0360043516610643565b005b341561021d57600080fd5b61022561068b565b60405190815260200160405180910390f35b341561024257600080fd5b61011c600160a060020a0360043581169060243516604435610691565b604051901515815260200160405180910390f35b341561027e57600080fd5b6102256106db565b60405190815260200160405180910390f35b34156102a357600080fd5b61011c600160a060020a03600435166024356106e1565b604051901515815260200160405180910390f35b34156102d957600080fd5b610225600160a060020a03600435166107b2565b60405190815260200160405180910390f35b341561030a57600080fd5b61011c6107d1565b604051901515815260200160405180910390f35b341561033157600080fd5b610210610847565b005b341561034657600080fd5b61034e61088a565b604051600160a060020a03909116815260200160405180910390f35b341561037557600080fd5b610143610899565b60405160208082528190810183818151815260200191508051906020019080838360005b838110156101805780820151818401525b602001610167565b50505050905090810190601f1680156101ad5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561040057600080fd5b61011c600160a060020a0360043516602435610937565b604051901515815260200160405180910390f35b341561043657600080fd5b610225600160a060020a036004358116906024351661097f565b60405190815260200160405180910390f35b341561046d57600080fd5b61034e6109ac565b604051600160a060020a03909116815260200160405180910390f35b341561049c57600080fd5b6102106109bb565b005b34156104b157600080fd5b610210600160a060020a03600435166109f8565b005b34156104d257600080fd5b61011c610a50565b604051901515815260200160405180910390f35b60035460a060020a900460ff1681565b60048054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156105945780601f1061056957610100808354040283529160200191610594565b820191906000526020600020905b81548152906001019060200180831161057757829003601f168201915b505050505081565b60008115806105ce5750600160a060020a03338116600090815260026020908152604080832093871683529290522054155b15156105d957600080fd5b600160a060020a03338116600081815260026020908152604080832094881680845294909152908190208590557f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259085905190815260200160405180910390a35060015b92915050565b60035433600160a060020a0390811691161461065e57600080fd5b6007805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0383161790555b5b50565b60005481565b60075460009060a060020a900460ff16806106ba575060075433600160a060020a039081169116145b15156106c557600080fd5b6106d0848484610a60565b90505b5b9392505050565b60065481565b60035460009033600160a060020a039081169116146106ff57600080fd5b60035460a060020a900460ff161561071657600080fd5b600054610729908363ffffffff610b7516565b6000908155600160a060020a038416815260016020526040902054610754908363ffffffff610b7516565b600160a060020a0384166000818152600160205260408082209390935590917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9085905190815260200160405180910390a35060015b5b5b92915050565b600160a060020a0381166000908152600160205260409020545b919050565b60035460009033600160a060020a039081169116146107ef57600080fd5b6003805474ff0000000000000000000000000000000000000000191660a060020a1790557fae5184fba832cb2b1f702aca6117b8d265eaf03ad33eb133f19dde0f5920fa0860405160405180910390a15060015b5b90565b60035433600160a060020a0390811691161461086257600080fd5b6007805474ff0000000000000000000000000000000000000000191660a060020a1790555b5b565b600354600160a060020a031681565b60058054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156105945780601f1061056957610100808354040283529160200191610594565b820191906000526020600020905b81548152906001019060200180831161057757829003601f168201915b505050505081565b60075460009060a060020a900460ff1680610960575060075433600160a060020a039081169116145b151561096b57600080fd5b6109758383610b8f565b90505b5b92915050565b600160a060020a038083166000908152600260209081526040808320938516835292905220545b92915050565b600754600160a060020a031681565b60035433600160a060020a039081169116146109d657600080fd5b6007805474ff0000000000000000000000000000000000000000191690555b5b565b60035433600160a060020a03908116911614610a1357600080fd5b600160a060020a03811615610687576003805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0383161790555b5b5b50565b60075460a060020a900460ff1681565b600160a060020a038084166000908152600260209081526040808320338516845282528083205493861683526001909152812054909190610aa7908463ffffffff610b7516565b600160a060020a038086166000908152600160205260408082209390935590871681522054610adc908463ffffffff610c4f16565b600160a060020a038616600090815260016020526040902055610b05818463ffffffff610c4f16565b600160a060020a03808716600081815260026020908152604080832033861684529091529081902093909355908616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9086905190815260200160405180910390a3600191505b509392505050565b600082820183811015610b8457fe5b8091505b5092915050565b600160a060020a033316600090815260016020526040812054610bb8908363ffffffff610c4f16565b600160a060020a033381166000908152600160205260408082209390935590851681522054610bed908363ffffffff610b7516565b600160a060020a0380851660008181526001602052604090819020939093559133909116907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9085905190815260200160405180910390a35060015b92915050565b600082821115610c5b57fe5b508082035b929150505600a165627a7a723058205983b0cddc8bdcb76d6e98685a31a433dd3b57a7a9cc23c3bfcaf2dc2ded0c240029

Deployed Bytecode

0x606060405236156101045763ffffffff7c010000000000000000000000000000000000000000000000000000000060003504166305d2035b811461010957806306fdde0314610130578063095ea7b3146101bb5780630e330106146101f157806318160ddd1461021257806323b872dd14610237578063313ce5671461027357806340c10f191461029857806370a08231146102ce5780637d64bcb4146102ff578063829c3428146103265780638da5cb5b1461033b57806395d89b411461036a578063a9059cbb146103f5578063dd62ed3e1461042b578063e576052014610462578063e7f9e40814610491578063f2fde38b146104a6578063f4880b22146104c7575b600080fd5b341561011457600080fd5b61011c6104ee565b604051901515815260200160405180910390f35b341561013b57600080fd5b6101436104fe565b60405160208082528190810183818151815260200191508051906020019080838360005b838110156101805780820151818401525b602001610167565b50505050905090810190601f1680156101ad5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34156101c657600080fd5b61011c600160a060020a036004351660243561059c565b604051901515815260200160405180910390f35b34156101fc57600080fd5b610210600160a060020a0360043516610643565b005b341561021d57600080fd5b61022561068b565b60405190815260200160405180910390f35b341561024257600080fd5b61011c600160a060020a0360043581169060243516604435610691565b604051901515815260200160405180910390f35b341561027e57600080fd5b6102256106db565b60405190815260200160405180910390f35b34156102a357600080fd5b61011c600160a060020a03600435166024356106e1565b604051901515815260200160405180910390f35b34156102d957600080fd5b610225600160a060020a03600435166107b2565b60405190815260200160405180910390f35b341561030a57600080fd5b61011c6107d1565b604051901515815260200160405180910390f35b341561033157600080fd5b610210610847565b005b341561034657600080fd5b61034e61088a565b604051600160a060020a03909116815260200160405180910390f35b341561037557600080fd5b610143610899565b60405160208082528190810183818151815260200191508051906020019080838360005b838110156101805780820151818401525b602001610167565b50505050905090810190601f1680156101ad5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561040057600080fd5b61011c600160a060020a0360043516602435610937565b604051901515815260200160405180910390f35b341561043657600080fd5b610225600160a060020a036004358116906024351661097f565b60405190815260200160405180910390f35b341561046d57600080fd5b61034e6109ac565b604051600160a060020a03909116815260200160405180910390f35b341561049c57600080fd5b6102106109bb565b005b34156104b157600080fd5b610210600160a060020a03600435166109f8565b005b34156104d257600080fd5b61011c610a50565b604051901515815260200160405180910390f35b60035460a060020a900460ff1681565b60048054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156105945780601f1061056957610100808354040283529160200191610594565b820191906000526020600020905b81548152906001019060200180831161057757829003601f168201915b505050505081565b60008115806105ce5750600160a060020a03338116600090815260026020908152604080832093871683529290522054155b15156105d957600080fd5b600160a060020a03338116600081815260026020908152604080832094881680845294909152908190208590557f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259085905190815260200160405180910390a35060015b92915050565b60035433600160a060020a0390811691161461065e57600080fd5b6007805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0383161790555b5b50565b60005481565b60075460009060a060020a900460ff16806106ba575060075433600160a060020a039081169116145b15156106c557600080fd5b6106d0848484610a60565b90505b5b9392505050565b60065481565b60035460009033600160a060020a039081169116146106ff57600080fd5b60035460a060020a900460ff161561071657600080fd5b600054610729908363ffffffff610b7516565b6000908155600160a060020a038416815260016020526040902054610754908363ffffffff610b7516565b600160a060020a0384166000818152600160205260408082209390935590917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9085905190815260200160405180910390a35060015b5b5b92915050565b600160a060020a0381166000908152600160205260409020545b919050565b60035460009033600160a060020a039081169116146107ef57600080fd5b6003805474ff0000000000000000000000000000000000000000191660a060020a1790557fae5184fba832cb2b1f702aca6117b8d265eaf03ad33eb133f19dde0f5920fa0860405160405180910390a15060015b5b90565b60035433600160a060020a0390811691161461086257600080fd5b6007805474ff0000000000000000000000000000000000000000191660a060020a1790555b5b565b600354600160a060020a031681565b60058054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156105945780601f1061056957610100808354040283529160200191610594565b820191906000526020600020905b81548152906001019060200180831161057757829003601f168201915b505050505081565b60075460009060a060020a900460ff1680610960575060075433600160a060020a039081169116145b151561096b57600080fd5b6109758383610b8f565b90505b5b92915050565b600160a060020a038083166000908152600260209081526040808320938516835292905220545b92915050565b600754600160a060020a031681565b60035433600160a060020a039081169116146109d657600080fd5b6007805474ff0000000000000000000000000000000000000000191690555b5b565b60035433600160a060020a03908116911614610a1357600080fd5b600160a060020a03811615610687576003805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0383161790555b5b5b50565b60075460a060020a900460ff1681565b600160a060020a038084166000908152600260209081526040808320338516845282528083205493861683526001909152812054909190610aa7908463ffffffff610b7516565b600160a060020a038086166000908152600160205260408082209390935590871681522054610adc908463ffffffff610c4f16565b600160a060020a038616600090815260016020526040902055610b05818463ffffffff610c4f16565b600160a060020a03808716600081815260026020908152604080832033861684529091529081902093909355908616917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9086905190815260200160405180910390a3600191505b509392505050565b600082820183811015610b8457fe5b8091505b5092915050565b600160a060020a033316600090815260016020526040812054610bb8908363ffffffff610c4f16565b600160a060020a033381166000908152600160205260408082209390935590851681522054610bed908363ffffffff610b7516565b600160a060020a0380851660008181526001602052604090819020939093559133909116907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9085905190815260200160405180910390a35060015b92915050565b600082821115610c5b57fe5b508082035b929150505600a165627a7a723058205983b0cddc8bdcb76d6e98685a31a433dd3b57a7a9cc23c3bfcaf2dc2ded0c240029

Swarm Source

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