Latest 25 transactions from a total of 28451 transactions

TxHash Age From To Value [TxFee]
0xe7a7838b581b2727fed2364d144a076c5b323f1b1c9ce8f1e64b91f7d78c7cb128 mins agoKucoin  IN   CoinFiToken0 Ether0.000538662
0x6186cac3ea6db7c09b202800c53d56e1c99110c844ea458b714efa00e4c1691923 hrs 50 mins ago0xf3f972426015c9e0f944295ad552a999b2dbb3c6  IN   CoinFiToken0 Ether0.000729776
0x492c74f950441b330870919413d9f4f6edc825448aad27a85c5af274a3abbd863 days 19 hrs ago0x86f749874edd9f51338e2c30d9b9198adcf1bea2  IN   CoinFiToken0 Ether0.000075492
0x92aa25f0375c5cfd021bec5032247435802f8afe814fe45f8681d4651b176e2d4 days 4 hrs agoGate.io_1  IN   CoinFiToken0 Ether0.00078058728
0x49e97805a0f4c5c6860562a7ced14323f9d819bb0d641bd124b462e5051250dd4 days 7 hrs ago0x251f078c89ea2a6456fae6ed578dd6cb00b304e4  IN   CoinFiToken0 Ether0.000214414
0xabdec423a739b9102c1bee28e19e2c81ca16405db754e91b7c72afd26b2daa154 days 11 hrs agoGate.io_1  IN   CoinFiToken0 Ether0.0006382266
0x082f0f6de3b62726729d992929f0b4290dbb9d75b23664ab6e66652a0cf733685 days 1 hr ago0x9a2222639b55893b293f386e208b357407b002b8  IN   CoinFiToken0 Ether0.000932586
0x9fff56901a38089f235edd49f3270b1696729a79661e5a775ce6fe5845007f0e5 days 1 hr ago0x9a2222639b55893b293f386e208b357407b002b8  IN   CoinFiToken0 Ether0.002157338
0xedc654151a8b61a3333222dfe2c89336f9d3a1c709692c7c7a2f6561727e7e7f5 days 2 hrs ago0x8a836776dc5e32ccf559272080aee797cbab0c89  IN   CoinFiToken0 Ether0.00022746
0xeff3ae1427625926bb15ee4fb6a68afef2b6e3233466227f887175fb98ba9d265 days 5 hrs ago0x77530851790b888b153860c3a905d0eefcd84767  IN   CoinFiToken0 Ether0.00045492
0x5d14f95373b5e92a30b4c2b7c23e55f9595c7affed412d96025ba204b384158d5 days 9 hrs ago0x9d4e4d67399828bd82f5ace79bf67bc5af33c66b  IN   CoinFiToken0 Ether0.001547586
0x75b63124c2156d6757df86b426da6c99155d7092acb5c0fe00cf7597fd542a8e5 days 9 hrs ago0x9d4e4d67399828bd82f5ace79bf67bc5af33c66b  IN   CoinFiToken0 Ether0.001547586
0x183451ad5abb036bec2634a194ad0e976a335c0f29c495960fbad17ba2bcff035 days 9 hrs ago0x9d4e4d67399828bd82f5ace79bf67bc5af33c66b  IN   CoinFiToken0 Ether0.001547586
0x1708d1ba922f7fa86e129cd5125a5f53e39784c7a8f95865a494a488863db5005 days 9 hrs ago0x9d4e4d67399828bd82f5ace79bf67bc5af33c66b  IN   CoinFiToken0 Ether0.001547586
0x80f06962fb6e340c1f6197d0d57c4dd3f36100c135e79b8bd9c4ffe74f30239a5 days 9 hrs ago0x9d4e4d67399828bd82f5ace79bf67bc5af33c66b  IN   CoinFiToken0 Ether0.001547586
0x373bd7c26523c93e10e73627e5572bdc0f9f547ef0a301de67df9978ede0fffc5 days 9 hrs ago0x9d4e4d67399828bd82f5ace79bf67bc5af33c66b  IN   CoinFiToken0 Ether0.001547586
0xa970606978afead3f3799ba2408564e9935d876af4296a297365a01ba5f9a4a35 days 9 hrs ago0x9d4e4d67399828bd82f5ace79bf67bc5af33c66b  IN   CoinFiToken0 Ether0.001547586
0x6e0e6b54023c0dc7e3c38b311e3a12a28315b66b854b42b70942917aceb167675 days 10 hrs ago0xf48c1642e03cd9645a0882183ca684f1a01232af  IN   CoinFiToken0 Ether0.000317548
0x0b892a6e8cce1112d11be74e15a7b1581fd2ca091b07ab7c4a9844b372a908c65 days 10 hrs ago0xd02eb1d57e4c1e31ede16896f0a59dc73fa8545a  IN   CoinFiToken0 Ether0.000363936
0x6b45cd7ff18debb4dc13c861a937e8e29f9927802f55b4d2fef0b7e003640e945 days 10 hrs ago0x616dd6a19bd34f480f650f98f1cd07ab3b667f4f  IN   CoinFiToken0 Ether0.0002424644
0xa54166c29457fdf0b88bb8f7b5e840e1047a2c8e7be240638b74ddde28403b3d5 days 11 hrs ago0xb578a020f545cb2a409d400a5d0be862d28196db  IN   CoinFiToken0 Ether0.00045492
0x7609aa83637cf16531587777964cfaa014d420a14dcf5e29d9a87b8e5f6b0fe25 days 13 hrs ago0x7a4aeb05bbdedb6b6f7f7e58b98c3b0444d58bdd  IN   CoinFiToken0 Ether0.000545904
0x790e25e3ec305407f37ad8e678a42b73f6b99112b31896a8af91ff53e2ee0c175 days 14 hrs ago0xc3208402b94362373fc1926f4480821f2448d79f  IN   CoinFiToken0 Ether0.00045492
0x88a287fae28ae4169d1e3ed238b2dd5555a6ed802241bfd86b7898d50c008a545 days 14 hrs ago0xf200a0a9da8aa84996051b25fd70648a0d1cb83a  IN   CoinFiToken0 Ether0.000417348799
0x2505f1c4d22db3920b592ae8fe579aca235b9e2a387550cc3f81b626923c108d5 days 22 hrs ago0x7c4979a3973d7a80b9de250af88817efaa06dcfb  IN   CoinFiToken0 Ether0.000638554
[ Download CSV Export  ] 
 Internal Transactions as a result of Contract Execution
View All
ParentTxHash Block Age From To Value
Warning: The Compiled Contract might be susceptible to ExpExponentCleanup (medium/high-severity), EventStructWrongData (very low-severity), NestedArrayFunctionCallDecoder (medium-severity) SolidityCompiler Bugs.

Contract Source Code Verified (Exact Match)
Contract Name: CoinFiToken
Compiler Text: v0.4.19+commit.c4cbbb05
Optimization Enabled: Yes
Runs (Optimiser):  200



  Contract Source Code   Find Similiar Contracts

pragma solidity ^0.4.18;


/**
 * https://github.com/OpenZeppelin/zeppelin-solidity/blob/master/contracts/math/SafeMath.sol
 * https://github.com/OpenZeppelin/zeppelin-solidity/commit/49b42e86963df7192e7024e0e5bd30fa9d7ccbef
 * @title SafeMath
 * @dev Math operations with safety checks that throw on error
 */
library SafeMath {

  /**
  * @dev Multiplies two numbers, throws on overflow.
  */
  function mul(uint256 a, uint256 b) internal pure returns (uint256) {
    if (a == 0) {
      return 0;
    }
    uint256 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
    uint256 c = a / b;
    // assert(a == b * c + a % b); // There is no case in which this doesn't hold
    return c;
  }

  /**
  * @dev Substracts 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) {
    uint256 c = a + b;
    assert(c >= a);
    return c;
  }
}


/**
 * https://raw.githubusercontent.com/OpenZeppelin/zeppelin-solidity/master/contracts/token/ERC20/ERC20Basic.sol
 * https://github.com/OpenZeppelin/zeppelin-solidity/commit/370e6a882aef6b9600949594d3a3e4854260d51e
 * @title ERC20Basic
 * @dev Simpler version of ERC20 interface
 * @dev see https://github.com/ethereum/EIPs/issues/179
 */
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);
}


/**
 * https://raw.githubusercontent.com/OpenZeppelin/zeppelin-solidity/master/contracts/token/ERC20/ERC20.sol
 * https://github.com/OpenZeppelin/zeppelin-solidity/commit/c5d66183abcb63a90a2528b8333b2b17067629fc
 * @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);
}


/**
 * https://raw.githubusercontent.com/OpenZeppelin/zeppelin-solidity/master/contracts/token/ERC20/SafeERC20.sol
 * https://github.com/OpenZeppelin/zeppelin-solidity/commit/b67856c69d3536f28d51b75b270dfff79343bf93
 * @title SafeERC20
 * @dev Wrappers around ERC20 operations that throw on failure.
 * To use this library you can add a `using SafeERC20 for ERC20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
library SafeERC20 {
  function safeTransfer(ERC20Basic token, address to, uint256 value) internal {
    assert(token.transfer(to, value));
  }

  function safeTransferFrom(ERC20 token, address from, address to, uint256 value) internal {
    assert(token.transferFrom(from, to, value));
  }

  function safeApprove(ERC20 token, address spender, uint256 value) internal {
    assert(token.approve(spender, value));
  }
}


/**
 * https://raw.githubusercontent.com/OpenZeppelin/zeppelin-solidity/master/contracts/token/ERC20/BasicToken.sol
 * https://github.com/OpenZeppelin/zeppelin-solidity/commit/c5d66183abcb63a90a2528b8333b2b17067629fc
 * @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]);

    // SafeMath.sub will throw if there is not enough balance.
    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) public view returns (uint256 balance) {
    return balances[_owner];
  }
}


/**
 * https://raw.githubusercontent.com/OpenZeppelin/zeppelin-solidity/master/contracts/token/ERC20/StandardToken.sol
 * https://github.com/OpenZeppelin/zeppelin-solidity/commit/c5d66183abcb63a90a2528b8333b2b17067629fc
 * @title Standard ERC20 token
 *
 * @dev Implementation of the basic standard token.
 * @dev https://github.com/ethereum/EIPs/issues/20
 * @dev Based on code by FirstBlood: https://github.com/Firstbloodio/token/blob/master/smart_contract/FirstBloodToken.sol
 */
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);
    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;
    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);
    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);
    }
    Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
    return true;
  }
}


/**
 * https://raw.githubusercontent.com/OpenZeppelin/zeppelin-solidity/master/contracts/ownership/Ownable.sol
 * https://github.com/OpenZeppelin/zeppelin-solidity/commit/e60aee61f20d25bffa0a1f651247810a8bc8a660
 * @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.
   */
  function Ownable() 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));
    OwnershipTransferred(owner, newOwner);
    owner = newOwner;
  }
}


/**
 * https://raw.githubusercontent.com/OpenZeppelin/zeppelin-solidity/master/contracts/token/ERC20/TokenVesting.sol
 * https://github.com/OpenZeppelin/zeppelin-solidity/commit/c5d66183abcb63a90a2528b8333b2b17067629fc
 * @title TokenVesting
 * @dev A token holder contract that can release its token balance gradually like a
 * typical vesting scheme, with a cliff and vesting period. Optionally revocable by the
 * owner.
 */
contract TokenVesting is Ownable {
  using SafeMath for uint256;
  using SafeERC20 for ERC20Basic;

  event Released(uint256 amount);
  event Revoked();

  // beneficiary of tokens after they are released
  address public beneficiary;

  uint256 public cliff;
  uint256 public start;
  uint256 public duration;

  bool public revocable;

  mapping (address => uint256) public released;
  mapping (address => bool) public revoked;

  /**
   * @dev Creates a vesting contract that vests its balance of any ERC20 token to the
   * _beneficiary, gradually in a linear fashion until _start + _duration. By then all
   * of the balance will have vested.
   * @param _beneficiary address of the beneficiary to whom vested tokens are transferred
   * @param _cliff duration in seconds of the cliff in which tokens will begin to vest
   * @param _duration duration in seconds of the period in which the tokens will vest
   * @param _revocable whether the vesting is revocable or not
   */
  function TokenVesting(address _beneficiary, uint256 _start, uint256 _cliff, uint256 _duration, bool _revocable) public {
    require(_beneficiary != address(0));
    require(_cliff <= _duration);

    beneficiary = _beneficiary;
    revocable = _revocable;
    duration = _duration;
    cliff = _start.add(_cliff);
    start = _start;
  }

  /**
   * @notice Transfers vested tokens to beneficiary.
   * @param token ERC20 token which is being vested
   */
  function release(ERC20Basic token) public {
    uint256 unreleased = releasableAmount(token);

    require(unreleased > 0);

    released[token] = released[token].add(unreleased);

    token.safeTransfer(beneficiary, unreleased);

    Released(unreleased);
  }

  /**
   * @notice Allows the owner to revoke the vesting. Tokens already vested
   * remain in the contract, the rest are returned to the owner.
   * @param token ERC20 token which is being vested
   */
  function revoke(ERC20Basic token) public onlyOwner {
    require(revocable);
    require(!revoked[token]);

    uint256 balance = token.balanceOf(this);

    uint256 unreleased = releasableAmount(token);
    uint256 refund = balance.sub(unreleased);

    revoked[token] = true;

    token.safeTransfer(owner, refund);

    Revoked();
  }

  /**
   * @dev Calculates the amount that has already vested but hasn't been released yet.
   * @param token ERC20 token which is being vested
   */
  function releasableAmount(ERC20Basic token) public view returns (uint256) {
    return vestedAmount(token).sub(released[token]);
  }

  /**
   * @dev Calculates the amount that has already vested.
   * @param token ERC20 token which is being vested
   */
  function vestedAmount(ERC20Basic token) public view returns (uint256) {
    uint256 currentBalance = token.balanceOf(this);
    uint256 totalBalance = currentBalance.add(released[token]);

    if (now < cliff) {
      return 0;
    } else if (now >= start.add(duration) || revoked[token]) {
      return totalBalance;
    } else {
      return totalBalance.mul(now.sub(start)).div(duration);
    }
  }
}


contract CoinFiToken is StandardToken, Ownable {
    string public constant name = "CoinFi";
    string public constant symbol = "COFI";
    uint8 public constant decimals = 18;

    // 300 million tokens minted
    uint256 public constant INITIAL_SUPPLY = 300000000 * (10 ** uint256(decimals));

    // Indicates whether token transfer is enabled
    bool public transferEnabled = false;

    // Specifies airdrop contract address which can transfer tokens before unlock
    address public airdropAddress;

    modifier onlyWhenTransferEnabled() {
        if (!transferEnabled) {
            require(msg.sender == owner || msg.sender == airdropAddress);
        }
        _;
    }

    function CoinFiToken() public {
        totalSupply_ = INITIAL_SUPPLY;
        balances[msg.sender] = INITIAL_SUPPLY;
        Transfer(0x0, msg.sender, INITIAL_SUPPLY);
    }

    /**
     * Enables everyone to start transferring their tokens.
     * This can only be called by the token owner.
     */
    function enableTransfer() external onlyOwner {
        transferEnabled = true;
    }

    /**
     * Disables the ability to transfer tokens except by owner.
     * This can only be called by the token owner.
     */
    function disableTransfer() external onlyOwner {
        transferEnabled = false;
    }

    /**
     * Sets the airdrop contract address which is allowed to transfer before unlock.
     * This can only be called by the token owner.
     */
    function setAirdropAddress(address _airdropAddress) external onlyOwner {
        airdropAddress = _airdropAddress;
    }

    /**
     * Overrides the ERC20Basic transfer() function to only allow token transfers after enableTransfer() is called.
     */
    function transfer(address _to, uint256 _value) public onlyWhenTransferEnabled returns (bool) {
        return super.transfer(_to, _value);
    }

    /**
     * Overrides the ERC20Basic transferFrom() function to only allow token transfers after enableTransfer() is called.
     */
    function transferFrom(address _from, address _to, uint256 _value) public onlyWhenTransferEnabled returns (bool) {
        return super.transferFrom(_from, _to, _value);
    }
}


contract CoinFiAirdrop is Ownable {
    uint256 public constant AIRDROP_AMOUNT = 500 * (10**18);

    // Actual token instance to airdrop
    ERC20 public token;

    function CoinFiAirdrop(ERC20 _token) public {
        token = _token;
    }

    function sendAirdrop(address[] airdropRecipients, bool allowDuplicates) external onlyOwner {
        require(airdropRecipients.length > 0);

        for (uint i = 0; i < airdropRecipients.length; i++) {
            if (token.balanceOf(airdropRecipients[i]) == 0 || allowDuplicates) {
                token.transferFrom(owner, airdropRecipients[i], AIRDROP_AMOUNT);
            }
        }
    }
}

    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":"INITIAL_SUPPLY","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"name":"","type":"uint8"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"transferEnabled","outputs":[{"name":"","type":"bool"}],"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":"balance","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"airdropAddress","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","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":false,"inputs":[{"name":"_airdropAddress","type":"address"}],"name":"setAirdropAddress","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"disableTransfer","outputs":[],"payable":false,"stateMutability":"nonpayable","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":"enableTransfer","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"inputs":[],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"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"}]

  Contract Creation Code Switch To Opcodes View
60606040526003805460a060020a60ff0219169055341561001f57600080fd5b60038054600160a060020a03191633600160a060020a03169081179091556af8277896582678ac000000600181905560008281526020819052604080822083905590917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef915190815260200160405180910390a3610bce806100a26000396000f3006060604052600436106101065763ffffffff7c010000000000000000000000000000000000000000000000000000000060003504166306fdde03811461010b578063095ea7b31461019557806318160ddd146101cb57806323b872dd146101f05780632ff2e9dc14610218578063313ce5671461022b5780634cd412d514610254578063661884631461026757806370a082311461028957806384413b65146102a85780638da5cb5b146102d757806395d89b41146102ea578063a9059cbb146102fd578063ab0eda9e1461031f578063b187984f14610340578063d73dd62314610353578063dd62ed3e14610375578063f1b50c1d1461039a578063f2fde38b146103ad575b600080fd5b341561011657600080fd5b61011e6103cc565b60405160208082528190810183818151815260200191508051906020019080838360005b8381101561015a578082015183820152602001610142565b50505050905090810190601f1680156101875780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34156101a057600080fd5b6101b7600160a060020a0360043516602435610403565b604051901515815260200160405180910390f35b34156101d657600080fd5b6101de61046f565b60405190815260200160405180910390f35b34156101fb57600080fd5b6101b7600160a060020a0360043581169060243516604435610475565b341561022357600080fd5b6101de6104d4565b341561023657600080fd5b61023e6104e3565b60405160ff909116815260200160405180910390f35b341561025f57600080fd5b6101b76104e8565b341561027257600080fd5b6101b7600160a060020a03600435166024356104f8565b341561029457600080fd5b6101de600160a060020a03600435166105f2565b34156102b357600080fd5b6102bb61060d565b604051600160a060020a03909116815260200160405180910390f35b34156102e257600080fd5b6102bb61061c565b34156102f557600080fd5b61011e61062b565b341561030857600080fd5b6101b7600160a060020a0360043516602435610662565b341561032a57600080fd5b61033e600160a060020a03600435166106bf565b005b341561034b57600080fd5b61033e610709565b341561035e57600080fd5b6101b7600160a060020a0360043516602435610744565b341561038057600080fd5b6101de600160a060020a03600435811690602435166107e8565b34156103a557600080fd5b61033e610813565b34156103b857600080fd5b61033e600160a060020a0360043516610854565b60408051908101604052600681527f436f696e46690000000000000000000000000000000000000000000000000000602082015281565b600160a060020a03338116600081815260026020908152604080832094871680845294909152808220859055909291907f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259085905190815260200160405180910390a350600192915050565b60015490565b60035460009060a060020a900460ff1615156104c15760035433600160a060020a03908116911614806104b6575060045433600160a060020a039081169116145b15156104c157600080fd5b6104cc8484846108ef565b949350505050565b6af8277896582678ac00000081565b601281565b60035460a060020a900460ff1681565b600160a060020a0333811660009081526002602090815260408083209386168352929052908120548083111561055557600160a060020a03338116600090815260026020908152604080832093881683529290529081205561058c565b610565818463ffffffff610a6f16565b600160a060020a033381166000908152600260209081526040808320938916835292905220555b600160a060020a0333811660008181526002602090815260408083209489168084529490915290819020547f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925915190815260200160405180910390a35060019392505050565b600160a060020a031660009081526020819052604090205490565b600454600160a060020a031681565b600354600160a060020a031681565b60408051908101604052600481527f434f464900000000000000000000000000000000000000000000000000000000602082015281565b60035460009060a060020a900460ff1615156106ae5760035433600160a060020a03908116911614806106a3575060045433600160a060020a039081169116145b15156106ae57600080fd5b6106b88383610a81565b9392505050565b60035433600160a060020a039081169116146106da57600080fd5b6004805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0392909216919091179055565b60035433600160a060020a0390811691161461072457600080fd5b6003805474ff000000000000000000000000000000000000000019169055565b600160a060020a03338116600090815260026020908152604080832093861683529290529081205461077c908363ffffffff610b9316565b600160a060020a0333811660008181526002602090815260408083209489168084529490915290819020849055919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591905190815260200160405180910390a350600192915050565b600160a060020a03918216600090815260026020908152604080832093909416825291909152205490565b60035433600160a060020a0390811691161461082e57600080fd5b6003805474ff0000000000000000000000000000000000000000191660a060020a179055565b60035433600160a060020a0390811691161461086f57600080fd5b600160a060020a038116151561088457600080fd5b600354600160a060020a0380831691167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a36003805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a0392909216919091179055565b6000600160a060020a038316151561090657600080fd5b600160a060020a03841660009081526020819052604090205482111561092b57600080fd5b600160a060020a038085166000908152600260209081526040808320339094168352929052205482111561095e57600080fd5b600160a060020a038416600090815260208190526040902054610987908363ffffffff610a6f16565b600160a060020a0380861660009081526020819052604080822093909355908516815220546109bc908363ffffffff610b9316565b600160a060020a0380851660009081526020818152604080832094909455878316825260028152838220339093168252919091522054610a02908363ffffffff610a6f16565b600160a060020a03808616600081815260026020908152604080832033861684529091529081902093909355908516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9085905190815260200160405180910390a35060019392505050565b600082821115610a7b57fe5b50900390565b6000600160a060020a0383161515610a9857600080fd5b600160a060020a033316600090815260208190526040902054821115610abd57600080fd5b600160a060020a033316600090815260208190526040902054610ae6908363ffffffff610a6f16565b600160a060020a033381166000908152602081905260408082209390935590851681522054610b1b908363ffffffff610b9316565b60008085600160a060020a0316600160a060020a031681526020019081526020016000208190555082600160a060020a031633600160a060020a03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405190815260200160405180910390a350600192915050565b6000828201838110156106b857fe00a165627a7a72305820bb67a0d368128a0d35db065631c0c9d4da2c3ecaa521370d91d0ab2b66c56ebb0029

   Swarm Source:
bzzr://bb67a0d368128a0d35db065631c0c9d4da2c3ecaa521370d91d0ab2b66c56ebb

 

View All
Block Age transaction Difficulty GasUsed Reward
View All
Block Age UncleNumber Difficulty GasUsed Reward
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.